2009-02-24 15:21:36 +00:00
|
|
|
#ifndef _LINUX_KERNEL_TRACE_EVENTS_H
|
|
|
|
#define _LINUX_KERNEL_TRACE_EVENTS_H
|
|
|
|
|
2009-02-24 19:15:08 +00:00
|
|
|
#include <linux/debugfs.h>
|
2009-02-24 15:21:36 +00:00
|
|
|
#include <linux/ftrace.h>
|
|
|
|
#include "trace.h"
|
|
|
|
|
|
|
|
struct ftrace_event_call {
|
|
|
|
char *name;
|
2009-02-24 19:15:08 +00:00
|
|
|
struct dentry *dir;
|
2009-02-24 15:21:36 +00:00
|
|
|
int enabled;
|
|
|
|
int (*regfunc)(void);
|
|
|
|
void (*unregfunc)(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#undef TPFMT
|
|
|
|
#define TPFMT(fmt, args...) fmt "\n", ##args
|
|
|
|
|
2009-02-25 20:49:52 +00:00
|
|
|
#undef TRACE_FORMAT
|
|
|
|
#define TRACE_FORMAT(call, proto, args, fmt) \
|
2009-02-24 15:21:36 +00:00
|
|
|
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 \
|
2009-02-24 19:15:08 +00:00
|
|
|
__attribute__((__aligned__(4))) \
|
2009-02-24 15:21:36 +00:00
|
|
|
__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, ...);
|
2009-02-24 19:15:08 +00:00
|
|
|
extern struct ftrace_event_call __start_ftrace_events[];
|
|
|
|
extern struct ftrace_event_call __stop_ftrace_events[];
|
2009-02-24 15:21:36 +00:00
|
|
|
|
|
|
|
#endif /* _LINUX_KERNEL_TRACE_EVENTS_H */
|