diff options
Diffstat (limited to 'kernel/trace/trace_event_profile.c')
-rw-r--r-- | kernel/trace/trace_event_profile.c | 45 |
1 files changed, 20 insertions, 25 deletions
diff --git a/kernel/trace/trace_event_profile.c b/kernel/trace/trace_event_profile.c index 8d5c171cc998..e0d351b01f5a 100644 --- a/kernel/trace/trace_event_profile.c +++ b/kernel/trace/trace_event_profile.c | |||
@@ -8,44 +8,39 @@ | |||
8 | #include <linux/module.h> | 8 | #include <linux/module.h> |
9 | #include "trace.h" | 9 | #include "trace.h" |
10 | 10 | ||
11 | /* | ||
12 | * We can't use a size but a type in alloc_percpu() | ||
13 | * So let's create a dummy type that matches the desired size | ||
14 | */ | ||
15 | typedef struct {char buf[FTRACE_MAX_PROFILE_SIZE];} profile_buf_t; | ||
16 | 11 | ||
17 | char *trace_profile_buf; | 12 | struct perf_trace_buf *perf_trace_buf; |
18 | EXPORT_SYMBOL_GPL(trace_profile_buf); | 13 | EXPORT_SYMBOL_GPL(perf_trace_buf); |
19 | 14 | ||
20 | char *trace_profile_buf_nmi; | 15 | struct perf_trace_buf *perf_trace_buf_nmi; |
21 | EXPORT_SYMBOL_GPL(trace_profile_buf_nmi); | 16 | EXPORT_SYMBOL_GPL(perf_trace_buf_nmi); |
22 | 17 | ||
23 | /* Count the events in use (per event id, not per instance) */ | 18 | /* Count the events in use (per event id, not per instance) */ |
24 | static int total_profile_count; | 19 | static int total_profile_count; |
25 | 20 | ||
26 | static int ftrace_profile_enable_event(struct ftrace_event_call *event) | 21 | static int ftrace_profile_enable_event(struct ftrace_event_call *event) |
27 | { | 22 | { |
28 | char *buf; | 23 | struct perf_trace_buf *buf; |
29 | int ret = -ENOMEM; | 24 | int ret = -ENOMEM; |
30 | 25 | ||
31 | if (atomic_inc_return(&event->profile_count)) | 26 | if (atomic_inc_return(&event->profile_count)) |
32 | return 0; | 27 | return 0; |
33 | 28 | ||
34 | if (!total_profile_count) { | 29 | if (!total_profile_count) { |
35 | buf = (char *)alloc_percpu(profile_buf_t); | 30 | buf = alloc_percpu(struct perf_trace_buf); |
36 | if (!buf) | 31 | if (!buf) |
37 | goto fail_buf; | 32 | goto fail_buf; |
38 | 33 | ||
39 | rcu_assign_pointer(trace_profile_buf, buf); | 34 | rcu_assign_pointer(perf_trace_buf, buf); |
40 | 35 | ||
41 | buf = (char *)alloc_percpu(profile_buf_t); | 36 | buf = alloc_percpu(struct perf_trace_buf); |
42 | if (!buf) | 37 | if (!buf) |
43 | goto fail_buf_nmi; | 38 | goto fail_buf_nmi; |
44 | 39 | ||
45 | rcu_assign_pointer(trace_profile_buf_nmi, buf); | 40 | rcu_assign_pointer(perf_trace_buf_nmi, buf); |
46 | } | 41 | } |
47 | 42 | ||
48 | ret = event->profile_enable(); | 43 | ret = event->profile_enable(event); |
49 | if (!ret) { | 44 | if (!ret) { |
50 | total_profile_count++; | 45 | total_profile_count++; |
51 | return 0; | 46 | return 0; |
@@ -53,10 +48,10 @@ static int ftrace_profile_enable_event(struct ftrace_event_call *event) | |||
53 | 48 | ||
54 | fail_buf_nmi: | 49 | fail_buf_nmi: |
55 | if (!total_profile_count) { | 50 | if (!total_profile_count) { |
56 | free_percpu(trace_profile_buf_nmi); | 51 | free_percpu(perf_trace_buf_nmi); |
57 | free_percpu(trace_profile_buf); | 52 | free_percpu(perf_trace_buf); |
58 | trace_profile_buf_nmi = NULL; | 53 | perf_trace_buf_nmi = NULL; |
59 | trace_profile_buf = NULL; | 54 | perf_trace_buf = NULL; |
60 | } | 55 | } |
61 | fail_buf: | 56 | fail_buf: |
62 | atomic_dec(&event->profile_count); | 57 | atomic_dec(&event->profile_count); |
@@ -84,19 +79,19 @@ int ftrace_profile_enable(int event_id) | |||
84 | 79 | ||
85 | static void ftrace_profile_disable_event(struct ftrace_event_call *event) | 80 | static void ftrace_profile_disable_event(struct ftrace_event_call *event) |
86 | { | 81 | { |
87 | char *buf, *nmi_buf; | 82 | struct perf_trace_buf *buf, *nmi_buf; |
88 | 83 | ||
89 | if (!atomic_add_negative(-1, &event->profile_count)) | 84 | if (!atomic_add_negative(-1, &event->profile_count)) |
90 | return; | 85 | return; |
91 | 86 | ||
92 | event->profile_disable(); | 87 | event->profile_disable(event); |
93 | 88 | ||
94 | if (!--total_profile_count) { | 89 | if (!--total_profile_count) { |
95 | buf = trace_profile_buf; | 90 | buf = perf_trace_buf; |
96 | rcu_assign_pointer(trace_profile_buf, NULL); | 91 | rcu_assign_pointer(perf_trace_buf, NULL); |
97 | 92 | ||
98 | nmi_buf = trace_profile_buf_nmi; | 93 | nmi_buf = perf_trace_buf_nmi; |
99 | rcu_assign_pointer(trace_profile_buf_nmi, NULL); | 94 | rcu_assign_pointer(perf_trace_buf_nmi, NULL); |
100 | 95 | ||
101 | /* | 96 | /* |
102 | * Ensure every events in profiling have finished before | 97 | * Ensure every events in profiling have finished before |