/** @file
Provide SecTemporaryRamDone function.
Copyright (c) 2020, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
**/
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
/**
This interface disables temporary memory in SEC Phase.
**/
VOID
EFIAPI
SecPlatformDisableTemporaryMemory (
VOID
)
{
EFI_STATUS Status;
VOID *TempRamExitParam;
CONST EFI_PEI_SERVICES **PeiServices;
FSP_TEMP_RAM_EXIT_PPI *TempRamExitPpi;
PLATFORM_INIT_TEMP_RAM_EXIT_PPI *PlatformInitTempRamExitPpi;
DEBUG ((DEBUG_INFO, "SecPlatformDisableTemporaryMemory enter\n"));
PeiServices = GetPeiServicesTablePointer ();
ASSERT (PeiServices != NULL);
if (PeiServices == NULL) {
return;
}
ASSERT ((*PeiServices) != NULL);
if ((*PeiServices) == NULL) {
return;
}
Status = (*PeiServices)->LocatePpi (
PeiServices,
&gPlatformInitTempRamExitPpiGuid,
0,
NULL,
(VOID **) &PlatformInitTempRamExitPpi
);
ASSERT_EFI_ERROR (Status);
if (EFI_ERROR (Status)) {
return;
}
Status = PlatformInitTempRamExitPpi->PlatformInitBeforeTempRamExit ();
ASSERT_EFI_ERROR (Status);
if (PcdGet8 (PcdFspModeSelection) == 1) {
//
// FSP API mode
//
TempRamExitParam = UpdateTempRamExitParam ();
Status = CallTempRamExit (TempRamExitParam);
DEBUG ((DEBUG_INFO, "TempRamExit status: 0x%x\n", Status));
ASSERT_EFI_ERROR (Status);
} else {
//
// FSP Dispatch mode
//
Status = (*PeiServices)->LocatePpi (
PeiServices,
&gFspTempRamExitPpiGuid,
0,
NULL,
(VOID **) &TempRamExitPpi
);
ASSERT_EFI_ERROR (Status);
if (EFI_ERROR (Status)) {
return;
}
TempRamExitPpi->TempRamExit (NULL);
}
Status = PlatformInitTempRamExitPpi->PlatformInitAfterTempRamExit ();
ASSERT_EFI_ERROR (Status);
return ;
}