mirror of https://gitee.com/openkylin/qemu.git
meson: generate trace events for qmp commands
1. Use --gen-trace when generate qmp commands 2. Add corresponding .trace-events files as outputs in qapi_files custom target 3. Define global qapi_trace_events list of .trace-events file targets, to fill in trace/qapi.build and to use in trace/meson.build 4. In trace/meson.build use the new array as an additional source of .trace_events files to be processed Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Acked-by: Paolo Bonzini <pbonzini@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Message-Id: <20220126161130.3240892-5-vsementsov@virtuozzo.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
bd2017bc41
commit
b83a80e831
|
@ -41,6 +41,7 @@ qemu_icondir = get_option('datadir') / 'icons'
|
||||||
|
|
||||||
config_host_data = configuration_data()
|
config_host_data = configuration_data()
|
||||||
genh = []
|
genh = []
|
||||||
|
qapi_trace_events = []
|
||||||
|
|
||||||
target_dirs = config_host['TARGET_DIRS'].split()
|
target_dirs = config_host['TARGET_DIRS'].split()
|
||||||
have_linux_user = false
|
have_linux_user = false
|
||||||
|
@ -2557,6 +2558,8 @@ if 'CONFIG_VHOST_USER' in config_host
|
||||||
vhost_user = libvhost_user.get_variable('vhost_user_dep')
|
vhost_user = libvhost_user.get_variable('vhost_user_dep')
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# NOTE: the trace/ subdirectory needs the qapi_trace_events variable
|
||||||
|
# that is filled in by qapi/.
|
||||||
subdir('qapi')
|
subdir('qapi')
|
||||||
subdir('qobject')
|
subdir('qobject')
|
||||||
subdir('stubs')
|
subdir('stubs')
|
||||||
|
|
|
@ -114,6 +114,7 @@ foreach module : qapi_all_modules
|
||||||
'qapi-events-@0@.h'.format(module),
|
'qapi-events-@0@.h'.format(module),
|
||||||
'qapi-commands-@0@.c'.format(module),
|
'qapi-commands-@0@.c'.format(module),
|
||||||
'qapi-commands-@0@.h'.format(module),
|
'qapi-commands-@0@.h'.format(module),
|
||||||
|
'qapi-commands-@0@.trace-events'.format(module),
|
||||||
]
|
]
|
||||||
endif
|
endif
|
||||||
if module.endswith('-target')
|
if module.endswith('-target')
|
||||||
|
@ -126,7 +127,7 @@ endforeach
|
||||||
qapi_files = custom_target('shared QAPI source files',
|
qapi_files = custom_target('shared QAPI source files',
|
||||||
output: qapi_util_outputs + qapi_specific_outputs + qapi_nonmodule_outputs,
|
output: qapi_util_outputs + qapi_specific_outputs + qapi_nonmodule_outputs,
|
||||||
input: [ files('qapi-schema.json') ],
|
input: [ files('qapi-schema.json') ],
|
||||||
command: [ qapi_gen, '-o', 'qapi', '-b', '@INPUT0@' ],
|
command: [ qapi_gen, '-o', 'qapi', '-b', '@INPUT0@', '--gen-trace' ],
|
||||||
depend_files: [ qapi_inputs, qapi_gen_depends ])
|
depend_files: [ qapi_inputs, qapi_gen_depends ])
|
||||||
|
|
||||||
# Now go through all the outputs and add them to the right sourceset.
|
# Now go through all the outputs and add them to the right sourceset.
|
||||||
|
@ -137,6 +138,9 @@ foreach output : qapi_util_outputs
|
||||||
if output.endswith('.h')
|
if output.endswith('.h')
|
||||||
genh += qapi_files[i]
|
genh += qapi_files[i]
|
||||||
endif
|
endif
|
||||||
|
if output.endswith('.trace-events')
|
||||||
|
qapi_trace_events += qapi_files[i]
|
||||||
|
endif
|
||||||
util_ss.add(qapi_files[i])
|
util_ss.add(qapi_files[i])
|
||||||
i = i + 1
|
i = i + 1
|
||||||
endforeach
|
endforeach
|
||||||
|
@ -145,6 +149,9 @@ foreach output : qapi_specific_outputs + qapi_nonmodule_outputs
|
||||||
if output.endswith('.h')
|
if output.endswith('.h')
|
||||||
genh += qapi_files[i]
|
genh += qapi_files[i]
|
||||||
endif
|
endif
|
||||||
|
if output.endswith('.trace-events')
|
||||||
|
qapi_trace_events += qapi_files[i]
|
||||||
|
endif
|
||||||
specific_ss.add(when: 'CONFIG_SOFTMMU', if_true: qapi_files[i])
|
specific_ss.add(when: 'CONFIG_SOFTMMU', if_true: qapi_files[i])
|
||||||
i = i + 1
|
i = i + 1
|
||||||
endforeach
|
endforeach
|
||||||
|
|
|
@ -2,10 +2,15 @@
|
||||||
specific_ss.add(files('control-target.c'))
|
specific_ss.add(files('control-target.c'))
|
||||||
|
|
||||||
trace_events_files = []
|
trace_events_files = []
|
||||||
foreach dir : [ '.' ] + trace_events_subdirs
|
foreach item : [ '.' ] + trace_events_subdirs + qapi_trace_events
|
||||||
trace_events_file = meson.project_source_root() / dir / 'trace-events'
|
if item in qapi_trace_events
|
||||||
|
trace_events_file = item
|
||||||
|
group_name = item.full_path().split('/')[-1].underscorify()
|
||||||
|
else
|
||||||
|
trace_events_file = meson.project_source_root() / item / 'trace-events'
|
||||||
|
group_name = item == '.' ? 'root' : item.underscorify()
|
||||||
|
endif
|
||||||
trace_events_files += [ trace_events_file ]
|
trace_events_files += [ trace_events_file ]
|
||||||
group_name = dir == '.' ? 'root' : dir.underscorify()
|
|
||||||
group = '--group=' + group_name
|
group = '--group=' + group_name
|
||||||
fmt = '@0@-' + group_name + '.@1@'
|
fmt = '@0@-' + group_name + '.@1@'
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue