define_trace.h 3.4 KB
Newer Older
1
/* SPDX-License-Identifier: GPL-2.0 */
2
/*
3
 * Trace files that want to automate creation of all tracepoints defined
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
 * in their file should include this file. The following are macros that the
 * trace file may define:
 *
 * TRACE_SYSTEM defines the system the tracepoint is for
 *
 * TRACE_INCLUDE_FILE if the file name is something other than TRACE_SYSTEM.h
 *     This macro may be defined to tell define_trace.h what file to include.
 *     Note, leave off the ".h".
 *
 * TRACE_INCLUDE_PATH if the path is something other than core kernel include/trace
 *     then this macro can define the path to use. Note, the path is relative to
 *     define_trace.h, not the file including it. Full path names for out of tree
 *     modules must be used.
 */

#ifdef CREATE_TRACE_POINTS

/* Prevent recursion */
#undef CREATE_TRACE_POINTS

#include <linux/stringify.h>

#undef TRACE_EVENT
#define TRACE_EVENT(name, proto, args, tstruct, assign, print)	\
	DEFINE_TRACE(name)

30 31 32 33 34 35 36 37 38
#undef TRACE_EVENT_CONDITION
#define TRACE_EVENT_CONDITION(name, proto, args, cond, tstruct, assign, print) \
	TRACE_EVENT(name,						\
		PARAMS(proto),						\
		PARAMS(args),						\
		PARAMS(tstruct),					\
		PARAMS(assign),						\
		PARAMS(print))

39 40 41 42 43
#undef TRACE_EVENT_FN
#define TRACE_EVENT_FN(name, proto, args, tstruct,		\
		assign, print, reg, unreg)			\
	DEFINE_TRACE_FN(name, reg, unreg)

44 45 46 47 48
#undef TRACE_EVENT_FN_COND
#define TRACE_EVENT_FN_COND(name, proto, args, cond, tstruct,		\
		assign, print, reg, unreg)			\
	DEFINE_TRACE_FN(name, reg, unreg)

49 50 51 52
#undef DEFINE_EVENT
#define DEFINE_EVENT(template, name, proto, args) \
	DEFINE_TRACE(name)

53 54 55 56
#undef DEFINE_EVENT_FN
#define DEFINE_EVENT_FN(template, name, proto, args, reg, unreg) \
	DEFINE_TRACE_FN(name, reg, unreg)

57 58 59 60
#undef DEFINE_EVENT_PRINT
#define DEFINE_EVENT_PRINT(template, name, proto, args, print)	\
	DEFINE_TRACE(name)

61 62 63 64
#undef DEFINE_EVENT_CONDITION
#define DEFINE_EVENT_CONDITION(template, name, proto, args, cond) \
	DEFINE_EVENT(template, name, PARAMS(proto), PARAMS(args))

65 66 67 68 69 70 71 72 73 74 75 76 77
#undef DECLARE_TRACE
#define DECLARE_TRACE(name, proto, args)	\
	DEFINE_TRACE(name)

#undef TRACE_INCLUDE
#undef __TRACE_INCLUDE

#ifndef TRACE_INCLUDE_FILE
# define TRACE_INCLUDE_FILE TRACE_SYSTEM
# define UNDEF_TRACE_INCLUDE_FILE
#endif

#ifndef TRACE_INCLUDE_PATH
78
# define __TRACE_INCLUDE(system) <trace/events/system.h>
79
# define UNDEF_TRACE_INCLUDE_PATH
80 81 82 83 84 85 86 87 88 89 90
#else
# define __TRACE_INCLUDE(system) __stringify(TRACE_INCLUDE_PATH/system.h)
#endif

# define TRACE_INCLUDE(system) __TRACE_INCLUDE(system)

/* Let the trace headers be reread */
#define TRACE_HEADER_MULTI_READ

#include TRACE_INCLUDE(TRACE_INCLUDE_FILE)

91 92 93 94
/* Make all open coded DECLARE_TRACE nops */
#undef DECLARE_TRACE
#define DECLARE_TRACE(name, proto, args)

95
#ifdef TRACEPOINTS_ENABLED
96
#include <trace/trace_events.h>
97
#include <trace/perf.h>
98
#include <trace/bpf_probe.h>
99 100
#endif

101
#undef TRACE_EVENT
102
#undef TRACE_EVENT_FN
103
#undef TRACE_EVENT_FN_COND
104
#undef TRACE_EVENT_CONDITION
105
#undef DECLARE_EVENT_CLASS
106
#undef DEFINE_EVENT
107
#undef DEFINE_EVENT_FN
108
#undef DEFINE_EVENT_PRINT
109
#undef DEFINE_EVENT_CONDITION
110
#undef TRACE_HEADER_MULTI_READ
111
#undef DECLARE_TRACE
112 113 114

/* Only undef what we defined in this file */
#ifdef UNDEF_TRACE_INCLUDE_FILE
115
# undef TRACE_INCLUDE_FILE
116 117 118
# undef UNDEF_TRACE_INCLUDE_FILE
#endif

119
#ifdef UNDEF_TRACE_INCLUDE_PATH
120
# undef TRACE_INCLUDE_PATH
121
# undef UNDEF_TRACE_INCLUDE_PATH
122 123 124 125 126 127
#endif

/* We may be processing more files */
#define CREATE_TRACE_POINTS

#endif /* CREATE_TRACE_POINTS */