]> git.proxmox.com Git - mirror_edk2.git/blob - EmbeddedPkg/EmbeddedPkg.dsc
76c5ced38692f8cefbd85800e7bc56739580b063
[mirror_edk2.git] / EmbeddedPkg / EmbeddedPkg.dsc
1 #/** @file
2 # Embedded Package
3 #
4 #
5 # Copyright (c) 2007, Intel Corporation. All rights reserved.<BR>
6 # Copyright (c) 2012-2015, ARM Ltd. All rights reserved.<BR>
7 #
8 # This program and the accompanying materials
9 # are licensed and made available under the terms and conditions of the BSD License
10 # which accompanies this distribution. The full text of the license may be found at
11 # http://opensource.org/licenses/bsd-license.php
12 #
13 # THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
15 #
16 #**/
17
18 ################################################################################
19 #
20 # Defines Section - statements that will be processed to create a Makefile.
21 #
22 ################################################################################
23 [Defines]
24 PLATFORM_NAME = Embedded
25 PLATFORM_GUID = 8DBB580B-CF89-4D57-95C6-DFE96C44686E
26 PLATFORM_VERSION = 0.1
27 DSC_SPECIFICATION = 0x00010005
28 OUTPUT_DIRECTORY = Build/Embedded
29 SUPPORTED_ARCHITECTURES = IA32|X64|IPF|ARM|AARCH64
30 BUILD_TARGETS = DEBUG|RELEASE
31 SKUID_IDENTIFIER = DEFAULT
32 FLASH_DEFINITION = EmbeddedPkg/EmbeddedPkg.fdf
33
34
35 ################################################################################
36 #
37 # SKU Identification section - list of all SKU IDs supported by this
38 # Platform.
39 #
40 ################################################################################
41 [SkuIds]
42 0|DEFAULT # The entry: 0|DEFAULT is reserved and always required.
43
44 ################################################################################
45 #
46 # Library Class section - list of all Library Classes needed by this Platform.
47 #
48 ################################################################################
49 [LibraryClasses.common]
50 # DebugLib|MdePkg/Library/UefiDebugLibConOut/UefiDebugLibConOut.inf
51 DebugLib|MdePkg/Library/BaseDebugLibNull/BaseDebugLibNull.inf
52
53
54 BaseLib|MdePkg/Library/BaseLib/BaseLib.inf
55 BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
56 PciLib|MdePkg/Library/BasePciLibCf8/BasePciLibCf8.inf
57 PerformanceLib|MdePkg/Library/BasePerformanceLibNull/BasePerformanceLibNull.inf
58 PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf
59 UefiDecompressLib|MdePkg/Library/BaseUefiDecompressLib/BaseUefiDecompressLib.inf
60 EfiFileLib|EmbeddedPkg/Library/EfiFileLib/EfiFileLib.inf
61
62 ReportStatusCodeLib|IntelFrameworkModulePkg/Library/PeiDxeDebugLibReportStatusCode/PeiDxeDebugLibReportStatusCode.inf
63
64 PeCoffGetEntryPointLib|MdePkg/Library/BasePeCoffGetEntryPointLib/BasePeCoffGetEntryPointLib.inf
65 PeCoffLib|MdePkg/Library/BasePeCoffLib/BasePeCoffLib.inf
66 PeCoffExtraActionLib|MdePkg/Library/BasePeCoffExtraActionLibNull/BasePeCoffExtraActionLibNull.inf
67 CacheMaintenanceLib|MdePkg/Library/BaseCacheMaintenanceLib/BaseCacheMaintenanceLib.inf
68 PrePiLib|EmbeddedPkg/Library/PrePiLib/PrePiLib.inf
69
70 SerialPortLib|MdePkg/Library/BaseSerialPortLibNull/BaseSerialPortLibNull.inf
71 SerialPortExtLib|EmbeddedPkg/Library/TemplateSerialPortExtLib/TemplateSerialPortExtLib.inf
72 RealTimeClockLib|EmbeddedPkg/Library/TemplateRealTimeClockLib/TemplateRealTimeClockLib.inf
73 EfiResetSystemLib|EmbeddedPkg/Library/TemplateResetSystemLib/TemplateResetSystemLib.inf
74 GdbSerialLib|EmbeddedPkg/Library/GdbSerialLib/GdbSerialLib.inf
75
76
77 #
78 # Need to change this for IPF
79 #
80 IoLib|MdePkg/Library/BaseIoLibIntrinsic/BaseIoLibIntrinsic.inf
81
82 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf
83 UefiLib|MdePkg/Library/UefiLib/UefiLib.inf
84 HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf
85 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf
86 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf
87 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
88 ExtractGuidedSectionLib|MdePkg/Library/DxeExtractGuidedSectionLib/DxeExtractGuidedSectionLib.inf
89
90 DxeServicesTableLib|MdePkg/Library/DxeServicesTableLib/DxeServicesTableLib.inf
91 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf
92 UefiApplicationEntryPoint|MdePkg/Library/UefiApplicationEntryPoint/UefiApplicationEntryPoint.inf
93
94 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
95 EblCmdLib|EmbeddedPkg/Library/EblCmdLibNull/EblCmdLibNull.inf
96
97 EblNetworkLib|EmbeddedPkg/Library/EblNetworkLib/EblNetworkLib.inf
98
99 AcpiLib|EmbeddedPkg/Library/AcpiLib/AcpiLib.inf
100 FdtLib|EmbeddedPkg/Library/FdtLib/FdtLib.inf
101
102 # Shell libraries
103 ShellLib|ShellPkg/Library/UefiShellLib/UefiShellLib.inf
104 FileHandleLib|MdePkg/Library/UefiFileHandleLib/UefiFileHandleLib.inf
105 SortLib|MdeModulePkg/Library/UefiSortLib/UefiSortLib.inf
106
107 # Networking Requirements
108 NetLib|MdeModulePkg/Library/DxeNetLib/DxeNetLib.inf
109 HiiLib|MdeModulePkg/Library/UefiHiiLib/UefiHiiLib.inf
110 UefiHiiServicesLib|MdeModulePkg/Library/UefiHiiServicesLib/UefiHiiServicesLib.inf
111
112 [LibraryClasses.common.DXE_DRIVER]
113 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
114 ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
115
116
117 [LibraryClasses.common.UEFI_APPLICATION]
118 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
119 ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
120
121 [LibraryClasses.common.UEFI_DRIVER]
122 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
123 ReportStatusCodeLib|IntelFrameworkModulePkg/Library/DxeReportStatusCodeLibFramework/DxeReportStatusCodeLib.inf
124
125 [LibraryClasses.common.SEC]
126 ExtractGuidedSectionLib|EmbeddedPkg/Library/PrePiExtractGuidedSectionLib/PrePiExtractGuidedSectionLib.inf
127
128 [LibraryClasses.ARM, LibraryClasses.AARCH64]
129 ArmGicLib|ArmPkg/Drivers/ArmGic/ArmGicLib.inf
130 ArmSmcLib|ArmPkg/Library/ArmSmcLib/ArmSmcLib.inf
131 BdsLib|ArmPkg/Library/BdsLib/BdsLib.inf
132 SemihostLib|ArmPkg/Library/SemihostLib/SemihostLib.inf
133 NULL|ArmPkg/Library/CompilerIntrinsicsLib/CompilerIntrinsicsLib.inf
134
135 # Add support for GCC stack protector
136 NULL|MdePkg/Library/BaseStackCheckLib/BaseStackCheckLib.inf
137
138 [LibraryClasses.ARM]
139 ArmLib|ArmPkg/Library/ArmLib/ArmV7/ArmV7Lib.inf
140
141 [LibraryClasses.AARCH64]
142 ArmLib|ArmPkg/Library/ArmLib/AArch64/AArch64Lib.inf
143
144
145 ################################################################################
146 #
147 # Pcd Section - list of all PCD Entries defined by this Platform
148 #
149 ################################################################################
150
151 [PcdsFeatureFlag.common]
152 gEfiMdePkgTokenSpaceGuid.PcdComponentNameDisable|FALSE
153 gEfiMdePkgTokenSpaceGuid.PcdDriverDiagnosticsDisable|FALSE
154 gEfiMdePkgTokenSpaceGuid.PcdComponentName2Disable|FALSE
155 gEfiMdePkgTokenSpaceGuid.PcdDriverDiagnostics2Disable|FALSE
156
157 #
158 # Control what commands are supported from the UI
159 # Turn these on and off to add features or save size
160 #
161 gEmbeddedTokenSpaceGuid.PcdEmbeddedMacBoot|TRUE
162 gEmbeddedTokenSpaceGuid.PcdEmbeddedDirCmd|TRUE
163 gEmbeddedTokenSpaceGuid.PcdEmbeddedHobCmd|TRUE
164 gEmbeddedTokenSpaceGuid.PcdEmbeddedHwDebugCmd|TRUE
165 gEmbeddedTokenSpaceGuid.PcdEmbeddedIoEnable|FALSE
166 gEmbeddedTokenSpaceGuid.PcdEmbeddedScriptCmd|FALSE
167 gEmbeddedTokenSpaceGuid.PcdEmbeddedPciDebugCmd|TRUE
168
169 gEmbeddedTokenSpaceGuid.PcdPrePiProduceMemoryTypeInformationHob|FALSE
170
171
172 [PcdsFixedAtBuild.common]
173 gEfiMdePkgTokenSpaceGuid.PcdMaximumUnicodeStringLength|1000000
174 gEfiMdePkgTokenSpaceGuid.PcdMaximumAsciiStringLength|1000000
175 gEfiMdePkgTokenSpaceGuid.PcdMaximumLinkedListLength|1000000
176 gEfiMdePkgTokenSpaceGuid.PcdSpinLockTimeout|10000000
177 gEfiMdePkgTokenSpaceGuid.PcdDebugPropertyMask|0x0f
178 gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x80000000
179 gEfiMdePkgTokenSpaceGuid.PcdReportStatusCodePropertyMask|0x06
180 gEfiMdePkgTokenSpaceGuid.PcdDebugClearMemoryValue|0xAF
181 gEfiMdePkgTokenSpaceGuid.PcdPerformanceLibraryPropertyMask|0
182 gEfiMdePkgTokenSpaceGuid.PcdPostCodePropertyMask|0
183 gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0xE0000000
184 gEfiMdePkgTokenSpaceGuid.PcdFSBClock|200000000
185 gEfiMdePkgTokenSpaceGuid.PcdUefiLibMaxPrintBufferSize|320
186 gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x80000000
187 gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress|0xE0000000
188 gEfiMdePkgTokenSpaceGuid.PcdFSBClock|200000000
189 gEmbeddedTokenSpaceGuid.PcdEmbeddedAutomaticBootCommand|L""
190 gEmbeddedTokenSpaceGuid.PcdEmbeddedDefaultTextColor|0x07
191 gEmbeddedTokenSpaceGuid.PcdEmbeddedMemVariableStoreSize|0x10000
192
193 gEmbeddedTokenSpaceGuid.PcdPrePiHobBase|0
194 gEmbeddedTokenSpaceGuid.PcdPrePiStackBase|0
195 gEmbeddedTokenSpaceGuid.PcdPrePiStackSize|0
196
197 #
198 # Optinal feature to help prevent EFI memory map fragments
199 # Turned on and off via: PcdPrePiProduceMemoryTypeInformationHob
200 # Values are in EFI Pages (4K). DXE Core will make sure that
201 # at least this much of each type of memory can be allocated
202 # from a single memory range. This way you only end up with
203 # maximum of two fragements for each type in the memory map
204 # (the memory used, and the free memory that was prereserved
205 # but not used).
206 #
207 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIReclaimMemory|0
208 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIMemoryNVS|0
209 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiReservedMemoryType|0
210 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesData|0
211 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesCode|0
212 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesCode|0
213 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesData|0
214 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderCode|0
215 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderData|0
216
217 #
218 # Timer config for this platform
219 #
220 gEmbeddedTokenSpaceGuid.PcdTimerBaseAddress|0x3c700000
221 gEmbeddedTokenSpaceGuid.PcdTimerVector|7
222 gEmbeddedTokenSpaceGuid.PcdTimerPeriod|100000
223
224 [PcdsFixedAtBuild.IPF]
225 gEfiMdePkgTokenSpaceGuid.PcdIoBlockBaseAddressForIpf|0x0ffffc000000
226
227 #
228 # This makes it so you can source level debug with NT32. VC++ debugger limitiation!
229 #
230 #[BuildOptions]
231 # DEBUG_*_IA32_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /ALIGN:4096 /SUBSYSTEM:CONSOLE
232 # RELEASE_*_IA32_DLINK_FLAGS = /ALIGN:4096
233 # *_*_IA32_CC_FLAGS = /D EFI_SPECIFICATION_VERSION=0x0002000A /D TIANO_RELEASE_VERSION=0x00080006
234
235 [BuildOptions]
236 RVCT:*_*_ARM_PLATFORM_FLAGS == --cpu=7-A.security
237
238
239 ################################################################################
240 #
241 # Components Section - list of all Modules needed by this Platform
242 #
243 ################################################################################
244 [Components.common]
245 EmbeddedPkg/Library/EblAddExternalCommandLib/EblAddExternalCommandLib.inf
246 EmbeddedPkg/Library/EblCmdLibNull/EblCmdLibNull.inf
247 EmbeddedPkg/Library/EfiFileLib/EfiFileLib.inf
248 EmbeddedPkg/Library/GdbSerialDebugPortLib/GdbSerialDebugPortLib.inf
249 EmbeddedPkg/Library/GdbSerialLib/GdbSerialLib.inf
250 EmbeddedPkg/Library/PrePiExtractGuidedSectionLib/PrePiExtractGuidedSectionLib.inf
251 EmbeddedPkg/Library/PrePiLib/PrePiLib.inf
252 MdePkg/Library/BaseSerialPortLibNull/BaseSerialPortLibNull.inf
253 EmbeddedPkg/Library/SerialPortExtLibNull/SerialPortExtLibNull.inf
254 EmbeddedPkg/Library/TemplateResetSystemLib/TemplateResetSystemLib.inf
255 EmbeddedPkg/Library/TemplateRealTimeClockLib/TemplateRealTimeClockLib.inf
256 EmbeddedPkg/Library/LzmaHobCustomDecompressLib/LzmaHobCustomDecompressLib.inf
257 EmbeddedPkg/Library/NullDmaLib/NullDmaLib.inf
258
259 EmbeddedPkg/Ebl/Ebl.inf
260 #### EmbeddedPkg/EblExternCmd/EblExternCmd.inf
261 EmbeddedPkg/EmbeddedMonotonicCounter/EmbeddedMonotonicCounter.inf
262 EmbeddedPkg/RealTimeClockRuntimeDxe/RealTimeClockRuntimeDxe.inf
263 EmbeddedPkg/ResetRuntimeDxe/ResetRuntimeDxe.inf
264 EmbeddedPkg/SerialDxe/SerialDxe.inf
265 EmbeddedPkg/SimpleTextInOutSerial/SimpleTextInOutSerial.inf
266 EmbeddedPkg/MetronomeDxe/MetronomeDxe.inf {
267 <LibraryClasses>
268 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
269 }
270
271 EmbeddedPkg/Universal/MmcDxe/MmcDxe.inf
272
273 # FDT installation
274 EmbeddedPkg/Drivers/FdtPlatformDxe/FdtPlatformDxe.inf {
275 <LibraryClasses>
276 # It depends on BdsLib that depends on TimerLib
277 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
278 }
279
280 EmbeddedPkg/Application/AndroidFastboot/AndroidFastbootApp.inf {
281 <LibraryClasses>
282 # It depends on BdsLib that depends on TimerLib
283 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
284 }
285 EmbeddedPkg/Drivers/AndroidFastbootTransportUsbDxe/FastbootTransportUsbDxe.inf
286 EmbeddedPkg/Drivers/AndroidFastbootTransportTcpDxe/FastbootTransportTcpDxe.inf
287
288 # Drivers
289 EmbeddedPkg/Drivers/Isp1761UsbDxe/Isp1761UsbDxe.inf
290 EmbeddedPkg/Drivers/Lan9118Dxe/Lan9118Dxe.inf
291
292 [Components.IA32, Components.X64, Components.IPF, Components.ARM]
293 EmbeddedPkg/GdbStub/GdbStub.inf