Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Trace files that want to automate creation of all tracepoints defined
4 * in their file should include this file. The following are macros that the
5 * trace file may define:
6 *
7 * TRACE_SYSTEM defines the system the tracepoint is for
8 *
9 * TRACE_INCLUDE_FILE if the file name is something other than TRACE_SYSTEM.h
10 * This macro may be defined to tell define_trace.h what file to include.
11 * Note, leave off the ".h".
12 *
13 * TRACE_INCLUDE_PATH if the path is something other than core kernel include/trace
14 * then this macro can define the path to use. Note, the path is relative to
15 * define_trace.h, not the file including it. Full path names for out of tree
16 * modules must be used.
17 */
18
19#ifdef CREATE_TRACE_POINTS
20
21/* Prevent recursion */
22#undef CREATE_TRACE_POINTS
23
24#include <linux/stringify.h>
25
26#undef TRACE_EVENT
27#define TRACE_EVENT(name, proto, args, tstruct, assign, print) \
28 DEFINE_TRACE(name)
29
30#undef TRACE_EVENT_CONDITION
31#define TRACE_EVENT_CONDITION(name, proto, args, cond, tstruct, assign, print) \
32 TRACE_EVENT(name, \
33 PARAMS(proto), \
34 PARAMS(args), \
35 PARAMS(tstruct), \
36 PARAMS(assign), \
37 PARAMS(print))
38
39#undef TRACE_EVENT_FN
40#define TRACE_EVENT_FN(name, proto, args, tstruct, \
41 assign, print, reg, unreg) \
42 DEFINE_TRACE_FN(name, reg, unreg)
43
44#undef TRACE_EVENT_FN_COND
45#define TRACE_EVENT_FN_COND(name, proto, args, cond, tstruct, \
46 assign, print, reg, unreg) \
47 DEFINE_TRACE_FN(name, reg, unreg)
48
49#undef TRACE_EVENT_NOP
50#define TRACE_EVENT_NOP(name, proto, args, struct, assign, print)
51
52#undef DEFINE_EVENT_NOP
53#define DEFINE_EVENT_NOP(template, name, proto, args)
54
55#undef DEFINE_EVENT
56#define DEFINE_EVENT(template, name, proto, args) \
57 DEFINE_TRACE(name)
58
59#undef DEFINE_EVENT_FN
60#define DEFINE_EVENT_FN(template, name, proto, args, reg, unreg) \
61 DEFINE_TRACE_FN(name, reg, unreg)
62
63#undef DEFINE_EVENT_PRINT
64#define DEFINE_EVENT_PRINT(template, name, proto, args, print) \
65 DEFINE_TRACE(name)
66
67#undef DEFINE_EVENT_CONDITION
68#define DEFINE_EVENT_CONDITION(template, name, proto, args, cond) \
69 DEFINE_EVENT(template, name, PARAMS(proto), PARAMS(args))
70
71#undef DECLARE_TRACE
72#define DECLARE_TRACE(name, proto, args) \
73 DEFINE_TRACE(name)
74
75#undef TRACE_INCLUDE
76#undef __TRACE_INCLUDE
77
78#ifndef TRACE_INCLUDE_FILE
79# define TRACE_INCLUDE_FILE TRACE_SYSTEM
80# define UNDEF_TRACE_INCLUDE_FILE
81#endif
82
83#ifndef TRACE_INCLUDE_PATH
84# define __TRACE_INCLUDE(system) <trace/events/system.h>
85# define UNDEF_TRACE_INCLUDE_PATH
86#else
87# define __TRACE_INCLUDE(system) __stringify(TRACE_INCLUDE_PATH/system.h)
88#endif
89
90# define TRACE_INCLUDE(system) __TRACE_INCLUDE(system)
91
92/* Let the trace headers be reread */
93#define TRACE_HEADER_MULTI_READ
94
95#include TRACE_INCLUDE(TRACE_INCLUDE_FILE)
96
97/* Make all open coded DECLARE_TRACE nops */
98#undef DECLARE_TRACE
99#define DECLARE_TRACE(name, proto, args)
100
101#ifdef TRACEPOINTS_ENABLED
102#include <trace/trace_events.h>
103#include <trace/perf.h>
104#include <trace/bpf_probe.h>
105#endif
106
107#undef TRACE_EVENT
108#undef TRACE_EVENT_FN
109#undef TRACE_EVENT_FN_COND
110#undef TRACE_EVENT_CONDITION
111#undef TRACE_EVENT_NOP
112#undef DEFINE_EVENT_NOP
113#undef DECLARE_EVENT_CLASS
114#undef DEFINE_EVENT
115#undef DEFINE_EVENT_FN
116#undef DEFINE_EVENT_PRINT
117#undef DEFINE_EVENT_CONDITION
118#undef TRACE_HEADER_MULTI_READ
119#undef DECLARE_TRACE
120
121/* Only undef what we defined in this file */
122#ifdef UNDEF_TRACE_INCLUDE_FILE
123# undef TRACE_INCLUDE_FILE
124# undef UNDEF_TRACE_INCLUDE_FILE
125#endif
126
127#ifdef UNDEF_TRACE_INCLUDE_PATH
128# undef TRACE_INCLUDE_PATH
129# undef UNDEF_TRACE_INCLUDE_PATH
130#endif
131
132/* We may be processing more files */
133#define CREATE_TRACE_POINTS
134
135#endif /* CREATE_TRACE_POINTS */
1/*
2 * Trace files that want to automate creation of all tracepoints defined
3 * in their file should include this file. The following are macros that the
4 * trace file may define:
5 *
6 * TRACE_SYSTEM defines the system the tracepoint is for
7 *
8 * TRACE_INCLUDE_FILE if the file name is something other than TRACE_SYSTEM.h
9 * This macro may be defined to tell define_trace.h what file to include.
10 * Note, leave off the ".h".
11 *
12 * TRACE_INCLUDE_PATH if the path is something other than core kernel include/trace
13 * then this macro can define the path to use. Note, the path is relative to
14 * define_trace.h, not the file including it. Full path names for out of tree
15 * modules must be used.
16 */
17
18#ifdef CREATE_TRACE_POINTS
19
20/* Prevent recursion */
21#undef CREATE_TRACE_POINTS
22
23#include <linux/stringify.h>
24
25#undef TRACE_EVENT
26#define TRACE_EVENT(name, proto, args, tstruct, assign, print) \
27 DEFINE_TRACE(name)
28
29#undef TRACE_EVENT_CONDITION
30#define TRACE_EVENT_CONDITION(name, proto, args, cond, tstruct, assign, print) \
31 TRACE_EVENT(name, \
32 PARAMS(proto), \
33 PARAMS(args), \
34 PARAMS(tstruct), \
35 PARAMS(assign), \
36 PARAMS(print))
37
38#undef TRACE_EVENT_FN
39#define TRACE_EVENT_FN(name, proto, args, tstruct, \
40 assign, print, reg, unreg) \
41 DEFINE_TRACE_FN(name, reg, unreg)
42
43#undef DEFINE_EVENT
44#define DEFINE_EVENT(template, name, proto, args) \
45 DEFINE_TRACE(name)
46
47#undef DEFINE_EVENT_FN
48#define DEFINE_EVENT_FN(template, name, proto, args, reg, unreg) \
49 DEFINE_TRACE_FN(name, reg, unreg)
50
51#undef DEFINE_EVENT_PRINT
52#define DEFINE_EVENT_PRINT(template, name, proto, args, print) \
53 DEFINE_TRACE(name)
54
55#undef DEFINE_EVENT_CONDITION
56#define DEFINE_EVENT_CONDITION(template, name, proto, args, cond) \
57 DEFINE_EVENT(template, name, PARAMS(proto), PARAMS(args))
58
59#undef DECLARE_TRACE
60#define DECLARE_TRACE(name, proto, args) \
61 DEFINE_TRACE(name)
62
63#undef TRACE_INCLUDE
64#undef __TRACE_INCLUDE
65
66#ifndef TRACE_INCLUDE_FILE
67# define TRACE_INCLUDE_FILE TRACE_SYSTEM
68# define UNDEF_TRACE_INCLUDE_FILE
69#endif
70
71#ifndef TRACE_INCLUDE_PATH
72# define __TRACE_INCLUDE(system) <trace/events/system.h>
73# define UNDEF_TRACE_INCLUDE_PATH
74#else
75# define __TRACE_INCLUDE(system) __stringify(TRACE_INCLUDE_PATH/system.h)
76#endif
77
78# define TRACE_INCLUDE(system) __TRACE_INCLUDE(system)
79
80/* Let the trace headers be reread */
81#define TRACE_HEADER_MULTI_READ
82
83#include TRACE_INCLUDE(TRACE_INCLUDE_FILE)
84
85/* Make all open coded DECLARE_TRACE nops */
86#undef DECLARE_TRACE
87#define DECLARE_TRACE(name, proto, args)
88
89#ifdef CONFIG_EVENT_TRACING
90#include <trace/ftrace.h>
91#endif
92
93#undef TRACE_EVENT
94#undef TRACE_EVENT_FN
95#undef TRACE_EVENT_CONDITION
96#undef DECLARE_EVENT_CLASS
97#undef DEFINE_EVENT
98#undef DEFINE_EVENT_FN
99#undef DEFINE_EVENT_PRINT
100#undef DEFINE_EVENT_CONDITION
101#undef TRACE_HEADER_MULTI_READ
102#undef DECLARE_TRACE
103
104/* Only undef what we defined in this file */
105#ifdef UNDEF_TRACE_INCLUDE_FILE
106# undef TRACE_INCLUDE_FILE
107# undef UNDEF_TRACE_INCLUDE_FILE
108#endif
109
110#ifdef UNDEF_TRACE_INCLUDE_PATH
111# undef TRACE_INCLUDE_PATH
112# undef UNDEF_TRACE_INCLUDE_PATH
113#endif
114
115/* We may be processing more files */
116#define CREATE_TRACE_POINTS
117
118#endif /* CREATE_TRACE_POINTS */