aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMasami Hiramatsu <mhiramat@redhat.com>2009-09-14 16:49:37 -0400
committerFrederic Weisbecker <fweisbec@gmail.com>2009-09-16 22:04:01 -0400
commit5a0d9050db4d1147722b42afef9011251b2651ee (patch)
tree1d3b3e080d4b3d1bf34d0a551ee3c06be0852331
parent74ebb63e7cd25f6fb02a45fc2ea7735bce1217c9 (diff)
tracing/kprobes: Disable kprobe events by default after creation
Disable newly created kprobe events by default, not to disturb another user using ftrace. "Disturb" means when someone is using ftrace and another user tries to use perf-tools, (in near future) if he defines new kprobe event via perf-tools, then new events will mess up the frace buffer. Fix this to allow proper and transparent kprobes events concurrent usage between ftrace users and perf users. Signed-off-by: Masami Hiramatsu <mhiramat@redhat.com> Acked-by: Steven Rostedt <rostedt@goodmis.org> Cc: Jim Keniston <jkenisto@us.ibm.com> Cc: Ananth N Mavinakayanahalli <ananth@in.ibm.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Christoph Hellwig <hch@infradead.org> Cc: Frank Ch. Eigler <fche@redhat.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Jason Baron <jbaron@redhat.com> Cc: K.Prasad <prasad@linux.vnet.ibm.com> Cc: Lai Jiangshan <laijs@cn.fujitsu.com> Cc: Li Zefan <lizf@cn.fujitsu.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> Cc: Tom Zanussi <tzanussi@gmail.com> LKML-Reference: <20090914204937.18779.59422.stgit@dhcp-100-2-132.bos.redhat.com> Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
-rw-r--r--Documentation/trace/kprobetrace.txt11
-rw-r--r--kernel/trace/trace_kprobe.c4
2 files changed, 11 insertions, 4 deletions
diff --git a/Documentation/trace/kprobetrace.txt b/Documentation/trace/kprobetrace.txt
index 6521681e7838..9b8f7c6040a7 100644
--- a/Documentation/trace/kprobetrace.txt
+++ b/Documentation/trace/kprobetrace.txt
@@ -122,8 +122,15 @@ print fmt: "(%lx) dfd=%lx filename=%lx flags=%lx mode=%lx", REC->ip, REC->dfd, R
122 122
123 echo > /sys/kernel/debug/tracing/kprobe_events 123 echo > /sys/kernel/debug/tracing/kprobe_events
124 124
125 This clears all probe points. and you can see the traced information via 125 This clears all probe points.
126/sys/kernel/debug/tracing/trace. 126
127 Right after definition, each event is disabled by default. For tracing these
128events, you need to enable it.
129
130 echo 1 > /sys/kernel/debug/tracing/events/kprobes/myprobe/enable
131 echo 1 > /sys/kernel/debug/tracing/events/kprobes/myretprobe/enable
132
133 And you can see the traced information via /sys/kernel/debug/tracing/trace.
127 134
128 cat /sys/kernel/debug/tracing/trace 135 cat /sys/kernel/debug/tracing/trace
129# tracer: nop 136# tracer: nop
diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c
index d8db9357489b..f6821f16227e 100644
--- a/kernel/trace/trace_kprobe.c
+++ b/kernel/trace/trace_kprobe.c
@@ -383,7 +383,7 @@ static int register_trace_probe(struct trace_probe *tp)
383 goto end; 383 goto end;
384 } 384 }
385 385
386 tp->flags = TP_FLAG_TRACE; 386 tp->rp.kp.flags |= KPROBE_FLAG_DISABLED;
387 if (probe_is_return(tp)) 387 if (probe_is_return(tp))
388 ret = register_kretprobe(&tp->rp); 388 ret = register_kretprobe(&tp->rp);
389 else 389 else
@@ -1298,7 +1298,7 @@ static int register_probe_event(struct trace_probe *tp)
1298 call->id = register_ftrace_event(&tp->event); 1298 call->id = register_ftrace_event(&tp->event);
1299 if (!call->id) 1299 if (!call->id)
1300 return -ENODEV; 1300 return -ENODEV;
1301 call->enabled = 1; 1301 call->enabled = 0;
1302 call->regfunc = probe_event_enable; 1302 call->regfunc = probe_event_enable;
1303 call->unregfunc = probe_event_disable; 1303 call->unregfunc = probe_event_disable;
1304 1304