alder_lake_bios/Insyde/InsydeModulePkg/Universal/IhisiServicesSmm/IhisiServicesSmm.c

84 lines
2.3 KiB
C

/** @file
SMM driver implementation for the IHISI Services
;******************************************************************************
;* Copyright (c) 2014 - 2019, Insyde Software Corp. All Rights Reserved.
;*
;* You may not reproduce, distribute, publish, display, perform, modify, adapt,
;* transmit, broadcast, present, recite, release, license or otherwise exploit
;* any part of this publication in any form, by any means, without the prior
;* written permission of Insyde Software Corporation.
;*
;******************************************************************************
*/
#include "IhisiServicesSmm.h"
/**
IhisiSmm module entry point
@param ImageHandle A handle for the image that is initializing this driver
@param SystemTable A pointer to the EFI system table
@retval EFI_SUCCESS: Module initialized successfully
@retval Others Module initialized unsuccessfully
**/
EFI_STATUS
EFIAPI
IhisiServicesSmmEntry(
IN EFI_HANDLE ImageHandle,
IN EFI_SYSTEM_TABLE *SystemTable
)
{
EFI_STATUS Status;
if (!InSmm ()) {
return EFI_SUCCESS;
}
Status = AllocateIhisiBuffer ();
ASSERT_EFI_ERROR (Status);
Status = InitIhisi();
ASSERT_EFI_ERROR (Status);
if (FeaturePcdGet (PcdH2OIhisiVatsSupported)) {
Status = InstallVatsServices ();
ASSERT_EFI_ERROR (Status);
}
if (FeaturePcdGet (PcdH2OIhisiFbtsSupported)) {
Status = InstallFbtsServices ();
ASSERT_EFI_ERROR (Status);
}
if (FeaturePcdGet (PcdH2OIhisiFetsSupported)) {
Status = InstallFetsServices ();
ASSERT_EFI_ERROR (Status);
}
if (FeaturePcdGet (PcdH2OIhisiFbts2Supported)) {
Status = InstallCommonRegionCommunicationServices ();
ASSERT_EFI_ERROR (Status);
}
Status = InstallOemExtraDataCommunicationServices ();
ASSERT_EFI_ERROR (Status);
if (FeaturePcdGet (PcdH2OIhisiFbts2Supported)) {
Status = InstallSecureFlashServices();
ASSERT_EFI_ERROR (Status);
}
InitIhisiSecurityStatus ();
Status = InstallIhisiCommonServices ();
ASSERT_EFI_ERROR (Status);
Status = InstallIhisiProtocol ();
ASSERT_EFI_ERROR (Status);
if (FeaturePcdGet(PcdH2OIhisiRuntimeProtect)) {
Status = IhisiRuntimeProtect ();
ASSERT_EFI_ERROR (Status);
}
return Status;
}