ftrace: Only disable ftrace_enabled to test buffer in selftest
authorSteven Rostedt (Red Hat) <rostedt@goodmis.org>
Fri, 12 Sep 2014 18:26:51 +0000 (14:26 -0400)
committerSteven Rostedt <rostedt@goodmis.org>
Sat, 13 Sep 2014 00:48:49 +0000 (20:48 -0400)
The ftrace_enabled variable is set to zero in the self tests to keep
delayed functions from being traced and messing with the checks. This
only needs to be done when the checks are being performed, otherwise,
if ftrace_enabled is off when calls back to the utility that is being
tested, it can cause errors to happen and the tests can fail with
false positives.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace_selftest.c

index 5ef60499dc8e6c6df909794c1a54eed4b9bb2dbf..61a6acd6025d9ec9f32cbea4f11b74500744001f 100644 (file)
@@ -382,6 +382,8 @@ static int trace_selftest_startup_dynamic_tracing(struct tracer *trace,
 
        /* check the trace buffer */
        ret = trace_test_buffer(&tr->trace_buffer, &count);
+
+       ftrace_enabled = 1;
        tracing_start();
 
        /* we should only have one item */
@@ -679,6 +681,8 @@ trace_selftest_startup_function(struct tracer *trace, struct trace_array *tr)
 
        /* check the trace buffer */
        ret = trace_test_buffer(&tr->trace_buffer, &count);
+
+       ftrace_enabled = 1;
        trace->reset(tr);
        tracing_start();