2 # Last PEIM executed in PEI phase to load DXE Core from a Firmware Volume.
4 # This module produces a special PPI named the DXE Initial Program Load (IPL)
5 # PPI to discover and dispatch the DXE Foundation and components that are
6 # needed to run the DXE Foundation.
8 # Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR>
9 # Copyright (c) 2017, AMD Incorporated. All rights reserved.<BR>
10 # Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR>
12 # SPDX-License-Identifier: BSD-2-Clause-Patent
17 INF_VERSION = 0x00010005
19 MODULE_UNI_FILE = DxeIpl.uni
20 FILE_GUID = 86D70125-BAA3-4296-A62F-602BEBBB9081
24 ENTRY_POINT = PeimInitializeDxeIpl
27 # The following information is for reference only and not required by the build tools.
29 # VALID_ARCHITECTURES = IA32 X64 EBC (EBC is for build only) AARCH64 RISCV64
40 Ia32/IdtVectorAsm.nasm
50 [Sources.ARM, Sources.AARCH64]
58 MdeModulePkg/MdeModulePkg.dec
60 [Packages.ARM, Packages.AARCH64]
67 ExtractGuidedSectionLib
76 PeiServicesTablePointerLib
79 [LibraryClasses.ARM, LibraryClasses.AARCH64]
83 gEfiDxeIplPpiGuid ## PRODUCES
84 gEfiPeiDecompressPpiGuid ## PRODUCES
85 gEfiEndOfPeiSignalPpiGuid ## SOMETIMES_PRODUCES # Not produced on S3 boot path
86 gEfiPeiReadOnlyVariable2PpiGuid ## SOMETIMES_CONSUMES
87 gEfiPeiLoadFilePpiGuid ## SOMETIMES_CONSUMES
88 gEfiPeiS3Resume2PpiGuid ## SOMETIMES_CONSUMES # Consumed on S3 boot path
89 gEfiPeiRecoveryModulePpiGuid ## SOMETIMES_CONSUMES # Consumed on recovery boot path
92 gEfiVectorHandoffInfoPpiGuid
93 gEfiPeiMemoryDiscoveredPpiGuid ## SOMETIMES_CONSUMES
94 gEdkiiPeiBootInCapsuleOnDiskModePpiGuid ## SOMETIMES_CONSUMES
95 gEdkiiPeiCapsuleOnDiskPpiGuid ## SOMETIMES_CONSUMES # Consumed on firmware update boot path
98 ## SOMETIMES_CONSUMES ## Variable:L"MemoryTypeInformation"
99 ## SOMETIMES_PRODUCES ## HOB
100 gEfiMemoryTypeInformationGuid
103 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSwitchToLongMode ## CONSUMES
106 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplBuildPageTables ## CONSUMES
109 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSupportUefiDecompress ## CONSUMES
112 gEfiMdeModulePkgTokenSpaceGuid.PcdUse1GPageTable ## SOMETIMES_CONSUMES
113 gEfiMdeModulePkgTokenSpaceGuid.PcdPteMemoryEncryptionAddressOrMask ## CONSUMES
114 gEfiMdeModulePkgTokenSpaceGuid.PcdNullPointerDetectionPropertyMask ## CONSUMES
115 gEfiMdeModulePkgTokenSpaceGuid.PcdHeapGuardPropertyMask ## CONSUMES
116 gEfiMdeModulePkgTokenSpaceGuid.PcdCpuStackGuard ## CONSUMES
117 gEfiMdeModulePkgTokenSpaceGuid.PcdUse5LevelPageTable ## SOMETIMES_CONSUMES
118 gEfiMdeModulePkgTokenSpaceGuid.PcdGhcbBase ## CONSUMES
119 gEfiMdeModulePkgTokenSpaceGuid.PcdGhcbSize ## CONSUMES
121 [Pcd.IA32,Pcd.X64,Pcd.ARM,Pcd.AARCH64]
122 gEfiMdeModulePkgTokenSpaceGuid.PcdSetNxForStack ## SOMETIMES_CONSUMES
123 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeNxMemoryProtectionPolicy ## SOMETIMES_CONSUMES
124 gEfiMdeModulePkgTokenSpaceGuid.PcdImageProtectionPolicy ## SOMETIMES_CONSUMES
127 gEfiPeiLoadFilePpiGuid AND gEfiPeiMasterBootModePpiGuid
131 # S3_RESUME ## SOMETIMES_CONSUMES
132 # RECOVERY_FULL ## SOMETIMES_CONSUMES
136 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # MEMORY_ALLOCATION_MODULE for DxeCore
137 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # New Stack HoB
138 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # Old Stack HOB
141 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # MEMORY_ALLOCATION_BSP_STORE
144 [UserExtensions.TianoCore."ExtraFiles"]