| #!/usr/bin/python3 |
| # Copyright lowRISC contributors. |
| # Licensed under the Apache License, Version 2.0, see LICENSE for details. |
| # SPDX-License-Identifier: Apache-2.0 |
| |
| from distutils.version import StrictVersion |
| import logging as log |
| import os |
| import subprocess |
| import sys |
| |
| # Display INFO log messages and up. |
| log.basicConfig(level=log.INFO, format="%(levelname)s: %(message)s") |
| |
| # Populate __TOOL_REQUIREMENTS__ |
| topsrcdir = os.path.join(os.path.dirname(__file__), '..') |
| exec(open(os.path.join(topsrcdir, 'tool_requirements.py')).read()) |
| |
| def get_verilator_version(): |
| try: |
| # Note: "verilator" needs to be called through a shell and with all |
| # arguments in a string, as it doesn't have a shebang, but instead |
| # relies on perl magic to parse command line arguments. |
| version_str = subprocess.run('verilator --version', shell=True, |
| check=True, stdout=subprocess.PIPE, |
| stderr=subprocess.STDOUT, |
| universal_newlines=True) |
| return version_str.stdout.split(' ')[1].strip() |
| |
| except subprocess.CalledProcessError as e: |
| log.error("Unable to call Verilator to check version: " + str(e)) |
| log.error(e.stdout) |
| return None |
| |
| def check_version(tool_name, required_version, actual_version): |
| if required_version is None or actual_version is None: |
| return False |
| |
| if StrictVersion(actual_version) < StrictVersion(required_version): |
| log.error("%s is too old: found version %s, need at least %s", |
| tool_name, actual_version, required_version) |
| return False |
| else: |
| log.info("Found sufficiently recent version of %s (found %s, need %s)", |
| tool_name, actual_version, required_version) |
| return True |
| |
| |
| def main(): |
| any_failed = False |
| |
| if not check_version('verilator', __TOOL_REQUIREMENTS__['verilator'], |
| get_verilator_version()): |
| any_failed = True |
| |
| if any_failed: |
| log.error("Tool requirements not fulfilled. " |
| "Please update the tools and retry.") |
| return 1 |
| return 0 |
| |
| if __name__ == "__main__": |
| sys.exit(main()) |