]> git.proxmox.com Git - mirror_edk2.git/blame - DuetPkg/Library/DuetBdsLib/BdsPlatform.h
BaseTools/CommonLib: drop definition of MAX_UINTN
[mirror_edk2.git] / DuetPkg / Library / DuetBdsLib / BdsPlatform.h
CommitLineData
c69dd9df 1/*++\r
2\r
ce68d3bc 3Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>\r
b1f700a8 4This program and the accompanying materials \r
c69dd9df 5are licensed and made available under the terms and conditions of the BSD License \r
6which accompanies this distribution. The full text of the license may be found at \r
7http://opensource.org/licenses/bsd-license.php \r
8 \r
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
11\r
12Module Name: \r
13\r
14 BdsPlatform.h\r
15\r
16Abstract:\r
17\r
18 Head file for BDS Platform specific code\r
19\r
20--*/\r
21\r
22#ifndef _PLATFORM_SPECIFIC_BDS_PLATFORM_H_\r
23#define _PLATFORM_SPECIFIC_BDS_PLATFORM_H_\r
24\r
25\r
26#include <PiDxe.h>\r
27\r
28#include <IndustryStandard/Pci.h>\r
29#include <IndustryStandard/Acpi.h>\r
d8bee43c 30#include <IndustryStandard/SmBios.h>\r
c69dd9df 31#include <IndustryStandard/LegacyBiosMpTable.h>\r
32\r
33#include <Library/DebugLib.h>\r
34#include <Library/BaseMemoryLib.h>\r
35#include <Library/UefiBootServicesTableLib.h>\r
36#include <Library/MemoryAllocationLib.h>\r
37#include <Library/BaseLib.h>\r
38#include <Library/PcdLib.h>\r
39#include <Library/GenericBdsLib.h>\r
40#include <Library/PlatformBdsLib.h>\r
c69dd9df 41#include <Library/HobLib.h>\r
42#include <Library/UefiLib.h>\r
43#include <Library/DxeServicesTableLib.h>\r
44#include <Library/DevicePathLib.h>\r
45\r
46#include <Protocol/PciIo.h>\r
47\r
c69dd9df 48#include <Guid/Acpi.h>\r
d8bee43c 49#include <Guid/SmBios.h>\r
c69dd9df 50#include <Guid/Mps.h>\r
51#include <Guid/HobList.h>\r
52#include <Guid/PciExpressBaseAddress.h>\r
53#include <Guid/GlobalVariable.h>\r
db4d3fa1 54#include <Guid/LdrMemoryDescriptor.h>\r
c69dd9df 55\r
56extern BDS_CONSOLE_CONNECT_ENTRY gPlatformConsole[];\r
57extern EFI_DEVICE_PATH_PROTOCOL *gPlatformConnectSequence[];\r
58extern EFI_DEVICE_PATH_PROTOCOL *gPlatformDriverOption[];\r
59extern EFI_DEVICE_PATH_PROTOCOL *gPlatformRootBridges[];\r
60extern ACPI_HID_DEVICE_PATH gPnpPs2KeyboardDeviceNode;\r
61extern ACPI_HID_DEVICE_PATH gPnp16550ComPortDeviceNode;\r
62extern UART_DEVICE_PATH gUartDeviceNode;\r
63extern VENDOR_DEVICE_PATH gTerminalTypeDeviceNode;\r
64//\r
65//\r
66//\r
67#define VarConsoleInpDev L"ConInDev"\r
68#define VarConsoleInp L"ConIn"\r
69#define VarConsoleOutDev L"ConOutDev"\r
70#define VarConsoleOut L"ConOut"\r
71#define VarErrorOutDev L"ErrOutDev"\r
72#define VarErrorOut L"ErrOut"\r
73\r
74#define PCI_DEVICE_PATH_NODE(Func, Dev) \\r
75 { \\r
9e65d5e9 76 { \\r
ce68d3bc
SZ
77 HARDWARE_DEVICE_PATH, \\r
78 HW_PCI_DP, \\r
79 { \\r
80 (UINT8) (sizeof (PCI_DEVICE_PATH)), \\r
81 (UINT8) ((sizeof (PCI_DEVICE_PATH)) >> 8) \\r
82 } \\r
9e65d5e9 83 }, \\r
c69dd9df 84 (Func), \\r
85 (Dev) \\r
86 }\r
87\r
88#define PNPID_DEVICE_PATH_NODE(PnpId) \\r
89 { \\r
9e65d5e9 90 { \\r
91 ACPI_DEVICE_PATH, \\r
92 ACPI_DP, \\r
93 { \\r
94 (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \\r
95 (UINT8) ((sizeof (ACPI_HID_DEVICE_PATH)) >> 8) \\r
96 } \\r
97 }, \\r
c69dd9df 98 EISA_PNP_ID((PnpId)), \\r
99 0 \\r
100 }\r
101\r
102#define gPciRootBridge \\r
103 PNPID_DEVICE_PATH_NODE(0x0A03)\r
104\r
105#define gPciIsaBridge \\r
106 PCI_DEVICE_PATH_NODE(0, 0x1f)\r
107\r
108#define gP2PBridge \\r
109 PCI_DEVICE_PATH_NODE(0, 0x1e)\r
110\r
111#define gPnpPs2Keyboard \\r
112 PNPID_DEVICE_PATH_NODE(0x0303)\r
113\r
114#define gPnp16550ComPort \\r
115 PNPID_DEVICE_PATH_NODE(0x0501)\r
116\r
117#define gUart \\r
118 { \\r
9e65d5e9 119 { \\r
120 MESSAGING_DEVICE_PATH, \\r
121 MSG_UART_DP, \\r
122 { \\r
123 (UINT8) (sizeof (UART_DEVICE_PATH)), \\r
124 (UINT8) ((sizeof (UART_DEVICE_PATH)) >> 8) \\r
125 } \\r
126 }, \\r
c69dd9df 127 0, \\r
128 115200, \\r
129 8, \\r
130 1, \\r
131 1 \\r
132 }\r
133\r
134#define gPcAnsiTerminal \\r
135 { \\r
9e65d5e9 136 { \\r
137 MESSAGING_DEVICE_PATH, \\r
138 MSG_VENDOR_DP, \\r
139 { \\r
140 (UINT8) (sizeof (VENDOR_DEVICE_PATH)), \\r
141 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8) \\r
142 } \\r
143 }, \\r
c69dd9df 144 DEVICE_PATH_MESSAGING_PC_ANSI \\r
145 }\r
146\r
147#define gEndEntire \\r
148 { \\r
149 END_DEVICE_PATH_TYPE, \\r
150 END_ENTIRE_DEVICE_PATH_SUBTYPE, \\r
9e65d5e9 151 { \\r
152 END_DEVICE_PATH_LENGTH, \\r
153 0 \\r
154 } \\r
c69dd9df 155 }\r
156\r
157#define PCI_CLASS_SCC 0x07\r
158#define PCI_SUBCLASS_SERIAL 0x00\r
159#define PCI_IF_16550 0x02\r
160#define IS_PCI_16550SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550)\r
161\r
162#define EFI_SYSTEM_TABLE_MAX_ADDRESS 0xFFFFFFFF\r
163#define SYS_TABLE_PAD(ptr) (((~ptr) +1) & 0x07 )\r
164//\r
165// Platform Root Bridge\r
166//\r
167typedef struct {\r
168 ACPI_HID_DEVICE_PATH PciRootBridge;\r
169 EFI_DEVICE_PATH_PROTOCOL End;\r
170} PLATFORM_ROOT_BRIDGE_DEVICE_PATH;\r
171\r
172typedef struct {\r
173 ACPI_HID_DEVICE_PATH PciRootBridge;\r
174 PCI_DEVICE_PATH IsaBridge;\r
175 ACPI_HID_DEVICE_PATH Keyboard;\r
176 EFI_DEVICE_PATH_PROTOCOL End;\r
177} PLATFORM_DUMMY_ISA_KEYBOARD_DEVICE_PATH;\r
178\r
179typedef struct {\r
180 ACPI_HID_DEVICE_PATH PciRootBridge;\r
181 PCI_DEVICE_PATH IsaBridge;\r
182 ACPI_HID_DEVICE_PATH IsaSerial;\r
183 UART_DEVICE_PATH Uart;\r
184 VENDOR_DEVICE_PATH TerminalType;\r
185 EFI_DEVICE_PATH_PROTOCOL End;\r
186} PLATFORM_DUMMY_ISA_SERIAL_DEVICE_PATH;\r
187\r
188typedef struct {\r
189 ACPI_HID_DEVICE_PATH PciRootBridge;\r
190 PCI_DEVICE_PATH VgaDevice;\r
191 EFI_DEVICE_PATH_PROTOCOL End;\r
192} PLATFORM_DUMMY_PCI_VGA_DEVICE_PATH;\r
193\r
194typedef struct {\r
195 ACPI_HID_DEVICE_PATH PciRootBridge;\r
196 PCI_DEVICE_PATH PciBridge;\r
197 PCI_DEVICE_PATH SerialDevice;\r
198 UART_DEVICE_PATH Uart;\r
199 VENDOR_DEVICE_PATH TerminalType;\r
200 EFI_DEVICE_PATH_PROTOCOL End;\r
201} PLATFORM_DUMMY_PCI_SERIAL_DEVICE_PATH;\r
202\r
203//\r
204// the short form device path for Usb keyboard\r
205//\r
206#define CLASS_HID 3\r
207#define SUBCLASS_BOOT 1\r
208#define PROTOCOL_KEYBOARD 1\r
209\r
210typedef struct {\r
211 USB_CLASS_DEVICE_PATH UsbClass;\r
212 EFI_DEVICE_PATH_PROTOCOL End;\r
213} USB_CLASS_FORMAT_DEVICE_PATH; \r
214\r
215extern PLATFORM_ROOT_BRIDGE_DEVICE_PATH gPlatformRootBridge0;\r
216\r
217//\r
218// Platform BDS Functions\r
219//\r
c69dd9df 220VOID\r
221PlatformBdsGetDriverOption (\r
222 IN LIST_ENTRY *BdsDriverLists\r
ed66e1bc 223 );\r
c69dd9df 224\r
225EFI_STATUS\r
226BdsMemoryTest (\r
227 EXTENDMEM_COVERAGE_LEVEL Level\r
ed66e1bc 228 );\r
c69dd9df 229\r
230EFI_STATUS\r
231PlatformBdsShowProgress (\r
232 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleForeground,\r
233 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleBackground,\r
234 CHAR16 *Title,\r
235 EFI_GRAPHICS_OUTPUT_BLT_PIXEL ProgressColor,\r
236 UINTN Progress,\r
237 UINTN PreviousValue\r
ed66e1bc 238 );\r
c69dd9df 239\r
240VOID\r
241PlatformBdsConnectSequence (\r
242 VOID\r
ed66e1bc 243 );\r
c69dd9df 244\r
c69dd9df 245EFI_STATUS\r
246ProcessCapsules (\r
247 EFI_BOOT_MODE BootMode\r
ed66e1bc 248 );\r
c69dd9df 249\r
250EFI_STATUS\r
251PlatformBdsConnectConsole (\r
252 IN BDS_CONSOLE_CONNECT_ENTRY *PlatformConsole\r
ed66e1bc 253 );\r
c69dd9df 254\r
255EFI_STATUS\r
256PlatformBdsNoConsoleAction (\r
257 VOID\r
ed66e1bc 258 );\r
c69dd9df 259\r
260EFI_STATUS\r
261ConvertMpsTable (\r
262 IN OUT VOID **Table\r
ed66e1bc 263 );\r
c69dd9df 264 \r
265EFI_STATUS\r
266ConvertSmbiosTable (\r
267 IN OUT VOID **Table\r
ed66e1bc 268 );\r
c69dd9df 269 \r
270EFI_STATUS\r
271ConvertAcpiTable (\r
272 IN UINTN TableLen,\r
273 IN OUT VOID **Table\r
ed66e1bc 274 );\r
c69dd9df 275\r
276EFI_STATUS\r
277ConvertSystemTable (\r
278 IN EFI_GUID *TableGuid,\r
279 IN OUT VOID **Table\r
ed66e1bc 280 );\r
c69dd9df 281\r
282VOID\r
283PlatformBdsEnterFrontPage (\r
284 IN UINT16 TimeoutDefault,\r
285 IN BOOLEAN ConnectAllHappened\r
ed66e1bc 286 );\r
c69dd9df 287\r
288#endif // _PLATFORM_SPECIFIC_BDS_PLATFORM_H_\r