mirror of https://github.com/acidanthera/audk.git
StandaloneMmPkg: StandaloneMmCoreEntryPoint: Extends support for X64
This change extends StandaloneMmCoreEntryPoint library to support X64 architecture. Cc: Ard Biesheuvel <ard.biesheuvel@arm.com> Cc: Sami Mujawar <sami.mujawar@arm.com> Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Supreeth Venkatesh <supreeth.venkatesh@arm.com> Signed-off-by: Kun Qin <kun.q@outlook.com> Reviewed-by: Jiewen Yao <Jiewen.yao@intel.com>
This commit is contained in:
parent
4bae4f02f3
commit
76ae542313
|
@ -26,6 +26,9 @@
|
||||||
AArch64/SetPermissions.c
|
AArch64/SetPermissions.c
|
||||||
AArch64/CreateHobList.c
|
AArch64/CreateHobList.c
|
||||||
|
|
||||||
|
[Sources.X64]
|
||||||
|
X64/StandaloneMmCoreEntryPoint.c
|
||||||
|
|
||||||
[Packages]
|
[Packages]
|
||||||
MdePkg/MdePkg.dec
|
MdePkg/MdePkg.dec
|
||||||
MdeModulePkg/MdeModulePkg.dec
|
MdeModulePkg/MdeModulePkg.dec
|
||||||
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
/** @file
|
||||||
|
Entry point to the Standalone Mm Core.
|
||||||
|
|
||||||
|
Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
|
||||||
|
Copyright (c) Microsoft Corporation.
|
||||||
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
|
|
||||||
|
**/
|
||||||
|
|
||||||
|
|
||||||
|
#include <PiMm.h>
|
||||||
|
|
||||||
|
#include <Library/StandaloneMmCoreEntryPoint.h>
|
||||||
|
#include <Library/DebugLib.h>
|
||||||
|
#include <Library/BaseLib.h>
|
||||||
|
|
||||||
|
//
|
||||||
|
// Cache copy of HobList pointer.
|
||||||
|
//
|
||||||
|
VOID *gHobList = NULL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
The entry point of PE/COFF Image for the STANDALONE MM Core.
|
||||||
|
|
||||||
|
This function is the entry point for the STANDALONE MM Core. This function is required to call
|
||||||
|
ProcessModuleEntryPointList() and ProcessModuleEntryPointList() is never expected to return.
|
||||||
|
The STANDALONE MM Core is responsible for calling ProcessLibraryConstructorList() as soon as the EFI
|
||||||
|
System Table and the image handle for the STANDALONE MM Core itself have been established.
|
||||||
|
If ProcessModuleEntryPointList() returns, then ASSERT() and halt the system.
|
||||||
|
|
||||||
|
@param HobStart Pointer to the beginning of the HOB List passed in from the PEI Phase.
|
||||||
|
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
EFIAPI
|
||||||
|
_ModuleEntryPoint (
|
||||||
|
IN VOID *HobStart
|
||||||
|
)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Cache a pointer to the HobList
|
||||||
|
//
|
||||||
|
gHobList = HobStart;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Call the Standalone MM Core entry point
|
||||||
|
//
|
||||||
|
ProcessModuleEntryPointList (HobStart);
|
||||||
|
|
||||||
|
//
|
||||||
|
// TODO: Set page table here?? AARCH64 has this step for some reason
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Required by the EBC compiler and identical in functionality to _ModuleEntryPoint().
|
||||||
|
|
||||||
|
This function is required to call _ModuleEntryPoint() passing in HobStart.
|
||||||
|
|
||||||
|
@param HobStart Pointer to the beginning of the HOB List passed in from the PEI Phase.
|
||||||
|
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
EFIAPI
|
||||||
|
EfiMain (
|
||||||
|
IN VOID *HobStart
|
||||||
|
)
|
||||||
|
{
|
||||||
|
_ModuleEntryPoint (HobStart);
|
||||||
|
}
|
Loading…
Reference in New Issue