3 Copyright (c) 2006 - 2007, Intel Corporation
4 All rights reserved. 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>
49 #include <Guid/Acpi.h>
50 #include <Guid/SmBios.h>
52 #include <Guid/HobList.h>
53 #include <Guid/PciExpressBaseAddress.h>
54 #include <Guid/GlobalVariable.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) \
76 HARDWARE_DEVICE_PATH, \
78 (UINT8) (sizeof (PCI_DEVICE_PATH)), \
79 (UINT8) ((sizeof (PCI_DEVICE_PATH)) >> 8), \
84 #define PNPID_DEVICE_PATH_NODE(PnpId) \
88 (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \
89 (UINT8) ((sizeof (ACPI_HID_DEVICE_PATH)) >> 8), \
90 EISA_PNP_ID((PnpId)), \
94 #define gPciRootBridge \
95 PNPID_DEVICE_PATH_NODE(0x0A03)
97 #define gPciIsaBridge \
98 PCI_DEVICE_PATH_NODE(0, 0x1f)
101 PCI_DEVICE_PATH_NODE(0, 0x1e)
103 #define gPnpPs2Keyboard \
104 PNPID_DEVICE_PATH_NODE(0x0303)
106 #define gPnp16550ComPort \
107 PNPID_DEVICE_PATH_NODE(0x0501)
111 MESSAGING_DEVICE_PATH, \
113 (UINT8) (sizeof (UART_DEVICE_PATH)), \
114 (UINT8) ((sizeof (UART_DEVICE_PATH)) >> 8), \
122 #define gPcAnsiTerminal \
124 MESSAGING_DEVICE_PATH, \
126 (UINT8) (sizeof (VENDOR_DEVICE_PATH)), \
127 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8), \
128 DEVICE_PATH_MESSAGING_PC_ANSI \
133 END_DEVICE_PATH_TYPE, \
134 END_ENTIRE_DEVICE_PATH_SUBTYPE, \
135 END_DEVICE_PATH_LENGTH, \
139 #define PCI_CLASS_SCC 0x07
140 #define PCI_SUBCLASS_SERIAL 0x00
141 #define PCI_IF_16550 0x02
142 #define IS_PCI_16550SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550)
144 #define EFI_SYSTEM_TABLE_MAX_ADDRESS 0xFFFFFFFF
145 #define SYS_TABLE_PAD(ptr) (((~ptr) +1) & 0x07 )
147 // Platform Root Bridge
150 ACPI_HID_DEVICE_PATH PciRootBridge
;
151 EFI_DEVICE_PATH_PROTOCOL End
;
152 } PLATFORM_ROOT_BRIDGE_DEVICE_PATH
;
155 ACPI_HID_DEVICE_PATH PciRootBridge
;
156 PCI_DEVICE_PATH IsaBridge
;
157 ACPI_HID_DEVICE_PATH Keyboard
;
158 EFI_DEVICE_PATH_PROTOCOL End
;
159 } PLATFORM_DUMMY_ISA_KEYBOARD_DEVICE_PATH
;
162 ACPI_HID_DEVICE_PATH PciRootBridge
;
163 PCI_DEVICE_PATH IsaBridge
;
164 ACPI_HID_DEVICE_PATH IsaSerial
;
165 UART_DEVICE_PATH Uart
;
166 VENDOR_DEVICE_PATH TerminalType
;
167 EFI_DEVICE_PATH_PROTOCOL End
;
168 } PLATFORM_DUMMY_ISA_SERIAL_DEVICE_PATH
;
171 ACPI_HID_DEVICE_PATH PciRootBridge
;
172 PCI_DEVICE_PATH VgaDevice
;
173 EFI_DEVICE_PATH_PROTOCOL End
;
174 } PLATFORM_DUMMY_PCI_VGA_DEVICE_PATH
;
177 ACPI_HID_DEVICE_PATH PciRootBridge
;
178 PCI_DEVICE_PATH PciBridge
;
179 PCI_DEVICE_PATH SerialDevice
;
180 UART_DEVICE_PATH Uart
;
181 VENDOR_DEVICE_PATH TerminalType
;
182 EFI_DEVICE_PATH_PROTOCOL End
;
183 } PLATFORM_DUMMY_PCI_SERIAL_DEVICE_PATH
;
186 // the short form device path for Usb keyboard
189 #define SUBCLASS_BOOT 1
190 #define PROTOCOL_KEYBOARD 1
193 USB_CLASS_DEVICE_PATH UsbClass
;
194 EFI_DEVICE_PATH_PROTOCOL End
;
195 } USB_CLASS_FORMAT_DEVICE_PATH
;
197 extern PLATFORM_ROOT_BRIDGE_DEVICE_PATH gPlatformRootBridge0
;
200 // Platform BDS Functions
204 IN EFI_BDS_ARCH_PROTOCOL_INSTANCE
*PrivateData
208 PlatformBdsPolicyBehavior (
209 IN EFI_BDS_ARCH_PROTOCOL_INSTANCE
*PrivateData
,
210 IN LIST_ENTRY
*DriverOptionList
,
211 IN LIST_ENTRY
*BootOptionList
215 PlatformBdsGetDriverOption (
216 IN LIST_ENTRY
*BdsDriverLists
221 EXTENDMEM_COVERAGE_LEVEL Level
225 PlatformBdsShowProgress (
226 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleForeground
,
227 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleBackground
,
229 EFI_GRAPHICS_OUTPUT_BLT_PIXEL ProgressColor
,
235 PlatformBdsConnectSequence (
240 PlatformBdsBootFail (
241 IN BDS_COMMON_OPTION
*Option
,
242 IN EFI_STATUS Status
,
244 IN UINTN ExitDataSize
248 PlatformBdsBootSuccess (
249 IN BDS_COMMON_OPTION
*Option
254 EFI_BOOT_MODE BootMode
258 PlatformBdsConnectConsole (
259 IN BDS_CONSOLE_CONNECT_ENTRY
*PlatformConsole
263 PlatformBdsNoConsoleAction (
285 IN EFI_GUID
*TableGuid
,
290 PlatformBdsEnterFrontPage (
291 IN UINT16 TimeoutDefault
,
292 IN BOOLEAN ConnectAllHappened
295 #endif // _PLATFORM_SPECIFIC_BDS_PLATFORM_H_