2 Platform BDS customizations include file.
4 Copyright (c) 2006 - 2007, Intel Corporation. All rights reserved.<BR>
5 This program and the accompanying materials
6 are licensed and made available under the terms and conditions of the BSD License
7 which accompanies this distribution. The full text of the license may be found at
8 http://opensource.org/licenses/bsd-license.php
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
19 Head file for BDS Platform specific code
23 #ifndef _PLATFORM_SPECIFIC_BDS_PLATFORM_H_
24 #define _PLATFORM_SPECIFIC_BDS_PLATFORM_H_
29 #include <IndustryStandard/Pci.h>
30 #include <IndustryStandard/Acpi.h>
31 #include <IndustryStandard/SmBios.h>
32 #include <IndustryStandard/PeImage.h>
34 #include <Library/DebugLib.h>
35 #include <Library/BaseMemoryLib.h>
36 #include <Library/UefiBootServicesTableLib.h>
37 #include <Library/UefiRuntimeServicesTableLib.h>
38 #include <Library/MemoryAllocationLib.h>
39 #include <Library/BaseLib.h>
40 #include <Library/PcdLib.h>
41 #include <Library/PciLib.h>
42 #include <Library/GenericBdsLib.h>
43 #include <Library/PlatformBdsLib.h>
44 #include <Library/HobLib.h>
45 #include <Library/UefiLib.h>
46 #include <Library/DxeServicesTableLib.h>
47 #include <Library/DevicePathLib.h>
48 #include <Library/IoLib.h>
49 #include <Library/NvVarsFileLib.h>
51 #include <Protocol/Decompress.h>
52 #include <Protocol/PciIo.h>
53 #include <Protocol/FirmwareVolume2.h>
54 #include <Protocol/SimpleFileSystem.h>
56 #include <Guid/Acpi.h>
57 #include <Guid/SmBios.h>
59 #include <Guid/HobList.h>
60 #include <Guid/GlobalVariable.h>
62 #include <OvmfPlatforms.h>
64 extern BDS_CONSOLE_CONNECT_ENTRY gPlatformConsole
[];
65 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformConnectSequence
[];
66 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformDriverOption
[];
67 extern EFI_DEVICE_PATH_PROTOCOL
*gPlatformRootBridges
[];
68 extern ACPI_HID_DEVICE_PATH gPnpPs2KeyboardDeviceNode
;
69 extern ACPI_HID_DEVICE_PATH gPnp16550ComPortDeviceNode
;
70 extern UART_DEVICE_PATH gUartDeviceNode
;
71 extern VENDOR_DEVICE_PATH gTerminalTypeDeviceNode
;
75 #define VarConsoleInpDev L"ConInDev"
76 #define VarConsoleInp L"ConIn"
77 #define VarConsoleOutDev L"ConOutDev"
78 #define VarConsoleOut L"ConOut"
79 #define VarErrorOutDev L"ErrOutDev"
80 #define VarErrorOut L"ErrOut"
82 #define PCI_DEVICE_PATH_NODE(Func, Dev) \
85 HARDWARE_DEVICE_PATH, \
88 (UINT8) (sizeof (PCI_DEVICE_PATH)), \
89 (UINT8) ((sizeof (PCI_DEVICE_PATH)) >> 8) \
96 #define PNPID_DEVICE_PATH_NODE(PnpId) \
102 (UINT8) (sizeof (ACPI_HID_DEVICE_PATH)), \
103 (UINT8) ((sizeof (ACPI_HID_DEVICE_PATH)) >> 8) \
106 EISA_PNP_ID((PnpId)), \
110 #define gPciRootBridge \
111 PNPID_DEVICE_PATH_NODE(0x0A03)
113 #define gPciIsaBridge \
114 PCI_DEVICE_PATH_NODE(0, 0x1f)
117 PCI_DEVICE_PATH_NODE(0, 0x1e)
119 #define gPnpPs2Keyboard \
120 PNPID_DEVICE_PATH_NODE(0x0303)
122 #define gPnp16550ComPort \
123 PNPID_DEVICE_PATH_NODE(0x0501)
128 MESSAGING_DEVICE_PATH, \
131 (UINT8) (sizeof (UART_DEVICE_PATH)), \
132 (UINT8) ((sizeof (UART_DEVICE_PATH)) >> 8) \
142 #define gPcAnsiTerminal \
145 MESSAGING_DEVICE_PATH, \
148 (UINT8) (sizeof (VENDOR_DEVICE_PATH)), \
149 (UINT8) ((sizeof (VENDOR_DEVICE_PATH)) >> 8) \
152 DEVICE_PATH_MESSAGING_PC_ANSI \
157 END_DEVICE_PATH_TYPE, \
158 END_ENTIRE_DEVICE_PATH_SUBTYPE, \
160 END_DEVICE_PATH_LENGTH, \
165 #define PCI_CLASS_SCC 0x07
166 #define PCI_SUBCLASS_SERIAL 0x00
167 #define PCI_IF_16550 0x02
168 #define IS_PCI_16550SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550)
170 #define EFI_SYSTEM_TABLE_MAX_ADDRESS 0xFFFFFFFF
171 #define SYS_TABLE_PAD(ptr) (((~ptr) +1) & 0x07 )
173 #define IS_PCI_ISA_PDECODE(_p) IS_CLASS3 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_ISA_PDECODE, 0)
176 // Platform Root Bridge
179 ACPI_HID_DEVICE_PATH PciRootBridge
;
180 EFI_DEVICE_PATH_PROTOCOL End
;
181 } PLATFORM_ROOT_BRIDGE_DEVICE_PATH
;
184 ACPI_HID_DEVICE_PATH PciRootBridge
;
185 PCI_DEVICE_PATH IsaBridge
;
186 ACPI_HID_DEVICE_PATH Keyboard
;
187 EFI_DEVICE_PATH_PROTOCOL End
;
188 } PLATFORM_DUMMY_ISA_KEYBOARD_DEVICE_PATH
;
191 ACPI_HID_DEVICE_PATH PciRootBridge
;
192 PCI_DEVICE_PATH IsaBridge
;
193 ACPI_HID_DEVICE_PATH IsaSerial
;
194 UART_DEVICE_PATH Uart
;
195 VENDOR_DEVICE_PATH TerminalType
;
196 EFI_DEVICE_PATH_PROTOCOL End
;
197 } PLATFORM_DUMMY_ISA_SERIAL_DEVICE_PATH
;
200 ACPI_HID_DEVICE_PATH PciRootBridge
;
201 PCI_DEVICE_PATH VgaDevice
;
202 EFI_DEVICE_PATH_PROTOCOL End
;
203 } PLATFORM_DUMMY_PCI_VGA_DEVICE_PATH
;
206 ACPI_HID_DEVICE_PATH PciRootBridge
;
207 PCI_DEVICE_PATH PciBridge
;
208 PCI_DEVICE_PATH SerialDevice
;
209 UART_DEVICE_PATH Uart
;
210 VENDOR_DEVICE_PATH TerminalType
;
211 EFI_DEVICE_PATH_PROTOCOL End
;
212 } PLATFORM_DUMMY_PCI_SERIAL_DEVICE_PATH
;
215 // the short form device path for Usb keyboard
218 #define SUBCLASS_BOOT 1
219 #define PROTOCOL_KEYBOARD 1
222 USB_CLASS_DEVICE_PATH UsbClass
;
223 EFI_DEVICE_PATH_PROTOCOL End
;
224 } USB_CLASS_FORMAT_DEVICE_PATH
;
226 extern PLATFORM_ROOT_BRIDGE_DEVICE_PATH gPlatformRootBridge0
;
229 // Platform BDS Functions
233 PlatformBdsGetDriverOption (
234 IN LIST_ENTRY
*BdsDriverLists
239 EXTENDMEM_COVERAGE_LEVEL Level
243 PlatformBdsShowProgress (
244 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleForeground
,
245 EFI_GRAPHICS_OUTPUT_BLT_PIXEL TitleBackground
,
247 EFI_GRAPHICS_OUTPUT_BLT_PIXEL ProgressColor
,
253 PlatformBdsConnectSequence (
259 EFI_BOOT_MODE BootMode
263 PlatformBdsConnectConsole (
264 IN BDS_CONSOLE_CONNECT_ENTRY
*PlatformConsole
268 PlatformBdsNoConsoleAction (
290 IN EFI_GUID
*TableGuid
,
295 PlatformBdsEnterFrontPage (
296 IN UINT16 TimeoutDefault
,
297 IN BOOLEAN ConnectAllHappened
301 Loads and boots UEFI Linux via the FwCfg interface.
303 @retval EFI_NOT_FOUND - The Linux kernel was not found
307 TryRunningQemuKernel (
311 #endif // _PLATFORM_SPECIFIC_BDS_PLATFORM_H_