ArmVirtPkg: fix ASSERT in ArmVirtGicArchLib with virtualization=on

ArmVirtGicArchLib was originally implemented before virtualization
emulation was implemented in QEMU, and the GICv2 model implemented only
the physical copy of control registers.

Enabling virtualization emulation to QEMU adds also the virtual copy,
doubling the RegSize returned by FindCompatibleNodeReg () in
ArmVirtGicArchLibConstructor (). This triggered an ASSERT when running
QEMU with -M virt,virtualization=on. Address this by testing for both
possible valid values of RegSize.

BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=2588

Cc: Laszlo Ersek <lersek@redhat.com>
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Leif Lindholm <leif@nuviainc.com>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
Leif Lindholm 2020-03-11 15:10:18 +00:00 committed by mergify[bot]
parent a2c3bf1f2f
commit 01ce872739
1 changed files with 6 additions and 1 deletions

View File

@ -110,7 +110,12 @@ ArmVirtGicArchLibConstructor (
break; break;
case 2: case 2:
ASSERT (RegSize == 32); //
// When the GICv2 is emulated with virtualization=on, it adds a virtual
// set of control registers. This means the register property can be
// either 32 or 64 bytes in size.
//
ASSERT ((RegSize == 32) || (RegSize == 64));
DistBase = SwapBytes64 (Reg[0]); DistBase = SwapBytes64 (Reg[0]);
CpuBase = SwapBytes64 (Reg[2]); CpuBase = SwapBytes64 (Reg[2]);