diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2013-06-10 10:52:03 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2013-06-11 16:04:47 -0400 |
commit | d7880812b3594d3c6dcbe3cfd71dabb17347d082 (patch) | |
tree | 87d72f75a691ac0d23776afcde0e9f35c09d8148 /kernel | |
parent | c7788792a5e7b0d5d7f96d0766b4cb6112d47d75 (diff) |
idle: Add the stack canary init to cpu_startup_entry()
Moving x86 to the generic idle implementation (commit 7d1a9417 "x86:
Use generic idle loop") wreckaged the stack protector.
I stupidly missed that boot_init_stack_canary() must be inlined from a
function which never returns, but I put that call into
arch_cpu_idle_prepare() which of course returns.
I pondered to play tricks with arch_cpu_idle_prepare() first, but then
I noticed, that the other archs which have implemented the
stackprotector (ARM and SH) do not initialize the canary for the
non-boot cpus.
So I decided to move the boot_init_stack_canary() call into
cpu_startup_entry() ifdeffed with an CONFIG_X86 for now. This #ifdef
is just a temporary measure as I don't want to inflict the
boot_init_stack_canary() call on ARM and SH that late in the cycle.
I'll queue a patch for 3.11 which removes the #ifdef if the ARM/SH
maintainers have no objection.
Reported-by: Wouter van Kesteren <woutershep@gmail.com>
Cc: x86@kernel.org
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Paul Mundt <lethal@linux-sh.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/cpu/idle.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/kernel/cpu/idle.c b/kernel/cpu/idle.c index d5585f5e038e..bf2ee1aafa0e 100644 --- a/kernel/cpu/idle.c +++ b/kernel/cpu/idle.c | |||
@@ -5,6 +5,7 @@ | |||
5 | #include <linux/cpu.h> | 5 | #include <linux/cpu.h> |
6 | #include <linux/tick.h> | 6 | #include <linux/tick.h> |
7 | #include <linux/mm.h> | 7 | #include <linux/mm.h> |
8 | #include <linux/stackprotector.h> | ||
8 | 9 | ||
9 | #include <asm/tlb.h> | 10 | #include <asm/tlb.h> |
10 | 11 | ||
@@ -112,6 +113,21 @@ static void cpu_idle_loop(void) | |||
112 | 113 | ||
113 | void cpu_startup_entry(enum cpuhp_state state) | 114 | void cpu_startup_entry(enum cpuhp_state state) |
114 | { | 115 | { |
116 | /* | ||
117 | * This #ifdef needs to die, but it's too late in the cycle to | ||
118 | * make this generic (arm and sh have never invoked the canary | ||
119 | * init for the non boot cpus!). Will be fixed in 3.11 | ||
120 | */ | ||
121 | #ifdef CONFIG_X86 | ||
122 | /* | ||
123 | * If we're the non-boot CPU, nothing set the stack canary up | ||
124 | * for us. The boot CPU already has it initialized but no harm | ||
125 | * in doing it again. This is a good place for updating it, as | ||
126 | * we wont ever return from this function (so the invalid | ||
127 | * canaries already on the stack wont ever trigger). | ||
128 | */ | ||
129 | boot_init_stack_canary(); | ||
130 | #endif | ||
115 | current_set_polling(); | 131 | current_set_polling(); |
116 | arch_cpu_idle_prepare(); | 132 | arch_cpu_idle_prepare(); |
117 | cpu_idle_loop(); | 133 | cpu_idle_loop(); |