trace: introduce a formal group name for trace events

The declarations in the generated-tracers.h file are
assuming there's only ever going to be one instance
of this header, as they are not namespaced. When we
have one header per event group, if a single source
file needs to include multiple sets of trace events,
the symbols will all clash.

This change thus introduces a '--group NAME' arg to the
'tracetool' program. This will cause all the symbols in
the generated header files to be given a unique namespace.

If no group is given, the group name 'common' is used,
which is suitable for the current usage where there is
only one global trace-events file used for code generation.

Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
Reviewed-by: Lluís Vilanova <vilanova@ac.upc.edu>
Message-id: 1475588159-30598-21-git-send-email-berrange@redhat.com
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
Daniel P. Berrange 2016-10-04 14:35:59 +01:00 committed by Stefan Hajnoczi
parent 0bc6484d58
commit 80dd5c4918
21 changed files with 73 additions and 55 deletions

View file

@ -74,7 +74,7 @@ def exists(name):
return tracetool.try_import("tracetool.format." + name)[1]
def generate(events, format, backend):
def generate(events, format, backend, group):
if not exists(format):
raise ValueError("unknown format: %s" % format)
format = format.replace("-", "_")
@ -82,4 +82,4 @@ def generate(events, format, backend):
"generate")[1]
if func is None:
raise AttributeError("format has no 'generate': %s" % format)
func(events, backend)
func(events, backend, group)

View file

@ -16,7 +16,7 @@ __email__ = "stefanha@linux.vnet.ibm.com"
from tracetool import out
def generate(events, backend):
def generate(events, backend, group):
active_events = [e for e in events
if "disable" not in e.properties]
@ -47,7 +47,8 @@ def generate(events, backend):
sstate = "TRACE_%s_ENABLED" % e.name.upper(),
dstate = e.api(e.QEMU_DSTATE))
out('TraceEvent *trace_events[] = {')
out('TraceEvent *%(group)s_trace_events[] = {',
group = group.lower())
for e in events:
out(' &%(event)s,', event = e.api(e.QEMU_EVENT))
@ -56,13 +57,14 @@ def generate(events, backend):
'};',
'')
out('static void trace_register_events(void)',
out('static void trace_%(group)s_register_events(void)',
'{',
' trace_event_register_group(trace_events);',
' trace_event_register_group(%(group)s_trace_events);',
'}',
'trace_init(trace_register_events)')
'trace_init(trace_%(group)s_register_events)',
group = group.lower())
backend.generate_begin(active_events)
backend.generate_begin(active_events, group)
for event in active_events:
backend.generate(event)
backend.generate_end(active_events)
backend.generate(event, group)
backend.generate_end(active_events, group)

View file

@ -29,7 +29,7 @@ RESERVED_WORDS = (
)
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disable" not in e.properties]

View file

@ -16,11 +16,11 @@ __email__ = "stefanha@linux.vnet.ibm.com"
from tracetool import out
def generate(events, backend):
def generate(events, backend, group):
out('/* This file is autogenerated by tracetool, do not edit. */',
'',
'#ifndef TRACE__GENERATED_TRACERS_H',
'#define TRACE__GENERATED_TRACERS_H',
'#ifndef TRACE_%s_GENERATED_TRACERS_H' % group.upper(),
'#define TRACE_%s_GENERATED_TRACERS_H' % group.upper(),
'',
'#include "qemu-common.h"',
'#include "trace/control.h"',
@ -46,7 +46,7 @@ def generate(events, backend):
enabled=enabled)
out('#define TRACE_%s_ENABLED %d' % (e.name.upper(), enabled))
backend.generate_begin(events)
backend.generate_begin(events, group)
for e in events:
if "vcpu" in e.properties:
@ -68,11 +68,11 @@ def generate(events, backend):
cond=cond)
if "disable" not in e.properties:
backend.generate(e)
backend.generate(e, group)
out(' }',
'}')
backend.generate_end(events)
backend.generate_end(events, group)
out('#endif /* TRACE__GENERATED_TRACERS_H */')
out('#endif /* TRACE_%s_GENERATED_TRACERS_H */' % group.upper())

View file

@ -19,7 +19,7 @@ from tracetool.backend.simple import is_string
from tracetool.format.stap import stap_escape
def generate(events, backend):
def generate(events, backend, group):
out('/* This file is autogenerated by tracetool, do not edit. */',
'',
'global event_name_to_id_map',

View file

@ -34,7 +34,7 @@ def stap_escape(identifier):
return identifier
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disable" not in e.properties]

View file

@ -27,12 +27,12 @@ def vcpu_transform_args(args):
])
def generate(events, backend):
def generate(events, backend, group):
out('/* This file is autogenerated by tracetool, do not edit. */',
'/* You must include this file after the inclusion of helper.h */',
'',
'#ifndef TRACE__GENERATED_TCG_TRACERS_H',
'#define TRACE__GENERATED_TCG_TRACERS_H',
'#ifndef TRACE_%s_GENERATED_TCG_TRACERS_H' % group.upper(),
'#define TRACE_%s_GENERATED_TCG_TRACERS_H' % group.upper(),
'',
'#include "trace.h"',
'#include "exec/helper-proto.h"',
@ -63,4 +63,4 @@ def generate(events, backend):
out('}')
out('',
'#endif /* TRACE__GENERATED_TCG_TRACERS_H */')
'#endif /* TRACE_%s_GENERATED_TCG_TRACERS_H */' % group.upper())

View file

@ -40,7 +40,7 @@ def vcpu_transform_args(args, mode):
assert False
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disable" not in e.properties]

View file

@ -18,7 +18,7 @@ from tracetool.transform import *
import tracetool.vcpu
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disable" not in e.properties]

View file

@ -18,7 +18,7 @@ from tracetool.transform import *
import tracetool.vcpu
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disable" not in e.properties]

View file

@ -16,7 +16,7 @@ __email__ = "stefanha@redhat.com"
from tracetool import out
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disabled" not in e.properties]

View file

@ -16,7 +16,7 @@ __email__ = "stefanha@redhat.com"
from tracetool import out
def generate(events, backend):
def generate(events, backend, group):
events = [e for e in events
if "disabled" not in e.properties]
@ -28,8 +28,9 @@ def generate(events, backend):
'#undef TRACEPOINT_INCLUDE_FILE',
'#define TRACEPOINT_INCLUDE_FILE ./generated-ust-provider.h',
'',
'#if !defined (TRACE__GENERATED_UST_H) || defined(TRACEPOINT_HEADER_MULTI_READ)',
'#define TRACE__GENERATED_UST_H',
'#if !defined (TRACE_%s_GENERATED_UST_H) || \\' % group.upper(),
' defined(TRACEPOINT_HEADER_MULTI_READ)',
'#define TRACE_%s_GENERATED_UST_H' % group.upper(),
'',
'#include "qemu-common.h"',
'#include <lttng/tracepoint.h>',
@ -94,7 +95,7 @@ def generate(events, backend):
'',
name=e.name)
out('#endif /* TRACE__GENERATED_UST_H */',
out('#endif /* TRACE_%s_GENERATED_UST_H */' % group.upper(),
'',
'/* This part must be outside ifdef protection */',
'#include <lttng/tracepoint-event.h>')