diff options
author | Li Zefan <lizefan@huawei.com> | 2013-03-04 01:15:59 -0500 |
---|---|---|
committer | Steven Rostedt <rostedt@goodmis.org> | 2013-03-15 00:34:54 -0400 |
commit | 523c81135bb23b2d9a8c21365d90d21b1309c138 (patch) | |
tree | bbecc47a046a3c2a6be1996d1bfdc3e902b96aa3 | |
parent | 315326c16ad08771fe0f075a08a18c99976f29f5 (diff) |
tracing: Fix some section mismatch warnings
As we've added __init annotation to field-defining functions, we should
add __refdata annotation to event_call variables, which reference those
functions.
Link: http://lkml.kernel.org/r/51343C1F.2050502@huawei.com
Reported-by: Fengguang Wu <fengguang.wu@intel.com>
Signed-off-by: Li Zefan <lizefan@huawei.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
-rw-r--r-- | include/trace/ftrace.h | 2 | ||||
-rw-r--r-- | kernel/trace/trace_export.c | 2 | ||||
-rw-r--r-- | kernel/trace/trace_syscalls.c | 4 |
3 files changed, 4 insertions, 4 deletions
diff --git a/include/trace/ftrace.h b/include/trace/ftrace.h index a536f66f84c6..bbf09c2021b9 100644 --- a/include/trace/ftrace.h +++ b/include/trace/ftrace.h | |||
@@ -572,7 +572,7 @@ static inline void ftrace_test_probe_##call(void) \ | |||
572 | #define DECLARE_EVENT_CLASS(call, proto, args, tstruct, assign, print) \ | 572 | #define DECLARE_EVENT_CLASS(call, proto, args, tstruct, assign, print) \ |
573 | _TRACE_PERF_PROTO(call, PARAMS(proto)); \ | 573 | _TRACE_PERF_PROTO(call, PARAMS(proto)); \ |
574 | static const char print_fmt_##call[] = print; \ | 574 | static const char print_fmt_##call[] = print; \ |
575 | static struct ftrace_event_class __used event_class_##call = { \ | 575 | static struct ftrace_event_class __used __refdata event_class_##call = { \ |
576 | .system = __stringify(TRACE_SYSTEM), \ | 576 | .system = __stringify(TRACE_SYSTEM), \ |
577 | .define_fields = ftrace_define_fields_##call, \ | 577 | .define_fields = ftrace_define_fields_##call, \ |
578 | .fields = LIST_HEAD_INIT(event_class_##call.fields),\ | 578 | .fields = LIST_HEAD_INIT(event_class_##call.fields),\ |
diff --git a/kernel/trace/trace_export.c b/kernel/trace/trace_export.c index 4f6a91c1370c..d21a74670088 100644 --- a/kernel/trace/trace_export.c +++ b/kernel/trace/trace_export.c | |||
@@ -168,7 +168,7 @@ ftrace_define_fields_##name(struct ftrace_event_call *event_call) \ | |||
168 | #define FTRACE_ENTRY_REG(call, struct_name, etype, tstruct, print, filter,\ | 168 | #define FTRACE_ENTRY_REG(call, struct_name, etype, tstruct, print, filter,\ |
169 | regfn) \ | 169 | regfn) \ |
170 | \ | 170 | \ |
171 | struct ftrace_event_class event_class_ftrace_##call = { \ | 171 | struct ftrace_event_class __refdata event_class_ftrace_##call = { \ |
172 | .system = __stringify(TRACE_SYSTEM), \ | 172 | .system = __stringify(TRACE_SYSTEM), \ |
173 | .define_fields = ftrace_define_fields_##call, \ | 173 | .define_fields = ftrace_define_fields_##call, \ |
174 | .fields = LIST_HEAD_INIT(event_class_ftrace_##call.fields),\ | 174 | .fields = LIST_HEAD_INIT(event_class_ftrace_##call.fields),\ |
diff --git a/kernel/trace/trace_syscalls.c b/kernel/trace/trace_syscalls.c index 00b5c3e6fbbe..1cd37ffb4093 100644 --- a/kernel/trace/trace_syscalls.c +++ b/kernel/trace/trace_syscalls.c | |||
@@ -479,7 +479,7 @@ struct trace_event_functions exit_syscall_print_funcs = { | |||
479 | .trace = print_syscall_exit, | 479 | .trace = print_syscall_exit, |
480 | }; | 480 | }; |
481 | 481 | ||
482 | struct ftrace_event_class event_class_syscall_enter = { | 482 | struct ftrace_event_class __refdata event_class_syscall_enter = { |
483 | .system = "syscalls", | 483 | .system = "syscalls", |
484 | .reg = syscall_enter_register, | 484 | .reg = syscall_enter_register, |
485 | .define_fields = syscall_enter_define_fields, | 485 | .define_fields = syscall_enter_define_fields, |
@@ -487,7 +487,7 @@ struct ftrace_event_class event_class_syscall_enter = { | |||
487 | .raw_init = init_syscall_trace, | 487 | .raw_init = init_syscall_trace, |
488 | }; | 488 | }; |
489 | 489 | ||
490 | struct ftrace_event_class event_class_syscall_exit = { | 490 | struct ftrace_event_class __refdata event_class_syscall_exit = { |
491 | .system = "syscalls", | 491 | .system = "syscalls", |
492 | .reg = syscall_exit_register, | 492 | .reg = syscall_exit_register, |
493 | .define_fields = syscall_exit_define_fields, | 493 | .define_fields = syscall_exit_define_fields, |