mirror of https://github.com/acidanthera/audk.git
UefiCpuPkg: Add SmmRelocationLib class
Intel plans to separate the smbase relocation logic from PiSmmCpuDxeSmm driver, and the related behavior will be moved to the new interface defined by the SmmRelocationLib class. The SmmRelocationLib class provides the SmmRelocationInit() interface for platform to do the smbase relocation, which shall provide below 2 functionalities: 1. Relocate smbases for each processor. 2. Create the gSmmBaseHobGuid HOB. With SmmRelocationLib, PiSmmCpuDxeSmm driver (which runs at a later phase) shall: 1. Consume the gSmmBaseHobGuid HOB for the relocated smbases for each Processor. 2. Execute the early SMM Init. This patch just provides the SmmRelocationLib class. Cc: Ray Ni <ray.ni@intel.com> Cc: Zeng Star <star.zeng@intel.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: Rahul Kumar <rahul1.kumar@intel.com> Signed-off-by: Jiaxin Wu <jiaxin.wu@intel.com> Reviewed-by: Ray Ni <ray.ni@intel.com>
This commit is contained in:
parent
987bea6525
commit
af9b851732
|
@ -0,0 +1,42 @@
|
|||
/** @file
|
||||
Header file for SMM Relocation Library.
|
||||
|
||||
The SmmRelocationLib class provides the SmmRelocationInit()
|
||||
interface for platform to do the smbase relocation, which
|
||||
shall provide below 2 functionalities:
|
||||
1. Relocate SmBases for each processor.
|
||||
2. Create the SmBase HOB (gSmmBaseHobGuid).
|
||||
|
||||
With SmmRelocationLib, PiSmmCpuDxeSmm driver (which runs at a later phase)
|
||||
shall:
|
||||
1. Consume the gSmmBaseHobGuid for the relocated smbase for each Processor.
|
||||
2. Execute early SMM init.
|
||||
|
||||
Copyright (c) 2024, Intel Corporation. All rights reserved.<BR>
|
||||
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||
|
||||
**/
|
||||
|
||||
#ifndef SMM_RELOCATION_LIB_H_
|
||||
#define SMM_RELOCATION_LIB_H_
|
||||
|
||||
#include <Ppi/MpServices2.h>
|
||||
|
||||
/**
|
||||
CPU SmmBase Relocation Init.
|
||||
|
||||
This function is to relocate CPU SmmBase.
|
||||
|
||||
@param[in] MpServices2 Pointer to this instance of the MpServices.
|
||||
|
||||
@retval EFI_SUCCESS CPU SmmBase Relocated successfully.
|
||||
@retval Others CPU SmmBase Relocation failed.
|
||||
|
||||
**/
|
||||
EFI_STATUS
|
||||
EFIAPI
|
||||
SmmRelocationInit (
|
||||
IN EDKII_PEI_MP_SERVICES2_PPI *MpServices2
|
||||
);
|
||||
|
||||
#endif
|
|
@ -71,6 +71,9 @@
|
|||
## @libraryclass Provides functions for SMM CPU Sync Operation.
|
||||
SmmCpuSyncLib|Include/Library/SmmCpuSyncLib.h
|
||||
|
||||
## @libraryclass Provides functions for SMM Relocation Operation.
|
||||
SmmRelocationLib|Include/Library/SmmRelocationLib.h
|
||||
|
||||
[LibraryClasses.RISCV64]
|
||||
## @libraryclass Provides functions to manage MMU features on RISCV64 CPUs.
|
||||
##
|
||||
|
|
Loading…
Reference in New Issue