blob: a0be8f9b0db96ed21ec4fcd6572b9ce657fdcb3b [file] [log] [blame]
Peter Maydellaadac5b2021-01-06 15:55:29 +00001
Marc-André Lureau0e1309d2019-09-03 16:47:00 +04002specific_ss.add(files('control-target.c'))
3
Paolo Bonzinia81df1b2020-08-19 08:44:56 -04004trace_events_files = []
5foreach dir : [ '.' ] + trace_events_subdirs
6 trace_events_file = meson.source_root() / dir / 'trace-events'
7 trace_events_files += [ trace_events_file ]
8 group_name = dir == '.' ? 'root' : dir.underscorify()
9 group = '--group=' + group_name
10 fmt = '@0@-' + group_name + '.@1@'
11
12 trace_h = custom_target(fmt.format('trace', 'h'),
13 output: fmt.format('trace', 'h'),
14 input: trace_events_file,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010015 command: [ tracetool, group, '--format=h', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040016 genh += trace_h
17 trace_c = custom_target(fmt.format('trace', 'c'),
18 output: fmt.format('trace', 'c'),
19 input: trace_events_file,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010020 command: [ tracetool, group, '--format=c', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040021 if 'CONFIG_TRACE_UST' in config_host
22 trace_ust_h = custom_target(fmt.format('trace-ust', 'h'),
23 output: fmt.format('trace-ust', 'h'),
24 input: trace_events_file,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010025 command: [ tracetool, group, '--format=ust-events-h', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040026 trace_ss.add(trace_ust_h, lttng, urcubp)
27 genh += trace_ust_h
28 endif
29 trace_ss.add(trace_h, trace_c)
30 if 'CONFIG_TRACE_DTRACE' in config_host
31 trace_dtrace = custom_target(fmt.format('trace-dtrace', 'dtrace'),
32 output: fmt.format('trace-dtrace', 'dtrace'),
33 input: trace_events_file,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010034 command: [ tracetool, group, '--format=d', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040035 trace_dtrace_h = custom_target(fmt.format('trace-dtrace', 'h'),
36 output: fmt.format('trace-dtrace', 'h'),
37 input: trace_dtrace,
Stefan Hajnoczi4b265c72020-11-19 14:14:57 +000038 command: [ 'dtrace', '-DSTAP_SDT_V2', '-o', '@OUTPUT@', '-h', '-s', '@INPUT@' ])
Roman Bolshakov568ac772020-08-23 12:05:47 +030039 trace_ss.add(trace_dtrace_h)
40 if host_machine.system() != 'darwin'
41 trace_dtrace_o = custom_target(fmt.format('trace-dtrace', 'o'),
42 output: fmt.format('trace-dtrace', 'o'),
43 input: trace_dtrace,
Stefan Hajnoczi4b265c72020-11-19 14:14:57 +000044 command: [ 'dtrace', '-DSTAP_SDT_V2', '-o', '@OUTPUT@', '-G', '-s', '@INPUT@' ])
Roman Bolshakov568ac772020-08-23 12:05:47 +030045 trace_ss.add(trace_dtrace_o)
46 endif
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040047
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040048 genh += trace_dtrace_h
49 endif
50endforeach
51
Marc-André Lureau10e1d262019-08-20 12:29:52 +040052trace_events_all = custom_target('trace-events-all',
53 output: 'trace-events-all',
54 input: trace_events_files,
55 command: [ 'cat', '@INPUT@' ],
56 capture: true,
57 install: true,
Marc-André Lureauab4c0992020-08-26 15:04:16 +040058 install_dir: qemu_datadir)
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040059
Marc-André Lureau71c782f2019-07-15 18:48:06 +040060foreach d : [
61 ['generated-tcg-tracers.h', 'tcg-h'],
62 ['generated-helpers.c', 'tcg-helper-c'],
63 ['generated-helpers.h', 'tcg-helper-h'],
64 ['generated-helpers-wrappers.h', 'tcg-helper-wrapper-h'],
65]
Marc-André Lureau0e1309d2019-09-03 16:47:00 +040066 gen = custom_target(d[0],
Marc-André Lureau71c782f2019-07-15 18:48:06 +040067 output: d[0],
68 input: meson.source_root() / 'trace-events',
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010069 command: [ tracetool, '--group=root', '--format=@0@'.format(d[1]), '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinie921f1a2020-12-16 13:32:45 +010070 specific_ss.add(when: 'CONFIG_TCG', if_true: gen)
Marc-André Lureau71c782f2019-07-15 18:48:06 +040071endforeach
72
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040073if 'CONFIG_TRACE_UST' in config_host
74 trace_ust_all_h = custom_target('trace-ust-all.h',
75 output: 'trace-ust-all.h',
76 input: trace_events_files,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010077 command: [ tracetool, '--group=all', '--format=ust-events-h', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040078 trace_ust_all_c = custom_target('trace-ust-all.c',
79 output: 'trace-ust-all.c',
80 input: trace_events_files,
Stefan Hajnoczic05012a2020-08-27 15:29:12 +010081 command: [ tracetool, '--group=all', '--format=ust-events-c', '@INPUT@', '@OUTPUT@' ])
Paolo Bonzinia81df1b2020-08-19 08:44:56 -040082 trace_ss.add(trace_ust_all_h, trace_ust_all_c)
83 genh += trace_ust_all_h
84endif
85
86trace_ss.add(when: 'CONFIG_TRACE_SIMPLE', if_true: files('simple.c'))
87trace_ss.add(when: 'CONFIG_TRACE_FTRACE', if_true: files('ftrace.c'))
88trace_ss.add(files('control.c'))
89trace_ss.add(files('qmp.c'))