ARM: 7700/2: Make cpu_init() notrace
authorJon Medhurst <tixy@linaro.org>
Thu, 25 Apr 2013 13:40:22 +0000 (14:40 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 26 Apr 2013 10:09:32 +0000 (11:09 +0100)
On resume from CPU power down any trace hooks enabled in cpu_init()
will get called before that function has done set_my_cpu_offset(),
so any use of per-cpu variables by trace hook code will cause bad
things to happen. Prevent this by marking the function notrace.

This fixes lockups/crashes seen when enabling function tracer on TC2
with the not yet mainlined cpuidle driver.

Signed-off-by: Jon Medhurst <tixy@linaro.org>
Acked-by: Nicolas Pitre <nico@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/kernel/setup.c

index 234e339196c0b8fbf0c10a920db0342f3411083f..63ae04bdda1bfd68c1d56167e48705d999882ab5 100644 (file)
@@ -389,7 +389,7 @@ static void __init feat_v6_fixup(void)
  *
  * cpu_init sets up the per-CPU stacks.
  */
-void cpu_init(void)
+void notrace cpu_init(void)
 {
        unsigned int cpu = smp_processor_id();
        struct stack *stk = &stacks[cpu];