]> git.baikalelectronics.ru Git - kernel.git/commit
x86/smpboot: Don't use mwait_play_dead() on AMD systems
authorYazen Ghannam <yazen.ghannam@amd.com>
Tue, 3 Apr 2018 14:02:28 +0000 (09:02 -0500)
committerThomas Gleixner <tglx@linutronix.de>
Thu, 26 Apr 2018 14:06:19 +0000 (16:06 +0200)
commit62f8a20669fde7a0f6c38a35734c75153e908331
tree3e9b31c0f4d627f5340822a4cdad8db20dd382ca
parentf2162f0480f82024ddf2e2420681190c8cf9d9e6
x86/smpboot: Don't use mwait_play_dead() on AMD systems

Recent AMD systems support using MWAIT for C1 state. However, MWAIT will
not allow deeper cstates than C1 on current systems.

play_dead() expects to use the deepest state available.  The deepest state
available on AMD systems is reached through SystemIO or HALT. If MWAIT is
available, it is preferred over the other methods, so the CPU never reaches
the deepest possible state.

Don't try to use MWAIT to play_dead() on AMD systems. Instead, use CPUIDLE
to enter the deepest state advertised by firmware. If CPUIDLE is not
available then fallback to HALT.

Signed-off-by: Yazen Ghannam <yazen.ghannam@amd.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Borislav Petkov <bp@suse.de>
Cc: stable@vger.kernel.org
Cc: Yazen Ghannam <Yazen.Ghannam@amd.com>
Link: https://lkml.kernel.org/r/20180403140228.58540-1-Yazen.Ghannam@amd.com
arch/x86/kernel/smpboot.c