]> git.proxmox.com Git - mirror_edk2.git/blame - DuetPkg/Library/DuetBdsLib/BdsPlatform.h
clean up the un-suitable ';' location when declaring the functions.
[mirror_edk2.git] / DuetPkg / Library / DuetBdsLib / BdsPlatform.h
CommitLineData
c69dd9df 1/*++\r
2\r
3Copyright (c) 2006 - 2007, Intel Corporation \r
4All rights reserved. This program and the accompanying materials \r
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
41#include <Library/GraphicsLib.h>\r
42#include <Library/HobLib.h>\r
43#include <Library/UefiLib.h>\r
44#include <Library/DxeServicesTableLib.h>\r
45#include <Library/DevicePathLib.h>\r
46\r
47#include <Protocol/PciIo.h>\r
48\r
49#include <Guid/Bmp.h>\r
50#include <Guid/Acpi.h>\r
d8bee43c 51#include <Guid/SmBios.h>\r
c69dd9df 52#include <Guid/Mps.h>\r
53#include <Guid/HobList.h>\r
54#include <Guid/PciExpressBaseAddress.h>\r
55#include <Guid/GlobalVariable.h>\r
56\r
57extern BDS_CONSOLE_CONNECT_ENTRY gPlatformConsole[];\r
58extern EFI_DEVICE_PATH_PROTOCOL *gPlatformConnectSequence[];\r
59extern EFI_DEVICE_PATH_PROTOCOL *gPlatformDriverOption[];\r
60extern EFI_DEVICE_PATH_PROTOCOL *gPlatformRootBridges[];\r
61extern ACPI_HID_DEVICE_PATH gPnpPs2KeyboardDeviceNode;\r
62extern ACPI_HID_DEVICE_PATH gPnp16550ComPortDeviceNode;\r
63extern UART_DEVICE_PATH gUartDeviceNode;\r
64extern VENDOR_DEVICE_PATH gTerminalTypeDeviceNode;\r
65//\r
66//\r
67//\r
68#define VarConsoleInpDev L"ConInDev"\r
69#define VarConsoleInp L"ConIn"\r
70#define VarConsoleOutDev L"ConOutDev"\r
71#define VarConsoleOut L"ConOut"\r
72#define VarErrorOutDev L"ErrOutDev"\r
73#define VarErrorOut L"ErrOut"\r
74\r
75#define PCI_DEVICE_PATH_NODE(Func, Dev) \\r
76 { \\r
77 HARDWARE_DEVICE_PATH, \\r
78 HW_PCI_DP, \\r
79 (UINT8) (sizeof (PCI_DEVICE_PATH)), \\r
80 (UINT8) ((sizeof (PCI_DEVICE_PATH)) >> 8), \\r
81 (Func), \\r
82 (Dev) \\r
83 }\r
84\r
85#define PNPID_DEVICE_PATH_NODE(PnpId) \\r
86 { \\r
87 ACPI_DEVICE_PATH, \\r
88 ACPI_DP, \\r
89 (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \\r
90 (UINT8) ((sizeof (ACPI_HID_DEVICE_PATH)) >> 8), \\r
91 EISA_PNP_ID((PnpId)), \\r
92 0 \\r
93 }\r
94\r
95#define gPciRootBridge \\r
96 PNPID_DEVICE_PATH_NODE(0x0A03)\r
97\r
98#define gPciIsaBridge \\r
99 PCI_DEVICE_PATH_NODE(0, 0x1f)\r
100\r
101#define gP2PBridge \\r
102 PCI_DEVICE_PATH_NODE(0, 0x1e)\r
103\r
104#define gPnpPs2Keyboard \\r
105 PNPID_DEVICE_PATH_NODE(0x0303)\r
106\r
107#define gPnp16550ComPort \\r
108 PNPID_DEVICE_PATH_NODE(0x0501)\r
109\r
110#define gUart \\r
111 { \\r
112 MESSAGING_DEVICE_PATH, \\r
113 MSG_UART_DP, \\r
114 (UINT8) (sizeof (UART_DEVICE_PATH)), \\r
115 (UINT8) ((sizeof (UART_DEVICE_PATH)) >> 8), \\r
116 0, \\r
117 115200, \\r
118 8, \\r
119 1, \\r
120 1 \\r
121 }\r
122\r
123#define gPcAnsiTerminal \\r
124 { \\r
125 MESSAGING_DEVICE_PATH, \\r
126 MSG_VENDOR_DP, \\r
127 (UINT8) (sizeof (VENDOR_DEVICE_PATH)), \\r
128 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8), \\r
129 DEVICE_PATH_MESSAGING_PC_ANSI \\r
130 }\r
131\r
132#define gEndEntire \\r
133 { \\r
134 END_DEVICE_PATH_TYPE, \\r
135 END_ENTIRE_DEVICE_PATH_SUBTYPE, \\r
136 END_DEVICE_PATH_LENGTH, \\r
137 0 \\r
138 }\r
139\r
140#define PCI_CLASS_SCC 0x07\r
141#define PCI_SUBCLASS_SERIAL 0x00\r
142#define PCI_IF_16550 0x02\r
143#define IS_PCI_16550SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550)\r
144\r
145#define EFI_SYSTEM_TABLE_MAX_ADDRESS 0xFFFFFFFF\r
146#define SYS_TABLE_PAD(ptr) (((~ptr) +1) & 0x07 )\r
147//\r
148// Platform Root Bridge\r
149//\r
150typedef struct {\r
151 ACPI_HID_DEVICE_PATH PciRootBridge;\r
152 EFI_DEVICE_PATH_PROTOCOL End;\r
153} PLATFORM_ROOT_BRIDGE_DEVICE_PATH;\r
154\r
155typedef struct {\r
156 ACPI_HID_DEVICE_PATH PciRootBridge;\r
157 PCI_DEVICE_PATH IsaBridge;\r
158 ACPI_HID_DEVICE_PATH Keyboard;\r
159 EFI_DEVICE_PATH_PROTOCOL End;\r
160} PLATFORM_DUMMY_ISA_KEYBOARD_DEVICE_PATH;\r
161\r
162typedef struct {\r
163 ACPI_HID_DEVICE_PATH PciRootBridge;\r
164 PCI_DEVICE_PATH IsaBridge;\r
165 ACPI_HID_DEVICE_PATH IsaSerial;\r
166 UART_DEVICE_PATH Uart;\r
167 VENDOR_DEVICE_PATH TerminalType;\r
168 EFI_DEVICE_PATH_PROTOCOL End;\r
169} PLATFORM_DUMMY_ISA_SERIAL_DEVICE_PATH;\r
170\r
171typedef struct {\r
172 ACPI_HID_DEVICE_PATH PciRootBridge;\r
173 PCI_DEVICE_PATH VgaDevice;\r
174 EFI_DEVICE_PATH_PROTOCOL End;\r
175} PLATFORM_DUMMY_PCI_VGA_DEVICE_PATH;\r
176\r
177typedef struct {\r
178 ACPI_HID_DEVICE_PATH PciRootBridge;\r
179 PCI_DEVICE_PATH PciBridge;\r
180 PCI_DEVICE_PATH SerialDevice;\r
181 UART_DEVICE_PATH Uart;\r
182 VENDOR_DEVICE_PATH TerminalType;\r
183 EFI_DEVICE_PATH_PROTOCOL End;\r
184} PLATFORM_DUMMY_PCI_SERIAL_DEVICE_PATH;\r
185\r
186//\r
187// the short form device path for Usb keyboard\r
188//\r
189#define CLASS_HID 3\r
190#define SUBCLASS_BOOT 1\r
191#define PROTOCOL_KEYBOARD 1\r
192\r
193typedef struct {\r
194 USB_CLASS_DEVICE_PATH UsbClass;\r
195 EFI_DEVICE_PATH_PROTOCOL End;\r
196} USB_CLASS_FORMAT_DEVICE_PATH; \r
197\r
198extern PLATFORM_ROOT_BRIDGE_DEVICE_PATH gPlatformRootBridge0;\r
199\r
200//\r
201// Platform BDS Functions\r
202//\r
203VOID\r
204PlatformBdsInit (\r
205 IN EFI_BDS_ARCH_PROTOCOL_INSTANCE *PrivateData\r
ed66e1bc 206 );\r
c69dd9df 207\r
208VOID\r
209PlatformBdsPolicyBehavior (\r
210 IN EFI_BDS_ARCH_PROTOCOL_INSTANCE *PrivateData,\r
211 IN LIST_ENTRY *DriverOptionList,\r
212 IN LIST_ENTRY *BootOptionList\r
ed66e1bc 213 );\r
c69dd9df 214\r
215VOID\r
216PlatformBdsGetDriverOption (\r
217 IN LIST_ENTRY *BdsDriverLists\r
ed66e1bc 218 );\r
c69dd9df 219\r
220EFI_STATUS\r
221BdsMemoryTest (\r
222 EXTENDMEM_COVERAGE_LEVEL Level\r
ed66e1bc 223 );\r
c69dd9df 224\r
225EFI_STATUS\r
226PlatformBdsShowProgress (\r
227 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleForeground,\r
228 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleBackground,\r
229 CHAR16 *Title,\r
230 EFI_GRAPHICS_OUTPUT_BLT_PIXEL ProgressColor,\r
231 UINTN Progress,\r
232 UINTN PreviousValue\r
ed66e1bc 233 );\r
c69dd9df 234\r
235VOID\r
236PlatformBdsConnectSequence (\r
237 VOID\r
ed66e1bc 238 );\r
c69dd9df 239\r
240VOID\r
241PlatformBdsBootFail (\r
242 IN BDS_COMMON_OPTION *Option,\r
243 IN EFI_STATUS Status,\r
244 IN CHAR16 *ExitData,\r
245 IN UINTN ExitDataSize\r
ed66e1bc 246 );\r
c69dd9df 247\r
248VOID\r
249PlatformBdsBootSuccess (\r
250 IN BDS_COMMON_OPTION *Option\r
ed66e1bc 251 );\r
c69dd9df 252\r
253EFI_STATUS\r
254ProcessCapsules (\r
255 EFI_BOOT_MODE BootMode\r
ed66e1bc 256 );\r
c69dd9df 257\r
258EFI_STATUS\r
259PlatformBdsConnectConsole (\r
260 IN BDS_CONSOLE_CONNECT_ENTRY *PlatformConsole\r
ed66e1bc 261 );\r
c69dd9df 262\r
263EFI_STATUS\r
264PlatformBdsNoConsoleAction (\r
265 VOID\r
ed66e1bc 266 );\r
c69dd9df 267\r
268EFI_STATUS\r
269ConvertMpsTable (\r
270 IN OUT VOID **Table\r
ed66e1bc 271 );\r
c69dd9df 272 \r
273EFI_STATUS\r
274ConvertSmbiosTable (\r
275 IN OUT VOID **Table\r
ed66e1bc 276 );\r
c69dd9df 277 \r
278EFI_STATUS\r
279ConvertAcpiTable (\r
280 IN UINTN TableLen,\r
281 IN OUT VOID **Table\r
ed66e1bc 282 );\r
c69dd9df 283\r
284EFI_STATUS\r
285ConvertSystemTable (\r
286 IN EFI_GUID *TableGuid,\r
287 IN OUT VOID **Table\r
ed66e1bc 288 );\r
c69dd9df 289\r
290VOID\r
291PlatformBdsEnterFrontPage (\r
292 IN UINT16 TimeoutDefault,\r
293 IN BOOLEAN ConnectAllHappened\r
ed66e1bc 294 );\r
c69dd9df 295\r
296#endif // _PLATFORM_SPECIFIC_BDS_PLATFORM_H_\r