xref: /openbmc/qemu/scripts/tracetool.py (revision 0806b30c8dff64e944456aa15bdc6957384e29a8)
1#!/usr/bin/env python
2# -*- coding: utf-8 -*-
3
4"""
5Command-line wrapper for the tracetool machinery.
6"""
7
8__author__     = "Lluís Vilanova <vilanova@ac.upc.edu>"
9__copyright__  = "Copyright 2012-2014, Lluís Vilanova <vilanova@ac.upc.edu>"
10__license__    = "GPL version 2 or (at your option) any later version"
11
12__maintainer__ = "Stefan Hajnoczi"
13__email__      = "stefanha@linux.vnet.ibm.com"
14
15
16import sys
17import getopt
18import os.path
19import re
20
21from tracetool import error_write, out
22import tracetool.backend
23import tracetool.format
24
25
26_SCRIPT = ""
27
28def error_opt(msg = None):
29    if msg is not None:
30        error_write("Error: " + msg + "\n")
31
32    backend_descr = "\n".join([ "    %-15s %s" % (n, d)
33                                for n,d in tracetool.backend.get_list() ])
34    format_descr = "\n".join([ "    %-15s %s" % (n, d)
35                               for n,d in tracetool.format.get_list() ])
36    error_write("""\
37Usage: %(script)s --format=<format> --backends=<backends> [<options>]
38
39Backends:
40%(backends)s
41
42Formats:
43%(formats)s
44
45Options:
46    --help                   This help message.
47    --list-backends          Print list of available backends.
48    --check-backends         Check if the given backend is valid.
49    --binary <path>          Full path to QEMU binary.
50    --target-type <type>     QEMU emulator target type ('system' or 'user').
51    --target-name <name>     QEMU emulator target name.
52    --group <name>           Name of the event group
53    --probe-prefix <prefix>  Prefix for dtrace probe names
54                             (default: qemu-<target-type>-<target-name>).\
55""" % {
56            "script" : _SCRIPT,
57            "backends" : backend_descr,
58            "formats" : format_descr,
59            })
60
61    if msg is None:
62        sys.exit(0)
63    else:
64        sys.exit(1)
65
66def main(args):
67    global _SCRIPT
68    _SCRIPT = args[0]
69
70    long_opts = ["backends=", "format=", "help", "list-backends",
71                 "check-backends", "group="]
72    long_opts += ["binary=", "target-type=", "target-name=", "probe-prefix="]
73
74    try:
75        opts, args = getopt.getopt(args[1:], "", long_opts)
76    except getopt.GetoptError as err:
77        error_opt(str(err))
78
79    check_backends = False
80    arg_backends = []
81    arg_format = ""
82    arg_group = None
83    binary = None
84    target_type = None
85    target_name = None
86    probe_prefix = None
87    for opt, arg in opts:
88        if opt == "--help":
89            error_opt()
90
91        elif opt == "--backends":
92            arg_backends = arg.split(",")
93        elif opt == "--group":
94            arg_group = arg
95        elif opt == "--format":
96            arg_format = arg
97
98        elif opt == "--list-backends":
99            public_backends = tracetool.backend.get_list(only_public = True)
100            out(", ".join([ b for b,_ in public_backends ]))
101            sys.exit(0)
102        elif opt == "--check-backends":
103            check_backends = True
104
105        elif opt == "--binary":
106            binary = arg
107        elif opt == '--target-type':
108            target_type = arg
109        elif opt == '--target-name':
110            target_name = arg
111        elif opt == '--probe-prefix':
112            probe_prefix = arg
113
114        else:
115            error_opt("unhandled option: %s" % opt)
116
117    if len(arg_backends) == 0:
118        error_opt("no backends specified")
119
120    if check_backends:
121        for backend in arg_backends:
122            if not tracetool.backend.exists(backend):
123                sys.exit(1)
124        sys.exit(0)
125
126    if arg_group is None:
127        error_opt("group name is required")
128
129    if arg_format == "stap":
130        if binary is None:
131            error_opt("--binary is required for SystemTAP tapset generator")
132        if probe_prefix is None and target_type is None:
133            error_opt("--target-type is required for SystemTAP tapset generator")
134        if probe_prefix is None and target_name is None:
135            error_opt("--target-name is required for SystemTAP tapset generator")
136
137        if probe_prefix is None:
138            probe_prefix = ".".join(["qemu", target_type, target_name])
139
140    if len(args) < 1:
141        error_opt("missing trace-events filepath")
142    events = []
143    for arg in args:
144        with open(arg, "r") as fh:
145            events.extend(tracetool.read_events(fh))
146
147    try:
148        tracetool.generate(events, arg_group, arg_format, arg_backends,
149                           binary=binary, probe_prefix=probe_prefix)
150    except tracetool.TracetoolError as e:
151        error_opt(str(e))
152
153if __name__ == "__main__":
154    main(sys.argv)
155