]> git.proxmox.com Git - mirror_edk2.git/blame - UefiPayloadPkg/UefiPayloadPkg.dsc
UefiPayloadPkg: consume the BootManagerMenuFile HOB
[mirror_edk2.git] / UefiPayloadPkg / UefiPayloadPkg.dsc
CommitLineData
04af8bf2
DG
1## @file\r
2# Bootloader Payload Package\r
3#\r
4# Provides drivers and definitions to create uefi payload for bootloaders.\r
5#\r
08c65f7c 6# Copyright (c) 2014 - 2021, Intel Corporation. All rights reserved.<BR>\r
d49fe0ca 7# Copyright (c) Microsoft Corporation.\r
04af8bf2
DG
8# SPDX-License-Identifier: BSD-2-Clause-Patent\r
9#\r
10##\r
11\r
12################################################################################\r
13#\r
14# Defines Section - statements that will be processed to create a Makefile.\r
15#\r
16################################################################################\r
17[Defines]\r
18 PLATFORM_NAME = UefiPayloadPkg\r
19 PLATFORM_GUID = F71608AB-D63D-4491-B744-A99998C8CD96\r
20 PLATFORM_VERSION = 0.1\r
21 DSC_SPECIFICATION = 0x00010005\r
22 SUPPORTED_ARCHITECTURES = IA32|X64\r
23 BUILD_TARGETS = DEBUG|RELEASE|NOOPT\r
24 SKUID_IDENTIFIER = DEFAULT\r
25 OUTPUT_DIRECTORY = Build/UefiPayloadPkgX64\r
26 FLASH_DEFINITION = UefiPayloadPkg/UefiPayloadPkg.fdf\r
27\r
28 DEFINE SOURCE_DEBUG_ENABLE = FALSE\r
33a32936 29 DEFINE PS2_KEYBOARD_ENABLE = FALSE\r
82f727c4 30 DEFINE UNIVERSAL_PAYLOAD = FALSE\r
04af8bf2
DG
31\r
32 #\r
33 # SBL: UEFI payload for Slim Bootloader\r
34 # COREBOOT: UEFI payload for coreboot\r
35 #\r
36 DEFINE BOOTLOADER = SBL\r
37\r
38 #\r
39 # CPU options\r
40 #\r
41 DEFINE MAX_LOGICAL_PROCESSORS = 64\r
42\r
43 #\r
44 # PCI options\r
45 #\r
3900a63e 46 DEFINE PCIE_BASE_SUPPORT = TRUE\r
04af8bf2
DG
47\r
48 #\r
49 # Serial port set up\r
50 #\r
51 DEFINE BAUD_RATE = 115200\r
52 DEFINE SERIAL_CLOCK_RATE = 1843200\r
53 DEFINE SERIAL_LINE_CONTROL = 3 # 8-bits, no parity\r
54 DEFINE SERIAL_HARDWARE_FLOW_CONTROL = FALSE\r
55 DEFINE SERIAL_DETECT_CABLE = FALSE\r
56 DEFINE SERIAL_FIFO_CONTROL = 7 # Enable FIFO\r
57 DEFINE SERIAL_EXTENDED_TX_FIFO_SIZE = 16\r
58 DEFINE UART_DEFAULT_BAUD_RATE = $(BAUD_RATE)\r
59 DEFINE UART_DEFAULT_DATA_BITS = 8\r
60 DEFINE UART_DEFAULT_PARITY = 1\r
61 DEFINE UART_DEFAULT_STOP_BITS = 1\r
62 DEFINE DEFAULT_TERMINAL_TYPE = 0\r
63\r
48aa2edf
PR
64 # Enabling the serial terminal will slow down the boot menu redering!\r
65 DEFINE DISABLE_SERIAL_TERMINAL = FALSE\r
66\r
04af8bf2
DG
67 #\r
68 # typedef struct {\r
69 # UINT16 VendorId; ///< Vendor ID to match the PCI device. The value 0xFFFF terminates the list of entries.\r
70 # UINT16 DeviceId; ///< Device ID to match the PCI device\r
71 # UINT32 ClockRate; ///< UART clock rate. Set to 0 for default clock rate of 1843200 Hz\r
72 # UINT64 Offset; ///< The byte offset into to the BAR\r
73 # UINT8 BarIndex; ///< Which BAR to get the UART base address\r
74 # UINT8 RegisterStride; ///< UART register stride in bytes. Set to 0 for default register stride of 1 byte.\r
75 # UINT16 ReceiveFifoDepth; ///< UART receive FIFO depth in bytes. Set to 0 for a default FIFO depth of 16 bytes.\r
76 # UINT16 TransmitFifoDepth; ///< UART transmit FIFO depth in bytes. Set to 0 for a default FIFO depth of 16 bytes.\r
77 # UINT8 Reserved[2];\r
78 # } PCI_SERIAL_PARAMETER;\r
79 #\r
80 # Vendor FFFF Device 0000 Prog Interface 1, BAR #0, Offset 0, Stride = 1, Clock 1843200 (0x1c2000)\r
81 #\r
82 # [Vendor] [Device] [----ClockRate---] [------------Offset-----------] [Bar] [Stride] [RxFifo] [TxFifo] [Rsvd] [Vendor]\r
83 DEFINE PCI_SERIAL_PARAMETERS = {0xff,0xff, 0x00,0x00, 0x0,0x20,0x1c,0x00, 0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0, 0x00, 0x01, 0x0,0x0, 0x0,0x0, 0x0,0x0, 0xff,0xff}\r
84\r
85 #\r
86 # Shell options: [BUILD_SHELL, MIN_BIN, NONE, UEFI_BIN]\r
87 #\r
88 DEFINE SHELL_TYPE = BUILD_SHELL\r
89\r
2db0ed93
ZL
90 DEFINE EMU_VARIABLE_ENABLE = TRUE\r
91 DEFINE DISABLE_RESET_SYSTEM = FALSE\r
92\r
04af8bf2
DG
93[BuildOptions]\r
94 *_*_*_CC_FLAGS = -D DISABLE_NEW_DEPRECATED_INTERFACES\r
95 GCC:*_UNIXGCC_*_CC_FLAGS = -DMDEPKG_NDEBUG\r
96 GCC:RELEASE_*_*_CC_FLAGS = -DMDEPKG_NDEBUG\r
97 INTEL:RELEASE_*_*_CC_FLAGS = /D MDEPKG_NDEBUG\r
98 MSFT:RELEASE_*_*_CC_FLAGS = /D MDEPKG_NDEBUG\r
99\r
7c4ab1c2
GD
100[BuildOptions.common.EDKII.DXE_RUNTIME_DRIVER]\r
101 GCC:*_*_*_DLINK_FLAGS = -z common-page-size=0x1000\r
102 XCODE:*_*_*_DLINK_FLAGS = -seg1addr 0x1000 -segalign 0x1000\r
103 XCODE:*_*_*_MTOC_FLAGS = -align 0x1000\r
104 CLANGPDB:*_*_*_DLINK_FLAGS = /ALIGN:4096\r
105 MSFT:*_*_*_DLINK_FLAGS = /ALIGN:4096\r
04af8bf2
DG
106\r
107################################################################################\r
108#\r
109# SKU Identification section - list of all SKU IDs supported by this Platform.\r
110#\r
111################################################################################\r
112[SkuIds]\r
113 0|DEFAULT\r
114\r
115################################################################################\r
116#\r
117# Library Class section - list of all Library Classes needed by this Platform.\r
118#\r
119################################################################################\r
08c65f7c
DB
120\r
121!include MdePkg/MdeLibs.dsc.inc\r
122\r
04af8bf2
DG
123[LibraryClasses]\r
124 #\r
125 # Entry point\r
126 #\r
04af8bf2
DG
127 DxeCoreEntryPoint|MdePkg/Library/DxeCoreEntryPoint/DxeCoreEntryPoint.inf\r
128 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf\r
129 UefiApplicationEntryPoint|MdePkg/Library/UefiApplicationEntryPoint/UefiApplicationEntryPoint.inf\r
130\r
131 #\r
132 # Basic\r
133 #\r
134 BaseLib|MdePkg/Library/BaseLib/BaseLib.inf\r
135 BaseMemoryLib|MdePkg/Library/BaseMemoryLibRepStr/BaseMemoryLibRepStr.inf\r
136 SynchronizationLib|MdePkg/Library/BaseSynchronizationLib/BaseSynchronizationLib.inf\r
137 PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf\r
138 CpuLib|MdePkg/Library/BaseCpuLib/BaseCpuLib.inf\r
139 IoLib|MdePkg/Library/BaseIoLibIntrinsic/BaseIoLibIntrinsic.inf\r
3900a63e 140!if $(PCIE_BASE_SUPPORT) == FALSE\r
04af8bf2
DG
141 PciLib|MdePkg/Library/BasePciLibCf8/BasePciLibCf8.inf\r
142 PciCf8Lib|MdePkg/Library/BasePciCf8Lib/BasePciCf8Lib.inf\r
143!else\r
144 PciLib|MdePkg/Library/BasePciLibPciExpress/BasePciLibPciExpress.inf\r
145 PciExpressLib|MdePkg/Library/BasePciExpressLib/BasePciExpressLib.inf\r
146!endif\r
3900a63e
RN
147 PciSegmentLib|MdePkg/Library/PciSegmentLibSegmentInfo/BasePciSegmentLibSegmentInfo.inf\r
148 PciSegmentInfoLib|UefiPayloadPkg/Library/PciSegmentInfoLibAcpiBoardInfo/PciSegmentInfoLibAcpiBoardInfo.inf\r
04af8bf2
DG
149 PeCoffLib|MdePkg/Library/BasePeCoffLib/BasePeCoffLib.inf\r
150 PeCoffGetEntryPointLib|MdePkg/Library/BasePeCoffGetEntryPointLib/BasePeCoffGetEntryPointLib.inf\r
151 CacheMaintenanceLib|MdePkg/Library/BaseCacheMaintenanceLib/BaseCacheMaintenanceLib.inf\r
6d95eff8 152 SafeIntLib|MdePkg/Library/BaseSafeIntLib/BaseSafeIntLib.inf\r
82f727c4
ZL
153 DxeHobListLib|UefiPayloadPkg/Library/DxeHobListLib/DxeHobListLib.inf\r
154\r
155!if $(UNIVERSAL_PAYLOAD) == TRUE\r
156 HobLib|UefiPayloadPkg/Library/DxeHobLib/DxeHobLib.inf\r
157!else\r
158 HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf\r
159!endif\r
04af8bf2
DG
160\r
161 #\r
162 # UEFI & PI\r
163 #\r
164 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf\r
165 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf\r
166 UefiRuntimeLib|MdePkg/Library/UefiRuntimeLib/UefiRuntimeLib.inf\r
167 UefiLib|MdePkg/Library/UefiLib/UefiLib.inf\r
168 UefiHiiServicesLib|MdeModulePkg/Library/UefiHiiServicesLib/UefiHiiServicesLib.inf\r
169 HiiLib|MdeModulePkg/Library/UefiHiiLib/UefiHiiLib.inf\r
170 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf\r
171 UefiDecompressLib|MdePkg/Library/BaseUefiDecompressLib/BaseUefiDecompressLib.inf\r
04af8bf2
DG
172 DxeServicesLib|MdePkg/Library/DxeServicesLib/DxeServicesLib.inf\r
173 DxeServicesTableLib|MdePkg/Library/DxeServicesTableLib/DxeServicesTableLib.inf\r
174 UefiCpuLib|UefiCpuPkg/Library/BaseUefiCpuLib/BaseUefiCpuLib.inf\r
175 SortLib|MdeModulePkg/Library/UefiSortLib/UefiSortLib.inf\r
176\r
177 #\r
178 # Generic Modules\r
179 #\r
180 UefiUsbLib|MdePkg/Library/UefiUsbLib/UefiUsbLib.inf\r
181 UefiScsiLib|MdePkg/Library/UefiScsiLib/UefiScsiLib.inf\r
182 OemHookStatusCodeLib|MdeModulePkg/Library/OemHookStatusCodeLibNull/OemHookStatusCodeLibNull.inf\r
183 CapsuleLib|MdeModulePkg/Library/DxeCapsuleLibNull/DxeCapsuleLibNull.inf\r
184 SecurityManagementLib|MdeModulePkg/Library/DxeSecurityManagementLib/DxeSecurityManagementLib.inf\r
185 UefiBootManagerLib|MdeModulePkg/Library/UefiBootManagerLib/UefiBootManagerLib.inf\r
186 CustomizedDisplayLib|MdeModulePkg/Library/CustomizedDisplayLib/CustomizedDisplayLib.inf\r
187 FrameBufferBltLib|MdeModulePkg/Library/FrameBufferBltLib/FrameBufferBltLib.inf\r
188\r
189 #\r
190 # CPU\r
191 #\r
192 MtrrLib|UefiCpuPkg/Library/MtrrLib/MtrrLib.inf\r
193 LocalApicLib|UefiCpuPkg/Library/BaseXApicX2ApicLib/BaseXApicX2ApicLib.inf\r
83c7f817 194 MicrocodeLib|UefiCpuPkg/Library/MicrocodeLib/MicrocodeLib.inf\r
04af8bf2
DG
195\r
196 #\r
197 # Platform\r
198 #\r
199 TimerLib|UefiPayloadPkg/Library/AcpiTimerLib/AcpiTimerLib.inf\r
200 ResetSystemLib|UefiPayloadPkg/Library/ResetSystemLib/ResetSystemLib.inf\r
201 SerialPortLib|MdeModulePkg/Library/BaseSerialPortLib16550/BaseSerialPortLib16550.inf\r
6b69f73b
ZL
202!if $(UNIVERSAL_PAYLOAD) == TRUE\r
203 PlatformHookLib|UefiPayloadPkg/Library/UniversalPayloadPlatformHookLib/PlatformHookLib.inf\r
204!else\r
04af8bf2 205 PlatformHookLib|UefiPayloadPkg/Library/PlatformHookLib/PlatformHookLib.inf\r
6b69f73b 206!endif\r
04af8bf2
DG
207 PlatformBootManagerLib|UefiPayloadPkg/Library/PlatformBootManagerLib/PlatformBootManagerLib.inf\r
208 IoApicLib|PcAtChipsetPkg/Library/BaseIoApicLib/BaseIoApicLib.inf\r
209\r
210 #\r
211 # Misc\r
212 #\r
213 DebugPrintErrorLevelLib|MdePkg/Library/BaseDebugPrintErrorLevelLib/BaseDebugPrintErrorLevelLib.inf\r
214 PerformanceLib|MdePkg/Library/BasePerformanceLibNull/BasePerformanceLibNull.inf\r
215!if $(SOURCE_DEBUG_ENABLE) == TRUE\r
216 PeCoffExtraActionLib|SourceLevelDebugPkg/Library/PeCoffExtraActionLibDebug/PeCoffExtraActionLibDebug.inf\r
217 DebugCommunicationLib|SourceLevelDebugPkg/Library/DebugCommunicationLibSerialPort/DebugCommunicationLibSerialPort.inf\r
218!else\r
219 PeCoffExtraActionLib|MdePkg/Library/BasePeCoffExtraActionLibNull/BasePeCoffExtraActionLibNull.inf\r
220 DebugAgentLib|MdeModulePkg/Library/DebugAgentLibNull/DebugAgentLibNull.inf\r
221!endif\r
222 PlatformSupportLib|UefiPayloadPkg/Library/PlatformSupportLibNull/PlatformSupportLibNull.inf\r
6b69f73b
ZL
223!if $(UNIVERSAL_PAYLOAD) == FALSE\r
224 !if $(BOOTLOADER) == "COREBOOT"\r
225 BlParseLib|UefiPayloadPkg/Library/CbParseLib/CbParseLib.inf\r
226 !else\r
227 BlParseLib|UefiPayloadPkg/Library/SblParseLib/SblParseLib.inf\r
228 !endif\r
04af8bf2
DG
229!endif\r
230\r
231 DebugLib|MdePkg/Library/BaseDebugLibSerialPort/BaseDebugLibSerialPort.inf\r
232 LockBoxLib|MdeModulePkg/Library/LockBoxNullLib/LockBoxNullLib.inf\r
233 FileExplorerLib|MdeModulePkg/Library/FileExplorerLib/FileExplorerLib.inf\r
234 AuthVariableLib|MdeModulePkg/Library/AuthVariableLibNull/AuthVariableLibNull.inf\r
235 TpmMeasurementLib|MdeModulePkg/Library/TpmMeasurementLibNull/TpmMeasurementLibNull.inf\r
236 VarCheckLib|MdeModulePkg/Library/VarCheckLib/VarCheckLib.inf\r
d49fe0ca
BB
237 VariablePolicyLib|MdeModulePkg/Library/VariablePolicyLib/VariablePolicyLib.inf\r
238 VariablePolicyHelperLib|MdeModulePkg/Library/VariablePolicyHelperLib/VariablePolicyHelperLib.inf\r
04af8bf2 239\r
7c4ab1c2 240[LibraryClasses.common.SEC]\r
82f727c4 241 HobLib|UefiPayloadPkg/Library/PayloadEntryHobLib/HobLib.inf\r
04af8bf2 242 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf\r
82f727c4 243 DxeHobListLib|UefiPayloadPkg/Library/DxeHobListLibNull/DxeHobListLibNull.inf\r
04af8bf2
DG
244\r
245[LibraryClasses.common.DXE_CORE]\r
82f727c4 246 DxeHobListLib|UefiPayloadPkg/Library/DxeHobListLibNull/DxeHobListLibNull.inf\r
04af8bf2
DG
247 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf\r
248 HobLib|MdePkg/Library/DxeCoreHobLib/DxeCoreHobLib.inf\r
249 MemoryAllocationLib|MdeModulePkg/Library/DxeCoreMemoryAllocationLib/DxeCoreMemoryAllocationLib.inf\r
250 ExtractGuidedSectionLib|MdePkg/Library/DxeExtractGuidedSectionLib/DxeExtractGuidedSectionLib.inf\r
251 ReportStatusCodeLib|MdeModulePkg/Library/DxeReportStatusCodeLib/DxeReportStatusCodeLib.inf\r
252!if $(SOURCE_DEBUG_ENABLE)\r
253 DebugAgentLib|SourceLevelDebugPkg/Library/DebugAgent/DxeDebugAgentLib.inf\r
254!endif\r
255 CpuExceptionHandlerLib|UefiCpuPkg/Library/CpuExceptionHandlerLib/DxeCpuExceptionHandlerLib.inf\r
3a4a6ead 256 VmgExitLib|UefiCpuPkg/Library/VmgExitLibNull/VmgExitLibNull.inf\r
04af8bf2
DG
257\r
258[LibraryClasses.common.DXE_DRIVER]\r
259 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf\r
04af8bf2
DG
260 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf\r
261 ExtractGuidedSectionLib|MdePkg/Library/DxeExtractGuidedSectionLib/DxeExtractGuidedSectionLib.inf\r
262 ReportStatusCodeLib|MdeModulePkg/Library/DxeReportStatusCodeLib/DxeReportStatusCodeLib.inf\r
263!if $(SOURCE_DEBUG_ENABLE)\r
264 DebugAgentLib|SourceLevelDebugPkg/Library/DebugAgent/DxeDebugAgentLib.inf\r
265!endif\r
266 CpuExceptionHandlerLib|UefiCpuPkg/Library/CpuExceptionHandlerLib/DxeCpuExceptionHandlerLib.inf\r
267 MpInitLib|UefiCpuPkg/Library/MpInitLib/DxeMpInitLib.inf\r
3a4a6ead 268 VmgExitLib|UefiCpuPkg/Library/VmgExitLibNull/VmgExitLibNull.inf\r
04af8bf2
DG
269\r
270[LibraryClasses.common.DXE_RUNTIME_DRIVER]\r
271 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf\r
04af8bf2
DG
272 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf\r
273 ReportStatusCodeLib|MdeModulePkg/Library/RuntimeDxeReportStatusCodeLib/RuntimeDxeReportStatusCodeLib.inf\r
d49fe0ca 274 VariablePolicyLib|MdeModulePkg/Library/VariablePolicyLib/VariablePolicyLibRuntimeDxe.inf\r
04af8bf2
DG
275\r
276[LibraryClasses.common.UEFI_DRIVER,LibraryClasses.common.UEFI_APPLICATION]\r
277 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf\r
278 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf\r
279 ReportStatusCodeLib|MdeModulePkg/Library/DxeReportStatusCodeLib/DxeReportStatusCodeLib.inf\r
04af8bf2
DG
280\r
281################################################################################\r
282#\r
283# Pcd Section - list of all EDK II PCD Entries defined by this Platform.\r
284#\r
285################################################################################\r
286[PcdsFeatureFlag]\r
04af8bf2
DG
287 gEfiMdeModulePkgTokenSpaceGuid.PcdDxeIplSwitchToLongMode|TRUE\r
288 gEfiMdeModulePkgTokenSpaceGuid.PcdConOutGopSupport|TRUE\r
289 gEfiMdeModulePkgTokenSpaceGuid.PcdConOutUgaSupport|FALSE\r
3eb72b30
ZL
290 ## This PCD specified whether ACPI SDT protocol is installed.\r
291 gEfiMdeModulePkgTokenSpaceGuid.PcdInstallAcpiSdtProtocol|TRUE\r
04af8bf2
DG
292\r
293[PcdsFixedAtBuild]\r
294 gEfiMdeModulePkgTokenSpaceGuid.PcdMaxVariableSize|0x10000\r
295 gEfiMdeModulePkgTokenSpaceGuid.PcdMaxHardwareErrorVariableSize|0x8000\r
296 gEfiMdeModulePkgTokenSpaceGuid.PcdVariableStoreSize|0x10000\r
297 #\r
298 # Make VariableRuntimeDxe work at emulated non-volatile variable mode.\r
299 #\r
300 gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvModeEnable|TRUE\r
301\r
302 gEfiMdeModulePkgTokenSpaceGuid.PcdVpdBaseAddress|0x0\r
763e0f0a
MT
303!if $(TARGET) == DEBUG\r
304 gEfiMdeModulePkgTokenSpaceGuid.PcdStatusCodeUseSerial|TRUE\r
305!else\r
306 gEfiMdeModulePkgTokenSpaceGuid.PcdStatusCodeUseSerial|FALSE\r
307!endif\r
308 gEfiMdeModulePkgTokenSpaceGuid.PcdStatusCodeUseMemory|FALSE\r
04af8bf2 309 gEfiMdeModulePkgTokenSpaceGuid.PcdUse1GPageTable|TRUE\r
04af8bf2 310\r
27cb64ff 311 gUefiPayloadPkgTokenSpaceGuid.PcdPcdDriverFile|{ 0x57, 0x72, 0xcf, 0x80, 0xab, 0x87, 0xf9, 0x47, 0xa3, 0xfe, 0xD5, 0x0B, 0x76, 0xd8, 0x95, 0x41 }\r
04af8bf2
DG
312\r
313!if $(SOURCE_DEBUG_ENABLE)\r
314 gEfiSourceLevelDebugPkgTokenSpaceGuid.PcdDebugLoadImageMethod|0x2\r
315!endif\r
316\r
317[PcdsPatchableInModule.common]\r
19a541d7 318 gEfiMdeModulePkgTokenSpaceGuid.PcdBootManagerMenuFile|{ 0x21, 0xaa, 0x2c, 0x46, 0x14, 0x76, 0x03, 0x45, 0x83, 0x6e, 0x8a, 0xb6, 0xf4, 0x66, 0x23, 0x31 }\r
04af8bf2
DG
319 gEfiMdePkgTokenSpaceGuid.PcdReportStatusCodePropertyMask|0x7\r
320 gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x8000004F\r
321!if $(SOURCE_DEBUG_ENABLE)\r
322 gEfiMdePkgTokenSpaceGuid.PcdDebugPropertyMask|0x17\r
323!else\r
324 gEfiMdePkgTokenSpaceGuid.PcdDebugPropertyMask|0x2F\r
325!endif\r
326\r
327 #\r
328 # The following parameters are set by Library/PlatformHookLib\r
329 #\r
330 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialUseMmio|FALSE\r
317d84ab 331 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterBase|0\r
04af8bf2
DG
332 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialBaudRate|$(BAUD_RATE)\r
333 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialRegisterStride|1\r
334\r
335 #\r
336 # Enable these parameters to be set on the command line\r
337 #\r
338 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialClockRate|$(SERIAL_CLOCK_RATE)\r
339 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialLineControl|$(SERIAL_LINE_CONTROL)\r
340 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialUseHardwareFlowControl|$(SERIAL_HARDWARE_FLOW_CONTROL)\r
341 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialDetectCable|$(SERIAL_DETECT_CABLE)\r
342 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialFifoControl|$(SERIAL_FIFO_CONTROL)\r
343 gEfiMdeModulePkgTokenSpaceGuid.PcdSerialExtendedTxFifoSize|$(SERIAL_EXTENDED_TX_FIFO_SIZE)\r
344\r
04af8bf2
DG
345 gEfiMdePkgTokenSpaceGuid.PcdUartDefaultBaudRate|$(UART_DEFAULT_BAUD_RATE)\r
346 gEfiMdePkgTokenSpaceGuid.PcdUartDefaultDataBits|$(UART_DEFAULT_DATA_BITS)\r
347 gEfiMdePkgTokenSpaceGuid.PcdUartDefaultParity|$(UART_DEFAULT_PARITY)\r
348 gEfiMdePkgTokenSpaceGuid.PcdUartDefaultStopBits|$(UART_DEFAULT_STOP_BITS)\r
349 gEfiMdePkgTokenSpaceGuid.PcdDefaultTerminalType|$(DEFAULT_TERMINAL_TYPE)\r
350 gEfiMdeModulePkgTokenSpaceGuid.PcdPciSerialParameters|$(PCI_SERIAL_PARAMETERS)\r
351\r
352 gUefiCpuPkgTokenSpaceGuid.PcdCpuMaxLogicalProcessorNumber|$(MAX_LOGICAL_PROCESSORS)\r
353\r
354\r
355################################################################################\r
356#\r
fa24b6ed 357# Pcd DynamicEx Section - list of all EDK II PCD Entries defined by this Platform\r
04af8bf2
DG
358#\r
359################################################################################\r
360\r
fa24b6ed 361[PcdsDynamicExDefault]\r
caa139fe 362 gEfiMdeModulePkgTokenSpaceGuid.PcdResetOnMemoryTypeInformationChange|FALSE\r
04af8bf2
DG
363 gEfiMdeModulePkgTokenSpaceGuid.PcdEmuVariableNvStoreReserved|0\r
364 gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageVariableBase64|0\r
365 gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwWorkingBase|0\r
366 gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwSpareBase|0\r
367 gEfiMdePkgTokenSpaceGuid.PcdPlatformBootTimeOut|3\r
368\r
369 ## This PCD defines the video horizontal resolution.\r
370 # This PCD could be set to 0 then video resolution could be at highest resolution.\r
371 gEfiMdeModulePkgTokenSpaceGuid.PcdVideoHorizontalResolution|0\r
372 ## This PCD defines the video vertical resolution.\r
373 # This PCD could be set to 0 then video resolution could be at highest resolution.\r
374 gEfiMdeModulePkgTokenSpaceGuid.PcdVideoVerticalResolution|0\r
375\r
376 ## The PCD is used to specify the video horizontal resolution of text setup.\r
377 gEfiMdeModulePkgTokenSpaceGuid.PcdSetupVideoHorizontalResolution|0\r
378 ## The PCD is used to specify the video vertical resolution of text setup.\r
379 gEfiMdeModulePkgTokenSpaceGuid.PcdSetupVideoVerticalResolution|0\r
380\r
381 gEfiMdeModulePkgTokenSpaceGuid.PcdConOutRow|31\r
382 gEfiMdeModulePkgTokenSpaceGuid.PcdConOutColumn|100\r
3900a63e 383 gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0\r
8028b290 384 gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseSize|0\r
fa24b6ed
ZL
385 gEfiMdeModulePkgTokenSpaceGuid.PcdGhcbBase|0\r
386 gEfiMdeModulePkgTokenSpaceGuid.PcdTestKeyUsed|FALSE\r
387 gUefiCpuPkgTokenSpaceGuid.PcdSevEsIsEnabled|0\r
99de2e7e 388 gEfiMdeModulePkgTokenSpaceGuid.PcdPciDisableBusEnumeration|TRUE\r
04af8bf2
DG
389\r
390################################################################################\r
391#\r
392# Components Section - list of all EDK II Modules needed by this Platform.\r
393#\r
394################################################################################\r
04af8bf2 395\r
7c4ab1c2
GD
396!if "IA32" in $(ARCH)\r
397 [Components.IA32]\r
6b69f73b
ZL
398 !if $(UNIVERSAL_PAYLOAD) == TRUE\r
399 UefiPayloadPkg/UefiPayloadEntry/UniversalPayloadEntry.inf\r
400 !else\r
7c4ab1c2 401 UefiPayloadPkg/UefiPayloadEntry/UefiPayloadEntry.inf\r
6b69f73b 402 !endif\r
7c4ab1c2
GD
403!else\r
404 [Components.X64]\r
6b69f73b
ZL
405 !if $(UNIVERSAL_PAYLOAD) == TRUE\r
406 UefiPayloadPkg/UefiPayloadEntry/UniversalPayloadEntry.inf\r
407 !else\r
7c4ab1c2 408 UefiPayloadPkg/UefiPayloadEntry/UefiPayloadEntry.inf\r
6b69f73b 409 !endif\r
7c4ab1c2 410!endif\r
04af8bf2
DG
411\r
412[Components.X64]\r
413 #\r
414 # DXE Core\r
415 #\r
416 MdeModulePkg/Core/Dxe/DxeMain.inf {\r
417 <LibraryClasses>\r
418 NULL|MdeModulePkg/Library/LzmaCustomDecompressLib/LzmaCustomDecompressLib.inf\r
419 }\r
420\r
421 #\r
422 # Components that produce the architectural protocols\r
423 #\r
424 MdeModulePkg/Universal/SecurityStubDxe/SecurityStubDxe.inf\r
425 UefiCpuPkg/CpuDxe/CpuDxe.inf\r
426 MdeModulePkg/Universal/BdsDxe/BdsDxe.inf\r
427 MdeModulePkg/Application/UiApp/UiApp.inf {\r
428 <LibraryClasses>\r
429 NULL|MdeModulePkg/Library/DeviceManagerUiLib/DeviceManagerUiLib.inf\r
430 NULL|MdeModulePkg/Library/BootManagerUiLib/BootManagerUiLib.inf\r
431 NULL|MdeModulePkg/Library/BootMaintenanceManagerUiLib/BootMaintenanceManagerUiLib.inf\r
432 }\r
433\r
434 PcAtChipsetPkg/HpetTimerDxe/HpetTimerDxe.inf\r
435 MdeModulePkg/Universal/Metronome/Metronome.inf\r
436 MdeModulePkg/Universal/WatchdogTimerDxe/WatchdogTimer.inf\r
437 MdeModulePkg/Core/RuntimeDxe/RuntimeDxe.inf\r
438 MdeModulePkg/Universal/CapsuleRuntimeDxe/CapsuleRuntimeDxe.inf\r
439 MdeModulePkg/Universal/MonotonicCounterRuntimeDxe/MonotonicCounterRuntimeDxe.inf\r
2db0ed93 440!if $(DISABLE_RESET_SYSTEM) == FALSE\r
04af8bf2 441 MdeModulePkg/Universal/ResetSystemRuntimeDxe/ResetSystemRuntimeDxe.inf\r
2db0ed93 442!endif\r
04af8bf2 443 PcAtChipsetPkg/PcatRealTimeClockRuntimeDxe/PcatRealTimeClockRuntimeDxe.inf\r
2db0ed93 444!if $(EMU_VARIABLE_ENABLE) == TRUE\r
04af8bf2 445 MdeModulePkg/Universal/Variable/RuntimeDxe/VariableRuntimeDxe.inf\r
2db0ed93 446!endif\r
04af8bf2
DG
447 #\r
448 # Following are the DXE drivers\r
449 #\r
450 MdeModulePkg/Universal/PCD/Dxe/Pcd.inf {\r
451 <LibraryClasses>\r
452 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf\r
453 }\r
454\r
455 MdeModulePkg/Universal/ReportStatusCodeRouter/RuntimeDxe/ReportStatusCodeRouterRuntimeDxe.inf\r
456 MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/StatusCodeHandlerRuntimeDxe.inf\r
457 UefiCpuPkg/CpuIo2Dxe/CpuIo2Dxe.inf\r
458 MdeModulePkg/Universal/DevicePathDxe/DevicePathDxe.inf\r
459 MdeModulePkg/Universal/MemoryTest/NullMemoryTestDxe/NullMemoryTestDxe.inf\r
04af8bf2
DG
460 MdeModulePkg/Universal/HiiDatabaseDxe/HiiDatabaseDxe.inf\r
461 MdeModulePkg/Universal/SetupBrowserDxe/SetupBrowserDxe.inf\r
462 MdeModulePkg/Universal/DisplayEngineDxe/DisplayEngineDxe.inf\r
463\r
464 UefiPayloadPkg/BlSupportDxe/BlSupportDxe.inf\r
465\r
466 #\r
467 # SMBIOS Support\r
468 #\r
469 MdeModulePkg/Universal/SmbiosDxe/SmbiosDxe.inf\r
470\r
471 #\r
472 # ACPI Support\r
473 #\r
474 MdeModulePkg/Universal/Acpi/AcpiTableDxe/AcpiTableDxe.inf\r
475\r
476 #\r
477 # PCI Support\r
478 #\r
479 MdeModulePkg/Bus/Pci/PciBusDxe/PciBusDxe.inf\r
480 MdeModulePkg/Bus/Pci/PciHostBridgeDxe/PciHostBridgeDxe.inf {\r
481 <LibraryClasses>\r
482 PciHostBridgeLib|UefiPayloadPkg/Library/PciHostBridgeLib/PciHostBridgeLib.inf\r
483 }\r
484\r
485 #\r
486 # SCSI/ATA/IDE/DISK Support\r
487 #\r
488 MdeModulePkg/Universal/Disk/DiskIoDxe/DiskIoDxe.inf\r
489 MdeModulePkg/Universal/Disk/PartitionDxe/PartitionDxe.inf\r
490 MdeModulePkg/Universal/Disk/UnicodeCollation/EnglishDxe/EnglishDxe.inf\r
491 FatPkg/EnhancedFatDxe/Fat.inf\r
492 MdeModulePkg/Bus/Pci/SataControllerDxe/SataControllerDxe.inf\r
493 MdeModulePkg/Bus/Ata/AtaBusDxe/AtaBusDxe.inf\r
494 MdeModulePkg/Bus/Ata/AtaAtapiPassThru/AtaAtapiPassThru.inf\r
495 MdeModulePkg/Bus/Scsi/ScsiBusDxe/ScsiBusDxe.inf\r
496 MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf\r
cf4cbe19 497 MdeModulePkg/Bus/Pci/NvmExpressDxe/NvmExpressDxe.inf\r
04af8bf2
DG
498\r
499 #\r
500 # SD/eMMC Support\r
501 #\r
502 MdeModulePkg/Bus/Pci/SdMmcPciHcDxe/SdMmcPciHcDxe.inf\r
503 MdeModulePkg/Bus/Sd/EmmcDxe/EmmcDxe.inf\r
504 MdeModulePkg/Bus/Sd/SdDxe/SdDxe.inf\r
505\r
506 #\r
507 # Usb Support\r
508 #\r
509 MdeModulePkg/Bus/Pci/UhciDxe/UhciDxe.inf\r
510 MdeModulePkg/Bus/Pci/EhciDxe/EhciDxe.inf\r
511 MdeModulePkg/Bus/Pci/XhciDxe/XhciDxe.inf\r
512 MdeModulePkg/Bus/Usb/UsbBusDxe/UsbBusDxe.inf\r
513 MdeModulePkg/Bus/Usb/UsbKbDxe/UsbKbDxe.inf\r
514 MdeModulePkg/Bus/Usb/UsbMassStorageDxe/UsbMassStorageDxe.inf\r
515\r
516 #\r
517 # ISA Support\r
518 #\r
519 MdeModulePkg/Universal/SerialDxe/SerialDxe.inf\r
33a32936
DG
520!if $(PS2_KEYBOARD_ENABLE) == TRUE\r
521 OvmfPkg/SioBusDxe/SioBusDxe.inf\r
522 MdeModulePkg/Bus/Isa/Ps2KeyboardDxe/Ps2KeyboardDxe.inf\r
523!endif\r
04af8bf2
DG
524\r
525 #\r
526 # Console Support\r
527 #\r
528 MdeModulePkg/Universal/Console/ConPlatformDxe/ConPlatformDxe.inf\r
529 MdeModulePkg/Universal/Console/ConSplitterDxe/ConSplitterDxe.inf\r
530 MdeModulePkg/Universal/Console/GraphicsConsoleDxe/GraphicsConsoleDxe.inf\r
d9a40845 531!if $(DISABLE_SERIAL_TERMINAL) == FALSE\r
04af8bf2 532 MdeModulePkg/Universal/Console/TerminalDxe/TerminalDxe.inf\r
d9a40845 533!endif\r
04af8bf2
DG
534 UefiPayloadPkg/GraphicsOutputDxe/GraphicsOutputDxe.inf\r
535\r
536 #------------------------------\r
537 # Build the shell\r
538 #------------------------------\r
539\r
540!if $(SHELL_TYPE) == BUILD_SHELL\r
541\r
542 #\r
543 # Shell Lib\r
544 #\r
545[LibraryClasses]\r
546 BcfgCommandLib|ShellPkg/Library/UefiShellBcfgCommandLib/UefiShellBcfgCommandLib.inf\r
547 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf\r
548 FileHandleLib|MdePkg/Library/UefiFileHandleLib/UefiFileHandleLib.inf\r
549 ShellLib|ShellPkg/Library/UefiShellLib/UefiShellLib.inf\r
005a5f2d 550 !include NetworkPkg/NetworkLibs.dsc.inc\r
04af8bf2
DG
551\r
552[Components.X64]\r
553 ShellPkg/DynamicCommand/TftpDynamicCommand/TftpDynamicCommand.inf {\r
554 <PcdsFixedAtBuild>\r
555 ## This flag is used to control initialization of the shell library\r
556 # This should be FALSE for compiling the dynamic command.\r
557 gEfiShellPkgTokenSpaceGuid.PcdShellLibAutoInitialize|FALSE\r
558 }\r
559 ShellPkg/DynamicCommand/DpDynamicCommand/DpDynamicCommand.inf {\r
560 <PcdsFixedAtBuild>\r
561 ## This flag is used to control initialization of the shell library\r
562 # This should be FALSE for compiling the dynamic command.\r
563 gEfiShellPkgTokenSpaceGuid.PcdShellLibAutoInitialize|FALSE\r
564 }\r
565 ShellPkg/Application/Shell/Shell.inf {\r
566 <PcdsFixedAtBuild>\r
567 ## This flag is used to control initialization of the shell library\r
568 # This should be FALSE for compiling the shell application itself only.\r
569 gEfiShellPkgTokenSpaceGuid.PcdShellLibAutoInitialize|FALSE\r
570\r
571 #------------------------------\r
572 # Basic commands\r
573 #------------------------------\r
574\r
575 <LibraryClasses>\r
576 NULL|ShellPkg/Library/UefiShellLevel1CommandsLib/UefiShellLevel1CommandsLib.inf\r
577 NULL|ShellPkg/Library/UefiShellLevel2CommandsLib/UefiShellLevel2CommandsLib.inf\r
578 NULL|ShellPkg/Library/UefiShellLevel3CommandsLib/UefiShellLevel3CommandsLib.inf\r
579 NULL|ShellPkg/Library/UefiShellDriver1CommandsLib/UefiShellDriver1CommandsLib.inf\r
580 NULL|ShellPkg/Library/UefiShellInstall1CommandsLib/UefiShellInstall1CommandsLib.inf\r
581 NULL|ShellPkg/Library/UefiShellDebug1CommandsLib/UefiShellDebug1CommandsLib.inf\r
582\r
583 #------------------------------\r
584 # Networking commands\r
585 #------------------------------\r
586\r
587 <LibraryClasses>\r
588 NULL|ShellPkg/Library/UefiShellNetwork1CommandsLib/UefiShellNetwork1CommandsLib.inf\r
589\r
590 #------------------------------\r
591 # Support libraries\r
592 #------------------------------\r
593\r
594 <LibraryClasses>\r
595 DebugLib|MdePkg/Library/UefiDebugLibConOut/UefiDebugLibConOut.inf\r
596 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf\r
597 HandleParsingLib|ShellPkg/Library/UefiHandleParsingLib/UefiHandleParsingLib.inf\r
ef03e726 598 OrderedCollectionLib|MdePkg/Library/BaseOrderedCollectionRedBlackTreeLib/BaseOrderedCollectionRedBlackTreeLib.inf\r
04af8bf2
DG
599 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf\r
600 ShellCEntryLib|ShellPkg/Library/UefiShellCEntryLib/UefiShellCEntryLib.inf\r
601 ShellCommandLib|ShellPkg/Library/UefiShellCommandLib/UefiShellCommandLib.inf\r
602 SortLib|MdeModulePkg/Library/UefiSortLib/UefiSortLib.inf\r
603 }\r
604\r
605!endif\r