data.c revision 1.1.1.1.10.2 1 1.1.1.1.10.2 tls /* $NetBSD: data.c,v 1.1.1.1.10.2 2014/08/20 00:04:24 tls Exp $ */
2 1.1.1.1.10.2 tls
3 1.1.1.1.10.2 tls /*++
4 1.1.1.1.10.2 tls
5 1.1.1.1.10.2 tls Copyright (c) 1998 Intel Corporation
6 1.1.1.1.10.2 tls
7 1.1.1.1.10.2 tls Module Name:
8 1.1.1.1.10.2 tls
9 1.1.1.1.10.2 tls data.c
10 1.1.1.1.10.2 tls
11 1.1.1.1.10.2 tls Abstract:
12 1.1.1.1.10.2 tls
13 1.1.1.1.10.2 tls EFI library global data
14 1.1.1.1.10.2 tls
15 1.1.1.1.10.2 tls
16 1.1.1.1.10.2 tls
17 1.1.1.1.10.2 tls Revision History
18 1.1.1.1.10.2 tls
19 1.1.1.1.10.2 tls --*/
20 1.1.1.1.10.2 tls
21 1.1.1.1.10.2 tls #include "lib.h"
22 1.1.1.1.10.2 tls
23 1.1.1.1.10.2 tls //
24 1.1.1.1.10.2 tls // LibInitialized - TRUE once InitializeLib() is called for the first time
25 1.1.1.1.10.2 tls //
26 1.1.1.1.10.2 tls
27 1.1.1.1.10.2 tls BOOLEAN LibInitialized = FALSE;
28 1.1.1.1.10.2 tls
29 1.1.1.1.10.2 tls //
30 1.1.1.1.10.2 tls // ST - pointer to the EFI system table
31 1.1.1.1.10.2 tls //
32 1.1.1.1.10.2 tls
33 1.1.1.1.10.2 tls EFI_SYSTEM_TABLE *ST;
34 1.1.1.1.10.2 tls
35 1.1.1.1.10.2 tls //
36 1.1.1.1.10.2 tls // BS - pointer to the boot services table
37 1.1.1.1.10.2 tls //
38 1.1.1.1.10.2 tls
39 1.1.1.1.10.2 tls EFI_BOOT_SERVICES *BS;
40 1.1.1.1.10.2 tls
41 1.1.1.1.10.2 tls
42 1.1.1.1.10.2 tls //
43 1.1.1.1.10.2 tls // Default pool allocation type
44 1.1.1.1.10.2 tls //
45 1.1.1.1.10.2 tls
46 1.1.1.1.10.2 tls EFI_MEMORY_TYPE PoolAllocationType = EfiBootServicesData;
47 1.1.1.1.10.2 tls
48 1.1.1.1.10.2 tls //
49 1.1.1.1.10.2 tls // Unicode collation functions that are in use
50 1.1.1.1.10.2 tls //
51 1.1.1.1.10.2 tls
52 1.1.1.1.10.2 tls EFI_UNICODE_COLLATION_INTERFACE LibStubUnicodeInterface = {
53 1.1.1.1.10.2 tls LibStubStriCmp,
54 1.1.1.1.10.2 tls LibStubMetaiMatch,
55 1.1.1.1.10.2 tls LibStubStrLwrUpr,
56 1.1.1.1.10.2 tls LibStubStrLwrUpr,
57 1.1.1.1.10.2 tls NULL, // FatToStr
58 1.1.1.1.10.2 tls NULL, // StrToFat
59 1.1.1.1.10.2 tls NULL // SupportedLanguages
60 1.1.1.1.10.2 tls };
61 1.1.1.1.10.2 tls
62 1.1.1.1.10.2 tls EFI_UNICODE_COLLATION_INTERFACE *UnicodeInterface = &LibStubUnicodeInterface;
63 1.1.1.1.10.2 tls
64 1.1.1.1.10.2 tls //
65 1.1.1.1.10.2 tls // Root device path
66 1.1.1.1.10.2 tls //
67 1.1.1.1.10.2 tls
68 1.1.1.1.10.2 tls EFI_DEVICE_PATH RootDevicePath[] = {
69 1.1.1.1.10.2 tls {END_DEVICE_PATH_TYPE, END_ENTIRE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH,0}}
70 1.1.1.1.10.2 tls };
71 1.1.1.1.10.2 tls
72 1.1.1.1.10.2 tls EFI_DEVICE_PATH EndDevicePath[] = {
73 1.1.1.1.10.2 tls {END_DEVICE_PATH_TYPE, END_ENTIRE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH, 0}}
74 1.1.1.1.10.2 tls };
75 1.1.1.1.10.2 tls
76 1.1.1.1.10.2 tls EFI_DEVICE_PATH EndInstanceDevicePath[] = {
77 1.1.1.1.10.2 tls {END_DEVICE_PATH_TYPE, END_INSTANCE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH, 0}}
78 1.1.1.1.10.2 tls };
79 1.1.1.1.10.2 tls
80 1.1.1.1.10.2 tls
81 1.1.1.1.10.2 tls //
82 1.1.1.1.10.2 tls // EFI IDs
83 1.1.1.1.10.2 tls //
84 1.1.1.1.10.2 tls
85 1.1.1.1.10.2 tls EFI_GUID EfiGlobalVariable = EFI_GLOBAL_VARIABLE;
86 1.1.1.1.10.2 tls EFI_GUID NullGuid = { 0,0,0,{0,0,0,0,0,0,0,0} };
87 1.1.1.1.10.2 tls
88 1.1.1.1.10.2 tls //
89 1.1.1.1.10.2 tls // Protocol IDs
90 1.1.1.1.10.2 tls //
91 1.1.1.1.10.2 tls
92 1.1.1.1.10.2 tls EFI_GUID DevicePathProtocol = DEVICE_PATH_PROTOCOL;
93 1.1.1.1.10.2 tls EFI_GUID LoadedImageProtocol = LOADED_IMAGE_PROTOCOL;
94 1.1.1.1.10.2 tls EFI_GUID TextInProtocol = SIMPLE_TEXT_INPUT_PROTOCOL;
95 1.1.1.1.10.2 tls EFI_GUID TextOutProtocol = SIMPLE_TEXT_OUTPUT_PROTOCOL;
96 1.1.1.1.10.2 tls EFI_GUID BlockIoProtocol = BLOCK_IO_PROTOCOL;
97 1.1.1.1.10.2 tls EFI_GUID DiskIoProtocol = DISK_IO_PROTOCOL;
98 1.1.1.1.10.2 tls EFI_GUID FileSystemProtocol = SIMPLE_FILE_SYSTEM_PROTOCOL;
99 1.1.1.1.10.2 tls EFI_GUID LoadFileProtocol = LOAD_FILE_PROTOCOL;
100 1.1.1.1.10.2 tls EFI_GUID DeviceIoProtocol = DEVICE_IO_PROTOCOL;
101 1.1.1.1.10.2 tls EFI_GUID UnicodeCollationProtocol = UNICODE_COLLATION_PROTOCOL;
102 1.1.1.1.10.2 tls EFI_GUID SerialIoProtocol = SERIAL_IO_PROTOCOL;
103 1.1.1.1.10.2 tls EFI_GUID SimpleNetworkProtocol = EFI_SIMPLE_NETWORK_PROTOCOL;
104 1.1.1.1.10.2 tls EFI_GUID PxeBaseCodeProtocol = EFI_PXE_BASE_CODE_PROTOCOL;
105 1.1.1.1.10.2 tls EFI_GUID PxeCallbackProtocol = EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL;
106 1.1.1.1.10.2 tls EFI_GUID NetworkInterfaceIdentifierProtocol = EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL;
107 1.1.1.1.10.2 tls EFI_GUID UiProtocol = EFI_UI_PROTOCOL;
108 1.1.1.1.10.2 tls EFI_GUID PciIoProtocol = EFI_PCI_IO_PROTOCOL;
109 1.1.1.1.10.2 tls //
110 1.1.1.1.10.2 tls // File system information IDs
111 1.1.1.1.10.2 tls //
112 1.1.1.1.10.2 tls
113 1.1.1.1.10.2 tls EFI_GUID GenericFileInfo = EFI_FILE_INFO_ID;
114 1.1.1.1.10.2 tls EFI_GUID FileSystemInfo = EFI_FILE_SYSTEM_INFO_ID;
115 1.1.1.1.10.2 tls EFI_GUID FileSystemVolumeLabelInfo = EFI_FILE_SYSTEM_VOLUME_LABEL_INFO_ID;
116 1.1.1.1.10.2 tls
117 1.1.1.1.10.2 tls //
118 1.1.1.1.10.2 tls // Reference implementation public protocol IDs
119 1.1.1.1.10.2 tls //
120 1.1.1.1.10.2 tls
121 1.1.1.1.10.2 tls EFI_GUID InternalShellProtocol = INTERNAL_SHELL_GUID;
122 1.1.1.1.10.2 tls EFI_GUID VariableStoreProtocol = VARIABLE_STORE_PROTOCOL;
123 1.1.1.1.10.2 tls EFI_GUID LegacyBootProtocol = LEGACY_BOOT_PROTOCOL;
124 1.1.1.1.10.2 tls EFI_GUID VgaClassProtocol = VGA_CLASS_DRIVER_PROTOCOL;
125 1.1.1.1.10.2 tls
126 1.1.1.1.10.2 tls EFI_GUID TextOutSpliterProtocol = TEXT_OUT_SPLITER_PROTOCOL;
127 1.1.1.1.10.2 tls EFI_GUID ErrorOutSpliterProtocol = ERROR_OUT_SPLITER_PROTOCOL;
128 1.1.1.1.10.2 tls EFI_GUID TextInSpliterProtocol = TEXT_IN_SPLITER_PROTOCOL;
129 1.1.1.1.10.2 tls /* Added for GOP support */
130 1.1.1.1.10.2 tls EFI_GUID GraphicsOutputProtocol = EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID;
131 1.1.1.1.10.2 tls
132 1.1.1.1.10.2 tls EFI_GUID AdapterDebugProtocol = ADAPTER_DEBUG_PROTOCOL;
133 1.1.1.1.10.2 tls
134 1.1.1.1.10.2 tls //
135 1.1.1.1.10.2 tls // Device path media protocol IDs
136 1.1.1.1.10.2 tls //
137 1.1.1.1.10.2 tls EFI_GUID PcAnsiProtocol = DEVICE_PATH_MESSAGING_PC_ANSI;
138 1.1.1.1.10.2 tls EFI_GUID Vt100Protocol = DEVICE_PATH_MESSAGING_VT_100;
139 1.1.1.1.10.2 tls
140 1.1.1.1.10.2 tls //
141 1.1.1.1.10.2 tls // EFI GPT Partition Type GUIDs
142 1.1.1.1.10.2 tls //
143 1.1.1.1.10.2 tls EFI_GUID EfiPartTypeSystemPartitionGuid = EFI_PART_TYPE_EFI_SYSTEM_PART_GUID;
144 1.1.1.1.10.2 tls EFI_GUID EfiPartTypeLegacyMbrGuid = EFI_PART_TYPE_LEGACY_MBR_GUID;
145 1.1.1.1.10.2 tls
146 1.1.1.1.10.2 tls
147 1.1.1.1.10.2 tls //
148 1.1.1.1.10.2 tls // Reference implementation Vendor Device Path Guids
149 1.1.1.1.10.2 tls //
150 1.1.1.1.10.2 tls EFI_GUID UnknownDevice = UNKNOWN_DEVICE_GUID;
151 1.1.1.1.10.2 tls
152 1.1.1.1.10.2 tls //
153 1.1.1.1.10.2 tls // Configuration Table GUIDs
154 1.1.1.1.10.2 tls //
155 1.1.1.1.10.2 tls
156 1.1.1.1.10.2 tls EFI_GUID MpsTableGuid = MPS_TABLE_GUID;
157 1.1.1.1.10.2 tls EFI_GUID AcpiTableGuid = ACPI_TABLE_GUID;
158 1.1.1.1.10.2 tls EFI_GUID SMBIOSTableGuid = SMBIOS_TABLE_GUID;
159 1.1.1.1.10.2 tls EFI_GUID SalSystemTableGuid = SAL_SYSTEM_TABLE_GUID;
160 1.1.1.1.10.2 tls
161 1.1.1.1.10.2 tls //
162 1.1.1.1.10.2 tls // Network protocol GUIDs
163 1.1.1.1.10.2 tls //
164 1.1.1.1.10.2 tls EFI_GUID Ip4ServiceBindingProtocol = EFI_IP4_SERVICE_BINDING_PROTOCOL;
165 1.1.1.1.10.2 tls EFI_GUID Ip4Protocol = EFI_IP4_PROTOCOL;
166 1.1.1.1.10.2 tls EFI_GUID Udp4ServiceBindingProtocol = EFI_UDP4_SERVICE_BINDING_PROTOCOL;
167 1.1.1.1.10.2 tls EFI_GUID Udp4Protocol = EFI_UDP4_PROTOCOL;
168 1.1.1.1.10.2 tls EFI_GUID Tcp4ServiceBindingProtocol = EFI_TCP4_SERVICE_BINDING_PROTOCOL;
169 1.1.1.1.10.2 tls EFI_GUID Tcp4Protocol = EFI_TCP4_PROTOCOL;
170