|  | #!/usr/bin/env python3 | 
|  | # Copyright lowRISC contributors. | 
|  | # Licensed under the Apache License, Version 2.0, see LICENSE for details. | 
|  | # SPDX-License-Identifier: Apache-2.0 | 
|  | """autogen_testutils.py is a script for auto-generating a portion of the | 
|  | `testutils` libraries from Mako templates. | 
|  |  | 
|  | `testutils` libraries are testing libraries that sit a layer above the DIFs | 
|  | that aid in writing chip-level tests by enabling test developers to re-use | 
|  | code that calls a specific collection of DIFs. | 
|  |  | 
|  | To render all testutil templates, run the script with: | 
|  | $ util/autogen_testutils.py | 
|  | """ | 
|  |  | 
|  | import argparse | 
|  | import glob | 
|  | import sys | 
|  | from pathlib import Path | 
|  |  | 
|  | import hjson | 
|  |  | 
|  | import topgen.lib as topgen_lib | 
|  | from autogen_testutils.gen import gen_testutils | 
|  | from make_new_dif.ip import Ip | 
|  |  | 
|  | # This file is $REPO_TOP/util/autogen_testutils.py, so it takes two parent() | 
|  | # calls to get back to the top. | 
|  | REPO_TOP = Path(__file__).resolve().parent.parent | 
|  |  | 
|  |  | 
|  | def main(): | 
|  | # Parse command line args. | 
|  | parser = argparse.ArgumentParser() | 
|  | parser.add_argument( | 
|  | "--topcfg_path", | 
|  | "-t", | 
|  | type=Path, | 
|  | default=(REPO_TOP / "hw/top_earlgrey/data/top_earlgrey.hjson"), | 
|  | help="path of the top hjson file.", | 
|  | ) | 
|  | args = parser.parse_args() | 
|  |  | 
|  | # Parse toplevel Hjson to get IPs that are templated / generated with IPgen. | 
|  | try: | 
|  | topcfg_text = args.topcfg_path.read_text() | 
|  | except FileNotFoundError: | 
|  | logging.error(f"hjson {args.topcfg_path} could not be found.") | 
|  | sys.exit(1) | 
|  | topcfg = hjson.loads(topcfg_text, use_decimal=True) | 
|  | templated_modules = topgen_lib.get_templated_modules(topcfg) | 
|  | ipgen_modules = topgen_lib.get_ipgen_modules(topcfg) | 
|  |  | 
|  | # Define autogen DIF directory. | 
|  | autogen_dif_directory = REPO_TOP / "sw/device/lib/dif/autogen" | 
|  |  | 
|  | # Create list of IPs to generate shared testutils code for. This is all IPs | 
|  | # that have a DIF library, that the testutils functions can use. Note, the | 
|  | # templates will take care of only generating ISR testutil functions for IPs | 
|  | # that can actually generate interrupts. | 
|  | ips_with_difs = [] | 
|  | for autogen_dif_filename in glob.iglob(str(autogen_dif_directory / "*.h")): | 
|  | # NOTE: the line below takes as input a file path | 
|  | # (/path/to/dif_uart_autogen.c) and returns the IP name in lower | 
|  | # case snake mode (i.e., uart). | 
|  | ip_name_snake = Path(autogen_dif_filename).stem[4:-8] | 
|  | # NOTE: ip.name_long_* not needed for auto-generated files which | 
|  | # are the only files (re-)generated in batch mode. | 
|  | ips_with_difs.append( | 
|  | Ip(ip_name_snake, "AUTOGEN", templated_modules, ipgen_modules)) | 
|  |  | 
|  | # Auto-generate testutils files. | 
|  | gen_testutils(ips_with_difs) | 
|  |  | 
|  |  | 
|  | if __name__ == "__main__": | 
|  | main() |