From 01cf2db1684d8f1fd445f8a37f3acb7361a3bd5e Mon Sep 17 00:00:00 2001 From: Peter Zijlstra Date: Thu, 19 Mar 2009 20:26:14 +0100 Subject: [PATCH] --- yaml --- r: 141000 b: refs/heads/master c: 28bea271e58e429eccfad3d7ee2ad12d6ee015bf h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/kernel/trace/trace_events_stage_3.h | 15 ++++++++++++++- trunk/kernel/trace/trace_output.c | 5 +++++ 3 files changed, 20 insertions(+), 2 deletions(-) diff --git a/[refs] b/[refs] index c5a751f82d2d..3fb9b53b3944 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 23725aeeab10ba02bcf10ec49ad73146b54cb52f +refs/heads/master: 28bea271e58e429eccfad3d7ee2ad12d6ee015bf diff --git a/trunk/kernel/trace/trace_events_stage_3.h b/trunk/kernel/trace/trace_events_stage_3.h index ae2e323df0c7..4c26d97b4508 100644 --- a/trunk/kernel/trace/trace_events_stage_3.h +++ b/trunk/kernel/trace/trace_events_stage_3.h @@ -130,7 +130,19 @@ static void ftrace_unreg_event_##call(void) \ { \ unregister_trace_##call(ftrace_event_##call); \ } \ - + \ +static struct ftrace_event_call event_##call; \ + \ +static int ftrace_init_event_##call(void) \ +{ \ + int id; \ + \ + id = register_ftrace_event(NULL); \ + if (!id) \ + return -ENODEV; \ + event_##call.id = id; \ + return 0; \ +} #undef TRACE_FORMAT #define TRACE_FORMAT(call, proto, args, fmt) \ @@ -140,6 +152,7 @@ __attribute__((__aligned__(4))) \ __attribute__((section("_ftrace_events"))) event_##call = { \ .name = #call, \ .system = __stringify(TRACE_SYSTEM), \ + .raw_init = ftrace_init_event_##call, \ .regfunc = ftrace_reg_event_##call, \ .unregfunc = ftrace_unreg_event_##call, \ } diff --git a/trunk/kernel/trace/trace_output.c b/trunk/kernel/trace/trace_output.c index b45141748af5..19261fdd2455 100644 --- a/trunk/kernel/trace/trace_output.c +++ b/trunk/kernel/trace/trace_output.c @@ -481,6 +481,11 @@ int register_ftrace_event(struct trace_event *event) mutex_lock(&trace_event_mutex); + if (!event) { + ret = next_event_type++; + goto out; + } + if (!event->type) event->type = next_event_type++; else if (event->type > __TRACE_LAST_TYPE) {