summaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/setup_percpu.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2022-09-15 13:10:41 +0200
committerPeter Zijlstra <peterz@infradead.org>2022-10-17 16:40:56 +0200
commitb5636d45aae42aa345b4c7918bdef245ed63da68 (patch)
tree4e8fd6a035991d8409d32dfeb1a37258ae389a81 /arch/x86/kernel/setup_percpu.c
parentLinux 6.1-rc1 (diff)
downloadlinux-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