A DMA-like transfer interface has recently been implemented in QEMU for
fw-cfg. For ARM and AARCH64 virtual machines, the binding prescribes a new
8-byte wide register at offset 0x10 in the register block. Make VirtFdtDxe
expose this register if it is present.
Please see "docs/specs/fw_cfg.txt" in the QEMU tree for more information.
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18544
6f19259b-4bc3-4df7-8a09-
765794883524
\r
gArmVirtTokenSpaceGuid.PcdFwCfgSelectorAddress|0x0|UINT64|0x00000004\r
gArmVirtTokenSpaceGuid.PcdFwCfgDataAddress|0x0|UINT64|0x00000005\r
+ gArmVirtTokenSpaceGuid.PcdFwCfgDmaAddress|0x0|UINT64|0x00000009\r
\r
#\r
# Supported GIC revision (2, 3, ...)\r
\r
gArmVirtTokenSpaceGuid.PcdFwCfgSelectorAddress|0x0\r
gArmVirtTokenSpaceGuid.PcdFwCfgDataAddress|0x0\r
+ gArmVirtTokenSpaceGuid.PcdFwCfgDmaAddress|0x0\r
\r
#\r
# Set video resolution for boot options and for text setup.\r
\r
gArmVirtTokenSpaceGuid.PcdFwCfgSelectorAddress|0x0\r
gArmVirtTokenSpaceGuid.PcdFwCfgDataAddress|0x0\r
+ gArmVirtTokenSpaceGuid.PcdFwCfgDmaAddress|0x0\r
\r
gArmVirtTokenSpaceGuid.PcdArmPsciMethod|0\r
\r
UINT64 FwCfgSelectorSize;\r
UINT64 FwCfgDataAddress;\r
UINT64 FwCfgDataSize;\r
+ UINT64 FwCfgDmaAddress;\r
+ UINT64 FwCfgDmaSize;\r
\r
Hob = GetFirstGuidHob(&gFdtHobGuid);\r
if (Hob == NULL || GET_GUID_HOB_DATA_SIZE (Hob) != sizeof (UINT64)) {\r
\r
DEBUG ((EFI_D_INFO, "Found FwCfg @ 0x%Lx/0x%Lx\n", FwCfgSelectorAddress,\r
FwCfgDataAddress));\r
+\r
+ if (fdt64_to_cpu (((UINT64 *)RegProp)[1]) >= 0x18) {\r
+ FwCfgDmaAddress = FwCfgDataAddress + 0x10;\r
+ FwCfgDmaSize = 0x08;\r
+\r
+ //\r
+ // See explanation above.\r
+ //\r
+ ASSERT (FwCfgDmaAddress <= MAX_UINTN - FwCfgDmaSize + 1);\r
+\r
+ PcdSet64 (PcdFwCfgDmaAddress, FwCfgDmaAddress);\r
+ DEBUG ((EFI_D_INFO, "Found FwCfg DMA @ 0x%Lx\n", FwCfgDmaAddress));\r
+ }\r
break;\r
\r
case PropertyTypeVirtio:\r
gArmVirtTokenSpaceGuid.PcdArmPsciMethod\r
gArmVirtTokenSpaceGuid.PcdFwCfgSelectorAddress\r
gArmVirtTokenSpaceGuid.PcdFwCfgDataAddress\r
+ gArmVirtTokenSpaceGuid.PcdFwCfgDmaAddress\r
gArmVirtTokenSpaceGuid.PcdArmGicRevision\r
gArmTokenSpaceGuid.PcdGicDistributorBase\r
gArmTokenSpaceGuid.PcdGicRedistributorsBase\r