This repository has been archived by the owner on Apr 6, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
RISC-V/PlatformPkg: Fixup FDT from HOB and install into config table
The Linux EFISTUB reads the FDT from the EFI system configuration table. Before installing the FDT needs to be patched with the booting hartid, because the kernel in S-Mode cannot determine it. Signed-off-by: Daniel Schaefer <[email protected]>
- Loading branch information
1 parent
8defe14
commit 3a3c857
Showing
5 changed files
with
172 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,116 @@ | ||
/** @file | ||
RISC-V Flattened Device Tree DXE module | ||
The Linux booting protocol on RISC-V requires the id of the booting hart to | ||
be passed as a0. Therefore the EFISTUB needs to get this information. Because | ||
it runs in S-Mode, it cannot get this information from mhartid. Instead we | ||
insert the id into the device tree, that the EFIFSTUB can read from the config table. | ||
Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR> | ||
SPDX-License-Identifier: BSD-2-Clause-Patent | ||
**/ | ||
|
||
#include <Library/UefiBootServicesTableLib.h> | ||
#include <Library/DebugLib.h> | ||
#include <Library/HobLib.h> | ||
#include <Library/BaseMemoryLib.h> | ||
#include <Library/PcdLib.h> | ||
#include <libfdt.h> | ||
|
||
/** | ||
Fix up the device tree with booting hartid for the kernel | ||
@param DtbBlob The device tree. Is extended to fit the hart id. | ||
@retval EFI_SUCCESS The device tree was success fixed up with the hart id. | ||
@retval EFI_OUT_OF_RESOURCES There is not enough memory available to complete the operation. | ||
**/ | ||
EFI_STATUS | ||
EFIAPI | ||
FixDtb ( | ||
IN OUT VOID *DtbBlob, | ||
IN UINTN BootingHartId | ||
) | ||
{ | ||
fdt32_t Size; | ||
UINT32 ChosenOffset, Err; | ||
|
||
DEBUG ((DEBUG_INFO, "Fixing up device tree with boot hart id: %d\n", | ||
BootingHartId)); | ||
|
||
Size = fdt_totalsize(DtbBlob); | ||
Err = fdt_open_into(DtbBlob, DtbBlob, Size + 32); | ||
if (Err < 0) { | ||
DEBUG ((DEBUG_ERROR, | ||
"Device Tree can't be expanded to accommodate new node\n", __FUNCTION__)); | ||
return EFI_OUT_OF_RESOURCES; | ||
} | ||
ChosenOffset = fdt_path_offset(DtbBlob, "/chosen"); | ||
fdt_setprop_u32(DtbBlob, ChosenOffset, "boot-hartid", BootingHartId); | ||
|
||
return EFI_SUCCESS; | ||
} | ||
|
||
/** | ||
Install the FDT passed in HOB into EFI system configuration table. | ||
@retval EFI_SUCCESS Successfully installed fixed up FDT in config table. | ||
@retval EFI_NOT_FOUND Did not find FDT HOB. | ||
@retval EFI_OUT_OF_RESOURCES There is not enough memory available to complete the operation. | ||
**/ | ||
EFI_STATUS | ||
EFIAPI | ||
InstallFdtFromHob (VOID) | ||
{ | ||
EFI_STATUS Status; | ||
EFI_HOB_GUID_TYPE *GuidHob; | ||
VOID *DataInHob; | ||
UINTN DataSize; | ||
|
||
GuidHob = GetFirstGuidHob (&gFdtHobGuid); | ||
if (GuidHob == NULL) { | ||
DEBUG ((DEBUG_ERROR, "Failed to find RISC-V DTB Hob\n", | ||
__FUNCTION__)); | ||
return EFI_NOT_FOUND; | ||
} | ||
DataInHob = (VOID *) *((UINTN *) GET_GUID_HOB_DATA (GuidHob)); | ||
DataSize = GET_GUID_HOB_DATA_SIZE (GuidHob); | ||
|
||
Status = FixDtb (DataInHob, PcdGet32(PcdBootHartId)); | ||
if (EFI_ERROR (Status)) { | ||
return Status; | ||
} | ||
|
||
Status = gBS->InstallConfigurationTable (&gFdtTableGuid, DataInHob); | ||
if (EFI_ERROR (Status)) { | ||
DEBUG ((DEBUG_ERROR, "%a: failed to install FDT configuration table\n", | ||
__FUNCTION__)); | ||
} | ||
return Status; | ||
} | ||
|
||
/** | ||
Install the FDT from the HOB into the EFI system configuration table. | ||
@param ImageHandle Image handle of this driver. | ||
@param SystemTable Pointer to the System Table. | ||
@retval EFI_SUCCESS FDT successfully installed into config table. | ||
@retval EFI_NOT_FOUND Did not find FDT HOB. | ||
@retval EFI_OUT_OF_RESOURCES There is not enough memory available to complete the operation. | ||
**/ | ||
EFI_STATUS | ||
EFIAPI | ||
InstallFdt ( | ||
IN EFI_HANDLE ImageHandle, | ||
IN EFI_SYSTEM_TABLE *SystemTable | ||
) | ||
{ | ||
EFI_STATUS Status; | ||
|
||
Status = InstallFdtFromHob (); | ||
|
||
return Status; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
## @file | ||
# RISC-V Flattened Device Tree DXE module. | ||
# | ||
# Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR> | ||
# SPDX-License-Identifier: BSD-2-Clause-Patent | ||
# | ||
## | ||
|
||
[Defines] | ||
INF_VERSION = 0x0001001b | ||
BASE_NAME = FdtDxe | ||
FILE_GUID = a7d8f3f7-d8a7-47df-b3ec-9E5A693C380C | ||
MODULE_TYPE = DXE_DRIVER | ||
VERSION_STRING = 1.0 | ||
ENTRY_POINT = InstallFdt | ||
|
||
# | ||
# The following information is for reference only and not required by the build tools. | ||
# | ||
# VALID_ARCHITECTURES = RISCV64 | ||
# | ||
|
||
|
||
[Packages] | ||
EmbeddedPkg/EmbeddedPkg.dec | ||
MdeModulePkg/MdeModulePkg.dec | ||
MdePkg/MdePkg.dec | ||
Platform/RISC-V/PlatformPkg/RiscVPlatformPkg.dec | ||
EmbeddedPkg/EmbeddedPkg.dec | ||
|
||
[LibraryClasses] | ||
BaseLib | ||
BaseMemoryLib | ||
DebugLib | ||
FdtLib | ||
HobLib | ||
MemoryAllocationLib | ||
RiscVCpuLib | ||
UefiBootServicesTableLib | ||
UefiDriverEntryPoint | ||
|
||
[Sources] | ||
FdtDxe.c | ||
|
||
[Guids] | ||
gFdtHobGuid | ||
gFdtTableGuid | ||
|
||
[Pcd] | ||
gUefiRiscVPlatformPkgTokenSpaceGuid.PcdBootHartId ## CONSUMES | ||
|
||
[Depex] | ||
TRUE |