]> git.proxmox.com Git - mirror_edk2.git/blame - EmbeddedPkg/EmbeddedPkg.dec
EmbeddedPkg: add platform boot manager protocol
[mirror_edk2.git] / EmbeddedPkg / EmbeddedPkg.dec
CommitLineData
2ef2b01e
A
1#/** @file\r
2# Framework Module Development Environment Industry Standards\r
3#\r
4# This Package provides headers and libraries that conform to EFI/PI Industry standards.\r
60274cca 5# Copyright (c) 2007, Intel Corporation. All rights reserved.<BR>\r
f6342447 6# Copyright (c) 2012-2015, ARM Ltd. All rights reserved.<BR>\r
4395f82e 7# Copyright (c) 2017, Linaro Ltd. All rights reserved.<BR>\r
2ef2b01e 8#\r
2ef2b01e
A
9# This program and the accompanying materials are licensed and made available under\r
10# the terms and conditions of the BSD License which accompanies this distribution.\r
11# The full text of the license may be found at\r
12# http://opensource.org/licenses/bsd-license.php\r
13#\r
14# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
15# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
16#\r
17#**/\r
18\r
19[Defines]\r
20 DEC_SPECIFICATION = 0x00010005\r
21 PACKAGE_NAME = EmbeddedPkg\r
22 PACKAGE_GUID = dea8e498-7e1b-47c1-b6fa-4bc04092587e\r
23 PACKAGE_VERSION = 0.1\r
24\r
25\r
26################################################################################\r
27#\r
28# Include Section - list of Include Paths that are provided by this package.\r
29# Comments are used for Keywords and Module Types.\r
30#\r
31# Supported Module Types:\r
32# BASE SEC PEI_CORE PEIM DXE_CORE DXE_DRIVER DXE_RUNTIME_DRIVER DXE_SMM_DRIVER DXE_SAL_DRIVER UEFI_DRIVER UEFI_APPLICATION\r
33#\r
34################################################################################\r
35[Includes.common]\r
36 Include # Root include for the package\r
37\r
38[LibraryClasses.common]\r
2ef2b01e
A
39 PrePiLib|Include/Library/PrePiLib.h\r
40 RealTimeClockLib|Include/Library/RealTimeClockLib.h\r
41 EfiResetSystemLib|Include/Library/EfiResetSystemLib.h\r
2ef2b01e 42 GdbSerialLib|Include/Library/GdbSerialLib.h\r
969eba7b 43 DebugAgentTimerLib|Include/Library/DebugAgentTimerLib.h\r
70466101 44 NorFlashInfoLib|Include/Library/NorFlashInfoLib.h\r
2ef2b01e 45\r
449a5df4 46 DtPlatformDtbLoaderLib|Include/Library/DtPlatformDtbLoaderLib.h\r
2ef2b01e
A
47\r
48[Guids.common]\r
49 gEmbeddedTokenSpaceGuid = { 0xe0d8ca17, 0x4276, 0x4386, { 0xbb, 0x79, 0x48, 0xcb, 0x81, 0x3d, 0x3c, 0x4f }}\r
50\r
90152e59
OM
51 ## FDT Configuration Table\r
52 # Include/Guid/Fdt.h\r
53 gFdtTableGuid = { 0xb1b621d5, 0xf19c, 0x41a5, { 0x83, 0x0b, 0xd9, 0x15, 0x2c, 0x69, 0xaa, 0xe0 } }\r
cc667df0
AB
54 # Include/Guid/FdtHob.h\r
55 gFdtHobGuid = { 0x16958446, 0x19B7, 0x480B, { 0xB0, 0x47, 0x74, 0x85, 0xAD, 0x3F, 0x71, 0x6D } }\r
158497a0 56 gFdtVariableGuid = { 0x25a4fd4a, 0x9703, 0x4ba9, { 0xa1, 0x90, 0xb7, 0xc8, 0x4e, 0xfb, 0x3e, 0x57 } }\r
90152e59 57\r
65a69b21
LE
58 ## Include/Guid/PlatformHasDeviceTree.h\r
59 gEdkiiPlatformHasDeviceTreeGuid = { 0x7ebb920d, 0x1aaf, 0x46d9, { 0xb2, 0xaf, 0x54, 0x1e, 0x1d, 0xce, 0x14, 0x8b } }\r
60\r
779cc439
AB
61 # HII form set GUID for DtPlatformDxe driver\r
62 gDtPlatformFormSetGuid = { 0x2b7a240d, 0xd5ad, 0x4fd6, { 0xbe, 0x1c, 0xdf, 0xa4, 0x41, 0x5f, 0x55, 0x26 } }\r
63\r
64 # File GUID for default DTB image embedded in the firmware volume\r
65 gDtPlatformDefaultDtbFileGuid = { 0x25462cda, 0x221f, 0x47df, { 0xac, 0x1d, 0x25, 0x9c, 0xfa, 0xa4, 0xe3, 0x26 } }\r
66\r
d8e36289
AB
67 # HII form set GUID for ConsolePrefDxe driver\r
68 gConsolePrefFormSetGuid = { 0x2d2358b4, 0xe96c, 0x484d, { 0xb2, 0xdd, 0x7c, 0x2e, 0xdf, 0xc7, 0xd5, 0x6f } }\r
69\r
7ab26d51
LE
70 ## Include/Guid/NvVarStoreFormatted.h\r
71 gEdkiiNvVarStoreFormattedGuid = { 0xd1a86e3f, 0x0707, 0x4c35, { 0x83, 0xcd, 0xdc, 0x2c, 0x29, 0xc8, 0x91, 0xa3 } }\r
72\r
2ef2b01e
A
73[Protocols.common]\r
74 gHardwareInterruptProtocolGuid = { 0x2890B3EA, 0x053D, 0x1643, { 0xAD, 0x0C, 0xD6, 0x48, 0x08, 0xDA, 0x3F, 0xF1 } }\r
e40c7289 75 gHardwareInterrupt2ProtocolGuid = { 0x32898322, 0x2da1, 0x474a, { 0xba, 0xaa, 0xf3, 0xf7, 0xcf, 0x56, 0x94, 0x70 } }\r
2ef2b01e
A
76 gEmbeddedDeviceGuid = { 0xbf4b9d10, 0x13ec, 0x43dd, { 0x88, 0x80, 0xe9, 0xb, 0x71, 0x8f, 0x27, 0xde } }\r
77 gEmbeddedExternalDeviceProtocolGuid = { 0x735F8C64, 0xD696, 0x44D0, { 0xBD, 0xF2, 0x44, 0x7F, 0xD0, 0x5A, 0x54, 0x06 }}\r
78 gEmbeddedGpioProtocolGuid = { 0x17a0a3d7, 0xc0a5, 0x4635, { 0xbb, 0xd5, 0x07, 0x21, 0x87, 0xdf, 0xe2, 0xee }}\r
e4dbec73 79 gPeCoffLoaderProtocolGuid = { 0xB323179B, 0x97FB, 0x477E, { 0xB0, 0xFE, 0xD8, 0x85, 0x91, 0xFA, 0x11, 0xAB } }\r
ce73d60a 80 gEfiMmcHostProtocolGuid = { 0x3e591c00, 0x9e4a, 0x11df, {0x92, 0x44, 0x00, 0x02, 0xA5, 0xD5, 0xC5, 0x1B }}\r
d8fd8862 81 gAndroidFastbootTransportProtocolGuid = { 0x74bd9fe0, 0x8902, 0x11e3, {0xb9, 0xd3, 0xf7, 0x22, 0x38, 0xfc, 0x9a, 0x31}}\r
ddd14366 82 gAndroidFastbootPlatformProtocolGuid = { 0x524685a0, 0x89a0, 0x11e3, {0x9d, 0x4d, 0xbf, 0xa9, 0xf6, 0xa4, 0x03, 0x08}}\r
d972f80b 83 gUsbDeviceProtocolGuid = { 0x021bd2ca, 0x51d2, 0x11e3, {0x8e, 0x56, 0xb7, 0x54, 0x17, 0xc7, 0x0b, 0x44 }}\r
7e074d15 84 gPlatformBootManagerProtocolGuid = { 0x7197c8a7, 0x6559, 0x4c93, { 0x93, 0xd5, 0x8a, 0x84, 0xf9, 0x88, 0x79, 0x8b }}\r
78741ce9 85 gPlatformGpioProtocolGuid = { 0x52ce9845, 0x5af4, 0x43e2, {0xba, 0xfd, 0x23, 0x08, 0x12, 0x54, 0x7a, 0xc2 }}\r
1df5fb2d 86 gPlatformVirtualKeyboardProtocolGuid = { 0x0e3606d2, 0x1dc3, 0x4e6f, { 0xbe, 0x65, 0x39, 0x49, 0x82, 0xa2, 0x65, 0x47 }}\r
fa74dd22 87 gAndroidBootImgProtocolGuid = { 0x9859bb19, 0x407c, 0x4f8b, {0xbc, 0xe1, 0xf8, 0xda, 0x65, 0x65, 0xf4, 0xa5 }}\r
62d441fb 88\r
b1832e16
AB
89[Ppis]\r
90 gEdkiiEmbeddedGpioPpiGuid = { 0x21c3b115, 0x4e0b, 0x470c, { 0x85, 0xc7, 0xe1, 0x05, 0xa5, 0x75, 0xc9, 0x7b }}\r
91\r
2ef2b01e 92[PcdsFeatureFlag.common]\r
2ef2b01e 93 gEmbeddedTokenSpaceGuid.PcdPrePiProduceMemoryTypeInformationHob|FALSE|BOOLEAN|0x0000001b\r
fb334ef6 94 gEmbeddedTokenSpaceGuid.PcdGdbSerial|FALSE|BOOLEAN|0x00000053\r
2ef2b01e 95\r
f6342447
OM
96 gEmbeddedTokenSpaceGuid.PcdSataSiI3132FeaturePMPSupport|FALSE|BOOLEAN|0x00000050\r
97 gEmbeddedTokenSpaceGuid.PcdSataSiI3132FeatureDirectCommandIssuing|FALSE|BOOLEAN|0x00000051\r
2ef2b01e
A
98\r
99[PcdsFixedAtBuild.common]\r
2ef2b01e
A
100 gEmbeddedTokenSpaceGuid.PcdPrePiStackBase|0|UINT32|0x0000000b\r
101 gEmbeddedTokenSpaceGuid.PcdPrePiStackSize|131072|UINT32|0x0000000c\r
3402aac7 102\r
753816a3 103 gEmbeddedTokenSpaceGuid.PcdMemoryBase|0x0|UINT32|0x0000004e\r
104 gEmbeddedTokenSpaceGuid.PcdMemorySize|0x0|UINT32|0x0000004f\r
105\r
2ef2b01e
A
106 gEmbeddedTokenSpaceGuid.PcdFlashFvMainBase|0x0|UINT32|0x00000043\r
107 gEmbeddedTokenSpaceGuid.PcdFlashFvMainOffset|0x0|UINT32|0x00000044\r
eca37a31 108 gEmbeddedTokenSpaceGuid.PcdFlashFvMainSize|0x0|UINT32|0x00000045\r
3402aac7 109\r
2ef2b01e
A
110# Used to help reduce fragmentation in the EFI memory map\r
111# EFI Pages (4K) are the units used\r
112 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIReclaimMemory|0|UINT32|0x00000012\r
113 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiACPIMemoryNVS|0|UINT32|0x00000013\r
114 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiReservedMemoryType|0|UINT32|0x00000014\r
115 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesData|0|UINT32|0x00000015\r
116 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiRuntimeServicesCode|0|UINT32|0x00000016\r
117 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesCode|0|UINT32|0x00000017\r
118 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiBootServicesData|0|UINT32|0x00000018\r
119 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderCode|0|UINT32|0x00000019\r
120 gEmbeddedTokenSpaceGuid.PcdMemoryTypeEfiLoaderData|0|UINT32|0x0000001a\r
121\r
122 gEmbeddedTokenSpaceGuid.PcdTimerBaseAddress|0x3c700000|UINT32|0x0000001c\r
123 gEmbeddedTokenSpaceGuid.PcdTimerVector|7|UINT32|0x0000001d\r
124 gEmbeddedTokenSpaceGuid.PcdTimerPeriod|100000|UINT32|0x0000001e\r
125 gEmbeddedTokenSpaceGuid.PcdInterruptBaseAddress|0x38e00000|UINT32|0x0000001f\r
0e568a7b 126\r
127 gEmbeddedTokenSpaceGuid.PcdMetronomeTickPeriod|100|UINT32|0x00000020\r
3402aac7 128\r
2ef2b01e
A
129 gEmbeddedTokenSpaceGuid.PcdEmbeddedFdBaseAddress|0xffff0000|UINT32|0x00000030\r
130 gEmbeddedTokenSpaceGuid.PcdEmbeddedFdSize|0x0000000|UINT32|0x00000031\r
6f6e0596 131 gEmbeddedTokenSpaceGuid.PcdEmbeddedPerformanceCounterFrequencyInHz|0x0000000|UINT64|0x00000032\r
132 gEmbeddedTokenSpaceGuid.PcdEmbeddedPerformanceCounterPeriodInNanoseconds|0x0000000|UINT32|0x00000033\r
2ef2b01e 133\r
2ef2b01e
A
134 gEmbeddedTokenSpaceGuid.PcdGdbBaudRate|115200|UINT64|0x00000047\r
135 gEmbeddedTokenSpaceGuid.PcdGdbDataBits|8|UINT8|0x00000048\r
136 gEmbeddedTokenSpaceGuid.PcdGdbParity|1|UINT8|0x00000049\r
137 gEmbeddedTokenSpaceGuid.PcdGdbStopBits|1|UINT8|0x0000004a\r
138 gEmbeddedTokenSpaceGuid.PcdGdbUartPort|0x3f8|UINT32|0x0000004b\r
139 gEmbeddedTokenSpaceGuid.PcdGdbMaxPacketRetryCount|10000000|UINT32|0x0000004c\r
6f6e0596 140 gEmbeddedTokenSpaceGuid.PcdGdbTimerPeriodMilliseconds|250|UINT32|0x0000004d\r
2ef2b01e 141\r
46f2c53b
OM
142 # LAN9118 Ethernet Driver PCDs\r
143 gEmbeddedTokenSpaceGuid.PcdLan9118DxeBaseAddress|0x0|UINT32|0x00000025\r
144 gEmbeddedTokenSpaceGuid.PcdLan9118DefaultMacAddress|0x0|UINT64|0x00000026\r
b7b7fb3d 145 gEmbeddedTokenSpaceGuid.PcdLan9118DefaultNegotiationTimeout|4000|UINT32|0x00000027\r
6336850c
RH
146 # The default feature mask below disables full duplex negotiation, since full\r
147 # duplex operation is suspected to be broken in the driver.\r
148 gEmbeddedTokenSpaceGuid.PcdLan9118NegotiationFeatureMask|0xFFFFFEBF|UINT32|0x00000028\r
46f2c53b 149\r
4395f82e
LL
150 # LAN91x Ethernet Driver PCDs\r
151 gEmbeddedTokenSpaceGuid.PcdLan91xDxeBaseAddress|0x0|UINT32|0x00000029\r
152\r
ee660531
LL
153 # DwEmmc Driver PCDs\r
154 gEmbeddedTokenSpaceGuid.PcdDwEmmcDxeBaseAddress|0x0|UINT32|0x00000035\r
155 gEmbeddedTokenSpaceGuid.PcdDwEmmcDxeClockFrequencyInHz|0x0|UINT32|0x00000036\r
d4102f68 156 gEmbeddedTokenSpaceGuid.PcdDwEmmcDxeMaxClockFreqInHz|0x0|UINT32|0x00000037\r
a58bfb37 157 gEmbeddedTokenSpaceGuid.PcdDwEmmcDxeFifoDepth|0x0|UINT32|0x00000038\r
ee660531 158\r
d3f99770
OM
159 #\r
160 # Android FastBoot\r
161 #\r
162\r
163 # The Android FastBoot utility has hard-coded USB Vendor IDs that it recognises\r
164 # (and 0xf00d isn't one of them!).\r
165 # You'll need to pass it "-i 0xf00d" to get it to recognise this device.\r
166 gEmbeddedTokenSpaceGuid.PcdAndroidFastbootUsbVendorId|0xf00d|UINT32|0x00000022\r
167 gEmbeddedTokenSpaceGuid.PcdAndroidFastbootUsbProductId|0xbeef|UINT32|0x00000023\r
4d6e1e5a 168 gEmbeddedTokenSpaceGuid.PcdAndroidFastbootTcpPort|1234|UINT32|0x00000024\r
d3f99770 169\r
fa74dd22 170 gEmbeddedTokenSpaceGuid.PcdAndroidBootDevicePath|L""|VOID*|0x00000057\r
158497a0 171\r
34b292fa
OM
172[PcdsFixedAtBuild.ARM]\r
173 gEmbeddedTokenSpaceGuid.PcdPrePiCpuMemorySize|32|UINT8|0x00000010\r
174 gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|0|UINT8|0x00000011\r
175\r
dbfd80d8
OM
176 # ISP1761 USB OTG Controller\r
177 gEmbeddedTokenSpaceGuid.PcdIsp1761BaseAddress|0|UINT32|0x00000021\r
178\r
34b292fa
OM
179[PcdsFixedAtBuild.AARCH64]\r
180 gEmbeddedTokenSpaceGuid.PcdPrePiCpuMemorySize|48|UINT8|0x00000010\r
181 gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|0|UINT8|0x00000011\r
182\r
183[PcdsFixedAtBuild.IA32]\r
184 gEmbeddedTokenSpaceGuid.PcdPrePiCpuMemorySize|36|UINT8|0x00000010\r
185 gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|16|UINT8|0x00000011\r
186\r
187[PcdsFixedAtBuild.X64]\r
188 gEmbeddedTokenSpaceGuid.PcdPrePiCpuMemorySize|52|UINT8|0x00000010\r
189 gEmbeddedTokenSpaceGuid.PcdPrePiCpuIoSize|16|UINT8|0x00000011\r
158497a0
RC
190\r
191[PcdsFixedAtBuild.common, PcdsDynamic.common]\r
0bcb8010
AB
192 #\r
193 # Value to add to a host address to obtain a device address, using\r
194 # unsigned 64-bit integer arithmetic. This means we can rely on\r
195 # truncation on overflow to specify negative offsets.\r
196 #\r
197 gEmbeddedTokenSpaceGuid.PcdDmaDeviceOffset|0x0|UINT64|0x0000058\r