ArmPkg: allow dynamic GIC base addresses

Allow the PCDs gArmTokenSpaceGuid.PcdGicDistributorBase and
gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase to be redeclared
as PcdsDynamic by the platform, so virtual machines can set these
properties during boot. As the PcdGet32() calls now call into the
PCD database, cache the values that are required during the handling
of interrupts.

Contributed-under: TianoCore Contribution Agreement 1.0
Acked-by: Laszlo Ersek <lersek@redhat.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Olivier Martin <olivier.martin@arm.com>



git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16072 6f19259b-4bc3-4df7-8a09-765794883524
diff --git a/ArmPkg/ArmPkg.dec b/ArmPkg/ArmPkg.dec
index fabecc2..ae22457 100644
--- a/ArmPkg/ArmPkg.dec
+++ b/ArmPkg/ArmPkg.dec
@@ -82,13 +82,6 @@
   gArmTokenSpaceGuid.PcdCpuResetAddress|0x00000000|UINT32|0x00000005

 

   #

-  # ARM Generic Interrupt Controller

-  #

-  gArmTokenSpaceGuid.PcdGicDistributorBase|0|UINT32|0x0000000C

-  gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase|0|UINT32|0x0000000D

-  gArmTokenSpaceGuid.PcdGicSgiIntId|0|UINT32|0x00000025

-

-  #

   # ARM Secure Firmware PCDs

   #

   gArmTokenSpaceGuid.PcdSecureFdBaseAddress|0|UINT32|0x00000015

@@ -216,6 +209,10 @@
   gArmTokenSpaceGuid.PcdArmLinuxFdtAlignment|0x00200000|UINT32|0x00000026

 

 

+#

+# These PCDs are also defined as 'PcdsDynamic' to be redefined when using UEFI in a

+# context of virtual machine.

+#

 [PcdsFixedAtBuild.common, PcdsDynamic.common]

   #

   # ARM Architectural Timer

@@ -227,3 +224,10 @@
   gArmTokenSpaceGuid.PcdArmArchTimerIntrNum|30|UINT32|0x00000036

   gArmTokenSpaceGuid.PcdArmArchTimerHypIntrNum|26|UINT32|0x00000040

   gArmTokenSpaceGuid.PcdArmArchTimerVirtIntrNum|27|UINT32|0x00000041

+

+  #

+  # ARM Generic Interrupt Controller

+  #

+  gArmTokenSpaceGuid.PcdGicDistributorBase|0|UINT32|0x0000000C

+  gArmTokenSpaceGuid.PcdGicInterruptInterfaceBase|0|UINT32|0x0000000D

+  gArmTokenSpaceGuid.PcdGicSgiIntId|0|UINT32|0x00000025