mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 08:43:55 -06:00
trace: Do not include qom/cpu.h into generated trace.h
docs/devel/tracing.txt explains "since many source files include
trace.h, [the generated trace.h use] a minimum of types and other
header files included to keep the namespace clean and compile times
and dependencies down."
Commit 4815185902
"trace: Add per-vCPU tracing states for events with
the 'vcpu' property" made them all include qom/cpu.h via
control-internal.h. qom/cpu.h in turn includes about thirty headers.
Ouch.
Per-vCPU tracing is currently not supported in sub-directories'
trace-events. In other words, qom/cpu.h can only be used in
trace-root.h, not in any trace.h.
Split trace/control-vcpu.h off trace/control.h and
trace/control-internal.h. Have the generated trace.h include
trace/control.h (which no longer includes qom/cpu.h), and trace-root.h
include trace/control-vcpu.h (which includes it).
The resulting improvement is a bit disappointing: in my "build
everything" tree, some 1100 out of 6600 objects (not counting tests
and objects that don't depend on qemu/osdep.h) depend on a trace.h,
and about 600 of them no longer depend on qom/cpu.h. But more than
1300 others depend on trace-root.h. More work is clearly needed.
Left for another day.
Cc: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Message-Id: <20190812052359.30071-8-armbru@redhat.com>
This commit is contained in:
parent
988fa10304
commit
13d4ff07e8
9 changed files with 74 additions and 51 deletions
|
@ -119,22 +119,6 @@ static const char * trace_event_get_name(TraceEvent *ev);
|
|||
#define trace_event_get_state_backends(id) \
|
||||
((id ##_ENABLED) && id ##_BACKEND_DSTATE())
|
||||
|
||||
/**
|
||||
* trace_event_get_vcpu_state:
|
||||
* @vcpu: Target vCPU.
|
||||
* @id: Event identifier name.
|
||||
*
|
||||
* Get the tracing state of an event (both static and dynamic) for the given
|
||||
* vCPU.
|
||||
*
|
||||
* If the event has the disabled property, the check will have no performance
|
||||
* impact.
|
||||
*/
|
||||
#define trace_event_get_vcpu_state(vcpu, id) \
|
||||
((id ##_ENABLED) && \
|
||||
trace_event_get_vcpu_state_dynamic_by_vcpu_id( \
|
||||
vcpu, _ ## id ## _EVENT.vcpu_id))
|
||||
|
||||
/**
|
||||
* trace_event_get_state_static:
|
||||
* @id: Event identifier.
|
||||
|
@ -155,14 +139,6 @@ static bool trace_event_get_state_static(TraceEvent *ev);
|
|||
*/
|
||||
static bool trace_event_get_state_dynamic(TraceEvent *ev);
|
||||
|
||||
/**
|
||||
* trace_event_get_vcpu_state_dynamic:
|
||||
*
|
||||
* Get the dynamic tracing state of an event for the given vCPU.
|
||||
*/
|
||||
static bool trace_event_get_vcpu_state_dynamic(CPUState *vcpu, TraceEvent *ev);
|
||||
|
||||
|
||||
/**
|
||||
* trace_event_set_state_dynamic:
|
||||
*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue