blob: 5de9ce96d3024b99e28dc5f7c2b704f3fa7bdd1b [file] [log] [blame]
Philippe Mathieu-Daudé3d004a32020-01-30 17:32:25 +01001#!/usr/bin/env python3
Lluís Vilanova650ab982012-04-03 20:47:39 +02002# -*- coding: utf-8 -*-
3
4"""
5Command-line wrapper for the tracetool machinery.
6"""
7
8__author__ = "Lluís Vilanova <vilanova@ac.upc.edu>"
Lluís Vilanova5b808272014-05-27 15:02:14 +02009__copyright__ = "Copyright 2012-2014, Lluís Vilanova <vilanova@ac.upc.edu>"
Lluís Vilanova650ab982012-04-03 20:47:39 +020010__license__ = "GPL version 2 or (at your option) any later version"
11
12__maintainer__ = "Stefan Hajnoczi"
Philippe Mathieu-Daudéf892b492020-05-11 10:28:16 +020013__email__ = "stefanha@redhat.com"
Lluís Vilanova650ab982012-04-03 20:47:39 +020014
15
16import sys
17import getopt
18
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010019from tracetool import error_write, out, out_open
Lluís Vilanova650ab982012-04-03 20:47:39 +020020import tracetool.backend
21import tracetool.format
22
23
24_SCRIPT = ""
25
26def error_opt(msg = None):
27 if msg is not None:
28 error_write("Error: " + msg + "\n")
29
30 backend_descr = "\n".join([ " %-15s %s" % (n, d)
31 for n,d in tracetool.backend.get_list() ])
32 format_descr = "\n".join([ " %-15s %s" % (n, d)
33 for n,d in tracetool.format.get_list() ])
34 error_write("""\
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010035Usage: %(script)s --format=<format> --backends=<backends> [<options>] <trace-events> ... <output>
Lluís Vilanova650ab982012-04-03 20:47:39 +020036
37Backends:
38%(backends)s
39
40Formats:
41%(formats)s
42
43Options:
44 --help This help message.
45 --list-backends Print list of available backends.
Lluís Vilanova5b808272014-05-27 15:02:14 +020046 --check-backends Check if the given backend is valid.
Daniel P. Berrangé081340d2024-01-08 17:13:55 +000047 --binary <path> Full path to QEMU binary (required for 'stap' backend).
48 --group <name> Name of the event group.
49 --probe-prefix <prefix> Prefix for dtrace probe names (required for 'stap' backend).
Lluís Vilanova650ab982012-04-03 20:47:39 +020050""" % {
51 "script" : _SCRIPT,
52 "backends" : backend_descr,
53 "formats" : format_descr,
54 })
55
56 if msg is None:
57 sys.exit(0)
58 else:
59 sys.exit(1)
60
Lluís Vilanova650ab982012-04-03 20:47:39 +020061def main(args):
62 global _SCRIPT
63 _SCRIPT = args[0]
64
Lluís Vilanova5b808272014-05-27 15:02:14 +020065 long_opts = ["backends=", "format=", "help", "list-backends",
Daniel P. Berrange2098c562017-01-25 16:14:14 +000066 "check-backends", "group="]
Daniel P. Berrangé081340d2024-01-08 17:13:55 +000067 long_opts += ["binary=", "probe-prefix="]
Lluís Vilanova650ab982012-04-03 20:47:39 +020068
69 try:
70 opts, args = getopt.getopt(args[1:], "", long_opts)
Markus Armbruster86b227d2015-12-18 08:52:43 +010071 except getopt.GetoptError as err:
Lluís Vilanova650ab982012-04-03 20:47:39 +020072 error_opt(str(err))
73
Lluís Vilanova5b808272014-05-27 15:02:14 +020074 check_backends = False
75 arg_backends = []
Lluís Vilanova650ab982012-04-03 20:47:39 +020076 arg_format = ""
Daniel P. Berrange2098c562017-01-25 16:14:14 +000077 arg_group = None
Lluís Vilanova52ef0932012-04-03 20:48:12 +020078 binary = None
Lluís Vilanova52ef0932012-04-03 20:48:12 +020079 probe_prefix = None
Lluís Vilanova650ab982012-04-03 20:47:39 +020080 for opt, arg in opts:
81 if opt == "--help":
82 error_opt()
83
Lluís Vilanova5b808272014-05-27 15:02:14 +020084 elif opt == "--backends":
85 arg_backends = arg.split(",")
Daniel P. Berrange2098c562017-01-25 16:14:14 +000086 elif opt == "--group":
87 arg_group = arg
Lluís Vilanova650ab982012-04-03 20:47:39 +020088 elif opt == "--format":
89 arg_format = arg
90
91 elif opt == "--list-backends":
Lluís Vilanova93fba162013-03-05 14:47:26 +010092 public_backends = tracetool.backend.get_list(only_public = True)
93 out(", ".join([ b for b,_ in public_backends ]))
Lluís Vilanova650ab982012-04-03 20:47:39 +020094 sys.exit(0)
Lluís Vilanova5b808272014-05-27 15:02:14 +020095 elif opt == "--check-backends":
96 check_backends = True
Lluís Vilanova650ab982012-04-03 20:47:39 +020097
Lluís Vilanova52ef0932012-04-03 20:48:12 +020098 elif opt == "--binary":
99 binary = arg
Lluís Vilanova52ef0932012-04-03 20:48:12 +0200100 elif opt == '--probe-prefix':
101 probe_prefix = arg
102
Lluís Vilanova650ab982012-04-03 20:47:39 +0200103 else:
104 error_opt("unhandled option: %s" % opt)
105
Lluís Vilanova5b808272014-05-27 15:02:14 +0200106 if len(arg_backends) == 0:
107 error_opt("no backends specified")
Lluís Vilanova650ab982012-04-03 20:47:39 +0200108
Lluís Vilanova5b808272014-05-27 15:02:14 +0200109 if check_backends:
110 for backend in arg_backends:
111 if not tracetool.backend.exists(backend):
112 sys.exit(1)
113 sys.exit(0)
Lluís Vilanova650ab982012-04-03 20:47:39 +0200114
Daniel P. Berrange2098c562017-01-25 16:14:14 +0000115 if arg_group is None:
116 error_opt("group name is required")
117
Lluís Vilanova52ef0932012-04-03 20:48:12 +0200118 if arg_format == "stap":
119 if binary is None:
120 error_opt("--binary is required for SystemTAP tapset generator")
Lluís Vilanova52ef0932012-04-03 20:48:12 +0200121 if probe_prefix is None:
Daniel P. Berrangé081340d2024-01-08 17:13:55 +0000122 error_opt("--probe-prefix is required for SystemTAP tapset generator")
Lluís Vilanova52ef0932012-04-03 20:48:12 +0200123
Stefan Hajnoczic05012a2020-08-27 15:29:12 +0100124 if len(args) < 2:
125 error_opt("missing trace-events and output filepaths")
Daniel P. Berrange0ab8ed12017-01-25 16:14:15 +0000126 events = []
Stefan Hajnoczic05012a2020-08-27 15:29:12 +0100127 for arg in args[:-1]:
Daniel P. Berrange0ab8ed12017-01-25 16:14:15 +0000128 with open(arg, "r") as fh:
Daniel P. Berrangé86b5aac2018-03-06 15:46:50 +0000129 events.extend(tracetool.read_events(fh, arg))
Daniel P. Berrange9096b782016-10-04 14:35:57 +0100130
Stefan Hajnoczic05012a2020-08-27 15:29:12 +0100131 out_open(args[-1])
132
Lluís Vilanova650ab982012-04-03 20:47:39 +0200133 try:
Daniel P. Berrange2098c562017-01-25 16:14:14 +0000134 tracetool.generate(events, arg_group, arg_format, arg_backends,
Lluís Vilanova5b808272014-05-27 15:02:14 +0200135 binary=binary, probe_prefix=probe_prefix)
Markus Armbruster86b227d2015-12-18 08:52:43 +0100136 except tracetool.TracetoolError as e:
Lluís Vilanova650ab982012-04-03 20:47:39 +0200137 error_opt(str(e))
138
139if __name__ == "__main__":
140 main(sys.argv)