You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Adam Joseph c0c6141971 coreboot: kgpe-d16: do not enable hw monitor until kernel boots
This commit adds a coreboot patch which causes kgpe-d16 to skip the
PNP enumeration/assignment process for the "hardware monitor"
(basically a temperature sensor and fan-speed controller) block on
the southbridge chip.

I have found this patch solves the last remaining boot reliability
problem I was having with my unattended kgpe-d16 machines.

The commit message for this patch is below:

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

The hardware monitor is one of the blocks within the w83667hg-a chip
(there are many others).  It is basically a bunch of ADCs (analog to
digital converters) hooked up to voltage, current, and temperature
sensors in various locations on the motherboard.

This block has the ability to generate several different interrupts
(SMI#, OVT#, etc) in response to thermal conditions.  It appears to
sometimes (about 10% of boot-ups, depending on temperature) spew
erroneous alarm interrupts the instant you enable it, when doing so
from within coreboot.  This causes the w83667hg-a chip and the
entire system to hang, and the watchdog cannot recover from this
state because it is part of the w83667hg-a chip too.

An even bigger problem is that the hardware monitor is initialized
*before* the fans are brought up to full speed.  So if the CPU is
above the critical temperature it will remain there because the fans
are in their default low-speed boot state.  The chip just keeps
getting hotter and hotter -- not enough to damage itself, but hot
enough that it won't come down to an acceptable temperature with
simple reboots and power-cycles; you have to leave the system off
for a while.  Since the fans aren't running while the system is off
this takes quite a while (several minutes).  It's a very fussy and
fidgety process, and not something you want to walk a remote-hands
guy at the datacenter through over the phone.

To avoid this whole mess, let's simply not assign PNP resources to
the hardware monitor from coreboot.  Linux doesn't need these
anyways; it communicates with the hardware using I2C.
2 years ago
..
0001-mainboard-asus-kgpe-d16-romstage.c-support-console-o.patch coreboot: several more kgpe patches 2 years ago
0001-mc146818rtc.c-mute-erroneous-warning.patch src/coreboot/patches: add !CONFIG_USE_OPTION_TABLE patches 2 years ago
0001-romstage-print-out-dimm-voltages.patch coreboot: kgpe-d16: print DIMM voltages to console 2 years ago
0002-kgpe-d16-do-not-enable-hw-monitor-until-kernel-boots.patch coreboot: kgpe-d16: do not enable hw monitor until kernel boots 2 years ago
0002-mc146818rtc_boot.c-always-report-cmos_chksum_valid-i.patch src/coreboot/patches: add !CONFIG_USE_OPTION_TABLE patches 2 years ago
0002-southbridge-amd-sb700-lpc.c-leave-LPC-timeout-mechan.patch coreboot: several more kgpe patches 2 years ago
0003-kgpe-d16-bootblock.c-use-RTC_BOOT_BYTE-even-when-CON.patch src/coreboot/patches: add !CONFIG_USE_OPTION_TABLE patches 2 years ago
0003-treewide-reduce-many-messages-to-BIOS_SPEW.patch coreboot: several more kgpe patches 2 years ago
0004-superio-winbond-w83667hg-a-superio.c-do-not-use-get_.patch src/coreboot/patches: add !CONFIG_USE_OPTION_TABLE patches 2 years ago
0006-remove-submodules.patch init 3 years ago
0008-payloads-external-linux-allow-CONFIG_LINUX_COMMAND_L.patch init 3 years ago
0009-payloads-Kconfig-add-CONFIG_UNCOMPRESSED_PAYLOAD.patch init 3 years ago
0010-rk3399-mainboard-google-gru-add-define-for-GPIO_PEN_.patch init 3 years ago
0011-rk3399-src-Kconfig-increase-HEAP_SIZE-to-0x40000-byt.patch init 3 years ago
0012-rk3399-include-soc-memlayout.ld-enlarge-RAMSTAGE-and.patch init 3 years ago
0013-kgpe-d16-src-arch-x86-use-CONFIG_CBFS_PREFIX-instead.patch init 3 years ago
0014-kgpe-d16-ignore-nvram-for-power_state-always_on-iomm.patch init 3 years ago
0015-kgpe-d16-factor-out-is_recovery_jumper_set-print-val.patch init 3 years ago
0016-kgpe-d16-src-drivers-pc80-factor-rewrite_cmos-out-of.patch init 3 years ago
0017-use_fallback-platform-independent-part.patch init 3 years ago
0018-use_fallback-rk3399-gru-kevin-use-fallback-if-watchd.patch init 3 years ago
0019-use_fallback-rk3399-gru-kevin-update-for-coreboot-4..patch init 3 years ago
0020-use_fallback-kgpe-d16-implement-using-nvram-with-cmo.patch init 3 years ago
0021-am1i-omit-amdfw.rom-completely-it-has-broken-address.patch init 3 years ago
0022-kgpe-d16-disable-sanitize_cmos-it-causes-too-many-pr.patch init 3 years ago
0023-kgpe-d16-disable-TPM.patch coreboot: several more kgpe patches 2 years ago
0024-amd-sb700-early_setup.c-select-console-properly.patch coreboot: several more kgpe patches 2 years ago
0025-southbridge-amd-sb700-lpc.c-set-SPI-flash-aperture-t.patch coreboot: several more kgpe patches 2 years ago