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