aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace/trace_events.c
diff options
context:
space:
mode:
authorLi Zefan <lizf@cn.fujitsu.com>2009-12-07 22:14:52 -0500
committerFrederic Weisbecker <fweisbec@gmail.com>2009-12-13 12:37:25 -0500
commit3b8e4273814a7f9e9a74ece517d9206fea919aaa (patch)
treeaa7960d90fe8cd4b04537bf9ea84ac73cb3b69ad /kernel/trace/trace_events.c
parent614a71a26ba3d97e9fa85649db69a682b78e407d (diff)
tracing: Move a printk out of ftrace_raw_reg_event_foo()
Move the printk from each ftrace_raw_reg_event_foo() to its caller ftrace_event_enable_disable(). This avoids each regfunc trace event callbacks to handle a same error report that can be carried from the caller. See how much space this saves: text data bss dec hex filename 5345151 1961864 7103260 14410275 dbe223 vmlinux.o.old 5331487 1961864 7103260 14396611 dbacc3 vmlinux.o Signed-off-by: Li Zefan <lizf@cn.fujitsu.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> Cc: Jason Baron <jbaron@redhat.com> LKML-Reference: <4B1DC4AC.802@cn.fujitsu.com> [start cmdline record before calling regfunc to avoid lost window of pid to comm resolution] Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Diffstat (limited to 'kernel/trace/trace_events.c')
-rw-r--r--kernel/trace/trace_events.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/kernel/trace/trace_events.c b/kernel/trace/trace_events.c
index 97b0b3aa166d..189b09baf4fb 100644
--- a/kernel/trace/trace_events.c
+++ b/kernel/trace/trace_events.c
@@ -118,9 +118,11 @@ int trace_event_raw_init(struct ftrace_event_call *call)
118} 118}
119EXPORT_SYMBOL_GPL(trace_event_raw_init); 119EXPORT_SYMBOL_GPL(trace_event_raw_init);
120 120
121static void ftrace_event_enable_disable(struct ftrace_event_call *call, 121static int ftrace_event_enable_disable(struct ftrace_event_call *call,
122 int enable) 122 int enable)
123{ 123{
124 int ret = 0;
125
124 switch (enable) { 126 switch (enable) {
125 case 0: 127 case 0:
126 if (call->enabled) { 128 if (call->enabled) {
@@ -131,12 +133,20 @@ static void ftrace_event_enable_disable(struct ftrace_event_call *call,
131 break; 133 break;
132 case 1: 134 case 1:
133 if (!call->enabled) { 135 if (!call->enabled) {
134 call->enabled = 1;
135 tracing_start_cmdline_record(); 136 tracing_start_cmdline_record();
136 call->regfunc(call); 137 ret = call->regfunc(call);
138 if (ret) {
139 tracing_stop_cmdline_record();
140 pr_info("event trace: Could not enable event "
141 "%s\n", call->name);
142 break;
143 }
144 call->enabled = 1;
137 } 145 }
138 break; 146 break;
139 } 147 }
148
149 return ret;
140} 150}
141 151
142static void ftrace_clear_events(void) 152static void ftrace_clear_events(void)
@@ -415,7 +425,7 @@ event_enable_write(struct file *filp, const char __user *ubuf, size_t cnt,
415 case 0: 425 case 0:
416 case 1: 426 case 1:
417 mutex_lock(&event_mutex); 427 mutex_lock(&event_mutex);
418 ftrace_event_enable_disable(call, val); 428 ret = ftrace_event_enable_disable(call, val);
419 mutex_unlock(&event_mutex); 429 mutex_unlock(&event_mutex);
420 break; 430 break;
421 431
@@ -425,7 +435,7 @@ event_enable_write(struct file *filp, const char __user *ubuf, size_t cnt,
425 435
426 *ppos += cnt; 436 *ppos += cnt;
427 437
428 return cnt; 438 return ret ? ret : cnt;
429} 439}
430 440
431static ssize_t 441static ssize_t