diff options
author | Martin Braun <martin.braun@ettus.com> | 2019-10-22 14:49:05 -0700 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2019-11-26 12:21:32 -0800 |
commit | 2a7e69d862f661075b98bab19e58d958c28a9af8 (patch) | |
tree | f0e5c7733ca330f85fd567be82244d2a1efab501 /host | |
parent | 1cd874911db0d4c0463264edd0d46067d072eccb (diff) | |
download | uhd-2a7e69d862f661075b98bab19e58d958c28a9af8.tar.gz uhd-2a7e69d862f661075b98bab19e58d958c28a9af8.tar.bz2 uhd-2a7e69d862f661075b98bab19e58d958c28a9af8.zip |
rfnoc: image_builder: Fix -I, allow devices/targets to bet set in YAML
- The -I switch now allows pointing to an OOT
- The image core file may now contain keys 'device' and
'default_target', which the image builder can use as default values.
Command line switches --device and --target are still honoured.
Diffstat (limited to 'host')
-rw-r--r-- | host/include/uhd/rfnoc/core/rfnoc_imagebuilder_args.json | 3 | ||||
-rwxr-xr-x | host/utils/bin/rfnoc_image_builder | 28 | ||||
-rwxr-xr-x | host/utils/rfnoc/image_builder.py | 12 |
3 files changed, 23 insertions, 20 deletions
diff --git a/host/include/uhd/rfnoc/core/rfnoc_imagebuilder_args.json b/host/include/uhd/rfnoc/core/rfnoc_imagebuilder_args.json index 65ef2dd76..2d76643be 100644 --- a/host/include/uhd/rfnoc/core/rfnoc_imagebuilder_args.json +++ b/host/include/uhd/rfnoc/core/rfnoc_imagebuilder_args.json @@ -5,7 +5,8 @@ "copyright": { "type": "string" }, "version": { "type": "number" }, "license": { "type": "string" }, - "device_desc": { "type": "string" }, + "device": { "type": "string" }, + "default_target": { "type": "string" }, "rfnoc_version": { "type": "number" }, "chdr_width": { "enum": [64, 256] }, diff --git a/host/utils/bin/rfnoc_image_builder b/host/utils/bin/rfnoc_image_builder index 0df0d5d3c..731fad0b2 100755 --- a/host/utils/bin/rfnoc_image_builder +++ b/host/utils/bin/rfnoc_image_builder @@ -50,7 +50,6 @@ def setup_parser(): config_group.add_argument( "-r", "--grc_config", help="Path to grc file to generate config from") - parser.add_argument( "-F", "--fpga-dir", help="Path directory of the FPGA source tree", @@ -65,13 +64,11 @@ def setup_parser(): help="Path to where to save the static router hex file. " "Defaults to the location of the YAML file, filename $device_static_router.hex", default=None) - parser.add_argument( "-I", "--include-dir", help="Path directory of the RFNoC Out-of-Tree module", nargs='+', default=None) - parser.add_argument( "-b", "--grc-blocks", help="Path directory of GRC block descriptions (needed for --grc-config only)", @@ -86,11 +83,13 @@ def setup_parser(): action="store_true") parser.add_argument( "-d", "--device", - help="Device to be programmed [x300, x310, e310, e320, n300, n310, n320]", - default="x310") + help="Device to be programmed [x300, x310, e310, e320, n300, n310, n320]." + "Needs to be specified either here, or in the configuration file.", + default=None) parser.add_argument( "-t", "--target", - help="Build target (e.g. X310_HG, N320_XG, ...)", + help="Build target (e.g. X310_HG, N320_XG, ...). Needs to be specified " + "either here, on the configuration file.", default=None) parser.add_argument( "-g", "--GUI", @@ -115,14 +114,16 @@ def image_config(args): :return: image configuration as dictionary """ if args.yaml_config: - return rfnoc.yaml_utils.load_config(args.yaml_config, get_config_path()), \ - args.yaml_config - + config = \ + rfnoc.yaml_utils.load_config(args.yaml_config, get_config_path()) + device = config.get('device') if args.device is None else args.device + target = config.get('default_target') if args.target is None else args.target + return config, args.yaml_config, device, target with open(args.grc_config) as grc_file: config = yaml.load(grc_file) logging.info("Converting GNU Radio Companion file to image builder format") config = rfnoc.image_builder.convert_to_image_config(config, args.grc_blocks) - return config, args.grc_config + return config, args.grc_config, args.device, args.target def resolve_path(path, local): @@ -170,7 +171,7 @@ def main(): if args.log_level is not None: logging.root.setLevel(args.log_level.upper()) - config, source = image_config(args) + config, source, device, target = image_config(args) source_hash = hashlib.sha256() with open(source, "rb") as source_file: source_hash.update(source_file.read()) @@ -179,8 +180,8 @@ def main(): config=config, fpga_path=args.fpga_dir, config_path=get_config_path(), - device=args.device, - target=args.target, + device=device, + target=target, generate_only=args.generate_only, clean_all=args.clean_all, gui=args.GUI, @@ -188,6 +189,7 @@ def main(): source_hash=source_hash.hexdigest(), output_path=args.image_core_output, router_hex_path=args.router_hex_output, + include_paths=args.include_dir, ) if __name__ == "__main__": diff --git a/host/utils/rfnoc/image_builder.py b/host/utils/rfnoc/image_builder.py index 92d8a909d..965b2d454 100755 --- a/host/utils/rfnoc/image_builder.py +++ b/host/utils/rfnoc/image_builder.py @@ -461,16 +461,15 @@ def convert_to_image_config(grc, grc_config_path): return result -def collect_module_paths(config_path): +def collect_module_paths(config_path, include_paths): """ - Create a list of directorties that contain noc block configuration files. + Create a list of directories that contain noc block configuration files. :param config_path: root path holding configuration files :return: list of noc block directories """ # rfnoc blocks - result = [os.path.join(config_path, 'rfnoc', 'blocks')] - # additional OOT blocks - # TODO parse modules from external includes as well + result = [os.path.join(config_path, 'rfnoc', 'blocks')] + \ + [os.path.join(x, 'blocks') for x in include_paths] return result @@ -732,6 +731,7 @@ def build_image(config, fpga_path, config_path, device, **args): generate_only: Do not build the code after generation. clean_all: passed to Makefile GUI: passed to Makefile + include_paths: Paths to additional blocks :return: Exit result of build process or 0 if generate-only is given. """ logging.info("Selected device %s", device) @@ -749,7 +749,7 @@ def build_image(config, fpga_path, config_path, device, **args): device_conf = IOConfig(device_config(core_config_path, device), signatures_conf) - block_paths = collect_module_paths(config_path) + block_paths = collect_module_paths(config_path, args.get('include_paths')) logging.debug("Looking for block descriptors in:") for path in block_paths: logging.debug(" %s", os.path.normpath(path)) |