diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2022-09-15 13:10:41 +0200 |
---|---|---|
committer | Peter Zijlstra <peterz@infradead.org> | 2022-10-17 16:40:56 +0200 |
commit | b5636d45aae42aa345b4c7918bdef245ed63da68 (patch) | |
tree | 4e8fd6a035991d8409d32dfeb1a37258ae389a81 /arch/x86/kernel/setup_percpu.c | |
parent | Linux 6.1-rc1 (diff) | |
download | linux-b5636d45aae42aa345b4c7918bdef245ed63da68.tar.xz linux-b5636d45aae42aa345b4c7918bdef245ed63da68.zip |
x86/cpu: Remove segment load from switch_to_new_gdt()
On 32bit FS and on 64bit GS segments are already set up correctly, but
load_percpu_segment() still sets [FG]S after switching from the early GDT
to the direct GDT.
For 32bit the segment load has no side effects, but on 64bit it causes
GSBASE to become 0, which means that any per CPU access before GSBASE is
set to the new value is going to fault. That's the reason why the whole
file containing this code has stackprotector removed.
But that's a pointless exercise for both 32 and 64 bit as the relevant
segment selector is already correct. Loading the new GDT does not change
that.
Remove the segment loads and add comments.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Link: https://lore.kernel.org/r/20220915111143.097052006@infradead.org
Diffstat (limited to 'arch/x86/kernel/setup_percpu.c')
0 files changed, 0 insertions, 0 deletions