]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
x86: setup stack canary for the idle threads
authorArjan van de Ven <arjan@linux.intel.com>
Mon, 12 May 2008 13:44:31 +0000 (15:44 +0200)
committerThomas Gleixner <tglx@linutronix.de>
Mon, 26 May 2008 14:15:31 +0000 (16:15 +0200)
The idle threads for non-boot CPUs are a bit special in how they
are created; the result is that these don't have the stack canary
set up properly in their PDA. Easiest fix is to just always set
the PDA up correctly when entering the idle thread; this is a NOP
for the boot cpu.

Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
arch/x86/kernel/process_64.c

index d8640388039e4ff280ab00d6092b22a3b587e2f5..9e69e223023e21e14e60c57799d4417ac13c2f98 100644 (file)
@@ -146,6 +146,15 @@ static inline void play_dead(void)
 void cpu_idle(void)
 {
        current_thread_info()->status |= TS_POLLING;
+
+#ifdef CONFIG_CC_STACKPROTECTOR
+       /*
+        * If we're the non-boot CPU, nothing set the PDA stack
+        * canary up for us. This is as good a place as any for
+        * doing that.
+        */
+       write_pda(stack_canary, current->stack_canary);
+#endif
        /* endless idle loop with no priority at all */
        while (1) {
                tick_nohz_stop_sched_tick();