data.c 5.0 KB

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