Skip to content

Commit 5b2bdbc

Browse files
rostedtIngo Molnar
authored andcommitted
x86: Init per-cpu shadow copy of CR4 on 32-bit CPUs too
Commit: 1e02ce4 ("x86: Store a per-cpu shadow copy of CR4") added a shadow CR4 such that reads and writes that do not modify the CR4 execute much faster than always reading the register itself. The change modified cpu_init() in common.c, so that the shadow CR4 gets initialized before anything uses it. Unfortunately, there's two cpu_init()s in common.c. There's one for 64-bit and one for 32-bit. The commit only added the shadow init to the 64-bit path, but the 32-bit path needs the init too. Link: http://lkml.kernel.org/r/20150227125208.71c36402@gandalf.local.home Fixes: 1e02ce4 "x86: Store a per-cpu shadow copy of CR4" Signed-off-by: Steven Rostedt <rostedt@goodmis.org> Acked-by: Andy Lutomirski <luto@amacapital.net> Cc: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: Linus Torvalds <torvalds@linux-foundation.org> Link: http://lkml.kernel.org/r/20150227145019.2bdd4354@gandalf.local.home Signed-off-by: Ingo Molnar <mingo@kernel.org>
1 parent 5838d18 commit 5b2bdbc

File tree

1 file changed

+6
-0
lines changed

1 file changed

+6
-0
lines changed

arch/x86/kernel/cpu/common.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1396,6 +1396,12 @@ void cpu_init(void)
13961396

13971397
wait_for_master_cpu(cpu);
13981398

1399+
/*
1400+
* Initialize the CR4 shadow before doing anything that could
1401+
* try to read it.
1402+
*/
1403+
cr4_init_shadow();
1404+
13991405
show_ucode_info_early();
14001406

14011407
printk(KERN_INFO "Initializing CPU#%d\n", cpu);

0 commit comments

Comments
 (0)