2014-09-18 19:53:36 +02:00
|
|
|
/** @file
|
|
|
|
|
2018-11-21 12:58:27 +01:00
|
|
|
Copyright (c) 2014-2018, Linaro Ltd. All rights reserved.<BR>
|
2014-09-18 19:53:36 +02:00
|
|
|
|
2019-04-04 01:03:23 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2014-09-18 19:53:36 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
2018-11-21 12:58:27 +01:00
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/DebugLib.h>
|
2014-09-18 19:53:36 +02:00
|
|
|
#include <Library/NorFlashPlatformLib.h>
|
2018-11-21 12:58:27 +01:00
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
|
|
|
|
|
|
#include <Protocol/FdtClient.h>
|
2014-09-18 19:53:36 +02:00
|
|
|
|
2017-11-15 14:59:08 +01:00
|
|
|
#define QEMU_NOR_BLOCK_SIZE SIZE_256KB
|
2018-11-21 12:58:27 +01:00
|
|
|
|
|
|
|
#define MAX_FLASH_BANKS 4
|
2017-11-15 14:59:08 +01:00
|
|
|
|
2014-09-18 19:53:36 +02:00
|
|
|
EFI_STATUS
|
|
|
|
NorFlashPlatformInitialization (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2018-11-21 12:58:27 +01:00
|
|
|
NOR_FLASH_DESCRIPTION mNorFlashDevices[MAX_FLASH_BANKS];
|
2014-09-18 19:53:36 +02:00
|
|
|
|
|
|
|
EFI_STATUS
|
|
|
|
NorFlashPlatformGetDevices (
|
|
|
|
OUT NOR_FLASH_DESCRIPTION **NorFlashDescriptions,
|
|
|
|
OUT UINT32 *Count
|
|
|
|
)
|
|
|
|
{
|
2018-11-21 12:58:27 +01:00
|
|
|
FDT_CLIENT_PROTOCOL *FdtClient;
|
|
|
|
INT32 Node;
|
|
|
|
EFI_STATUS Status;
|
|
|
|
EFI_STATUS FindNodeStatus;
|
|
|
|
CONST UINT32 *Reg;
|
|
|
|
UINT32 PropSize;
|
|
|
|
UINT32 Num;
|
|
|
|
UINT64 Base;
|
|
|
|
UINT64 Size;
|
|
|
|
|
|
|
|
Status = gBS->LocateProtocol (&gFdtClientProtocolGuid, NULL,
|
|
|
|
(VOID **)&FdtClient);
|
|
|
|
ASSERT_EFI_ERROR (Status);
|
|
|
|
|
|
|
|
Num = 0;
|
|
|
|
for (FindNodeStatus = FdtClient->FindCompatibleNode (FdtClient,
|
|
|
|
"cfi-flash", &Node);
|
|
|
|
!EFI_ERROR (FindNodeStatus) && Num < MAX_FLASH_BANKS;
|
|
|
|
FindNodeStatus = FdtClient->FindNextCompatibleNode (FdtClient,
|
|
|
|
"cfi-flash", Node, &Node)) {
|
|
|
|
|
|
|
|
Status = FdtClient->GetNodeProperty (FdtClient, Node, "reg",
|
|
|
|
(CONST VOID **)&Reg, &PropSize);
|
|
|
|
if (EFI_ERROR (Status)) {
|
|
|
|
DEBUG ((DEBUG_ERROR, "%a: GetNodeProperty () failed (Status == %r)\n",
|
|
|
|
__FUNCTION__, Status));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
ASSERT ((PropSize % (4 * sizeof (UINT32))) == 0);
|
|
|
|
|
|
|
|
while (PropSize >= (4 * sizeof (UINT32)) && Num < MAX_FLASH_BANKS) {
|
|
|
|
Base = SwapBytes64 (ReadUnaligned64 ((VOID *)&Reg[0]));
|
|
|
|
Size = SwapBytes64 (ReadUnaligned64 ((VOID *)&Reg[2]));
|
|
|
|
Reg += 4;
|
|
|
|
|
2018-11-30 12:28:28 +01:00
|
|
|
PropSize -= 4 * sizeof (UINT32);
|
|
|
|
|
|
|
|
//
|
|
|
|
// Disregard any flash devices that overlap with the primary FV.
|
|
|
|
// The firmware is not updatable from inside the guest anyway.
|
|
|
|
//
|
|
|
|
if ((PcdGet64 (PcdFvBaseAddress) + PcdGet32 (PcdFvSize) > Base) &&
|
|
|
|
(Base + Size) > PcdGet64 (PcdFvBaseAddress)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-11-21 12:58:27 +01:00
|
|
|
mNorFlashDevices[Num].DeviceBaseAddress = (UINTN)Base;
|
|
|
|
mNorFlashDevices[Num].RegionBaseAddress = (UINTN)Base;
|
|
|
|
mNorFlashDevices[Num].Size = (UINTN)Size;
|
|
|
|
mNorFlashDevices[Num].BlockSize = QEMU_NOR_BLOCK_SIZE;
|
|
|
|
Num++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-18 19:53:36 +02:00
|
|
|
*NorFlashDescriptions = mNorFlashDevices;
|
2018-11-21 12:58:27 +01:00
|
|
|
*Count = Num;
|
|
|
|
|
2014-09-18 19:53:36 +02:00
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|