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>
11 # Copyright (c) 2022, Loongson Technology Corporation Limited. All rights reserved.<BR>
13 # SPDX-License-Identifier: BSD-2-Clause-Patent
18 INF_VERSION = 0x00010005
20 MODULE_UNI_FILE = DxeIpl.uni
21 FILE_GUID = 86D70125-BAA3-4296-A62F-602BEBBB9081
25 ENTRY_POINT = PeimInitializeDxeIpl
28 # The following information is for reference only and not required by the build tools.
30 # VALID_ARCHITECTURES = IA32 X64 EBC (EBC is for build only) AARCH64 RISCV64 LOONGARCH64
41 Ia32/IdtVectorAsm.nasm
51 [Sources.ARM, Sources.AARCH64]
58 LoongArch64/DxeLoadFunc.c
62 MdeModulePkg/MdeModulePkg.dec
64 [Packages.ARM, Packages.AARCH64]
71 ExtractGuidedSectionLib
80 PeiServicesTablePointerLib
83 [LibraryClasses.ARM, LibraryClasses.AARCH64]
87 gEfiDxeIplPpiGuid ## PRODUCES
88 gEfiPeiDecompressPpiGuid ## PRODUCES
89 gEfiEndOfPeiSignalPpiGuid ## SOMETIMES_PRODUCES # Not produced on S3 boot path
90 gEfiPeiReadOnlyVariable2PpiGuid ## SOMETIMES_CONSUMES
91 gEfiPeiLoadFilePpiGuid ## SOMETIMES_CONSUMES
92 gEfiPeiS3Resume2PpiGuid ## SOMETIMES_CONSUMES # Consumed on S3 boot path
93 gEfiPeiRecoveryModulePpiGuid ## SOMETIMES_CONSUMES # Consumed on recovery boot path
96 gEfiVectorHandoffInfoPpiGuid
97 gEfiPeiMemoryDiscoveredPpiGuid ## SOMETIMES_CONSUMES
98 gEdkiiPeiBootInCapsuleOnDiskModePpiGuid ## SOMETIMES_CONSUMES
99 gEdkiiPeiCapsuleOnDiskPpiGuid ## SOMETIMES_CONSUMES # Consumed on firmware update boot path
102 ## SOMETIMES_CONSUMES ## Variable:L"MemoryTypeInformation"
103 ## SOMETIMES_PRODUCES ## HOB
104 gEfiMemoryTypeInformationGuid
107 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSwitchToLongMode ## CONSUMES
110 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplBuildPageTables ## CONSUMES
113 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSupportUefiDecompress ## CONSUMES
116 gEfiMdeModulePkgTokenSpaceGuid.PcdUse1GPageTable ## SOMETIMES_CONSUMES
117 gEfiMdeModulePkgTokenSpaceGuid.PcdPteMemoryEncryptionAddressOrMask ## CONSUMES
118 gEfiMdeModulePkgTokenSpaceGuid.PcdNullPointerDetectionPropertyMask ## CONSUMES
119 gEfiMdeModulePkgTokenSpaceGuid.PcdHeapGuardPropertyMask ## CONSUMES
120 gEfiMdeModulePkgTokenSpaceGuid.PcdCpuStackGuard ## CONSUMES
121 gEfiMdeModulePkgTokenSpaceGuid.PcdUse5LevelPageTable ## SOMETIMES_CONSUMES
122 gEfiMdeModulePkgTokenSpaceGuid.PcdGhcbBase ## CONSUMES
123 gEfiMdeModulePkgTokenSpaceGuid.PcdGhcbSize ## CONSUMES
125 [Pcd.IA32,Pcd.X64,Pcd.ARM,Pcd.AARCH64]
126 gEfiMdeModulePkgTokenSpaceGuid.PcdSetNxForStack ## SOMETIMES_CONSUMES
127 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeNxMemoryProtectionPolicy ## SOMETIMES_CONSUMES
128 gEfiMdeModulePkgTokenSpaceGuid.PcdImageProtectionPolicy ## SOMETIMES_CONSUMES
131 gEfiPeiLoadFilePpiGuid AND gEfiPeiMasterBootModePpiGuid
135 # S3_RESUME ## SOMETIMES_CONSUMES
136 # RECOVERY_FULL ## SOMETIMES_CONSUMES
140 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # MEMORY_ALLOCATION_MODULE for DxeCore
141 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # New Stack HoB
142 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # Old Stack HOB
145 # MEMORY_ALLOCATION ## SOMETIMES_PRODUCES # MEMORY_ALLOCATION_BSP_STORE
148 [UserExtensions.TianoCore."ExtraFiles"]