stackprotector: add boot_init_stack_canary()
authorIngo Molnar <mingo@elte.hu>
Thu, 14 Feb 2008 08:42:02 +0000 (09:42 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Mon, 26 May 2008 14:15:32 +0000 (16:15 +0200)
add the boot_init_stack_canary() and make the secondary idle threads
use it.

Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
arch/x86/kernel/process_64.c
include/asm-x86/stackprotector.h
include/linux/stackprotector.h

index d4c7ac7..5107cb2 100644 (file)
@@ -147,7 +147,6 @@ 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 - and if we are the boot CPU we have
@@ -156,9 +155,8 @@ void cpu_idle(void)
         * invalid canaries already on the stack wont ever
         * trigger):
         */
-       current->stack_canary = get_random_int();
-       write_pda(stack_canary, current->stack_canary);
-#endif
+       boot_init_stack_canary();
+
        /* endless idle loop with no priority at all */
        while (1) {
                tick_nohz_stop_sched_tick();
index dcac7a6..0f91f7a 100644 (file)
@@ -1,4 +1,24 @@
 #ifndef _ASM_STACKPROTECTOR_H
 #define _ASM_STACKPROTECTOR_H 1
 
+/*
+ * Initialize the stackprotector canary value.
+ *
+ * NOTE: this must only be called from functions that never return,
+ * and it must always be inlined.
+ */
+static __always_inline void boot_init_stack_canary(void)
+{
+       /*
+        * If we're the non-boot CPU, nothing set the PDA stack
+        * canary up for us - and if we are the boot CPU we have
+        * a 0 stack canary. This is a good place for updating
+        * it, as we wont ever return from this function (so the
+        * invalid canaries already on the stack wont ever
+        * trigger):
+        */
+       current->stack_canary = get_random_int();
+       write_pda(stack_canary, current->stack_canary);
+}
+
 #endif
index d3e8bbe..422e71a 100644 (file)
@@ -3,6 +3,10 @@
 
 #ifdef CONFIG_CC_STACKPROTECTOR
 # include <asm/stackprotector.h>
+#else
+static inline void boot_init_stack_canary(void)
+{
+}
 #endif
 
 #endif