Commit c7ef3a90 authored by Steven Rostedt's avatar Steven Rostedt Committed by Steven Rostedt

tracing: Have syscall tracing call its own init function

In the clean up of having all events call one specific function,
the syscall event init was changed to call this helper function.

With the new print_fmt updates, the syscalls need to do special
initializations. This patch converts the syscall events to call
its own init function again.

Cc: Lai Jiangshan <laijs@cn.fujitsu.com>
Cc: Li Zefan <lizf@cn.fujitsu.com>
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent a342a028
...@@ -143,7 +143,7 @@ struct perf_event_attr; ...@@ -143,7 +143,7 @@ struct perf_event_attr;
.name = "sys_enter"#sname, \ .name = "sys_enter"#sname, \
.system = "syscalls", \ .system = "syscalls", \
.event = &enter_syscall_print_##sname, \ .event = &enter_syscall_print_##sname, \
.raw_init = trace_event_raw_init, \ .raw_init = init_syscall_trace, \
.show_format = syscall_enter_format, \ .show_format = syscall_enter_format, \
.define_fields = syscall_enter_define_fields, \ .define_fields = syscall_enter_define_fields, \
.regfunc = reg_event_syscall_enter, \ .regfunc = reg_event_syscall_enter, \
...@@ -165,7 +165,7 @@ struct perf_event_attr; ...@@ -165,7 +165,7 @@ struct perf_event_attr;
.name = "sys_exit"#sname, \ .name = "sys_exit"#sname, \
.system = "syscalls", \ .system = "syscalls", \
.event = &exit_syscall_print_##sname, \ .event = &exit_syscall_print_##sname, \
.raw_init = trace_event_raw_init, \ .raw_init = init_syscall_trace, \
.show_format = syscall_exit_format, \ .show_format = syscall_exit_format, \
.define_fields = syscall_exit_define_fields, \ .define_fields = syscall_exit_define_fields, \
.regfunc = reg_event_syscall_exit, \ .regfunc = reg_event_syscall_exit, \
......
...@@ -450,14 +450,14 @@ int init_syscall_trace(struct ftrace_event_call *call) ...@@ -450,14 +450,14 @@ int init_syscall_trace(struct ftrace_event_call *call)
if (set_syscall_print_fmt(call) < 0) if (set_syscall_print_fmt(call) < 0)
return -ENOMEM; return -ENOMEM;
id = register_ftrace_event(call->event); id = trace_event_raw_init(call);
if (!id) {
if (id < 0) {
free_syscall_print_fmt(call); free_syscall_print_fmt(call);
return -ENODEV; return id;
} }
call->id = id;
INIT_LIST_HEAD(&call->fields); return id;
return 0;
} }
int __init init_ftrace_syscalls(void) int __init init_ftrace_syscalls(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment