mirror of https://github.com/acidanthera/audk.git
MdeModulePkg Core: Propagate PEI-phase FV authentication status to DXE
FV3 HOB was introduced by new (>= 1.5) PI spec, it is intended to be used to propagate PEI-phase FV authentication status to DXE. This patch is to update PeiCore to build FV3 HOB with the authentication status and DxeCore to get the authentication status from FV3 HOB when producing FVB Protocol. Cc: Liming Gao <liming.gao@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Star Zeng <star.zeng@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
parent
e4623bd5e6
commit
c60370454e
|
@ -380,10 +380,43 @@ DxeMain (
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (Hob.Raw = HobStart; !END_OF_HOB_LIST(Hob); Hob.Raw = GET_NEXT_HOB(Hob)) {
|
for (Hob.Raw = HobStart; !END_OF_HOB_LIST(Hob); Hob.Raw = GET_NEXT_HOB(Hob)) {
|
||||||
if (GET_HOB_TYPE (Hob) == EFI_HOB_TYPE_FV2) {
|
if (GET_HOB_TYPE (Hob) == EFI_HOB_TYPE_FV) {
|
||||||
DEBUG ((DEBUG_INFO | DEBUG_LOAD, "FV2 Hob 0x%0lx - 0x%0lx\n", Hob.FirmwareVolume2->BaseAddress, Hob.FirmwareVolume2->BaseAddress + Hob.FirmwareVolume2->Length - 1));
|
DEBUG ((
|
||||||
} else if (GET_HOB_TYPE (Hob) == EFI_HOB_TYPE_FV) {
|
DEBUG_INFO | DEBUG_LOAD,
|
||||||
DEBUG ((DEBUG_INFO | DEBUG_LOAD, "FV Hob 0x%0lx - 0x%0lx\n", Hob.FirmwareVolume->BaseAddress, Hob.FirmwareVolume->BaseAddress + Hob.FirmwareVolume->Length - 1));
|
"FV Hob 0x%0lx - 0x%0lx\n",
|
||||||
|
Hob.FirmwareVolume->BaseAddress,
|
||||||
|
Hob.FirmwareVolume->BaseAddress + Hob.FirmwareVolume->Length - 1
|
||||||
|
));
|
||||||
|
} else if (GET_HOB_TYPE (Hob) == EFI_HOB_TYPE_FV2) {
|
||||||
|
DEBUG ((
|
||||||
|
DEBUG_INFO | DEBUG_LOAD,
|
||||||
|
"FV2 Hob 0x%0lx - 0x%0lx\n",
|
||||||
|
Hob.FirmwareVolume2->BaseAddress,
|
||||||
|
Hob.FirmwareVolume2->BaseAddress + Hob.FirmwareVolume2->Length - 1
|
||||||
|
));
|
||||||
|
DEBUG ((
|
||||||
|
DEBUG_INFO | DEBUG_LOAD,
|
||||||
|
" %g - %g\n",
|
||||||
|
&Hob.FirmwareVolume2->FvName,
|
||||||
|
&Hob.FirmwareVolume2->FileName
|
||||||
|
));
|
||||||
|
} else if (GET_HOB_TYPE (Hob) == EFI_HOB_TYPE_FV3) {
|
||||||
|
DEBUG ((
|
||||||
|
DEBUG_INFO | DEBUG_LOAD,
|
||||||
|
"FV3 Hob 0x%0lx - 0x%0lx - 0x%x - 0x%x\n",
|
||||||
|
Hob.FirmwareVolume3->BaseAddress,
|
||||||
|
Hob.FirmwareVolume3->BaseAddress + Hob.FirmwareVolume3->Length - 1,
|
||||||
|
Hob.FirmwareVolume3->AuthenticationStatus,
|
||||||
|
Hob.FirmwareVolume3->ExtractedFv
|
||||||
|
));
|
||||||
|
if (Hob.FirmwareVolume3->ExtractedFv) {
|
||||||
|
DEBUG ((
|
||||||
|
DEBUG_INFO | DEBUG_LOAD,
|
||||||
|
" %g - %g\n",
|
||||||
|
&Hob.FirmwareVolume3->FvName,
|
||||||
|
&Hob.FirmwareVolume3->FileName
|
||||||
|
));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
DEBUG_CODE_END ();
|
DEBUG_CODE_END ();
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Layers on top of Firmware Block protocol to produce a file abstraction
|
Layers on top of Firmware Block protocol to produce a file abstraction
|
||||||
of FV based files.
|
of FV based files.
|
||||||
|
|
||||||
Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
are licensed and made available under the terms and conditions of the BSD License
|
||||||
which accompanies this distribution. The full text of the license may be found at
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -711,13 +711,10 @@ NotifyFwVolBlock (
|
||||||
FvDevice->FwVolHeader = FwVolHeader;
|
FvDevice->FwVolHeader = FwVolHeader;
|
||||||
FvDevice->IsFfs3Fv = CompareGuid (&FwVolHeader->FileSystemGuid, &gEfiFirmwareFileSystem3Guid);
|
FvDevice->IsFfs3Fv = CompareGuid (&FwVolHeader->FileSystemGuid, &gEfiFirmwareFileSystem3Guid);
|
||||||
FvDevice->Fv.ParentHandle = Fvb->ParentHandle;
|
FvDevice->Fv.ParentHandle = Fvb->ParentHandle;
|
||||||
|
//
|
||||||
if (Fvb->ParentHandle != NULL) {
|
// Inherit the authentication status from FVB.
|
||||||
//
|
//
|
||||||
// Inherit the authentication status from FVB.
|
FvDevice->AuthenticationStatus = GetFvbAuthenticationStatus (Fvb);
|
||||||
//
|
|
||||||
FvDevice->AuthenticationStatus = GetFvbAuthenticationStatus (Fvb);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!EFI_ERROR (FvCheck (FvDevice))) {
|
if (!EFI_ERROR (FvCheck (FvDevice))) {
|
||||||
//
|
//
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
It consumes FV HOBs and creates read-only Firmare Volume Block protocol
|
It consumes FV HOBs and creates read-only Firmare Volume Block protocol
|
||||||
instances for each of them.
|
instances for each of them.
|
||||||
|
|
||||||
Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2006 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
are licensed and made available under the terms and conditions of the BSD License
|
||||||
which accompanies this distribution. The full text of the license may be found at
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -517,9 +517,7 @@ ProduceFVBProtocolOnBuffer (
|
||||||
FvbDev->BaseAddress = BaseAddress;
|
FvbDev->BaseAddress = BaseAddress;
|
||||||
FvbDev->FvbAttributes = FwVolHeader->Attributes;
|
FvbDev->FvbAttributes = FwVolHeader->Attributes;
|
||||||
FvbDev->FwVolBlockInstance.ParentHandle = ParentHandle;
|
FvbDev->FwVolBlockInstance.ParentHandle = ParentHandle;
|
||||||
if (ParentHandle != NULL) {
|
FvbDev->AuthenticationStatus = AuthenticationStatus;
|
||||||
FvbDev->AuthenticationStatus = AuthenticationStatus;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Init the block caching fields of the device
|
// Init the block caching fields of the device
|
||||||
|
@ -630,16 +628,31 @@ FwVolBlockDriverInit (
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
EFI_PEI_HOB_POINTERS FvHob;
|
EFI_PEI_HOB_POINTERS FvHob;
|
||||||
|
EFI_PEI_HOB_POINTERS Fv3Hob;
|
||||||
|
UINT32 AuthenticationStatus;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Core Needs Firmware Volumes to function
|
// Core Needs Firmware Volumes to function
|
||||||
//
|
//
|
||||||
FvHob.Raw = GetHobList ();
|
FvHob.Raw = GetHobList ();
|
||||||
while ((FvHob.Raw = GetNextHob (EFI_HOB_TYPE_FV, FvHob.Raw)) != NULL) {
|
while ((FvHob.Raw = GetNextHob (EFI_HOB_TYPE_FV, FvHob.Raw)) != NULL) {
|
||||||
|
AuthenticationStatus = 0;
|
||||||
|
//
|
||||||
|
// Get the authentication status propagated from PEI-phase to DXE.
|
||||||
|
//
|
||||||
|
Fv3Hob.Raw = GetHobList ();
|
||||||
|
while ((Fv3Hob.Raw = GetNextHob (EFI_HOB_TYPE_FV3, Fv3Hob.Raw)) != NULL) {
|
||||||
|
if ((Fv3Hob.FirmwareVolume3->BaseAddress == FvHob.FirmwareVolume->BaseAddress) &&
|
||||||
|
(Fv3Hob.FirmwareVolume3->Length == FvHob.FirmwareVolume->Length)) {
|
||||||
|
AuthenticationStatus = Fv3Hob.FirmwareVolume3->AuthenticationStatus;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Fv3Hob.Raw = GET_NEXT_HOB (Fv3Hob);
|
||||||
|
}
|
||||||
//
|
//
|
||||||
// Produce an FVB protocol for it
|
// Produce an FVB protocol for it
|
||||||
//
|
//
|
||||||
ProduceFVBProtocolOnBuffer (FvHob.FirmwareVolume->BaseAddress, FvHob.FirmwareVolume->Length, NULL, 0, NULL);
|
ProduceFVBProtocolOnBuffer (FvHob.FirmwareVolume->BaseAddress, FvHob.FirmwareVolume->Length, NULL, AuthenticationStatus, NULL);
|
||||||
FvHob.Raw = GET_NEXT_HOB (FvHob);
|
FvHob.Raw = GET_NEXT_HOB (FvHob);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1452,6 +1452,18 @@ ProcessFvFile (
|
||||||
&FileInfo.FileName
|
&FileInfo.FileName
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Build FV3 HOB with authentication status to be propagated to DXE.
|
||||||
|
//
|
||||||
|
BuildFv3Hob (
|
||||||
|
(EFI_PHYSICAL_ADDRESS) (UINTN) FvHeader,
|
||||||
|
FvHeader->FvLength,
|
||||||
|
AuthenticationStatus,
|
||||||
|
TRUE,
|
||||||
|
&ParentFvImageInfo.FvName,
|
||||||
|
&FileInfo.FileName
|
||||||
|
);
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue