VirtualBox

source: vbox/trunk/src/VBox/Devices/EFI/Firmware/UefiPayloadPkg/PayloadLoaderPeim/PayloadLoaderPeim.c@ 107675

最後變更 在這個檔案從107675是 99404,由 vboxsync 提交於 2 年 前

Devices/EFI/FirmwareNew: Update to edk2-stable202302 and make it build, bugref:4643

  • 屬性 svn:eol-style 設為 native
檔案大小: 6.0 KB
 
1/** @file
2 ELF Load Image Support
3
4Copyright (c) 2021, Intel Corporation. All rights reserved.<BR>
5SPDX-License-Identifier: BSD-2-Clause-Patent
6
7**/
8
9#include <PiPei.h>
10#include <UniversalPayload/UniversalPayload.h>
11#include <UniversalPayload/ExtraData.h>
12
13#include <Ppi/LoadFile.h>
14
15#include <Library/DebugLib.h>
16#include <Library/HobLib.h>
17#include <Library/PeiServicesLib.h>
18#include <Library/MemoryAllocationLib.h>
19#include <Library/BaseMemoryLib.h>
20
21#include "ElfLib.h"
22
23/**
24 The wrapper function of PeiLoadImageLoadImage().
25
26 @param This - Pointer to EFI_PEI_LOAD_FILE_PPI.
27 @param FileHandle - Pointer to the FFS file header of the image.
28 @param ImageAddressArg - Pointer to PE/TE image.
29 @param ImageSizeArg - Size of PE/TE image.
30 @param EntryPoint - Pointer to entry point of specified image file for output.
31 @param AuthenticationState - Pointer to attestation authentication state of image.
32
33 @return Status of PeiLoadImageLoadImage().
34
35**/
36EFI_STATUS
37EFIAPI
38PeiLoadFileLoadPayload (
39 IN CONST EFI_PEI_LOAD_FILE_PPI *This,
40 IN EFI_PEI_FILE_HANDLE FileHandle,
41 OUT EFI_PHYSICAL_ADDRESS *ImageAddressArg OPTIONAL,
42 OUT UINT64 *ImageSizeArg OPTIONAL,
43 OUT EFI_PHYSICAL_ADDRESS *EntryPoint,
44 OUT UINT32 *AuthenticationState
45 )
46{
47 EFI_STATUS Status;
48 VOID *Elf;
49 UNIVERSAL_PAYLOAD_EXTRA_DATA *ExtraData;
50 ELF_IMAGE_CONTEXT Context;
51 UINT32 Index;
52 UINT16 ExtraDataIndex;
53 CHAR8 *SectionName;
54 UINTN Offset;
55 UINTN Size;
56 UINT32 ExtraDataCount;
57 UINTN Instance;
58 UINTN Length;
59
60 //
61 // ELF is added to file as RAW section for EDKII bootloader.
62 // But RAW section might be added by build tool before the ELF RAW section when alignment is specified for ELF RAW section.
63 // Below loop skips the RAW section that doesn't contain valid ELF image.
64 //
65 Instance = 0;
66 do {
67 Status = PeiServicesFfsFindSectionData3 (EFI_SECTION_RAW, Instance++, FileHandle, &Elf, AuthenticationState);
68 if (EFI_ERROR (Status)) {
69 return Status;
70 }
71
72 ZeroMem (&Context, sizeof (Context));
73 Status = ParseElfImage (Elf, &Context);
74 } while (EFI_ERROR (Status));
75
76 DEBUG ((
77 DEBUG_INFO,
78 "Payload File Size: 0x%08X, Mem Size: 0x%08x, Reload: %d\n",
79 Context.FileSize,
80 Context.ImageSize,
81 Context.ReloadRequired
82 ));
83
84 //
85 // Get UNIVERSAL_PAYLOAD_INFO_HEADER and number of additional PLD sections.
86 //
87 ExtraDataCount = 0;
88 for (Index = 0; Index < Context.ShNum; Index++) {
89 Status = GetElfSectionName (&Context, Index, &SectionName);
90 if (EFI_ERROR (Status)) {
91 continue;
92 }
93
94 DEBUG ((DEBUG_INFO, "Payload Section[%d]: %a\n", Index, SectionName));
95 if (AsciiStrCmp (SectionName, UNIVERSAL_PAYLOAD_INFO_SEC_NAME) == 0) {
96 Status = GetElfSectionPos (&Context, Index, &Offset, &Size);
97 } else if (AsciiStrnCmp (SectionName, UNIVERSAL_PAYLOAD_EXTRA_SEC_NAME_PREFIX, UNIVERSAL_PAYLOAD_EXTRA_SEC_NAME_PREFIX_LENGTH) == 0) {
98 Status = GetElfSectionPos (&Context, Index, &Offset, &Size);
99 if (!EFI_ERROR (Status)) {
100 ExtraDataCount++;
101 }
102 }
103 }
104
105 //
106 // Report the additional PLD sections through HOB.
107 //
108 Length = sizeof (UNIVERSAL_PAYLOAD_EXTRA_DATA) + ExtraDataCount * sizeof (UNIVERSAL_PAYLOAD_EXTRA_DATA_ENTRY);
109 ExtraData = BuildGuidHob (
110 &gUniversalPayloadExtraDataGuid,
111 Length
112 );
113 ExtraData->Count = ExtraDataCount;
114 ExtraData->Header.Revision = UNIVERSAL_PAYLOAD_EXTRA_DATA_REVISION;
115 ExtraData->Header.Length = (UINT16)Length;
116 if (ExtraDataCount != 0) {
117 for (ExtraDataIndex = 0, Index = 0; Index < Context.ShNum; Index++) {
118 Status = GetElfSectionName (&Context, Index, &SectionName);
119 if (EFI_ERROR (Status)) {
120 continue;
121 }
122
123 if (AsciiStrnCmp (SectionName, UNIVERSAL_PAYLOAD_EXTRA_SEC_NAME_PREFIX, UNIVERSAL_PAYLOAD_EXTRA_SEC_NAME_PREFIX_LENGTH) == 0) {
124 Status = GetElfSectionPos (&Context, Index, &Offset, &Size);
125 if (!EFI_ERROR (Status)) {
126 ASSERT (ExtraDataIndex < ExtraDataCount);
127 AsciiStrCpyS (
128 ExtraData->Entry[ExtraDataIndex].Identifier,
129 sizeof (ExtraData->Entry[ExtraDataIndex].Identifier),
130 SectionName + UNIVERSAL_PAYLOAD_EXTRA_SEC_NAME_PREFIX_LENGTH
131 );
132 ExtraData->Entry[ExtraDataIndex].Base = (UINTN)(Context.FileBase + Offset);
133 ExtraData->Entry[ExtraDataIndex].Size = Size;
134 ExtraDataIndex++;
135 }
136 }
137 }
138 }
139
140 if (Context.ReloadRequired || (Context.PreferredImageAddress != Context.FileBase)) {
141 Context.ImageAddress = AllocatePages (EFI_SIZE_TO_PAGES (Context.ImageSize));
142 } else {
143 Context.ImageAddress = Context.FileBase;
144 }
145
146 //
147 // Load ELF into the required base
148 //
149 Status = LoadElfImage (&Context);
150 if (!EFI_ERROR (Status)) {
151 *ImageAddressArg = (UINTN)Context.ImageAddress;
152 *EntryPoint = Context.EntryPoint;
153 *ImageSizeArg = Context.ImageSize;
154 }
155
156 return Status;
157}
158
159EFI_PEI_LOAD_FILE_PPI mPeiLoadFilePpi = {
160 PeiLoadFileLoadPayload
161};
162
163EFI_PEI_PPI_DESCRIPTOR gPpiLoadFilePpiList = {
164 (EFI_PEI_PPI_DESCRIPTOR_PPI | EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST),
165 &gEfiPeiLoadFilePpiGuid,
166 &mPeiLoadFilePpi
167};
168
169/**
170
171 Install Pei Load File PPI.
172
173 @param FileHandle Handle of the file being invoked.
174 @param PeiServices Describes the list of possible PEI Services.
175
176 @retval EFI_SUCESS The entry point executes successfully.
177 @retval Others Some error occurs during the execution of this function.
178
179**/
180EFI_STATUS
181EFIAPI
182InitializePayloadLoaderPeim (
183 IN EFI_PEI_FILE_HANDLE FileHandle,
184 IN CONST EFI_PEI_SERVICES **PeiServices
185 )
186{
187 EFI_STATUS Status;
188
189 Status = PeiServicesInstallPpi (&gPpiLoadFilePpiList);
190
191 return Status;
192}
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette