audk/OvmfPkg/Library/AcpiTimerLib
Gabriel Somlo e2ab3f819f OvmfPkg: Q35: Use correct ACPI PM control register:bit
On PIIX4, function 3, the PMREGMISC register at offset 0x80, with
default value 0x00 has its bit 0 (PMIOSE) indicate whether the PM
IO space given in the PMBA register (offset 0x40) is enabled.
PMBA must be configured *before* setting this bit.

On Q35/ICH9+, function 0x1f, the equivalent role is fulfilled by
bit 7 (ACPI_EN) in the ACPI Control Register (ACPI_CNTL) at offset
0x44, also with a default value of 0x00.

Currently, OVMF hangs when Q35 reboots, because while PMBA is reset
by QEMU, the register at offset 0x80 (matching PMREGMISC on PIIX4)
is not reset, since it has a completely different meaning on LPC.
As such, the power management initialization logic in OVMF finds
the "PMIOSE" bit enabled after a reboot and decides to skip setting
PMBA. This causes the ACPI timer tick routine to read a constant
value from the wrong register, which in turn causes the ACPI delay
loop to hang indefinitely.

This patch modifies the Base[Rom]AcpiTimerLib constructors and the
PlatformPei ACPI PM init routines to use ACPI_CNTL:ACPI_EN instead
of PMREGMISC:PMIOSE when running on Q35.

Reported-by: Reza Jelveh <reza.jelveh@tuhh.de>
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Gabriel Somlo <somlo@cmu.edu>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
Tested-by: Laszlo Ersek <lersek@redhat.com>

git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17076 6f19259b-4bc3-4df7-8a09-765794883524
2015-03-26 19:06:07 +00:00
..
AcpiTimerLib.c OvmfPkg: AcpiTimerLib: Split into multiple phase-specific instances 2014-11-14 00:38:17 +00:00
AcpiTimerLib.h OvmfPkg: AcpiTimerLib: Split into multiple phase-specific instances 2014-11-14 00:38:17 +00:00
BaseAcpiTimerLib.c OvmfPkg: Q35: Use correct ACPI PM control register:bit 2015-03-26 19:06:07 +00:00
BaseAcpiTimerLib.inf OvmfPkg: AcpiTimerLib: Switch additional stages to PCD-based Dxe instance 2014-11-14 00:38:53 +00:00
BaseRomAcpiTimerLib.c OvmfPkg: Q35: Use correct ACPI PM control register:bit 2015-03-26 19:06:07 +00:00
BaseRomAcpiTimerLib.inf OvmfPkg: AcpiTimerLib: Use global variable during PEI_CORE and PEIM 2014-11-14 00:38:35 +00:00
DxeAcpiTimerLib.c OvmfPkg: AcpiTimerLib: Split into multiple phase-specific instances 2014-11-14 00:38:17 +00:00
DxeAcpiTimerLib.inf OvmfPkg: AcpiTimerLib: Switch additional stages to PCD-based Dxe instance 2014-11-14 00:38:53 +00:00