data.c revision 1.1.1.1.36.1 1 /* $NetBSD: data.c,v 1.1.1.1.36.1 2019/06/10 22:08:36 christos Exp $ */
2
3 /*++
4
5 Copyright (c) 1998 Intel Corporation
6
7 Module Name:
8
9 data.c
10
11 Abstract:
12
13 EFI library global data
14
15
16
17 Revision History
18
19 --*/
20
21 #include "lib.h"
22
23 //
24 // LibInitialized - TRUE once InitializeLib() is called for the first time
25 //
26
27 BOOLEAN LibInitialized = FALSE;
28
29 //
30 // ImageHandle - Current ImageHandle, as passed to InitializeLib
31 //
32 EFI_HANDLE LibImageHandle;
33
34 //
35 // ST - pointer to the EFI system table
36 //
37
38 EFI_SYSTEM_TABLE *ST;
39
40 //
41 // BS - pointer to the boot services table
42 //
43
44 EFI_BOOT_SERVICES *BS;
45
46
47 //
48 // Default pool allocation type
49 //
50
51 EFI_MEMORY_TYPE PoolAllocationType = EfiBootServicesData;
52
53 //
54 // Unicode collation functions that are in use
55 //
56
57 EFI_UNICODE_COLLATION_INTERFACE LibStubUnicodeInterface = {
58 LibStubStriCmp,
59 LibStubMetaiMatch,
60 LibStubStrLwrUpr,
61 LibStubStrLwrUpr,
62 NULL, // FatToStr
63 NULL, // StrToFat
64 NULL // SupportedLanguages
65 };
66
67 EFI_UNICODE_COLLATION_INTERFACE *UnicodeInterface = &LibStubUnicodeInterface;
68
69 //
70 // Root device path
71 //
72
73 EFI_DEVICE_PATH RootDevicePath[] = {
74 {END_DEVICE_PATH_TYPE, END_ENTIRE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH,0}}
75 };
76
77 EFI_DEVICE_PATH EndDevicePath[] = {
78 {END_DEVICE_PATH_TYPE, END_ENTIRE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH, 0}}
79 };
80
81 EFI_DEVICE_PATH EndInstanceDevicePath[] = {
82 {END_DEVICE_PATH_TYPE, END_INSTANCE_DEVICE_PATH_SUBTYPE, {END_DEVICE_PATH_LENGTH, 0}}
83 };
84
85
86 //
87 // EFI IDs
88 //
89
90 EFI_GUID gEfiGlobalVariableGuid = EFI_GLOBAL_VARIABLE;
91 EFI_GUID NullGuid = { 0,0,0,{0,0,0,0,0,0,0,0} };
92
93 //
94 // Protocol IDs
95 //
96
97 EFI_GUID gEfiDevicePathProtocolGuid = EFI_DEVICE_PATH_PROTOCOL_GUID;
98 EFI_GUID gEfiDevicePathToTextProtocolGuid = EFI_DEVICE_PATH_TO_TEXT_PROTOCOL_GUID;
99 EFI_GUID gEfiDevicePathFromTextProtocolGuid = EFI_DEVICE_PATH_FROM_TEXT_PROTOCOL_GUID;
100 EFI_GUID gEfiLoadedImageProtocolGuid = EFI_LOADED_IMAGE_PROTOCOL_GUID;
101 EFI_GUID gEfiSimpleTextInProtocolGuid = EFI_SIMPLE_TEXT_INPUT_PROTOCOL_GUID;
102 EFI_GUID gEfiSimpleTextOutProtocolGuid = EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL_GUID;
103 EFI_GUID gEfiBlockIoProtocolGuid = EFI_BLOCK_IO_PROTOCOL_GUID;
104 EFI_GUID gEfiBlockIo2ProtocolGuid = EFI_BLOCK_IO2_PROTOCOL_GUID;
105 EFI_GUID gEfiDiskIoProtocolGuid = EFI_DISK_IO_PROTOCOL_GUID;
106 EFI_GUID gEfiDiskIo2ProtocolGuid = EFI_DISK_IO2_PROTOCOL_GUID;
107 EFI_GUID gEfiSimpleFileSystemProtocolGuid = EFI_SIMPLE_FILE_SYSTEM_PROTOCOL_GUID;
108 EFI_GUID gEfiLoadFileProtocolGuid = EFI_LOAD_FILE_PROTOCOL_GUID;
109 EFI_GUID gEfiDeviceIoProtocolGuid = EFI_DEVICE_IO_PROTOCOL_GUID;
110 EFI_GUID gEfiUnicodeCollationProtocolGuid = EFI_UNICODE_COLLATION_PROTOCOL_GUID;
111 EFI_GUID gEfiSerialIoProtocolGuid = EFI_SERIAL_IO_PROTOCOL_GUID;
112 EFI_GUID gEfiSimpleNetworkProtocolGuid = EFI_SIMPLE_NETWORK_PROTOCOL_GUID;
113 EFI_GUID gEfiPxeBaseCodeProtocolGuid = EFI_PXE_BASE_CODE_PROTOCOL_GUID;
114 EFI_GUID gEfiPxeBaseCodeCallbackProtocolGuid = EFI_PXE_BASE_CODE_CALLBACK_PROTOCOL_GUID;
115 EFI_GUID gEfiNetworkInterfaceIdentifierProtocolGuid = EFI_NETWORK_INTERFACE_IDENTIFIER_PROTOCOL_GUID;
116 EFI_GUID gEFiUiInterfaceProtocolGuid = EFI_UI_INTERFACE_PROTOCOL_GUID;
117 EFI_GUID gEfiPciIoProtocolGuid = EFI_PCI_IO_PROTOCOL_GUID;
118 EFI_GUID gEfiPciRootBridgeIoProtocolGuid = EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_GUID;
119 EFI_GUID gEfiDriverBindingProtocolGuid = EFI_DRIVER_BINDING_PROTOCOL_GUID;
120 EFI_GUID gEfiComponentNameProtocolGuid = EFI_COMPONENT_NAME_PROTOCOL_GUID;
121 EFI_GUID gEfiComponentName2ProtocolGuid = EFI_COMPONENT_NAME2_PROTOCOL_GUID;
122 EFI_GUID gEfiHashProtocolGuid = EFI_HASH_PROTOCOL_GUID;
123 EFI_GUID gEfiPlatformDriverOverrideProtocolGuid = EFI_PLATFORM_DRIVER_OVERRIDE_PROTOCOL_GUID;
124 EFI_GUID gEfiBusSpecificDriverOverrideProtocolGuid = EFI_BUS_SPECIFIC_DRIVER_OVERRIDE_PROTOCOL_GUID;
125 EFI_GUID gEfiDriverFamilyOverrideProtocolGuid = EFI_DRIVER_FAMILY_OVERRIDE_PROTOCOL_GUID;
126 EFI_GUID gEfiEbcProtocolGuid = EFI_EBC_PROTOCOL_GUID;
127
128 //
129 // File system information IDs
130 //
131
132 EFI_GUID gEfiFileInfoGuid = EFI_FILE_INFO_ID;
133 EFI_GUID gEfiFileSystemInfoGuid = EFI_FILE_SYSTEM_INFO_ID;
134 EFI_GUID gEfiFileSystemVolumeLabelInfoIdGuid = EFI_FILE_SYSTEM_VOLUME_LABEL_INFO_ID;
135
136 //
137 // Reference implementation public protocol IDs
138 //
139
140 EFI_GUID InternalShellProtocol = INTERNAL_SHELL_GUID;
141 EFI_GUID VariableStoreProtocol = VARIABLE_STORE_PROTOCOL;
142 EFI_GUID LegacyBootProtocol = LEGACY_BOOT_PROTOCOL;
143 EFI_GUID VgaClassProtocol = VGA_CLASS_DRIVER_PROTOCOL;
144
145 EFI_GUID TextOutSpliterProtocol = TEXT_OUT_SPLITER_PROTOCOL;
146 EFI_GUID ErrorOutSpliterProtocol = ERROR_OUT_SPLITER_PROTOCOL;
147 EFI_GUID TextInSpliterProtocol = TEXT_IN_SPLITER_PROTOCOL;
148 /* Added for GOP support */
149 EFI_GUID gEfiGraphicsOutputProtocolGuid = EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID;
150 EFI_GUID gEfiEdidDiscoveredProtocolGuid = EFI_EDID_DISCOVERED_PROTOCOL_GUID;
151 EFI_GUID gEfiEdidActiveProtocolGuid = EFI_EDID_ACTIVE_PROTOCOL_GUID;
152 EFI_GUID gEfiEdidOverrideProtocolGuid = EFI_EDID_OVERRIDE_PROTOCOL_GUID;
153
154 EFI_GUID AdapterDebugProtocol = ADAPTER_DEBUG_PROTOCOL;
155
156 //
157 // Device path media protocol IDs
158 //
159 EFI_GUID gEfiPcAnsiGuid = EFI_PC_ANSI_GUID;
160 EFI_GUID gEfiVT100Guid = EFI_VT_100_GUID;
161 EFI_GUID gEfiVT100PlusGuid = EFI_VT_100_PLUS_GUID;
162 EFI_GUID gEfiVTUTF8Guid = EFI_VT_UTF8_GUID;
163
164 //
165 // EFI GPT Partition Type GUIDs
166 //
167 EFI_GUID EfiPartTypeSystemPartitionGuid = EFI_PART_TYPE_EFI_SYSTEM_PART_GUID;
168 EFI_GUID EfiPartTypeLegacyMbrGuid = EFI_PART_TYPE_LEGACY_MBR_GUID;
169
170
171 //
172 // Reference implementation Vendor Device Path Guids
173 //
174 EFI_GUID UnknownDevice = UNKNOWN_DEVICE_GUID;
175
176 //
177 // Configuration Table GUIDs
178 //
179
180 EFI_GUID MpsTableGuid = MPS_TABLE_GUID;
181 EFI_GUID AcpiTableGuid = ACPI_TABLE_GUID;
182 EFI_GUID SMBIOSTableGuid = SMBIOS_TABLE_GUID;
183 EFI_GUID SalSystemTableGuid = SAL_SYSTEM_TABLE_GUID;
184
185 //
186 // Network protocol GUIDs
187 //
188 EFI_GUID Ip4ServiceBindingProtocol = EFI_IP4_SERVICE_BINDING_PROTOCOL;
189 EFI_GUID Ip4Protocol = EFI_IP4_PROTOCOL;
190 EFI_GUID Udp4ServiceBindingProtocol = EFI_UDP4_SERVICE_BINDING_PROTOCOL;
191 EFI_GUID Udp4Protocol = EFI_UDP4_PROTOCOL;
192 EFI_GUID Tcp4ServiceBindingProtocol = EFI_TCP4_SERVICE_BINDING_PROTOCOL;
193 EFI_GUID Tcp4Protocol = EFI_TCP4_PROTOCOL;
194
195 //
196 // Pointer protocol GUIDs
197 //
198 EFI_GUID SimplePointerProtocol = EFI_SIMPLE_POINTER_PROTOCOL_GUID;
199 EFI_GUID AbsolutePointerProtocol = EFI_ABSOLUTE_POINTER_PROTOCOL_GUID;
200
201 //
202 // Debugger protocol GUIDs
203 //
204 EFI_GUID gEfiDebugImageInfoTableGuid = EFI_DEBUG_IMAGE_INFO_TABLE_GUID;
205 EFI_GUID gEfiDebugSupportProtocolGuid = EFI_DEBUG_SUPPORT_PROTOCOL_GUID;
206