https://bugzilla.tianocore.org/show_bug.cgi?id=4195 1.Updated the GDT table in VTF0 to align with the one in S3Resume2Pei. By doing so can simplify the changes to enable S3 in 64bit PEI. 2.Use SwitchStack() between PEI and SMM in S3 resume path when both are in the same execution mode. 3.Transfer from PEI to OS waking vector by calling SwitchStack() when both are in the same execution mode. 4.Removed the debug assertion in S3Resume.c to support 64bit PEI. Reviewed-by: Ray Ni <ray.ni@intel.com> Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com> Cc: Chasel Chiu <chasel.chiu@intel.com> Cc: Nate DeSimone <nathaniel.l.desimone@intel.com> Cc: Star Zeng <star.zeng@intel.com> Cc: Ashraf Ali S <ashraf.ali.s@intel.com> Cc: Chinni B Duggapu <chinni.b.duggapu@intel.com> Signed-off-by: Ted Kuo <ted.kuo@intel.com>
157 lines
5.1 KiB
INI
157 lines
5.1 KiB
INI
## @file
|
|
# CPU SMM driver.
|
|
#
|
|
# This SMM driver performs SMM initialization, deploy SMM Entry Vector,
|
|
# provides CPU specific services in SMM.
|
|
#
|
|
# Copyright (c) 2009 - 2022, Intel Corporation. All rights reserved.<BR>
|
|
# Copyright (c) 2017, AMD Incorporated. All rights reserved.<BR>
|
|
#
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
#
|
|
##
|
|
|
|
[Defines]
|
|
INF_VERSION = 0x00010005
|
|
BASE_NAME = PiSmmCpuDxeSmm
|
|
MODULE_UNI_FILE = PiSmmCpuDxeSmm.uni
|
|
FILE_GUID = A3FF0EF5-0C28-42f5-B544-8C7DE1E80014
|
|
MODULE_TYPE = DXE_SMM_DRIVER
|
|
VERSION_STRING = 1.0
|
|
PI_SPECIFICATION_VERSION = 0x0001000A
|
|
ENTRY_POINT = PiCpuSmmEntry
|
|
|
|
#
|
|
# The following information is for reference only and not required by the build tools.
|
|
#
|
|
# VALID_ARCHITECTURES = IA32 X64
|
|
#
|
|
|
|
[Sources]
|
|
PiSmmCpuDxeSmm.c
|
|
PiSmmCpuDxeSmm.h
|
|
MpService.c
|
|
SyncTimer.c
|
|
CpuS3.c
|
|
CpuService.c
|
|
CpuService.h
|
|
SmmProfile.c
|
|
SmmProfile.h
|
|
SmmProfileInternal.h
|
|
SmramSaveState.c
|
|
SmmCpuMemoryManagement.c
|
|
SmmMp.h
|
|
SmmMp.c
|
|
|
|
[Sources.Ia32]
|
|
Ia32/Semaphore.c
|
|
Ia32/PageTbl.c
|
|
Ia32/SmmFuncsArch.c
|
|
Ia32/SmmProfileArch.c
|
|
Ia32/SmmProfileArch.h
|
|
Ia32/SmmInit.nasm
|
|
Ia32/SmiEntry.nasm
|
|
Ia32/SmiException.nasm
|
|
Ia32/MpFuncs.nasm
|
|
Ia32/Cet.nasm
|
|
|
|
[Sources.X64]
|
|
X64/Semaphore.c
|
|
X64/PageTbl.c
|
|
X64/SmmFuncsArch.c
|
|
X64/SmmProfileArch.c
|
|
X64/SmmProfileArch.h
|
|
X64/SmmInit.nasm
|
|
X64/SmiEntry.nasm
|
|
X64/SmiException.nasm
|
|
X64/MpFuncs.nasm
|
|
X64/Cet.nasm
|
|
|
|
[Packages]
|
|
MdePkg/MdePkg.dec
|
|
MdeModulePkg/MdeModulePkg.dec
|
|
UefiCpuPkg/UefiCpuPkg.dec
|
|
|
|
[LibraryClasses]
|
|
UefiDriverEntryPoint
|
|
UefiRuntimeServicesTableLib
|
|
PcdLib
|
|
DebugLib
|
|
BaseLib
|
|
SynchronizationLib
|
|
BaseMemoryLib
|
|
MtrrLib
|
|
IoLib
|
|
TimerLib
|
|
SmmServicesTableLib
|
|
MemoryAllocationLib
|
|
DebugAgentLib
|
|
HobLib
|
|
PciLib
|
|
LocalApicLib
|
|
UefiCpuLib
|
|
SmmCpuPlatformHookLib
|
|
CpuExceptionHandlerLib
|
|
UefiLib
|
|
DxeServicesTableLib
|
|
CpuLib
|
|
ReportStatusCodeLib
|
|
SmmCpuFeaturesLib
|
|
PeCoffGetEntryPointLib
|
|
|
|
[Protocols]
|
|
gEfiSmmAccess2ProtocolGuid ## CONSUMES
|
|
gEfiMpServiceProtocolGuid ## CONSUMES
|
|
gEfiSmmConfigurationProtocolGuid ## PRODUCES
|
|
gEfiSmmCpuProtocolGuid ## PRODUCES
|
|
gEfiSmmReadyToLockProtocolGuid ## NOTIFY
|
|
gEfiSmmCpuServiceProtocolGuid ## PRODUCES
|
|
gEdkiiSmmMemoryAttributeProtocolGuid ## PRODUCES
|
|
gEfiMmMpProtocolGuid ## PRODUCES
|
|
gEdkiiSmmCpuRendezvousProtocolGuid ## PRODUCES
|
|
|
|
[Guids]
|
|
gEfiAcpiVariableGuid ## SOMETIMES_CONSUMES ## HOB # it is used for S3 boot.
|
|
gEdkiiPiSmmMemoryAttributesTableGuid ## CONSUMES ## SystemTable
|
|
gEfiMemoryAttributesTableGuid ## CONSUMES ## SystemTable
|
|
|
|
[FeaturePcd]
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmDebug ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmBlockStartupThisAp ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmEnableBspElection ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuHotPlugSupport ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmStackGuard ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmProfileEnable ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmProfileRingBuffer ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmFeatureControlMsrLock ## CONSUMES
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSwitchToLongMode ## CONSUMES
|
|
|
|
[Pcd]
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuMaxLogicalProcessorNumber ## SOMETIMES_CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmProfileSize ## SOMETIMES_CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmStackSize ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmApSyncTimeout ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuS3DataAddress ## SOMETIMES_CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuHotPlugDataAddress ## SOMETIMES_PRODUCES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmCodeAccessCheckEnable ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmSyncMode ## CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmShadowStackSize ## SOMETIMES_CONSUMES
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuFeaturesInitOnS3Resume ## CONSUMES
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdAcpiS3Enable ## CONSUMES
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdPteMemoryEncryptionAddressOrMask ## CONSUMES
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdNullPointerDetectionPropertyMask ## CONSUMES
|
|
gEfiMdeModulePkgTokenSpaceGuid.PcdHeapGuardPropertyMask ## CONSUMES
|
|
gEfiMdePkgTokenSpaceGuid.PcdControlFlowEnforcementPropertyMask ## CONSUMES
|
|
|
|
[FixedPcd]
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmMpTokenCountPerChunk ## CONSUMES
|
|
|
|
[Pcd.X64]
|
|
gUefiCpuPkgTokenSpaceGuid.PcdCpuSmmRestrictedMemoryAccess ## CONSUMES
|
|
|
|
[Depex]
|
|
gEfiMpServiceProtocolGuid
|
|
|
|
[UserExtensions.TianoCore."ExtraFiles"]
|
|
PiSmmCpuDxeSmmExtra.uni
|