aboutsummaryrefslogtreecommitdiff
path: root/arch/x86/kernel/smp.c
diff options
context:
space:
mode:
authorGravatar Thomas Gleixner <tglx@linutronix.de> 2023-06-15 22:33:55 +0200
committerGravatar Thomas Gleixner <tglx@linutronix.de> 2023-06-20 14:51:47 +0200
commitf9c9987bf52f4e42e940ae217333ebb5a4c3b506 (patch)
treedbe59974c15a712c3491253d3caac47b18306bc2 /arch/x86/kernel/smp.c
parentx86/smp: Remove pointless wmb()s from native_stop_other_cpus() (diff)
downloadlinux-f9c9987bf52f4e42e940ae217333ebb5a4c3b506.tar.gz
linux-f9c9987bf52f4e42e940ae217333ebb5a4c3b506.tar.bz2
linux-f9c9987bf52f4e42e940ae217333ebb5a4c3b506.zip
x86/smp: Use dedicated cache-line for mwait_play_dead()
Monitoring idletask::thread_info::flags in mwait_play_dead() has been an obvious choice as all what is needed is a cache line which is not written by other CPUs. But there is a use case where a "dead" CPU needs to be brought out of MWAIT: kexec(). This is required as kexec() can overwrite text, pagetables, stacks and the monitored cacheline of the original kernel. The latter causes MWAIT to resume execution which obviously causes havoc on the kexec kernel which results usually in triple faults. Use a dedicated per CPU storage to prepare for that. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Ashok Raj <ashok.raj@intel.com> Reviewed-by: Borislav Petkov (AMD) <bp@alien8.de> Cc: stable@vger.kernel.org Link: https://lore.kernel.org/r/20230615193330.434553750@linutronix.de
Diffstat (limited to 'arch/x86/kernel/smp.c')
0 files changed, 0 insertions, 0 deletions