From: Steven Rostedt Date: Tue, 22 Dec 2009 03:35:16 +0000 (-0500) Subject: tracing: Fix setting tracer specific options X-Git-Tag: v2.6.33-rc3~30^2~8 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c757bea93bea4b77ebd181cc6dca60c15e3b1a2c;p=profile%2Fcommon%2Fkernel-common.git tracing: Fix setting tracer specific options The function __set_tracer_option() takes as its last parameter a "neg" value. If set it should negate the value of the option. The trace_options_write() passed the value written to the file which is what the new value needs to be set as. But since this is not the negative, it never sets the value. Reported-by: Peter Zijlstra Cc: Li Zefan Signed-off-by: Steven Rostedt --- diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index ee61915..d0a4c12 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -3949,7 +3949,7 @@ trace_options_write(struct file *filp, const char __user *ubuf, size_t cnt, if (!!(topt->flags->val & topt->opt->bit) != val) { mutex_lock(&trace_types_lock); ret = __set_tracer_option(current_trace, topt->flags, - topt->opt, val); + topt->opt, !val); mutex_unlock(&trace_types_lock); if (ret) return ret;