From: Frederic Weisbecker Date: Sat, 15 Nov 2008 01:37:44 +0000 (+0100) Subject: tracing/function-return-tracer: add a barrier to ensure return stack index is increme... X-Git-Tag: v2.6.29-rc1~586^2~58^2~1 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=b01c746617da5e260803eb10ed64ca043e9a1241;p=linux-2.6-omap-h63xx.git tracing/function-return-tracer: add a barrier to ensure return stack index is incremented in memory Impact: fix possible race condition in ftrace function return tracer This fixes a possible race condition if index incrementation is not immediately flushed in memory. Thanks for Andi Kleen and Steven Rostedt for pointing out this issue and give me this solution. Signed-off-by: Frederic Weisbecker Signed-off-by: Ingo Molnar --- diff --git a/arch/x86/kernel/ftrace.c b/arch/x86/kernel/ftrace.c index 762222ad138..d98b5a8ecf4 100644 --- a/arch/x86/kernel/ftrace.c +++ b/arch/x86/kernel/ftrace.c @@ -56,6 +56,7 @@ static int push_return_trace(unsigned long ret, unsigned long long time, return -EBUSY; index = ++ti->curr_ret_stack; + barrier(); ti->ret_stack[index].ret = ret; ti->ret_stack[index].func = func; ti->ret_stack[index].calltime = time;