3 Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR>
4 This program and the accompanying materials
5 are licensed and made available under the terms and conditions of the BSD License
6 which accompanies this distribution. The full text of the license may be found at
7 http://opensource.org/licenses/bsd-license.php
9 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
10 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
18 Head file for BDS Platform specific code
22 #ifndef _PLATFORM_SPECIFIC_BDS_PLATFORM_H_
23 #define _PLATFORM_SPECIFIC_BDS_PLATFORM_H_
28 #include <IndustryStandard/Pci.h>
29 #include <IndustryStandard/Acpi.h>
30 #include <IndustryStandard/SmBios.h>
31 #include <IndustryStandard/LegacyBiosMpTable.h>
33 #include <Library/DebugLib.h>
34 #include <Library/BaseMemoryLib.h>
35 #include <Library/UefiBootServicesTableLib.h>
36 #include <Library/MemoryAllocationLib.h>
37 #include <Library/BaseLib.h>
38 #include <Library/PcdLib.h>
39 #include <Library/GenericBdsLib.h>
40 #include <Library/PlatformBdsLib.h>
41 #include <Library/HobLib.h>
42 #include <Library/UefiLib.h>
43 #include <Library/DxeServicesTableLib.h>
44 #include <Library/DevicePathLib.h>
46 #include <Protocol/PciIo.h>
48 #include <Guid/Acpi.h>
49 #include <Guid/SmBios.h>
51 #include <Guid/HobList.h>
52 #include <Guid/PciExpressBaseAddress.h>
53 #include <Guid/GlobalVariable.h>
54 #include <Guid/LdrMemoryDescriptor.h>
56 extern BDS_CONSOLE_CONNECT_ENTRY gPlatformConsole
[];
57 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformConnectSequence
[];
58 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformDriverOption
[];
59 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformRootBridges
[];
60 extern ACPI_HID_DEVICE_PATH gPnpPs2KeyboardDeviceNode
;
61 extern ACPI_HID_DEVICE_PATH gPnp16550ComPortDeviceNode
;
62 extern UART_DEVICE_PATH gUartDeviceNode
;
63 extern VENDOR_DEVICE_PATH gTerminalTypeDeviceNode
;
67 #define VarConsoleInpDev L"ConInDev"
68 #define VarConsoleInp L"ConIn"
69 #define VarConsoleOutDev L"ConOutDev"
70 #define VarConsoleOut L"ConOut"
71 #define VarErrorOutDev L"ErrOutDev"
72 #define VarErrorOut L"ErrOut"
74 #define PCI_DEVICE_PATH_NODE(Func, Dev) \
77 HARDWARE_DEVICE_PATH, \
80 (UINT8) (sizeof (PCI_DEVICE_PATH)), \
81 (UINT8) ((sizeof (PCI_DEVICE_PATH)) >> 8) \
88 #define PNPID_DEVICE_PATH_NODE(PnpId) \
94 (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \
95 (UINT8) ((sizeof (ACPI_HID_DEVICE_PATH)) >> 8) \
98 EISA_PNP_ID((PnpId)), \
102 #define gPciRootBridge \
103 PNPID_DEVICE_PATH_NODE(0x0A03)
105 #define gPciIsaBridge \
106 PCI_DEVICE_PATH_NODE(0, 0x1f)
109 PCI_DEVICE_PATH_NODE(0, 0x1e)
111 #define gPnpPs2Keyboard \
112 PNPID_DEVICE_PATH_NODE(0x0303)
114 #define gPnp16550ComPort \
115 PNPID_DEVICE_PATH_NODE(0x0501)
120 MESSAGING_DEVICE_PATH, \
123 (UINT8) (sizeof (UART_DEVICE_PATH)), \
124 (UINT8) ((sizeof (UART_DEVICE_PATH)) >> 8) \
134 #define gPcAnsiTerminal \
137 MESSAGING_DEVICE_PATH, \
140 (UINT8) (sizeof (VENDOR_DEVICE_PATH)), \
141 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8) \
144 DEVICE_PATH_MESSAGING_PC_ANSI \
149 END_DEVICE_PATH_TYPE, \
150 END_ENTIRE_DEVICE_PATH_SUBTYPE, \
152 END_DEVICE_PATH_LENGTH, \
157 #define PCI_CLASS_SCC 0x07
158 #define PCI_SUBCLASS_SERIAL 0x00
159 #define PCI_IF_16550 0x02
160 #define IS_PCI_16550SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550)
162 #define EFI_SYSTEM_TABLE_MAX_ADDRESS 0xFFFFFFFF
163 #define SYS_TABLE_PAD(ptr) (((~ptr) +1) & 0x07 )
165 // Platform Root Bridge
168 ACPI_HID_DEVICE_PATH PciRootBridge
;
169 EFI_DEVICE_PATH_PROTOCOL End
;
170 } PLATFORM_ROOT_BRIDGE_DEVICE_PATH
;
173 ACPI_HID_DEVICE_PATH PciRootBridge
;
174 PCI_DEVICE_PATH IsaBridge
;
175 ACPI_HID_DEVICE_PATH Keyboard
;
176 EFI_DEVICE_PATH_PROTOCOL End
;
177 } PLATFORM_DUMMY_ISA_KEYBOARD_DEVICE_PATH
;
180 ACPI_HID_DEVICE_PATH PciRootBridge
;
181 PCI_DEVICE_PATH IsaBridge
;
182 ACPI_HID_DEVICE_PATH IsaSerial
;
183 UART_DEVICE_PATH Uart
;
184 VENDOR_DEVICE_PATH TerminalType
;
185 EFI_DEVICE_PATH_PROTOCOL End
;
186 } PLATFORM_DUMMY_ISA_SERIAL_DEVICE_PATH
;
189 ACPI_HID_DEVICE_PATH PciRootBridge
;
190 PCI_DEVICE_PATH VgaDevice
;
191 EFI_DEVICE_PATH_PROTOCOL End
;
192 } PLATFORM_DUMMY_PCI_VGA_DEVICE_PATH
;
195 ACPI_HID_DEVICE_PATH PciRootBridge
;
196 PCI_DEVICE_PATH PciBridge
;
197 PCI_DEVICE_PATH SerialDevice
;
198 UART_DEVICE_PATH Uart
;
199 VENDOR_DEVICE_PATH TerminalType
;
200 EFI_DEVICE_PATH_PROTOCOL End
;
201 } PLATFORM_DUMMY_PCI_SERIAL_DEVICE_PATH
;
204 // the short form device path for Usb keyboard
207 #define SUBCLASS_BOOT 1
208 #define PROTOCOL_KEYBOARD 1
211 USB_CLASS_DEVICE_PATH UsbClass
;
212 EFI_DEVICE_PATH_PROTOCOL End
;
213 } USB_CLASS_FORMAT_DEVICE_PATH
;
215 extern PLATFORM_ROOT_BRIDGE_DEVICE_PATH gPlatformRootBridge0
;
218 // Platform BDS Functions
221 PlatformBdsGetDriverOption (
222 IN LIST_ENTRY
*BdsDriverLists
227 EXTENDMEM_COVERAGE_LEVEL Level
231 PlatformBdsShowProgress (
232 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleForeground
,
233 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleBackground
,
235 EFI_GRAPHICS_OUTPUT_BLT_PIXEL ProgressColor
,
241 PlatformBdsConnectSequence (
247 EFI_BOOT_MODE BootMode
251 PlatformBdsConnectConsole (
252 IN BDS_CONSOLE_CONNECT_ENTRY
*PlatformConsole
256 PlatformBdsNoConsoleAction (
278 IN EFI_GUID
*TableGuid
,
283 PlatformBdsEnterFrontPage (
284 IN UINT16 TimeoutDefault
,
285 IN BOOLEAN ConnectAllHappened
288 #endif // _PLATFORM_SPECIFIC_BDS_PLATFORM_H_