Commit 633c8e98 authored by Nicholas Piggin's avatar Nicholas Piggin Committed by Michael Ellerman

powerpc/pseries: Enable hardlockup watchdog for PowerVM partitions

PowerVM will not arbitrarily oversubscribe or stop guests, page out the
guest kernel text to a NFS volume connected by carrier pigeon to abacus
based storage, etc., as a KVM host might. So PowerVM guests are not
likely to be killed by the hard lockup watchdog in normal operation,
even with shared processor LPARs which still get a minimum allotment of
CPU time.

Enable the hard lockup detector by default on !KVM guests, which we will
assume is PowerVM. It has been useful in finding problems on bare metal
kernels.
Signed-off-by: default avatarNicholas Piggin <npiggin@gmail.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20210623021528.702241-1-npiggin@gmail.com
parent 6eaaf9de
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
#include <linux/pgtable.h> #include <linux/pgtable.h>
#include <asm/debugfs.h> #include <asm/debugfs.h>
#include <asm/kvm_guest.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/kdump.h> #include <asm/kdump.h>
#include <asm/prom.h> #include <asm/prom.h>
...@@ -939,16 +940,20 @@ u64 hw_nmi_get_sample_period(int watchdog_thresh) ...@@ -939,16 +940,20 @@ u64 hw_nmi_get_sample_period(int watchdog_thresh)
* disable it by default. Book3S has a soft-nmi hardlockup detector based * disable it by default. Book3S has a soft-nmi hardlockup detector based
* on the decrementer interrupt, so it does not suffer from this problem. * on the decrementer interrupt, so it does not suffer from this problem.
* *
* It is likely to get false positives in VM guests, so disable it there * It is likely to get false positives in KVM guests, so disable it there
* by default too. * by default too. PowerVM will not stop or arbitrarily oversubscribe
* CPUs, but give a minimum regular allotment even with SPLPAR, so enable
* the detector for non-KVM guests, assume PowerVM.
*/ */
static int __init disable_hardlockup_detector(void) static int __init disable_hardlockup_detector(void)
{ {
#ifdef CONFIG_HARDLOCKUP_DETECTOR_PERF #ifdef CONFIG_HARDLOCKUP_DETECTOR_PERF
hardlockup_detector_disable(); hardlockup_detector_disable();
#else #else
if (firmware_has_feature(FW_FEATURE_LPAR)) if (firmware_has_feature(FW_FEATURE_LPAR)) {
if (is_kvm_guest())
hardlockup_detector_disable(); hardlockup_detector_disable();
}
#endif #endif
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment