332 lines
9.9 KiB
C
332 lines
9.9 KiB
C
|
/** @file
|
||
|
In FSP API V2 mode, it will be invoked only once. It will call FspMemoryInit API,
|
||
|
register TemporaryRamDonePpi to call TempRamExit API, and register MemoryDiscoveredPpi
|
||
|
notify to call FspSiliconInit API.
|
||
|
|
||
|
Copyright (c) 2015, Intel Corporation. All rights reserved.<BR>
|
||
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||
|
|
||
|
**/
|
||
|
|
||
|
|
||
|
#include "FspInitPei.h"
|
||
|
|
||
|
/**
|
||
|
Return Hob list produced by FSP.
|
||
|
|
||
|
@param[in] PeiServices The pointer to the PEI Services Table.
|
||
|
@param[in] This The pointer to this instance of this PPI.
|
||
|
@param[out] FspHobList The pointer to Hob list produced by FSP.
|
||
|
|
||
|
@return EFI_SUCCESS FReturn Hob list produced by FSP successfully.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
FspInitDoneGetFspHobListV2 (
|
||
|
IN CONST EFI_PEI_SERVICES **PeiServices,
|
||
|
IN FSP_INIT_DONE_PPI *This,
|
||
|
OUT VOID **FspHobList
|
||
|
);
|
||
|
|
||
|
FSP_INIT_DONE_PPI mFspInitDonePpiV2 = {
|
||
|
FspInitDoneGetFspHobListV2
|
||
|
};
|
||
|
|
||
|
EFI_PEI_PPI_DESCRIPTOR mPeiFspInitDonePpiV2 = {
|
||
|
EFI_PEI_PPI_DESCRIPTOR_PPI | EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST,
|
||
|
&gFspInitDonePpiGuid,
|
||
|
&mFspInitDonePpiV2
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
This function is called after PEI core discover memory and finish migration.
|
||
|
|
||
|
@param[in] PeiServices Pointer to PEI Services Table.
|
||
|
@param[in] NotifyDesc Pointer to the descriptor for the Notification event that
|
||
|
caused this function to execute.
|
||
|
@param[in] Ppi Pointer to the PPI data associated with this function.
|
||
|
|
||
|
@retval EFI_STATUS Always return EFI_SUCCESS
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
PeiMemoryDiscoveredNotify (
|
||
|
IN EFI_PEI_SERVICES **PeiServices,
|
||
|
IN EFI_PEI_NOTIFY_DESCRIPTOR *NotifyDesc,
|
||
|
IN VOID *Ppi
|
||
|
);
|
||
|
|
||
|
EFI_PEI_NOTIFY_DESCRIPTOR mPeiMemoryDiscoveredNotifyDesc = {
|
||
|
(EFI_PEI_PPI_DESCRIPTOR_NOTIFY_CALLBACK | EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST),
|
||
|
&gEfiPeiMemoryDiscoveredPpiGuid,
|
||
|
PeiMemoryDiscoveredNotify
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
TemporaryRamDone() disables the use of Temporary RAM. If present, this service is invoked
|
||
|
by the PEI Foundation after the EFI_PEI_PERMANANT_MEMORY_INSTALLED_PPI is installed.
|
||
|
|
||
|
@retval EFI_SUCCESS Use of Temporary RAM was disabled.
|
||
|
@retval EFI_INVALID_PARAMETER Temporary RAM could not be disabled.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
PeiTemporaryRamDone (
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
EFI_PEI_TEMPORARY_RAM_DONE_PPI mPeiTemporaryRamDonePpi = {
|
||
|
PeiTemporaryRamDone
|
||
|
};
|
||
|
|
||
|
EFI_PEI_PPI_DESCRIPTOR mPeiTemporaryRamDoneDesc = {
|
||
|
(EFI_PEI_PPI_DESCRIPTOR_PPI | EFI_PEI_PPI_DESCRIPTOR_TERMINATE_LIST),
|
||
|
&gEfiTemporaryRamDonePpiGuid,
|
||
|
&mPeiTemporaryRamDonePpi
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
Return Hob list produced by FSP.
|
||
|
|
||
|
@param[in] PeiServices The pointer to the PEI Services Table.
|
||
|
@param[in] This The pointer to this instance of this PPI.
|
||
|
@param[out] FspHobList The pointer to Hob list produced by FSP.
|
||
|
|
||
|
@return EFI_SUCCESS FReturn Hob list produced by FSP successfully.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
FspInitDoneGetFspHobListV2 (
|
||
|
IN CONST EFI_PEI_SERVICES **PeiServices,
|
||
|
IN FSP_INIT_DONE_PPI *This,
|
||
|
OUT VOID **FspHobList
|
||
|
)
|
||
|
{
|
||
|
EFI_HOB_GUID_TYPE *GuidHob;
|
||
|
|
||
|
GuidHob = GetFirstGuidHob (&gFspInitDonePpiGuid);
|
||
|
if (GuidHob != NULL) {
|
||
|
*FspHobList = *(VOID **)GET_GUID_HOB_DATA (GuidHob);
|
||
|
return EFI_SUCCESS;
|
||
|
} else {
|
||
|
return EFI_NOT_FOUND;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Call FspMemoryInit API.
|
||
|
|
||
|
@param[in] FspHeader FSP header pointer.
|
||
|
|
||
|
@return Status returned by FspMemoryInit API.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
PeiFspMemoryInit (
|
||
|
IN FSP_INFO_HEADER *FspHeader
|
||
|
)
|
||
|
{
|
||
|
FSP_MEMORY_INIT_PARAMS FspMemoryInitParams;
|
||
|
FSP_INIT_RT_COMMON_BUFFER FspRtBuffer;
|
||
|
UINT8 FspUpdRgn[FixedPcdGet32 (PcdMaxUpdRegionSize)];
|
||
|
UINT32 UpdRegionSize;
|
||
|
EFI_BOOT_MODE BootMode;
|
||
|
UINT64 StackSize;
|
||
|
EFI_PHYSICAL_ADDRESS StackBase;
|
||
|
EFI_STATUS Status;
|
||
|
VOID *FspHobList;
|
||
|
VOID *HobData;
|
||
|
|
||
|
DEBUG ((DEBUG_INFO, "PeiFspMemoryInit enter\n"));
|
||
|
|
||
|
PeiServicesGetBootMode (&BootMode);
|
||
|
DEBUG ((DEBUG_INFO, "BootMode - 0x%x\n", BootMode));
|
||
|
|
||
|
GetStackInfo (BootMode, FALSE, &StackSize, &StackBase);
|
||
|
DEBUG ((DEBUG_INFO, "StackBase - 0x%x\n", StackBase));
|
||
|
DEBUG ((DEBUG_INFO, "StackSize - 0x%x\n", StackSize));
|
||
|
|
||
|
ZeroMem (&FspRtBuffer, sizeof(FspRtBuffer));
|
||
|
FspRtBuffer.StackTop = (UINT32 *)(UINTN)(StackBase + StackSize);
|
||
|
|
||
|
FspRtBuffer.BootMode = BootMode;
|
||
|
|
||
|
/* Platform override any UPD configs */
|
||
|
UpdRegionSize = GetUpdRegionSize();
|
||
|
DEBUG ((DEBUG_INFO, "UpdRegionSize - 0x%x\n", UpdRegionSize));
|
||
|
DEBUG ((DEBUG_INFO, "sizeof(FspUpdRgn) - 0x%x\n", sizeof(FspUpdRgn)));
|
||
|
ASSERT(sizeof(FspUpdRgn) >= UpdRegionSize);
|
||
|
ZeroMem (FspUpdRgn, UpdRegionSize);
|
||
|
FspRtBuffer.UpdDataRgnPtr = UpdateFspUpdConfigs (FspUpdRgn);
|
||
|
FspRtBuffer.BootLoaderTolumSize = GetBootLoaderTolumSize ();
|
||
|
|
||
|
ZeroMem (&FspMemoryInitParams, sizeof(FspMemoryInitParams));
|
||
|
FspMemoryInitParams.NvsBufferPtr = GetNvsBuffer ();
|
||
|
DEBUG ((DEBUG_INFO, "NvsBufferPtr - 0x%x\n", FspMemoryInitParams.NvsBufferPtr));
|
||
|
FspMemoryInitParams.RtBufferPtr = (VOID *)&FspRtBuffer;
|
||
|
FspHobList = NULL;
|
||
|
FspMemoryInitParams.HobListPtr = &FspHobList;
|
||
|
|
||
|
DEBUG ((DEBUG_INFO, "FspMemoryInitParams - 0x%x\n", &FspMemoryInitParams));
|
||
|
DEBUG ((DEBUG_INFO, " NvsBufferPtr - 0x%x\n", FspMemoryInitParams.NvsBufferPtr));
|
||
|
DEBUG ((DEBUG_INFO, " RtBufferPtr - 0x%x\n", FspMemoryInitParams.RtBufferPtr));
|
||
|
DEBUG ((DEBUG_INFO, " StackTop - 0x%x\n", FspRtBuffer.StackTop));
|
||
|
DEBUG ((DEBUG_INFO, " BootMode - 0x%x\n", FspRtBuffer.BootMode));
|
||
|
DEBUG ((DEBUG_INFO, " UpdDataRgnPtr - 0x%x\n", FspRtBuffer.UpdDataRgnPtr));
|
||
|
DEBUG ((DEBUG_INFO, " HobListPtr - 0x%x\n", FspMemoryInitParams.HobListPtr));
|
||
|
|
||
|
Status = CallFspMemoryInit (FspHeader, &FspMemoryInitParams);
|
||
|
DEBUG((DEBUG_INFO, "FspMemoryInit status: 0x%x\n", Status));
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
|
||
|
DEBUG ((DEBUG_INFO, " HobListPtr (returned) - 0x%x\n", FspHobList));
|
||
|
ASSERT (FspHobList != NULL);
|
||
|
|
||
|
FspHobProcessForMemoryResource (FspHobList);
|
||
|
|
||
|
//
|
||
|
// FspHobList is not complete at this moment.
|
||
|
// Save FspHobList pointer to hob, so that it can be got later
|
||
|
//
|
||
|
HobData = BuildGuidHob (
|
||
|
&gFspInitDonePpiGuid,
|
||
|
sizeof (VOID *)
|
||
|
);
|
||
|
ASSERT (HobData != NULL);
|
||
|
CopyMem (HobData, &FspHobList, sizeof (FspHobList));
|
||
|
|
||
|
return Status;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
TemporaryRamDone() disables the use of Temporary RAM. If present, this service is invoked
|
||
|
by the PEI Foundation after the EFI_PEI_PERMANANT_MEMORY_INSTALLED_PPI is installed.
|
||
|
|
||
|
@retval EFI_SUCCESS Use of Temporary RAM was disabled.
|
||
|
@retval EFI_INVALID_PARAMETER Temporary RAM could not be disabled.
|
||
|
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
PeiTemporaryRamDone (
|
||
|
VOID
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
VOID *TempRamExitParam;
|
||
|
FSP_INFO_HEADER *FspHeader;
|
||
|
|
||
|
FspHeader = FspFindFspHeader (PcdGet32 (PcdFlashFvFspBase));
|
||
|
if (FspHeader == NULL) {
|
||
|
return EFI_DEVICE_ERROR;
|
||
|
}
|
||
|
|
||
|
DEBUG ((DEBUG_INFO, "PeiTemporaryRamDone enter\n"));
|
||
|
|
||
|
TempRamExitParam = GetTempRamExitParam ();
|
||
|
Status = CallTempRamExit (FspHeader, TempRamExitParam);
|
||
|
DEBUG((DEBUG_INFO, "TempRamExit status: 0x%x\n", Status));
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
|
||
|
return EFI_SUCCESS;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
This function is called after PEI core discover memory and finish migration.
|
||
|
|
||
|
@param[in] PeiServices Pointer to PEI Services Table.
|
||
|
@param[in] NotifyDesc Pointer to the descriptor for the Notification event that
|
||
|
caused this function to execute.
|
||
|
@param[in] Ppi Pointer to the PPI data associated with this function.
|
||
|
|
||
|
@retval EFI_STATUS Always return EFI_SUCCESS
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
EFIAPI
|
||
|
PeiMemoryDiscoveredNotify (
|
||
|
IN EFI_PEI_SERVICES **PeiServices,
|
||
|
IN EFI_PEI_NOTIFY_DESCRIPTOR *NotifyDesc,
|
||
|
IN VOID *Ppi
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
VOID *FspSiliconInitParam;
|
||
|
FSP_INFO_HEADER *FspHeader;
|
||
|
VOID *FspHobList;
|
||
|
EFI_HOB_GUID_TYPE *GuidHob;
|
||
|
|
||
|
if (PcdGet32 (PcdFlashFvSecondFspBase) == 0) {
|
||
|
FspHeader = FspFindFspHeader (PcdGet32 (PcdFlashFvFspBase));
|
||
|
} else {
|
||
|
FspHeader = FspFindFspHeader (PcdGet32 (PcdFlashFvSecondFspBase));
|
||
|
}
|
||
|
if (FspHeader == NULL) {
|
||
|
return EFI_DEVICE_ERROR;
|
||
|
}
|
||
|
|
||
|
DEBUG ((DEBUG_INFO, "PeiMemoryDiscoveredNotify enter\n"));
|
||
|
|
||
|
FspSiliconInitParam = GetFspSiliconInitParam ();
|
||
|
Status = CallFspSiliconInit (FspHeader, FspSiliconInitParam);
|
||
|
DEBUG((DEBUG_ERROR, "FspSiliconInit status: 0x%x\n", Status));
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
|
||
|
//
|
||
|
// Now FspHobList complete, process it
|
||
|
//
|
||
|
GuidHob = GetFirstGuidHob (&gFspInitDonePpiGuid);
|
||
|
ASSERT (GuidHob != NULL);
|
||
|
FspHobList = *(VOID **)GET_GUID_HOB_DATA (GuidHob);
|
||
|
DEBUG ((DEBUG_INFO, "FspHobList - 0x%x\n", FspHobList));
|
||
|
FspHobProcessForOtherData (FspHobList);
|
||
|
|
||
|
//
|
||
|
// Install FspInitDonePpi so that any other driver can consume this info.
|
||
|
//
|
||
|
Status = PeiServicesInstallPpi (&mPeiFspInitDonePpiV2);
|
||
|
ASSERT_EFI_ERROR(Status);
|
||
|
|
||
|
return EFI_SUCCESS;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
Do FSP initialization based on FspApi version 2.
|
||
|
|
||
|
@param[in] FspHeader FSP header pointer.
|
||
|
|
||
|
@return FSP initialization status.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
PeiFspInitV2 (
|
||
|
IN FSP_INFO_HEADER *FspHeader
|
||
|
)
|
||
|
{
|
||
|
EFI_STATUS Status;
|
||
|
EFI_BOOT_MODE BootMode;
|
||
|
|
||
|
Status = PeiFspMemoryInit (FspHeader);
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
|
||
|
//
|
||
|
// Install TempramDonePpi to run TempRamExit
|
||
|
//
|
||
|
Status = PeiServicesInstallPpi (&mPeiTemporaryRamDoneDesc);
|
||
|
ASSERT_EFI_ERROR(Status);
|
||
|
|
||
|
//
|
||
|
// Register MemoryDiscovered Nofity to run FspSiliconInit
|
||
|
//
|
||
|
Status = PeiServicesNotifyPpi (&mPeiMemoryDiscoveredNotifyDesc);
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
|
||
|
//
|
||
|
// Register EndOfPei Notify for S3 to run FspNotifyPhase
|
||
|
//
|
||
|
PeiServicesGetBootMode (&BootMode);
|
||
|
if (BootMode == BOOT_ON_S3_RESUME) {
|
||
|
Status = PeiServicesNotifyPpi (&mS3EndOfPeiNotifyDesc);
|
||
|
ASSERT_EFI_ERROR (Status);
|
||
|
}
|
||
|
|
||
|
return EFI_SUCCESS;
|
||
|
}
|