mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-30 00:54:06 +02:00
ArmVirtualizationPkg: move early UART discovery to PlatformPeim
This is partially motivated by the desire to use PrePi in a virt environment, and in that configuration, ArmPlatformInitializeSystemMemory() is never called. But actually, this is a more suitable place anyway. Contributed-under: TianoCore Contribution Agreement 1.0 Reviewed-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Olivier Martin <olivier.martin@arm.com> Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Laszlo Ersek <lersek@redhat.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16958 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
ada518b7d6
commit
337d450e20
@ -62,6 +62,3 @@
|
|||||||
gArmTokenSpaceGuid.PcdArmPrimaryCore
|
gArmTokenSpaceGuid.PcdArmPrimaryCore
|
||||||
gArmTokenSpaceGuid.PcdFdBaseAddress
|
gArmTokenSpaceGuid.PcdFdBaseAddress
|
||||||
gArmTokenSpaceGuid.PcdFdSize
|
gArmTokenSpaceGuid.PcdFdSize
|
||||||
|
|
||||||
[Guids]
|
|
||||||
gEarlyPL011BaseAddressGuid
|
|
||||||
|
@ -24,9 +24,6 @@
|
|||||||
#include <Pi/PiBootMode.h>
|
#include <Pi/PiBootMode.h>
|
||||||
#include <Uefi/UefiBaseType.h>
|
#include <Uefi/UefiBaseType.h>
|
||||||
#include <Uefi/UefiMultiPhase.h>
|
#include <Uefi/UefiMultiPhase.h>
|
||||||
#include <Pi/PiHob.h>
|
|
||||||
#include <Library/HobLib.h>
|
|
||||||
#include <Guid/EarlyPL011BaseAddress.h>
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Return the current Boot Mode
|
Return the current Boot Mode
|
||||||
@ -77,25 +74,13 @@ ArmPlatformInitializeSystemMemory (
|
|||||||
INT32 Node, Prev;
|
INT32 Node, Prev;
|
||||||
UINT64 NewBase;
|
UINT64 NewBase;
|
||||||
UINT64 NewSize;
|
UINT64 NewSize;
|
||||||
BOOLEAN HaveMemory, HaveUART;
|
|
||||||
UINT64 *HobData;
|
|
||||||
CONST CHAR8 *Type;
|
CONST CHAR8 *Type;
|
||||||
CONST CHAR8 *Compatible;
|
|
||||||
CONST CHAR8 *CompItem;
|
|
||||||
INT32 Len;
|
INT32 Len;
|
||||||
CONST UINT64 *RegProp;
|
CONST UINT64 *RegProp;
|
||||||
UINT64 UartBase;
|
|
||||||
|
|
||||||
NewBase = 0;
|
NewBase = 0;
|
||||||
NewSize = 0;
|
NewSize = 0;
|
||||||
|
|
||||||
HaveMemory = FALSE;
|
|
||||||
HaveUART = FALSE;
|
|
||||||
|
|
||||||
HobData = BuildGuidHob (&gEarlyPL011BaseAddressGuid, sizeof *HobData);
|
|
||||||
ASSERT (HobData != NULL);
|
|
||||||
*HobData = 0;
|
|
||||||
|
|
||||||
DeviceTreeBase = (VOID *)(UINTN)PcdGet64 (PcdDeviceTreeInitialBaseAddress);
|
DeviceTreeBase = (VOID *)(UINTN)PcdGet64 (PcdDeviceTreeInitialBaseAddress);
|
||||||
ASSERT (DeviceTreeBase != NULL);
|
ASSERT (DeviceTreeBase != NULL);
|
||||||
|
|
||||||
@ -107,7 +92,7 @@ ArmPlatformInitializeSystemMemory (
|
|||||||
//
|
//
|
||||||
// Look for a memory node
|
// Look for a memory node
|
||||||
//
|
//
|
||||||
for (Prev = 0; !(HaveMemory && HaveUART); Prev = Node) {
|
for (Prev = 0;; Prev = Node) {
|
||||||
Node = fdt_next_node (DeviceTreeBase, Prev, NULL);
|
Node = fdt_next_node (DeviceTreeBase, Prev, NULL);
|
||||||
if (Node < 0) {
|
if (Node < 0) {
|
||||||
break;
|
break;
|
||||||
@ -140,34 +125,7 @@ ArmPlatformInitializeSystemMemory (
|
|||||||
DEBUG ((EFI_D_ERROR, "%a: Failed to parse FDT memory node\n",
|
DEBUG ((EFI_D_ERROR, "%a: Failed to parse FDT memory node\n",
|
||||||
__FUNCTION__));
|
__FUNCTION__));
|
||||||
}
|
}
|
||||||
HaveMemory = TRUE;
|
break;
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Check for UART node
|
|
||||||
//
|
|
||||||
Compatible = fdt_getprop (DeviceTreeBase, Node, "compatible", &Len);
|
|
||||||
|
|
||||||
//
|
|
||||||
// Iterate over the NULL-separated items in the compatible string
|
|
||||||
//
|
|
||||||
for (CompItem = Compatible; CompItem != NULL && CompItem < Compatible + Len;
|
|
||||||
CompItem += 1 + AsciiStrLen (CompItem)) {
|
|
||||||
|
|
||||||
if (AsciiStrCmp (CompItem, "arm,pl011") == 0) {
|
|
||||||
RegProp = fdt_getprop (DeviceTreeBase, Node, "reg", &Len);
|
|
||||||
ASSERT (Len == 16);
|
|
||||||
|
|
||||||
UartBase = fdt64_to_cpu (ReadUnaligned64 (RegProp));
|
|
||||||
|
|
||||||
DEBUG ((EFI_D_INFO, "%a: PL011 UART @ 0x%lx\n", __FUNCTION__, UartBase));
|
|
||||||
|
|
||||||
*HobData = UartBase;
|
|
||||||
|
|
||||||
HaveUART = TRUE;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,6 +21,8 @@
|
|||||||
#include <Library/PcdLib.h>
|
#include <Library/PcdLib.h>
|
||||||
#include <libfdt.h>
|
#include <libfdt.h>
|
||||||
|
|
||||||
|
#include <Guid/EarlyPL011BaseAddress.h>
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
PlatformPeim (
|
PlatformPeim (
|
||||||
@ -30,6 +32,14 @@ PlatformPeim (
|
|||||||
VOID *Base;
|
VOID *Base;
|
||||||
VOID *NewBase;
|
VOID *NewBase;
|
||||||
UINTN FdtSize;
|
UINTN FdtSize;
|
||||||
|
UINT64 *UartHobData;
|
||||||
|
INT32 Node, Prev;
|
||||||
|
CONST CHAR8 *Compatible;
|
||||||
|
CONST CHAR8 *CompItem;
|
||||||
|
INT32 Len;
|
||||||
|
CONST UINT64 *RegProp;
|
||||||
|
UINT64 UartBase;
|
||||||
|
|
||||||
|
|
||||||
Base = (VOID*)(UINTN)FixedPcdGet64 (PcdDeviceTreeInitialBaseAddress);
|
Base = (VOID*)(UINTN)FixedPcdGet64 (PcdDeviceTreeInitialBaseAddress);
|
||||||
ASSERT (fdt_check_header (Base) == 0);
|
ASSERT (fdt_check_header (Base) == 0);
|
||||||
@ -41,6 +51,44 @@ PlatformPeim (
|
|||||||
CopyMem (NewBase, Base, FdtSize);
|
CopyMem (NewBase, Base, FdtSize);
|
||||||
PcdSet64 (PcdDeviceTreeBaseAddress, (UINT64)(UINTN)NewBase);
|
PcdSet64 (PcdDeviceTreeBaseAddress, (UINT64)(UINTN)NewBase);
|
||||||
|
|
||||||
|
UartHobData = BuildGuidHob (&gEarlyPL011BaseAddressGuid, sizeof *UartHobData);
|
||||||
|
ASSERT (UartHobData != NULL);
|
||||||
|
*UartHobData = 0;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Look for a UART node
|
||||||
|
//
|
||||||
|
for (Prev = 0;; Prev = Node) {
|
||||||
|
Node = fdt_next_node (Base, Prev, NULL);
|
||||||
|
if (Node < 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Check for UART node
|
||||||
|
//
|
||||||
|
Compatible = fdt_getprop (Base, Node, "compatible", &Len);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Iterate over the NULL-separated items in the compatible string
|
||||||
|
//
|
||||||
|
for (CompItem = Compatible; CompItem != NULL && CompItem < Compatible + Len;
|
||||||
|
CompItem += 1 + AsciiStrLen (CompItem)) {
|
||||||
|
|
||||||
|
if (AsciiStrCmp (CompItem, "arm,pl011") == 0) {
|
||||||
|
RegProp = fdt_getprop (Base, Node, "reg", &Len);
|
||||||
|
ASSERT (Len == 16);
|
||||||
|
|
||||||
|
UartBase = fdt64_to_cpu (ReadUnaligned64 (RegProp));
|
||||||
|
|
||||||
|
DEBUG ((EFI_D_INFO, "%a: PL011 UART @ 0x%lx\n", __FUNCTION__, UartBase));
|
||||||
|
|
||||||
|
*UartHobData = UartBase;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
BuildFvHob (PcdGet64 (PcdFvBaseAddress), PcdGet32 (PcdFvSize));
|
BuildFvHob (PcdGet64 (PcdFvBaseAddress), PcdGet32 (PcdFvSize));
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
|
@ -44,5 +44,8 @@
|
|||||||
[Pcd]
|
[Pcd]
|
||||||
gArmVirtualizationTokenSpaceGuid.PcdDeviceTreeBaseAddress
|
gArmVirtualizationTokenSpaceGuid.PcdDeviceTreeBaseAddress
|
||||||
|
|
||||||
|
[Guids]
|
||||||
|
gEarlyPL011BaseAddressGuid
|
||||||
|
|
||||||
[Depex]
|
[Depex]
|
||||||
gEfiPeiMemoryDiscoveredPpiGuid
|
gEfiPeiMemoryDiscoveredPpiGuid
|
||||||
|
Loading…
x
Reference in New Issue
Block a user