mirror of https://github.com/acidanthera/audk.git
BaseTools/GenFv: Account for rebase of FV section containing VTF file
Account for rebase of FV section containing VTF file on IA32/IA64. This supports cases where the reset vector may not be set at 0xFFFFFFF0. For example, FV section defined as: [FV.FvSecPei] FvBaseAddress = $(FV_BOOT_BASE) FvForceRebase = TRUE Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Leo Duran <leo.duran@amd.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
parent
62b8b5be71
commit
adb6ac2563
|
@ -2770,11 +2770,13 @@ Returns:
|
||||||
//
|
//
|
||||||
// Update reset vector (SALE_ENTRY for IPF)
|
// Update reset vector (SALE_ENTRY for IPF)
|
||||||
// Now for IA32 and IA64 platform, the fv which has bsf file must have the
|
// Now for IA32 and IA64 platform, the fv which has bsf file must have the
|
||||||
// EndAddress of 0xFFFFFFFF. Thus, only this type fv needs to update the
|
// EndAddress of 0xFFFFFFFF (unless the section was rebased).
|
||||||
// reset vector. If the PEI Core is found, the VTF file will probably get
|
// Thus, only this type fv needs to update the reset vector.
|
||||||
|
// If the PEI Core is found, the VTF file will probably get
|
||||||
// corrupted by updating the entry point.
|
// corrupted by updating the entry point.
|
||||||
//
|
//
|
||||||
if ((mFvDataInfo.BaseAddress + mFvDataInfo.Size) == FV_IMAGES_TOP_ADDRESS) {
|
if (mFvDataInfo.ForceRebase == 1 ||
|
||||||
|
(mFvDataInfo.BaseAddress + mFvDataInfo.Size) == FV_IMAGES_TOP_ADDRESS) {
|
||||||
Status = UpdateResetVector (&FvImageMemoryFile, &mFvDataInfo, VtfFileImage);
|
Status = UpdateResetVector (&FvImageMemoryFile, &mFvDataInfo, VtfFileImage);
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
Error (NULL, 0, 3000, "Invalid", "Could not update the reset vector.");
|
Error (NULL, 0, 3000, "Invalid", "Could not update the reset vector.");
|
||||||
|
|
Loading…
Reference in New Issue