mirror of https://github.com/acidanthera/audk.git
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:
parent
a2c3bf1f2f
commit
01ce872739
|
@ -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]);
|
||||||
|
|
Loading…
Reference in New Issue