1b6c62aa7SNam Cao#!/usr/bin/env python3 2b6c62aa7SNam Cao# SPDX-License-Identifier: GPL-2.0-only 3b6c62aa7SNam Cao# 4b6c62aa7SNam Cao# Copyright (C) 2019-2022 Red Hat, Inc. Daniel Bristot de Oliveira <bristot@kernel.org> 5b6c62aa7SNam Cao# 6b6c62aa7SNam Cao# dot2k: transform dot files into a monitor for the Linux kernel. 7b6c62aa7SNam Cao# 8b6c62aa7SNam Cao# For further information, see: 9b6c62aa7SNam Cao# Documentation/trace/rv/da_monitor_synthesis.rst 10b6c62aa7SNam Cao 11b6c62aa7SNam Caoif __name__ == '__main__': 12b6c62aa7SNam Cao from rvgen.dot2k import dot2k 13cce86e03SNam Cao from rvgen.generator import Monitor 14cce86e03SNam Cao from rvgen.container import Container 15*97ffa4ceSNam Cao from rvgen.ltl2k import ltl2k 16b6c62aa7SNam Cao import argparse 17b6c62aa7SNam Cao import sys 18b6c62aa7SNam Cao 19b6c62aa7SNam Cao parser = argparse.ArgumentParser(description='Generate kernel rv monitor') 20b6c62aa7SNam Cao parser.add_argument("-D", "--description", dest="description", required=False) 21b6c62aa7SNam Cao parser.add_argument("-a", "--auto_patch", dest="auto_patch", 22b6c62aa7SNam Cao action="store_true", required=False, 23b6c62aa7SNam Cao help="Patch the kernel in place") 24b6c62aa7SNam Cao 25b6c62aa7SNam Cao subparsers = parser.add_subparsers(dest="subcmd", required=True) 26b6c62aa7SNam Cao 27b6c62aa7SNam Cao monitor_parser = subparsers.add_parser("monitor") 28b6c62aa7SNam Cao monitor_parser.add_argument('-n', "--model_name", dest="model_name") 29b6c62aa7SNam Cao monitor_parser.add_argument("-p", "--parent", dest="parent", 30b6c62aa7SNam Cao required=False, help="Create a monitor nested to parent") 31b6c62aa7SNam Cao monitor_parser.add_argument('-c', "--class", dest="monitor_class", 32b6c62aa7SNam Cao help="Monitor class, either \"da\" or \"ltl\"") 33b6c62aa7SNam Cao monitor_parser.add_argument('-s', "--spec", dest="spec", help="Monitor specification file") 34b6c62aa7SNam Cao monitor_parser.add_argument('-t', "--monitor_type", dest="monitor_type", 35cce86e03SNam Cao help=f"Available options: {', '.join(Monitor.monitor_types.keys())}") 36b6c62aa7SNam Cao 37b6c62aa7SNam Cao container_parser = subparsers.add_parser("container") 38b6c62aa7SNam Cao container_parser.add_argument('-n', "--model_name", dest="model_name", required=True) 39b6c62aa7SNam Cao 40b6c62aa7SNam Cao params = parser.parse_args() 41b6c62aa7SNam Cao 42b6c62aa7SNam Cao try: 43b6c62aa7SNam Cao if params.subcmd == "monitor": 44b6c62aa7SNam Cao print("Opening and parsing the specification file %s" % params.spec) 45b6c62aa7SNam Cao if params.monitor_class == "da": 46b6c62aa7SNam Cao monitor = dot2k(params.spec, params.monitor_type, vars(params)) 47b6c62aa7SNam Cao elif params.monitor_class == "ltl": 48*97ffa4ceSNam Cao monitor = ltl2k(params.spec, params.monitor_type, vars(params)) 49b6c62aa7SNam Cao else: 50b6c62aa7SNam Cao print("Unknown monitor class:", params.monitor_class) 51b6c62aa7SNam Cao sys.exit(1) 52b6c62aa7SNam Cao else: 53cce86e03SNam Cao monitor = Container(vars(params)) 54b6c62aa7SNam Cao except Exception as e: 55b6c62aa7SNam Cao print('Error: '+ str(e)) 56b6c62aa7SNam Cao print("Sorry : :-(") 57b6c62aa7SNam Cao sys.exit(1) 58b6c62aa7SNam Cao 59b6c62aa7SNam Cao print("Writing the monitor into the directory %s" % monitor.name) 60b6c62aa7SNam Cao monitor.print_files() 61b6c62aa7SNam Cao print("Almost done, checklist") 62b6c62aa7SNam Cao if params.subcmd == "monitor": 63b6c62aa7SNam Cao print(" - Edit the %s/%s.c to add the instrumentation" % (monitor.name, monitor.name)) 64b6c62aa7SNam Cao print(monitor.fill_tracepoint_tooltip()) 65b6c62aa7SNam Cao print(monitor.fill_makefile_tooltip()) 66b6c62aa7SNam Cao print(monitor.fill_kconfig_tooltip()) 67b6c62aa7SNam Cao print(monitor.fill_monitor_tooltip()) 68