eef62a6826
There's been a bit confusion to whether DEFINE/DECLARE_TRACE_FMT should be a DEFINE or a DECLARE. Ingo Molnar suggested simply calling it TRACE_FORMAT. Reported-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Steven Rostedt <srostedt@redhat.com>
56 lines
1.4 KiB
C
56 lines
1.4 KiB
C
#ifndef _LINUX_KERNEL_TRACE_EVENTS_H
|
|
#define _LINUX_KERNEL_TRACE_EVENTS_H
|
|
|
|
#include <linux/debugfs.h>
|
|
#include <linux/ftrace.h>
|
|
#include "trace.h"
|
|
|
|
struct ftrace_event_call {
|
|
char *name;
|
|
struct dentry *dir;
|
|
int enabled;
|
|
int (*regfunc)(void);
|
|
void (*unregfunc)(void);
|
|
};
|
|
|
|
|
|
#undef TPFMT
|
|
#define TPFMT(fmt, args...) fmt "\n", ##args
|
|
|
|
#undef TRACE_FORMAT
|
|
#define TRACE_FORMAT(call, proto, args, fmt) \
|
|
static void ftrace_event_##call(proto) \
|
|
{ \
|
|
event_trace_printk(_RET_IP_, "(" #call ") " fmt); \
|
|
} \
|
|
\
|
|
static int ftrace_reg_event_##call(void) \
|
|
{ \
|
|
int ret; \
|
|
\
|
|
ret = register_trace_##call(ftrace_event_##call); \
|
|
if (!ret) \
|
|
pr_info("event trace: Could not activate trace point " \
|
|
"probe to " #call); \
|
|
return ret; \
|
|
} \
|
|
\
|
|
static void ftrace_unreg_event_##call(void) \
|
|
{ \
|
|
unregister_trace_##call(ftrace_event_##call); \
|
|
} \
|
|
\
|
|
static struct ftrace_event_call __used \
|
|
__attribute__((__aligned__(4))) \
|
|
__attribute__((section("_ftrace_events"))) event_##call = { \
|
|
.name = #call, \
|
|
.regfunc = ftrace_reg_event_##call, \
|
|
.unregfunc = ftrace_unreg_event_##call, \
|
|
}
|
|
|
|
void event_trace_printk(unsigned long ip, const char *fmt, ...);
|
|
extern struct ftrace_event_call __start_ftrace_events[];
|
|
extern struct ftrace_event_call __stop_ftrace_events[];
|
|
|
|
#endif /* _LINUX_KERNEL_TRACE_EVENTS_H */
|