aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/syscalls.h30
-rw-r--r--include/trace/syscall.h1
-rw-r--r--kernel/trace/trace_syscalls.c12
3 files changed, 15 insertions, 28 deletions
diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h
index 3c280d7ecb76..cf0d923ea40e 100644
--- a/include/linux/syscalls.h
+++ b/include/linux/syscalls.h
@@ -158,19 +158,6 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
158 struct trace_event enter_syscall_print_##sname = { \ 158 struct trace_event enter_syscall_print_##sname = { \
159 .trace = print_syscall_enter, \ 159 .trace = print_syscall_enter, \
160 }; \ 160 }; \
161 static int init_enter_##sname(struct ftrace_event_call *call) \
162 { \
163 int num, id; \
164 num = __syscall_meta_##sname.syscall_nr; \
165 if (num < 0) \
166 return -ENOSYS; \
167 id = register_ftrace_event(&enter_syscall_print_##sname);\
168 if (!id) \
169 return -ENODEV; \
170 event_enter_##sname.id = id; \
171 INIT_LIST_HEAD(&event_enter_##sname.fields); \
172 return 0; \
173 } \
174 TRACE_SYS_ENTER_PROFILE(sname); \ 161 TRACE_SYS_ENTER_PROFILE(sname); \
175 static struct ftrace_event_call __used \ 162 static struct ftrace_event_call __used \
176 __attribute__((__aligned__(4))) \ 163 __attribute__((__aligned__(4))) \
@@ -179,7 +166,7 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
179 .name = "sys_enter"#sname, \ 166 .name = "sys_enter"#sname, \
180 .system = "syscalls", \ 167 .system = "syscalls", \
181 .event = &enter_syscall_print_##sname, \ 168 .event = &enter_syscall_print_##sname, \
182 .raw_init = init_enter_##sname, \ 169 .raw_init = init_syscall_trace, \
183 .show_format = syscall_enter_format, \ 170 .show_format = syscall_enter_format, \
184 .define_fields = syscall_enter_define_fields, \ 171 .define_fields = syscall_enter_define_fields, \
185 .regfunc = reg_event_syscall_enter, \ 172 .regfunc = reg_event_syscall_enter, \
@@ -194,19 +181,6 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
194 struct trace_event exit_syscall_print_##sname = { \ 181 struct trace_event exit_syscall_print_##sname = { \
195 .trace = print_syscall_exit, \ 182 .trace = print_syscall_exit, \
196 }; \ 183 }; \
197 static int init_exit_##sname(struct ftrace_event_call *call) \
198 { \
199 int num, id; \
200 num = __syscall_meta_##sname.syscall_nr; \
201 if (num < 0) \
202 return -ENOSYS; \
203 id = register_ftrace_event(&exit_syscall_print_##sname);\
204 if (!id) \
205 return -ENODEV; \
206 event_exit_##sname.id = id; \
207 INIT_LIST_HEAD(&event_exit_##sname.fields); \
208 return 0; \
209 } \
210 TRACE_SYS_EXIT_PROFILE(sname); \ 184 TRACE_SYS_EXIT_PROFILE(sname); \
211 static struct ftrace_event_call __used \ 185 static struct ftrace_event_call __used \
212 __attribute__((__aligned__(4))) \ 186 __attribute__((__aligned__(4))) \
@@ -215,7 +189,7 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
215 .name = "sys_exit"#sname, \ 189 .name = "sys_exit"#sname, \
216 .system = "syscalls", \ 190 .system = "syscalls", \
217 .event = &exit_syscall_print_##sname, \ 191 .event = &exit_syscall_print_##sname, \
218 .raw_init = init_exit_##sname, \ 192 .raw_init = init_syscall_trace, \
219 .show_format = syscall_exit_format, \ 193 .show_format = syscall_exit_format, \
220 .define_fields = syscall_exit_define_fields, \ 194 .define_fields = syscall_exit_define_fields, \
221 .regfunc = reg_event_syscall_exit, \ 195 .regfunc = reg_event_syscall_exit, \
diff --git a/include/trace/syscall.h b/include/trace/syscall.h
index 1531eef3071f..dff9371e5274 100644
--- a/include/trace/syscall.h
+++ b/include/trace/syscall.h
@@ -32,6 +32,7 @@ struct syscall_metadata {
32 32
33#ifdef CONFIG_FTRACE_SYSCALLS 33#ifdef CONFIG_FTRACE_SYSCALLS
34extern unsigned long arch_syscall_addr(int nr); 34extern unsigned long arch_syscall_addr(int nr);
35extern int init_syscall_trace(struct ftrace_event_call *call);
35 36
36extern int syscall_enter_format(struct ftrace_event_call *call, 37extern int syscall_enter_format(struct ftrace_event_call *call,
37 struct trace_seq *s); 38 struct trace_seq *s);
diff --git a/kernel/trace/trace_syscalls.c b/kernel/trace/trace_syscalls.c
index 144cc14d8551..c6514093c95a 100644
--- a/kernel/trace/trace_syscalls.c
+++ b/kernel/trace/trace_syscalls.c
@@ -412,6 +412,18 @@ void unreg_event_syscall_exit(struct ftrace_event_call *call)
412 mutex_unlock(&syscall_trace_lock); 412 mutex_unlock(&syscall_trace_lock);
413} 413}
414 414
415int init_syscall_trace(struct ftrace_event_call *call)
416{
417 int id;
418
419 id = register_ftrace_event(call->event);
420 if (!id)
421 return -ENODEV;
422 call->id = id;
423 INIT_LIST_HEAD(&call->fields);
424 return 0;
425}
426
415int __init init_ftrace_syscalls(void) 427int __init init_ftrace_syscalls(void)
416{ 428{
417 struct syscall_metadata *meta; 429 struct syscall_metadata *meta;