aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorSteven Rostedt (Red Hat) <rostedt@goodmis.org>2014-06-25 10:27:30 -0400
committerSteven Rostedt <rostedt@goodmis.org>2014-07-18 13:56:56 -0400
commit96d4f43e3d012824f7e61920a340a1c03b6aacb0 (patch)
tree802730c1f8d56f7a68a32354d340d0cd609594ff /arch
parent3a46588e4b843afaa8f989fb494172d10e007afb (diff)
powerpc/ftrace: Add call to ftrace_graph_is_dead() in function graph code
ftrace_stop() is going away as it disables parts of function tracing that affects users that should not be affected. But ftrace_graph_stop() is built on ftrace_stop(). Here's another example of killing all of function tracing because something went wrong with function graph tracing. Instead of disabling all users of function tracing on function graph error, disable only function graph tracing. To do this, the arch code must call ftrace_graph_is_dead() before it implements function graph. Cc: Anton Blanchard <anton@samba.org> Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/powerpc/kernel/ftrace.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/ftrace.c b/arch/powerpc/kernel/ftrace.c
index d178834fe508..390311c0f03d 100644
--- a/arch/powerpc/kernel/ftrace.c
+++ b/arch/powerpc/kernel/ftrace.c
@@ -525,6 +525,9 @@ void prepare_ftrace_return(unsigned long *parent, unsigned long self_addr)
525 struct ftrace_graph_ent trace; 525 struct ftrace_graph_ent trace;
526 unsigned long return_hooker = (unsigned long)&return_to_handler; 526 unsigned long return_hooker = (unsigned long)&return_to_handler;
527 527
528 if (unlikely(ftrace_graph_is_dead()))
529 return;
530
528 if (unlikely(atomic_read(&current->tracing_graph_pause))) 531 if (unlikely(atomic_read(&current->tracing_graph_pause)))
529 return; 532 return;
530 533