aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/syscalls.h31
-rw-r--r--include/trace/syscall.h8
-rw-r--r--kernel/trace/trace_syscalls.c24
3 files changed, 16 insertions, 47 deletions
diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h
index cf0d923ea40e..c2df3a593236 100644
--- a/include/linux/syscalls.h
+++ b/include/linux/syscalls.h
@@ -99,37 +99,16 @@ struct perf_event_attr;
99#define __SC_TEST6(t6, a6, ...) __SC_TEST(t6); __SC_TEST5(__VA_ARGS__) 99#define __SC_TEST6(t6, a6, ...) __SC_TEST(t6); __SC_TEST5(__VA_ARGS__)
100 100
101#ifdef CONFIG_EVENT_PROFILE 101#ifdef CONFIG_EVENT_PROFILE
102#define TRACE_SYS_ENTER_PROFILE(sname) \
103static int prof_sysenter_enable_##sname(struct ftrace_event_call *unused) \
104{ \
105 return reg_prof_syscall_enter("sys"#sname); \
106} \
107 \
108static void prof_sysenter_disable_##sname(struct ftrace_event_call *unused) \
109{ \
110 unreg_prof_syscall_enter("sys"#sname); \
111}
112
113#define TRACE_SYS_EXIT_PROFILE(sname) \
114static int prof_sysexit_enable_##sname(struct ftrace_event_call *unused) \
115{ \
116 return reg_prof_syscall_exit("sys"#sname); \
117} \
118 \
119static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
120{ \
121 unreg_prof_syscall_exit("sys"#sname); \
122}
123 102
124#define TRACE_SYS_ENTER_PROFILE_INIT(sname) \ 103#define TRACE_SYS_ENTER_PROFILE_INIT(sname) \
125 .profile_count = ATOMIC_INIT(-1), \ 104 .profile_count = ATOMIC_INIT(-1), \
126 .profile_enable = prof_sysenter_enable_##sname, \ 105 .profile_enable = prof_sysenter_enable, \
127 .profile_disable = prof_sysenter_disable_##sname, 106 .profile_disable = prof_sysenter_disable,
128 107
129#define TRACE_SYS_EXIT_PROFILE_INIT(sname) \ 108#define TRACE_SYS_EXIT_PROFILE_INIT(sname) \
130 .profile_count = ATOMIC_INIT(-1), \ 109 .profile_count = ATOMIC_INIT(-1), \
131 .profile_enable = prof_sysexit_enable_##sname, \ 110 .profile_enable = prof_sysexit_enable, \
132 .profile_disable = prof_sysexit_disable_##sname, 111 .profile_disable = prof_sysexit_disable,
133#else 112#else
134#define TRACE_SYS_ENTER_PROFILE(sname) 113#define TRACE_SYS_ENTER_PROFILE(sname)
135#define TRACE_SYS_ENTER_PROFILE_INIT(sname) 114#define TRACE_SYS_ENTER_PROFILE_INIT(sname)
@@ -158,7 +137,6 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
158 struct trace_event enter_syscall_print_##sname = { \ 137 struct trace_event enter_syscall_print_##sname = { \
159 .trace = print_syscall_enter, \ 138 .trace = print_syscall_enter, \
160 }; \ 139 }; \
161 TRACE_SYS_ENTER_PROFILE(sname); \
162 static struct ftrace_event_call __used \ 140 static struct ftrace_event_call __used \
163 __attribute__((__aligned__(4))) \ 141 __attribute__((__aligned__(4))) \
164 __attribute__((section("_ftrace_events"))) \ 142 __attribute__((section("_ftrace_events"))) \
@@ -181,7 +159,6 @@ static void prof_sysexit_disable_##sname(struct ftrace_event_call *unused) \
181 struct trace_event exit_syscall_print_##sname = { \ 159 struct trace_event exit_syscall_print_##sname = { \
182 .trace = print_syscall_exit, \ 160 .trace = print_syscall_exit, \
183 }; \ 161 }; \
184 TRACE_SYS_EXIT_PROFILE(sname); \
185 static struct ftrace_event_call __used \ 162 static struct ftrace_event_call __used \
186 __attribute__((__aligned__(4))) \ 163 __attribute__((__aligned__(4))) \
187 __attribute__((section("_ftrace_events"))) \ 164 __attribute__((section("_ftrace_events"))) \
diff --git a/include/trace/syscall.h b/include/trace/syscall.h
index dff9371e5274..961fda3556bb 100644
--- a/include/trace/syscall.h
+++ b/include/trace/syscall.h
@@ -50,10 +50,10 @@ enum print_line_t print_syscall_enter(struct trace_iterator *iter, int flags);
50enum print_line_t print_syscall_exit(struct trace_iterator *iter, int flags); 50enum print_line_t print_syscall_exit(struct trace_iterator *iter, int flags);
51#endif 51#endif
52#ifdef CONFIG_EVENT_PROFILE 52#ifdef CONFIG_EVENT_PROFILE
53int reg_prof_syscall_enter(char *name); 53int prof_sysenter_enable(struct ftrace_event_call *call);
54void unreg_prof_syscall_enter(char *name); 54void prof_sysenter_disable(struct ftrace_event_call *call);
55int reg_prof_syscall_exit(char *name); 55int prof_sysexit_enable(struct ftrace_event_call *call);
56void unreg_prof_syscall_exit(char *name); 56void prof_sysexit_disable(struct ftrace_event_call *call);
57 57
58#endif 58#endif
59 59
diff --git a/kernel/trace/trace_syscalls.c b/kernel/trace/trace_syscalls.c
index c6514093c95a..1e85b6cc26aa 100644
--- a/kernel/trace/trace_syscalls.c
+++ b/kernel/trace/trace_syscalls.c
@@ -520,14 +520,12 @@ end_recursion:
520 local_irq_restore(flags); 520 local_irq_restore(flags);
521} 521}
522 522
523int reg_prof_syscall_enter(char *name) 523int prof_sysenter_enable(struct ftrace_event_call *call)
524{ 524{
525 int ret = 0; 525 int ret = 0;
526 int num; 526 int num;
527 527
528 num = syscall_name_to_nr(name); 528 num = ((struct syscall_metadata *)call->data)->syscall_nr;
529 if (num < 0 || num >= NR_syscalls)
530 return -ENOSYS;
531 529
532 mutex_lock(&syscall_trace_lock); 530 mutex_lock(&syscall_trace_lock);
533 if (!sys_prof_refcount_enter) 531 if (!sys_prof_refcount_enter)
@@ -543,13 +541,11 @@ int reg_prof_syscall_enter(char *name)
543 return ret; 541 return ret;
544} 542}
545 543
546void unreg_prof_syscall_enter(char *name) 544void prof_sysenter_disable(struct ftrace_event_call *call)
547{ 545{
548 int num; 546 int num;
549 547
550 num = syscall_name_to_nr(name); 548 num = ((struct syscall_metadata *)call->data)->syscall_nr;
551 if (num < 0 || num >= NR_syscalls)
552 return;
553 549
554 mutex_lock(&syscall_trace_lock); 550 mutex_lock(&syscall_trace_lock);
555 sys_prof_refcount_enter--; 551 sys_prof_refcount_enter--;
@@ -625,14 +621,12 @@ end_recursion:
625 local_irq_restore(flags); 621 local_irq_restore(flags);
626} 622}
627 623
628int reg_prof_syscall_exit(char *name) 624int prof_sysexit_enable(struct ftrace_event_call *call)
629{ 625{
630 int ret = 0; 626 int ret = 0;
631 int num; 627 int num;
632 628
633 num = syscall_name_to_nr(name); 629 num = ((struct syscall_metadata *)call->data)->syscall_nr;
634 if (num < 0 || num >= NR_syscalls)
635 return -ENOSYS;
636 630
637 mutex_lock(&syscall_trace_lock); 631 mutex_lock(&syscall_trace_lock);
638 if (!sys_prof_refcount_exit) 632 if (!sys_prof_refcount_exit)
@@ -648,13 +642,11 @@ int reg_prof_syscall_exit(char *name)
648 return ret; 642 return ret;
649} 643}
650 644
651void unreg_prof_syscall_exit(char *name) 645void prof_sysexit_disable(struct ftrace_event_call *call)
652{ 646{
653 int num; 647 int num;
654 648
655 num = syscall_name_to_nr(name); 649 num = ((struct syscall_metadata *)call->data)->syscall_nr;
656 if (num < 0 || num >= NR_syscalls)
657 return;
658 650
659 mutex_lock(&syscall_trace_lock); 651 mutex_lock(&syscall_trace_lock);
660 sys_prof_refcount_exit--; 652 sys_prof_refcount_exit--;