xref: /linux/tools/verification/rvgen/__main__.py (revision 4ff261e725d7376c12e745fdbe8a33cd6dbd5a83)
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