forked from Minki/linux
1473e4417c
This patch adds the directory /debug/tracing/events/ that will contain all the registered trace points. # ls /debug/tracing/events/ sched_kthread_stop sched_process_fork sched_switch sched_kthread_stop_ret sched_process_free sched_wait_task sched_migrate_task sched_process_wait sched_wakeup sched_process_exit sched_signal_send sched_wakeup_new # ls /debug/tracing/events/sched_switch/ enable # cat /debug/tracing/events/sched_switch/enable 1 # cat /debug/tracing/set_event sched_switch 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 DEFINE_TRACE_FMT
|
|
#define DEFINE_TRACE_FMT(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 */
|