vendorcode/intel: Remove UDK2015 headers
The headers are now unused, drop them. Change-Id: Ibfaa3029ddc614935481ce736c9d971bf4831b5d Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/62992 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
This commit is contained in:
		
				
					committed by
					
						 Felix Held
						Felix Held
					
				
			
			
				
	
			
			
			
						parent
						
							05ca05466c
						
					
				
				
					commit
					d7803c89b6
				
			| @@ -7,10 +7,6 @@ config UEFI_2_4_BINDING | ||||
| 	def_bool n | ||||
| 	select UDK_BASE | ||||
|  | ||||
| config UDK_2015_BINDING | ||||
| 	def_bool n | ||||
| 	select UDK_BASE | ||||
|  | ||||
| config UDK_2017_BINDING | ||||
| 	def_bool n | ||||
| 	select UDK_BASE | ||||
| @@ -28,10 +24,6 @@ config UDK_2013_VERSION | ||||
| 	int | ||||
| 	default 2013 | ||||
|  | ||||
| config UDK_2015_VERSION | ||||
| 	int | ||||
| 	default 2015 | ||||
|  | ||||
| config UDK_2017_VERSION | ||||
| 	int | ||||
| 	default 2017 | ||||
| @@ -49,7 +41,6 @@ config UDK_VERSION | ||||
| 	default UDK_202111_VERSION if UDK_202111_BINDING | ||||
| 	default UDK_202005_VERSION if UDK_202005_BINDING | ||||
| 	default UDK_2017_VERSION if UDK_2017_BINDING | ||||
| 	default UDK_2015_VERSION if UDK_2015_BINDING | ||||
| 	default UDK_2013_VERSION | ||||
| 	help | ||||
| 	  UEFI Development Kit version for Platform | ||||
|   | ||||
| @@ -9,11 +9,6 @@ ifeq ($(CONFIG_UEFI_2_4_BINDING),y) | ||||
| CPPFLAGS_x86_32 += -I$(src)/vendorcode/intel/edk2/uefi_2.4/MdePkg/Include/Ia32 | ||||
| CPPFLAGS_x86_64 += -I$(src)/vendorcode/intel/edk2/uefi_2.4/MdePkg/Include/X64 | ||||
| CPPFLAGS_common += -I$(src)/vendorcode/intel/edk2/uefi_2.4/MdePkg/Include | ||||
| else ifeq ($(CONFIG_UDK_2015_BINDING),y) | ||||
| CPPFLAGS_x86_32 += -I$(src)/vendorcode/intel/edk2/UDK2015/MdePkg/Include/Ia32 | ||||
| CPPFLAGS_x86_64 += -I$(src)/vendorcode/intel/edk2/UDK2015/MdePkg/Include/X64 | ||||
| CPPFLAGS_common += -I$(src)/vendorcode/intel/edk2/UDK2015/MdePkg/Include | ||||
| CPPFLAGS_common += -I$(src)/vendorcode/intel/edk2/UDK2015/IntelFsp2Pkg/Include | ||||
| else ifeq ($(CONFIG_UDK_2017_BINDING),y) | ||||
| CPPFLAGS_x86_32 += -I$(src)/vendorcode/intel/edk2/UDK2017/MdePkg/Include/Ia32 | ||||
| CPPFLAGS_x86_64 += -I$(src)/vendorcode/intel/edk2/UDK2017/MdePkg/Include/X64 | ||||
|   | ||||
| @@ -1,32 +0,0 @@ | ||||
| /** @file | ||||
|   The header file of FSP data table | ||||
|  | ||||
|   Copyright (c) 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_DATA_TABLE_H_ | ||||
| #define _FSP_DATA_TABLE_H_ | ||||
|  | ||||
| #pragma pack(1) | ||||
|  | ||||
| #define FSP_DATA_SIGNATURE  SIGNATURE_32 ('F', 'S', 'P', 'D') | ||||
|  | ||||
| typedef struct  { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
|   UINT32  FsptBase; | ||||
|   UINT32  FspmBase; | ||||
|   UINT32  FspsBase; | ||||
| } FSP_DATA_TABLE; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
| @@ -1,24 +0,0 @@ | ||||
| /** @file | ||||
|   Intel FSP definition from Intel Firmware Support Package External | ||||
|   Architecture Specification v2.0. | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_EAS_H_ | ||||
| #define _FSP_EAS_H_ | ||||
|  | ||||
| #include <Uefi.h> | ||||
| #include <Guid/GuidHobFspEas.h> | ||||
| #include <Guid/FspHeaderFile.h> | ||||
| #include <FspEas/FspApi.h> | ||||
|  | ||||
| #endif | ||||
| @@ -1,296 +0,0 @@ | ||||
| /** @file | ||||
|   Intel FSP API definition from Intel Firmware Support Package External | ||||
|   Architecture Specification v2.0. | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_API_H_ | ||||
| #define _FSP_API_H_ | ||||
|  | ||||
| /// | ||||
| /// FSP Reset Status code | ||||
| /// These are defined in FSP EAS v2.0 section 11.2.2 - OEM Status Code | ||||
| /// @{ | ||||
| #define FSP_STATUS_RESET_REQUIRED_COLD         0x40000001 | ||||
| #define FSP_STATUS_RESET_REQUIRED_WARM         0x40000002 | ||||
| #define FSP_STATUS_RESET_REQUIRED_3            0x40000003 | ||||
| #define FSP_STATUS_RESET_REQUIRED_4            0x40000004 | ||||
| #define FSP_STATUS_RESET_REQUIRED_5            0x40000005 | ||||
| #define FSP_STATUS_RESET_REQUIRED_6            0x40000006 | ||||
| #define FSP_STATUS_RESET_REQUIRED_7            0x40000007 | ||||
| #define FSP_STATUS_RESET_REQUIRED_8            0x40000008 | ||||
| /// @} | ||||
|  | ||||
| #pragma pack(1) | ||||
| /// | ||||
| /// FSP_UPD_HEADER Configuration. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// UPD Region Signature. This signature will be | ||||
|   /// "XXXXXX_T" for FSP-T | ||||
|   /// "XXXXXX_M" for FSP-M | ||||
|   /// "XXXXXX_S" for FSP-S | ||||
|   /// Where XXXXXX is an unique signature | ||||
|   /// | ||||
|   UINT64                      Signature; | ||||
|   /// | ||||
|   /// Revision of the Data structure. For FSP v2.0 value is 1. | ||||
|   /// | ||||
|   UINT8                       Revision; | ||||
|   UINT8                       Reserved[23]; | ||||
| } FSP_UPD_HEADER; | ||||
|  | ||||
| #if CONFIG(PLATFORM_USES_FSP2_X86_32) | ||||
| /// | ||||
| /// FSPM_ARCH_UPD Configuration. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Revision of the structure. For FSP v2.0 value is 1. | ||||
|   /// | ||||
|   UINT8                       Revision; | ||||
|   UINT8                       Reserved[3]; | ||||
|   /// | ||||
|   /// Pointer to the non-volatile storage (NVS) data buffer. | ||||
|   /// If it is NULL it indicates the NVS data is not available. | ||||
|   /// | ||||
|   /// Note: This ought to be VOID*, but that won't allow calling this binary on x86_64. | ||||
|   /// | ||||
|   UINT32                      NvsBufferPtr; | ||||
|   /// | ||||
|   /// Pointer to the temporary stack base address to be | ||||
|   /// consumed inside FspMemoryInit() API. | ||||
|   /// | ||||
|   /// Note: This ought to be VOID*, but that won't allow calling this binary on x86_64. | ||||
|   /// | ||||
|   UINT32                      StackBase; | ||||
|   /// | ||||
|   /// Temporary stack size to be consumed inside | ||||
|   /// FspMemoryInit() API. | ||||
|   /// | ||||
|   UINT32                      StackSize; | ||||
|   /// | ||||
|   /// Size of memory to be reserved by FSP below "top | ||||
|   /// of low usable memory" for bootloader usage. | ||||
|   /// | ||||
|   UINT32                      BootLoaderTolumSize; | ||||
|   /// | ||||
|   /// Current boot mode. | ||||
|   /// | ||||
|   UINT32                      BootMode; | ||||
|   UINT8                       Reserved1[8]; | ||||
| } FSPM_ARCH_UPD; | ||||
| #else | ||||
| #error You need to implement this struct for x86_64 FSP | ||||
| #endif | ||||
|  | ||||
| /// | ||||
| /// FSPT_UPD_COMMON Configuration. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// FSP_UPD_HEADER Configuration. | ||||
|   /// | ||||
|   FSP_UPD_HEADER              FspUpdHeader; | ||||
| } FSPT_UPD_COMMON; | ||||
|  | ||||
| /// | ||||
| /// FSPM_UPD_COMMON Configuration. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// FSP_UPD_HEADER Configuration. | ||||
|   /// | ||||
|   FSP_UPD_HEADER              FspUpdHeader; | ||||
|   /// | ||||
|   /// FSPM_ARCH_UPD Configuration. | ||||
|   /// | ||||
|   FSPM_ARCH_UPD               FspmArchUpd; | ||||
| } FSPM_UPD_COMMON; | ||||
|  | ||||
| /// | ||||
| /// FSPS_UPD_COMMON Configuration. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// FSP_UPD_HEADER Configuration. | ||||
|   /// | ||||
|   FSP_UPD_HEADER              FspUpdHeader; | ||||
| } FSPS_UPD_COMMON; | ||||
|  | ||||
| /// | ||||
| /// Enumeration of FSP_INIT_PHASE for NOTIFY_PHASE. | ||||
| /// | ||||
| typedef enum { | ||||
|   /// | ||||
|   /// This stage is notified when the bootloader completes the | ||||
|   /// PCI enumeration and the resource allocation for the | ||||
|   /// PCI devices is complete. | ||||
|   /// | ||||
|   EnumInitPhaseAfterPciEnumeration = 0x20, | ||||
|   /// | ||||
|   /// This stage is notified just before the bootloader hand-off | ||||
|   /// to the OS loader. | ||||
|   /// | ||||
|   EnumInitPhaseReadyToBoot         = 0x40, | ||||
|   /// | ||||
|   /// This stage is notified just before the firmware/Preboot | ||||
|   /// environment transfers management of all system resources | ||||
|   /// to the OS or next level execution environment. | ||||
|   /// | ||||
|   EnumInitPhaseEndOfFirmware       = 0xF0 | ||||
| } FSP_INIT_PHASE; | ||||
|  | ||||
| /// | ||||
| /// Definition of NOTIFY_PHASE_PARAMS. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Notification phase used for NotifyPhase API | ||||
|   /// | ||||
|   FSP_INIT_PHASE     Phase; | ||||
| } NOTIFY_PHASE_PARAMS; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| /** | ||||
|   This FSP API is called soon after coming out of reset and before memory and stack is | ||||
|   available. This FSP API will load the microcode update, enable code caching for the | ||||
|   region specified by the boot loader and also setup a temporary stack to be used until | ||||
|   main memory is initialized. | ||||
|  | ||||
|   A hardcoded stack can be set up with the following values, and the "esp" register | ||||
|   initialized to point to this hardcoded stack. | ||||
|   1. The return address where the FSP will return control after setting up a temporary | ||||
|      stack. | ||||
|   2. A pointer to the input parameter structure | ||||
|  | ||||
|   However, since the stack is in ROM and not writeable, this FSP API cannot be called | ||||
|   using the "call" instruction, but needs to be jumped to. | ||||
|  | ||||
|   @param[in] FsptUpdDataPtr     Pointer to the FSPT_UPD data structure. | ||||
|  | ||||
|   @retval EFI_SUCCESS           Temporary RAM was initialized successfully. | ||||
|   @retval EFI_INVALID_PARAMETER Input parameters are invalid. | ||||
|   @retval EFI_UNSUPPORTED       The FSP calling conditions were not met. | ||||
|   @retval EFI_DEVICE_ERROR      Temp RAM initialization failed. | ||||
|  | ||||
|   If this function is successful, the FSP initializes the ECX and EDX registers to point to | ||||
|   a temporary but writeable memory range available to the boot loader and returns with | ||||
|   FSP_SUCCESS in register EAX. Register ECX points to the start of this temporary | ||||
|   memory range and EDX points to the end of the range. Boot loader is free to use the | ||||
|   whole range described. Typically the boot loader can reload the ESP register to point | ||||
|   to the end of this returned range so that it can be used as a standard stack. | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *FSP_TEMP_RAM_INIT) ( | ||||
|   IN  VOID    *FsptUpdDataPtr | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   This FSP API is used to notify the FSP about the different phases in the boot process. | ||||
|   This allows the FSP to take appropriate actions as needed during different initialization | ||||
|   phases. The phases will be platform dependent and will be documented with the FSP | ||||
|   release. The current FSP supports two notify phases: | ||||
|     Post PCI enumeration | ||||
|     Ready To Boot | ||||
|  | ||||
|   @param[in] NotifyPhaseParamPtr Address pointer to the NOTIFY_PHASE_PRAMS | ||||
|  | ||||
|   @retval EFI_SUCCESS           The notification was handled successfully. | ||||
|   @retval EFI_UNSUPPORTED       The notification was not called in the proper order. | ||||
|   @retval EFI_INVALID_PARAMETER The notification code is invalid. | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *FSP_NOTIFY_PHASE) ( | ||||
|   IN NOTIFY_PHASE_PARAMS *NotifyPhaseParamPtr | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   This FSP API is called after TempRamInit and initializes the memory. | ||||
|   This FSP API accepts a pointer to a data structure that will be platform dependent | ||||
|   and defined for each FSP binary. This will be documented in Integration guide with | ||||
|   each FSP release. | ||||
|   After FspMemInit completes its execution, it passes the pointer to the HobList and | ||||
|   returns to the boot loader from where it was called. BootLoader is responsible to | ||||
|   migrate it's stack and data to Memory. | ||||
|   FspMemoryInit, TempRamExit and FspSiliconInit APIs provide an alternate method to | ||||
|   complete the silicon initialization and provides bootloader an opportunity to get | ||||
|   control after system memory is available and before the temporary RAM is torn down. | ||||
|  | ||||
|   @param[in]  FspmUpdDataPtr          Pointer to the FSPM_UPD data sructure. | ||||
|   @param[out] HobListPtr              Pointer to receive the address of the HOB list. | ||||
|  | ||||
|   @retval EFI_SUCCESS                 FSP execution environment was initialized successfully. | ||||
|   @retval EFI_INVALID_PARAMETER       Input parameters are invalid. | ||||
|   @retval EFI_UNSUPPORTED             The FSP calling conditions were not met. | ||||
|   @retval EFI_DEVICE_ERROR            FSP initialization failed. | ||||
|   @retval EFI_OUT_OF_RESOURCES        Stack range requested by FSP is not met. | ||||
|   @retval FSP_STATUS_RESET_REQUIREDx  A reset is reuired. These status codes will not be returned during S3. | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *FSP_MEMORY_INIT) ( | ||||
|   IN  VOID    *FspmUpdDataPtr, | ||||
|   OUT VOID    **HobListPtr | ||||
|   ); | ||||
|  | ||||
|  | ||||
| /** | ||||
|   This FSP API is called after FspMemoryInit API. This FSP API tears down the temporary | ||||
|   memory setup by TempRamInit API. This FSP API accepts a pointer to a data structure | ||||
|   that will be platform dependent and defined for each FSP binary. This will be | ||||
|   documented in Integration Guide. | ||||
|   FspMemoryInit, TempRamExit and FspSiliconInit APIs provide an alternate method to | ||||
|   complete the silicon initialization and provides bootloader an opportunity to get | ||||
|   control after system memory is available and before the temporary RAM is torn down. | ||||
|  | ||||
|   @param[in] TempRamExitParamPtr Pointer to the Temp Ram Exit parameters structure. | ||||
|                                  This structure is normally defined in the Integration Guide. | ||||
|                                  And if it is not defined in the Integration Guide, pass NULL. | ||||
|  | ||||
|   @retval EFI_SUCCESS            FSP execution environment was initialized successfully. | ||||
|   @retval EFI_INVALID_PARAMETER  Input parameters are invalid. | ||||
|   @retval EFI_UNSUPPORTED        The FSP calling conditions were not met. | ||||
|   @retval EFI_DEVICE_ERROR       FSP initialization failed. | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *FSP_TEMP_RAM_EXIT) ( | ||||
|   IN  VOID    *TempRamExitParamPtr | ||||
|   ); | ||||
|  | ||||
|  | ||||
| /** | ||||
|   This FSP API is called after TempRamExit API. | ||||
|   FspMemoryInit, TempRamExit and FspSiliconInit APIs provide an alternate method to complete the | ||||
|   silicon initialization. | ||||
|  | ||||
|   @param[in] FspsUpdDataPtr     Pointer to the FSPS_UPD data structure. | ||||
|                                 If NULL, FSP will use the default parameters. | ||||
|  | ||||
|   @retval EFI_SUCCESS                 FSP execution environment was initialized successfully. | ||||
|   @retval EFI_INVALID_PARAMETER       Input parameters are invalid. | ||||
|   @retval EFI_UNSUPPORTED             The FSP calling conditions were not met. | ||||
|   @retval EFI_DEVICE_ERROR            FSP initialization failed. | ||||
|   @retval FSP_STATUS_RESET_REQUIREDx  A reset is reuired. These status codes will not be returned during S3. | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *FSP_SILICON_INIT) ( | ||||
|   IN  VOID    *FspsUpdDataPtr | ||||
|   ); | ||||
|  | ||||
| #endif | ||||
| @@ -1,68 +0,0 @@ | ||||
| /** @file | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_GLOBAL_DATA_H_ | ||||
| #define _FSP_GLOBAL_DATA_H_ | ||||
|  | ||||
| #include <FspEas.h> | ||||
|  | ||||
| #pragma pack(1) | ||||
|  | ||||
| typedef enum { | ||||
|   TempRamInitApiIndex, | ||||
|   FspInitApiIndex, | ||||
|   NotifyPhaseApiIndex, | ||||
|   FspMemoryInitApiIndex, | ||||
|   TempRamExitApiIndex, | ||||
|   FspSiliconInitApiIndex, | ||||
|   FspApiIndexMax | ||||
| } FSP_API_INDEX; | ||||
|  | ||||
| typedef struct  { | ||||
|    VOID               *DataPtr; | ||||
|    UINT32             MicrocodeRegionBase; | ||||
|    UINT32             MicrocodeRegionSize; | ||||
|    UINT32             CodeRegionBase; | ||||
|    UINT32             CodeRegionSize; | ||||
|    UINT32             CarBase; | ||||
|    UINT32             CarSize; | ||||
| } FSP_PLAT_DATA; | ||||
|  | ||||
| #define FSP_GLOBAL_DATA_SIGNATURE  SIGNATURE_32 ('F', 'S', 'P', 'D') | ||||
| #define FSP_PERFORMANCE_DATA_SIGNATURE  SIGNATURE_32 ('P', 'E', 'R', 'F') | ||||
|  | ||||
| typedef struct  { | ||||
|    UINT32             Signature; | ||||
|    UINT8              Version; | ||||
|    UINT8              Reserved1[3]; | ||||
|    UINT32             CoreStack; | ||||
|    UINT32             StatusCode; | ||||
|    UINT32             Reserved2[8]; | ||||
|    FSP_PLAT_DATA      PlatformData; | ||||
|    FSP_INFO_HEADER    *FspInfoHeader; | ||||
|    VOID               *UpdDataPtr; | ||||
|    VOID               *TempRamInitUpdPtr; | ||||
|    VOID               *MemoryInitUpdPtr; | ||||
|    VOID               *SiliconInitUpdPtr; | ||||
|    UINT8              ApiIdx; | ||||
|    UINT8              Reserved3[31]; | ||||
|    UINT32             PerfSig; | ||||
|    UINT16             PerfLen; | ||||
|    UINT16             Reserved4; | ||||
|    UINT32             PerfIdx; | ||||
|    UINT64             PerfData[32]; | ||||
| } FSP_GLOBAL_DATA; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
| @@ -1,62 +0,0 @@ | ||||
| /** @file | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_MEASURE_POINT_ID_H_ | ||||
| #define _FSP_MEASURE_POINT_ID_H_ | ||||
|  | ||||
| // | ||||
| // 0xD0 - 0xEF are reserved for FSP common measure point | ||||
| // | ||||
| #define  FSP_PERF_ID_MRC_INIT_ENTRY               0xD0 | ||||
| #define  FSP_PERF_ID_MRC_INIT_EXIT                (FSP_PERF_ID_MRC_INIT_ENTRY +  1) | ||||
|  | ||||
| #define  FSP_PERF_ID_SYSTEM_AGENT_INIT_ENTRY      0xD8 | ||||
| #define  FSP_PERF_ID_SYSTEM_AGENT_INIT_EXIT       (FSP_PERF_ID_SYSTEM_AGENT_INIT_ENTRY +  1) | ||||
|  | ||||
| #define  FSP_PERF_ID_PCH_INIT_ENTRY               0xDA | ||||
| #define  FSP_PERF_ID_PCH_INIT_EXIT                (FSP_PERF_ID_PCH_INIT_ENTRY +  1) | ||||
|  | ||||
| #define  FSP_PERF_ID_CPU_INIT_ENTRY               0xE0 | ||||
| #define  FSP_PERF_ID_CPU_INIT_EXIT                (FSP_PERF_ID_CPU_INIT_ENTRY +  1) | ||||
|  | ||||
| #define  FSP_PERF_ID_GFX_INIT_ENTRY               0xE8 | ||||
| #define  FSP_PERF_ID_GFX_INIT_EXIT                (FSP_PERF_ID_GFX_INIT_ENTRY +  1) | ||||
|  | ||||
| #define  FSP_PERF_ID_ME_INIT_ENTRY                0xEA | ||||
| #define  FSP_PERF_ID_ME_INIT_EXIT                 (FSP_PERF_ID_ME_INIT_ENTRY +  1) | ||||
|  | ||||
| // | ||||
| // 0xF0 - 0xFF are reserved for FSP API | ||||
| // | ||||
| #define  FSP_PERF_ID_API_TEMP_RAM_INIT_ENTRY           0xF0 | ||||
| #define  FSP_PERF_ID_API_TEMP_RAM_INIT_EXIT            (FSP_PERF_ID_API_TEMP_RAM_INIT_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_FSP_MEMORY_INIT_ENTRY         0xF2 | ||||
| #define  FSP_PERF_ID_API_FSP_MEMORY_INIT_EXIT          (FSP_PERF_ID_API_FSP_MEMORY_INIT_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_TEMP_RAM_EXIT_ENTRY           0xF4 | ||||
| #define  FSP_PERF_ID_API_TEMP_RAM_EXIT_EXIT            (FSP_PERF_ID_API_TEMP_RAM_EXIT_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_FSP_SILICON_INIT_ENTRY        0xF6 | ||||
| #define  FSP_PERF_ID_API_FSP_SILICON_INIT_EXIT         (FSP_PERF_ID_API_FSP_SILICON_INIT_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_NOTIFY_POST_PCI_ENTRY         0xF8 | ||||
| #define  FSP_PERF_ID_API_NOTIFY_POST_PCI_EXIT          (FSP_PERF_ID_API_NOTIFY_POST_PCI_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_NOTIFY_READY_TO_BOOT_ENTRY    0xFA | ||||
| #define  FSP_PERF_ID_API_NOTIFY_READY_TO_BOOT_EXIT     (FSP_PERF_ID_API_NOTIFY_READY_TO_BOOT_ENTRY + 1) | ||||
|  | ||||
| #define  FSP_PERF_ID_API_NOTIFY_END_OF_FIRMWARE_ENTRY  0xFC | ||||
| #define  FSP_PERF_ID_API_NOTIFY_END_OF_FIRMWARE_EXIT   (FSP_PERF_ID_API_NOTIFY_END_OF_FIRMWARE_ENTRY + 1) | ||||
|  | ||||
| #endif | ||||
| @@ -1,46 +0,0 @@ | ||||
| /** @file | ||||
|   Intel FSP status code definition | ||||
|  | ||||
|   Copyright (c) 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _FSP_STATUS_CODE_H_ | ||||
| #define _FSP_STATUS_CODE_H_ | ||||
|  | ||||
| // | ||||
| // FSP API - 4 BITS | ||||
| // | ||||
| #define FSP_STATUS_CODE_TEMP_RAM_INIT                0xF000 | ||||
| #define FSP_STATUS_CODE_MEMORY_INIT                  0xD000 | ||||
| #define FSP_STATUS_CODE_TEMP_RAM_EXIT                0xB000 | ||||
| #define FSP_STATUS_CODE_SILICON_INIT                 0x9000 | ||||
| #define FSP_STATUS_CODE_POST_PCIE_ENUM_NOTIFICATION  0x6000 | ||||
| #define FSP_STATUS_CODE_READY_TO_BOOT_NOTIFICATION   0x4000 | ||||
| #define FSP_STATUS_CODE_END_OF_FIRMWARE_NOTIFICATION 0x2000 | ||||
|  | ||||
| // | ||||
| // MODULE - 4 BITS | ||||
| // | ||||
| #define FSP_STATUS_CODE_GFX_PEIM                     0x0700 | ||||
| #define FSP_STATUS_CODE_COMMON_CODE                  0x0800 | ||||
| #define FSP_STATUS_CODE_SILICON_COMMON_CODE          0x0900 | ||||
| #define FSP_STATUS_CODE_SYSTEM_AGENT                 0x0A00 | ||||
| #define FSP_STATUS_CODE_PCH                          0x0B00 | ||||
| #define FSP_STATUS_CODE_CPU                          0x0C00 | ||||
| #define FSP_STATUS_CODE_MRC                          0x0D00 | ||||
| #define FSP_STATUS_CODE_ME_BIOS                      0x0E00 | ||||
| // | ||||
| // Individual Codes - 1 BYTE | ||||
| // | ||||
| #define FSP_STATUS_CODE_API_ENTRY                    0x0000 | ||||
| #define FSP_STATUS_CODE_API_EXIT                     0x007F | ||||
|  | ||||
| #endif | ||||
| @@ -1,204 +0,0 @@ | ||||
| /** @file | ||||
|   Intel FSP Header File definition from Intel Firmware Support Package External | ||||
|   Architecture Specification v2.0. | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __FSP_HEADER_FILE_H__ | ||||
| #define __FSP_HEADER_FILE_H__ | ||||
|  | ||||
| #define FSP_HEADER_REVISION_3   3 | ||||
|  | ||||
| #define FSPE_HEADER_REVISION_1  1 | ||||
| #define FSPP_HEADER_REVISION_1  1 | ||||
|  | ||||
| /// | ||||
| /// Fixed FSP header offset in the FSP image | ||||
| /// | ||||
| #define FSP_INFO_HEADER_OFF    0x94 | ||||
|  | ||||
| #define OFFSET_IN_FSP_INFO_HEADER(x)  (UINT32)&((FSP_INFO_HEADER *)(UINTN)0)->x | ||||
|  | ||||
| #define FSP_INFO_HEADER_SIGNATURE  SIGNATURE_32 ('F', 'S', 'P', 'H') | ||||
|  | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// FSP Information Header as described in FSP v2.0 Spec section 5.1.1. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Byte 0x00: Signature ('FSPH') for the FSP Information Header. | ||||
|   /// | ||||
|   UINT32  Signature; | ||||
|   /// | ||||
|   /// Byte 0x04: Length of the FSP Information Header. | ||||
|   /// | ||||
|   UINT32  HeaderLength; | ||||
|   /// | ||||
|   /// Byte 0x08: Reserved. | ||||
|   /// | ||||
|   UINT8   Reserved1[2]; | ||||
|   /// | ||||
|   /// Byte 0x0A: Indicates compliance with a revision of this specification in the BCD format. | ||||
|   /// | ||||
|   UINT8   SpecVersion; | ||||
|   /// | ||||
|   /// Byte 0x0B: Revision of the FSP Information Header. | ||||
|   /// | ||||
|   UINT8   HeaderRevision; | ||||
|   /// | ||||
|   /// Byte 0x0C: Revision of the FSP binary. | ||||
|   /// | ||||
|   UINT32  ImageRevision; | ||||
|   /// | ||||
|   /// Byte 0x10: Signature string that will help match the FSP Binary to a supported HW configuration. | ||||
|   /// | ||||
|   CHAR8   ImageId[8]; | ||||
|   /// | ||||
|   /// Byte 0x18: Size of the entire FSP binary. | ||||
|   /// | ||||
|   UINT32  ImageSize; | ||||
|   /// | ||||
|   /// Byte 0x1C: FSP binary preferred base address. | ||||
|   /// | ||||
|   UINT32  ImageBase; | ||||
|   /// | ||||
|   /// Byte 0x20: Attribute for the FSP binary. | ||||
|   /// | ||||
|   UINT16  ImageAttribute; | ||||
|   /// | ||||
|   /// Byte 0x22: Attributes of the FSP Component. | ||||
|   /// | ||||
|   UINT16  ComponentAttribute; | ||||
|   /// | ||||
|   /// Byte 0x24: Offset of the FSP configuration region. | ||||
|   /// | ||||
|   UINT32  CfgRegionOffset; | ||||
|   /// | ||||
|   /// Byte 0x28: Size of the FSP configuration region. | ||||
|   /// | ||||
|   UINT32  CfgRegionSize; | ||||
|   /// | ||||
|   /// Byte 0x2C: Reserved2. | ||||
|   /// | ||||
|   UINT32  Reserved2; | ||||
|   /// | ||||
|   /// Byte 0x30: The offset for the API to setup a temporary stack till the memory is initialized. | ||||
|   /// | ||||
|   UINT32  TempRamInitEntryOffset; | ||||
|   /// | ||||
|   /// Byte 0x34: Reserved3. | ||||
|   /// | ||||
|   UINT32  Reserved3; | ||||
|   /// | ||||
|   /// Byte 0x38: The offset for the API to inform the FSP about the different stages in the boot process. | ||||
|   /// | ||||
|   UINT32  NotifyPhaseEntryOffset; | ||||
|   /// | ||||
|   /// Byte 0x3C: The offset for the API to initialize the memory. | ||||
|   /// | ||||
|   UINT32  FspMemoryInitEntryOffset; | ||||
|   /// | ||||
|   /// Byte 0x40: The offset for the API to tear down temporary RAM. | ||||
|   /// | ||||
|   UINT32  TempRamExitEntryOffset; | ||||
|   /// | ||||
|   /// Byte 0x44: The offset for the API to initialize the CPU and chipset. | ||||
|   /// | ||||
|   UINT32  FspSiliconInitEntryOffset; | ||||
| } FSP_INFO_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Signature of the FSP Extended Header | ||||
| /// | ||||
| #define FSP_INFO_EXTENDED_HEADER_SIGNATURE  SIGNATURE_32 ('F', 'S', 'P', 'E') | ||||
|  | ||||
| /// | ||||
| /// FSP Information Extended Header as described in FSP v2.0 Spec section 5.1.2. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Byte 0x00: Signature ('FSPE') for the FSP Extended Information Header. | ||||
|   /// | ||||
|   UINT32  Signature; | ||||
|   /// | ||||
|   /// Byte 0x04: Length of the table in bytes, including all additional FSP producer defined data. | ||||
|   /// | ||||
|   UINT32  Length; | ||||
|   /// | ||||
|   /// Byte 0x08: FSP producer defined revision of the table. | ||||
|   /// | ||||
|   UINT8   Revision; | ||||
|   /// | ||||
|   /// Byte 0x09: Reserved for future use. | ||||
|   /// | ||||
|   UINT8   Reserved; | ||||
|   /// | ||||
|   /// Byte 0x0A: FSP producer identification string | ||||
|   /// | ||||
|   CHAR8   FspProducerId[6]; | ||||
|   /// | ||||
|   /// Byte 0x10: FSP producer implementation revision number. Larger numbers are assumed to be newer revisions. | ||||
|   /// | ||||
|   UINT32  FspProducerRevision; | ||||
|   /// | ||||
|   /// Byte 0x14: Size of the FSP producer defined data (n) in bytes. | ||||
|   /// | ||||
|   UINT32  FspProducerDataSize; | ||||
|   /// | ||||
|   /// Byte 0x18: FSP producer defined data of size (n) defined by FspProducerDataSize. | ||||
|   /// | ||||
| } FSP_INFO_EXTENDED_HEADER; | ||||
|  | ||||
| // | ||||
| // A generic table search algorithm for additional tables can be implemented with a | ||||
| // signature search algorithm until a terminator signature 'FSPP' is found. | ||||
| // | ||||
| #define FSP_FSPP_SIGNATURE  SIGNATURE_32 ('F', 'S', 'P', 'P') | ||||
| #define FSP_PATCH_TABLE_SIGNATURE  FSP_FSPP_SIGNATURE | ||||
|  | ||||
| /// | ||||
| /// FSP Patch Table as described in FSP v2.0 Spec section 5.1.5. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Byte 0x00: FSP Patch Table Signature "FSPP". | ||||
|   /// | ||||
|   UINT32  Signature; | ||||
|   /// | ||||
|   /// Byte 0x04: Size including the PatchData. | ||||
|   /// | ||||
|   UINT16  HeaderLength; | ||||
|   /// | ||||
|   /// Byte 0x06: Revision is set to 0x01. | ||||
|   /// | ||||
|   UINT8   HeaderRevision; | ||||
|   /// | ||||
|   /// Byte 0x07: Reserved for future use. | ||||
|   /// | ||||
|   UINT8   Reserved; | ||||
|   /// | ||||
|   /// Byte 0x08: Number of entries to Patch. | ||||
|   /// | ||||
|   UINT32  PatchEntryNum; | ||||
|   /// | ||||
|   /// Byte 0x0C: Patch Data. | ||||
|   /// | ||||
| //UINT32  PatchData[]; | ||||
| } FSP_PATCH_TABLE; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| extern EFI_GUID gFspHeaderFileGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,23 +0,0 @@ | ||||
| /** @file | ||||
|   Intel FSP Hob Guid definition from Intel Firmware Support Package External | ||||
|   Architecture Specification v2.0. | ||||
|  | ||||
|   Copyright (c) 2014 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __GUID_HOB_FSP_EAS_GUID__ | ||||
| #define __GUID_HOB_FSP_EAS_GUID__ | ||||
|  | ||||
| extern EFI_GUID gFspBootLoaderTolumHobGuid; | ||||
| extern EFI_GUID gFspReservedMemoryResourceHobGuid; | ||||
| extern EFI_GUID gFspNonVolatileStorageHobGuid; | ||||
|  | ||||
| #endif | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,40 +0,0 @@ | ||||
| /** @file | ||||
|   Guid used to define the Firmware File System 2. | ||||
|  | ||||
|   Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   GUIDs introduced in PI Version 1.0. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __FIRMWARE_FILE_SYSTEM2_GUID_H__ | ||||
| #define __FIRMWARE_FILE_SYSTEM2_GUID_H__ | ||||
|  | ||||
| /// | ||||
| /// The firmware volume header contains a data field for | ||||
| /// the file system GUID | ||||
| /// | ||||
| #define EFI_FIRMWARE_FILE_SYSTEM2_GUID \ | ||||
|   { 0x8c8ce578, 0x8a3d, 0x4f1c, { 0x99, 0x35, 0x89, 0x61, 0x85, 0xc3, 0x2d, 0xd3 } } | ||||
|  | ||||
| /// | ||||
| /// A Volume Top File (VTF) is a file that must be | ||||
| /// located such that the last byte of the file is | ||||
| /// also the last byte of the firmware volume | ||||
| /// | ||||
| #define EFI_FFS_VOLUME_TOP_FILE_GUID \ | ||||
|   { 0x1BA0062E, 0xC779, 0x4582, { 0x85, 0x66, 0x33, 0x6A, 0xE8, 0xF7, 0x8F, 0x9 } } | ||||
|  | ||||
|  | ||||
| extern EFI_GUID gEfiFirmwareFileSystem2Guid; | ||||
| extern EFI_GUID gEfiFirmwareVolumeTopFileGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,25 +0,0 @@ | ||||
| /** @file | ||||
|   Guid used to identify HII FormMap configuration method. | ||||
|  | ||||
|   Copyright (c) 2009, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   GUID defined in UEFI 2.2 spec. | ||||
| **/ | ||||
|  | ||||
| #ifndef __EFI_HII_FORMMAP_GUID_H__ | ||||
| #define __EFI_HII_FORMMAP_GUID_H__ | ||||
|  | ||||
| #define EFI_HII_STANDARD_FORM_GUID \ | ||||
|   { 0x3bd2f4ec, 0xe524, 0x46e4, { 0xa9, 0xd8, 0x51, 0x1, 0x17, 0x42, 0x55, 0x62 } } | ||||
|  | ||||
| extern EFI_GUID gEfiHiiStandardFormGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,58 +0,0 @@ | ||||
| /** @file | ||||
|   Terminal Device Path Vendor Guid. | ||||
|  | ||||
|   Copyright (c) 2006 - 2009, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   GUIDs defined in UEFI 2.0 spec. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PC_ANSI_H__ | ||||
| #define __PC_ANSI_H__ | ||||
|  | ||||
| #define EFI_PC_ANSI_GUID \ | ||||
|   { \ | ||||
|     0xe0c14753, 0xf9be, 0x11d2, {0x9a, 0x0c, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d } \ | ||||
|   } | ||||
|  | ||||
| #define EFI_VT_100_GUID \ | ||||
|   { \ | ||||
|     0xdfa66065, 0xb419, 0x11d3, {0x9a, 0x2d, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d } \ | ||||
|   } | ||||
|  | ||||
| #define EFI_VT_100_PLUS_GUID \ | ||||
|   { \ | ||||
|     0x7baec70b, 0x57e0, 0x4c76, {0x8e, 0x87, 0x2f, 0x9e, 0x28, 0x08, 0x83, 0x43 } \ | ||||
|   } | ||||
|  | ||||
| #define EFI_VT_UTF8_GUID \ | ||||
|   { \ | ||||
|     0xad15a0d6, 0x8bec, 0x4acf, {0xa0, 0x73, 0xd0, 0x1d, 0xe7, 0x7e, 0x2d, 0x88 } \ | ||||
|   } | ||||
|  | ||||
| #define DEVICE_PATH_MESSAGING_UART_FLOW_CONTROL \ | ||||
|   { \ | ||||
|     0x37499a9d, 0x542f, 0x4c89, {0xa0, 0x26, 0x35, 0xda, 0x14, 0x20, 0x94, 0xe4 } \ | ||||
|   } | ||||
|  | ||||
| #define EFI_SAS_DEVICE_PATH_GUID \ | ||||
|   { \ | ||||
|     0xd487ddb4, 0x008b, 0x11d9, {0xaf, 0xdc, 0x00, 0x10, 0x83, 0xff, 0xca, 0x4d } \ | ||||
|   } | ||||
|  | ||||
| extern EFI_GUID gEfiPcAnsiGuid; | ||||
| extern EFI_GUID gEfiVT100Guid; | ||||
| extern EFI_GUID gEfiVT100PlusGuid; | ||||
| extern EFI_GUID gEfiVTUTF8Guid; | ||||
| extern EFI_GUID gEfiUartDevicePathGuid; | ||||
| extern EFI_GUID gEfiSasDevicePathGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,128 +0,0 @@ | ||||
| /** @file | ||||
|   GUID for UEFI WIN_CERTIFICATE structure. | ||||
|  | ||||
|   Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   GUID defined in UEFI 2.0 spec. | ||||
| **/ | ||||
|  | ||||
| #ifndef __EFI_WIN_CERTIFICATE_H__ | ||||
| #define __EFI_WIN_CERTIFICATE_H__ | ||||
|  | ||||
| // | ||||
| // _WIN_CERTIFICATE.wCertificateType | ||||
| // | ||||
| #define WIN_CERT_TYPE_PKCS_SIGNED_DATA 0x0002 | ||||
| #define WIN_CERT_TYPE_EFI_PKCS115      0x0EF0 | ||||
| #define WIN_CERT_TYPE_EFI_GUID         0x0EF1 | ||||
|  | ||||
| /// | ||||
| /// The WIN_CERTIFICATE structure is part of the PE/COFF specification. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The length of the entire certificate, | ||||
|   /// including the length of the header, in bytes. | ||||
|   /// | ||||
|   UINT32  dwLength; | ||||
|   /// | ||||
|   /// The revision level of the WIN_CERTIFICATE | ||||
|   /// structure. The current revision level is 0x0200. | ||||
|   /// | ||||
|   UINT16  wRevision; | ||||
|   /// | ||||
|   /// The certificate type. See WIN_CERT_TYPE_xxx for the UEFI | ||||
|   /// certificate types. The UEFI specification reserves the range of | ||||
|   /// certificate type values from 0x0EF0 to 0x0EFF. | ||||
|   /// | ||||
|   UINT16  wCertificateType; | ||||
|   /// | ||||
|   /// The following is the actual certificate. The format of | ||||
|   /// the certificate depends on wCertificateType. | ||||
|   /// | ||||
|   /// UINT8 bCertificate[ANYSIZE_ARRAY]; | ||||
|   /// | ||||
| } WIN_CERTIFICATE; | ||||
|  | ||||
| /// | ||||
| /// WIN_CERTIFICATE_UEFI_GUID.CertType | ||||
| /// | ||||
| #define EFI_CERT_TYPE_RSA2048_SHA256_GUID \ | ||||
|   {0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } } | ||||
|  | ||||
| /// | ||||
| /// WIN_CERTIFICATE_UEFI_GUID.CertData | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_GUID  HashType; | ||||
|   UINT8     PublicKey[256]; | ||||
|   UINT8     Signature[256]; | ||||
| } EFI_CERT_BLOCK_RSA_2048_SHA256; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Certificate which encapsulates a GUID-specific digital signature | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// This is the standard WIN_CERTIFICATE header, where | ||||
|   /// wCertificateType is set to WIN_CERT_TYPE_EFI_GUID. | ||||
|   /// | ||||
|   WIN_CERTIFICATE   Hdr; | ||||
|   /// | ||||
|   /// This is the unique id which determines the | ||||
|   /// format of the CertData. . | ||||
|   /// | ||||
|   EFI_GUID          CertType; | ||||
|   /// | ||||
|   /// The following is the certificate data. The format of | ||||
|   /// the data is determined by the CertType. | ||||
|   /// If CertType is EFI_CERT_TYPE_RSA2048_SHA256_GUID, | ||||
|   /// the CertData will be EFI_CERT_BLOCK_RSA_2048_SHA256 structure. | ||||
|   /// | ||||
|   UINT8            CertData[1]; | ||||
| } WIN_CERTIFICATE_UEFI_GUID; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Certificate which encapsulates the RSASSA_PKCS1-v1_5 digital signature. | ||||
| /// | ||||
| /// The WIN_CERTIFICATE_UEFI_PKCS1_15 structure is derived from | ||||
| /// WIN_CERTIFICATE and encapsulate the information needed to | ||||
| /// implement the RSASSA-PKCS1-v1_5 digital signature algorithm as | ||||
| /// specified in RFC2437. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// This is the standard WIN_CERTIFICATE header, where | ||||
|   /// wCertificateType is set to WIN_CERT_TYPE_UEFI_PKCS1_15. | ||||
|   /// | ||||
|   WIN_CERTIFICATE Hdr; | ||||
|   /// | ||||
|   /// This is the hashing algorithm which was performed on the | ||||
|   /// UEFI executable when creating the digital signature. | ||||
|   /// | ||||
|   EFI_GUID        HashAlgorithm; | ||||
|   /// | ||||
|   /// The following is the actual digital signature. The | ||||
|   /// size of the signature is the same size as the key | ||||
|   /// (1024-bit key is 128 bytes) and can be determined by | ||||
|   /// subtracting the length of the other parts of this header | ||||
|   /// from the total length of the certificate as found in | ||||
|   /// Hdr.dwLength. | ||||
|   /// | ||||
|   /// UINT8 Signature[]; | ||||
|   /// | ||||
| } WIN_CERTIFICATE_EFI_PKCS1_15; | ||||
|  | ||||
| extern EFI_GUID gEfiCertTypeRsa2048Sha256Guid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,312 +0,0 @@ | ||||
| /** @file | ||||
|   Processor or Compiler specific defines and types for IA-32 architecture. | ||||
|  | ||||
| Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PROCESSOR_BIND_H__ | ||||
| #define __PROCESSOR_BIND_H__ | ||||
|  | ||||
| /// | ||||
| /// Define the processor type so other code can make processor based choices. | ||||
| /// | ||||
| #define MDE_CPU_IA32 | ||||
|  | ||||
| // | ||||
| // Make sure we are using the correct packing rules per EFI specification | ||||
| // | ||||
| #if !defined(__GNUC__) | ||||
| #pragma pack() | ||||
| #endif | ||||
|  | ||||
| #if defined(__INTEL_COMPILER) | ||||
| // | ||||
| // Disable ICC's remark #869: "Parameter" was never referenced warning. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with -Wall | ||||
| // | ||||
| #pragma warning ( disable : 869 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #1418: external function definition with no prior declaration. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 1418 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #1419: external declaration in primary source file | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 1419 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #593: "Variable" was set but never used. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 593 ) | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(_MSC_EXTENSIONS) | ||||
|  | ||||
| // | ||||
| // Disable warning that make it impossible to compile at /W4 | ||||
| // This only works for Microsoft* tools | ||||
| // | ||||
|  | ||||
| // | ||||
| // Disabling bitfield type checking warnings. | ||||
| // | ||||
| #pragma warning ( disable : 4214 ) | ||||
|  | ||||
| // | ||||
| // Disabling the unreferenced formal parameter warnings. | ||||
| // | ||||
| #pragma warning ( disable : 4100 ) | ||||
|  | ||||
| // | ||||
| // Disable slightly different base types warning as CHAR8 * can not be set | ||||
| // to a constant string. | ||||
| // | ||||
| #pragma warning ( disable : 4057 ) | ||||
|  | ||||
| // | ||||
| // ASSERT(FALSE) or while (TRUE) are legal constructes so supress this warning | ||||
| // | ||||
| #pragma warning ( disable : 4127 ) | ||||
|  | ||||
| // | ||||
| // This warning is caused by functions defined but not used. For precompiled header only. | ||||
| // | ||||
| #pragma warning ( disable : 4505 ) | ||||
|  | ||||
| // | ||||
| // This warning is caused by empty (after preprocessing) source file. For precompiled header only. | ||||
| // | ||||
| #pragma warning ( disable : 4206 ) | ||||
|  | ||||
| #if _MSC_VER == 1800 || _MSC_VER == 1900 | ||||
|  | ||||
| // | ||||
| // Disable these warnings for VS2013. | ||||
| // | ||||
|  | ||||
| // | ||||
| // This warning is for potentially uninitialized local variable, and it may cause false | ||||
| // positive issues in VS2013 and VS2015 build | ||||
| // | ||||
| #pragma warning ( disable : 4701 ) | ||||
|  | ||||
| // | ||||
| // This warning is for potentially uninitialized local pointer variable, and it may cause | ||||
| // false positive issues in VS2013 and VS2015 build | ||||
| // | ||||
| #pragma warning ( disable : 4703 ) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(_MSC_EXTENSIONS) | ||||
|  | ||||
|   // | ||||
|   // use Microsoft C complier dependent integer width types | ||||
|   // | ||||
|  | ||||
|   /// | ||||
|   /// 8-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned __int64    UINT64; | ||||
|   /// | ||||
|   /// 8-byte signed value. | ||||
|   /// | ||||
|   typedef __int64             INT64; | ||||
|   /// | ||||
|   /// 4-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned __int32    UINT32; | ||||
|   /// | ||||
|   /// 4-byte signed value. | ||||
|   /// | ||||
|   typedef __int32             INT32; | ||||
|   /// | ||||
|   /// 2-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned short      UINT16; | ||||
|   /// | ||||
|   /// 2-byte Character.  Unless otherwise specified all strings are stored in the | ||||
|   /// UTF-16 encoding format as defined by Unicode 2.1 and ISO/IEC 10646 standards. | ||||
|   /// | ||||
|   typedef unsigned short      CHAR16; | ||||
|   /// | ||||
|   /// 2-byte signed value. | ||||
|   /// | ||||
|   typedef short               INT16; | ||||
|   /// | ||||
|   /// Logical Boolean.  1-byte value containing 0 for FALSE or a 1 for TRUE.  Other | ||||
|   /// values are undefined. | ||||
|   /// | ||||
|   typedef unsigned char       BOOLEAN; | ||||
|   /// | ||||
|   /// 1-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned char       UINT8; | ||||
|   /// | ||||
|   /// 1-byte Character. | ||||
|   /// | ||||
|   typedef char                CHAR8; | ||||
|   /// | ||||
|   /// 1-byte signed value. | ||||
|   /// | ||||
|   typedef signed char         INT8; | ||||
| #else | ||||
|   /// | ||||
|   /// 8-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned long long  UINT64; | ||||
|   /// | ||||
|   /// 8-byte signed value. | ||||
|   /// | ||||
|   typedef long long           INT64; | ||||
|   /// | ||||
|   /// 4-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned int        UINT32; | ||||
|   /// | ||||
|   /// 4-byte signed value. | ||||
|   /// | ||||
|   typedef int                 INT32; | ||||
|   /// | ||||
|   /// 2-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned short      UINT16; | ||||
|   /// | ||||
|   /// 2-byte Character.  Unless otherwise specified all strings are stored in the | ||||
|   /// UTF-16 encoding format as defined by Unicode 2.1 and ISO/IEC 10646 standards. | ||||
|   /// | ||||
|   typedef unsigned short      CHAR16; | ||||
|   /// | ||||
|   /// 2-byte signed value. | ||||
|   /// | ||||
|   typedef short               INT16; | ||||
|   /// | ||||
|   /// Logical Boolean.  1-byte value containing 0 for FALSE or a 1 for TRUE.  Other | ||||
|   /// values are undefined. | ||||
|   /// | ||||
|   typedef unsigned char       BOOLEAN; | ||||
|   /// | ||||
|   /// 1-byte unsigned value. | ||||
|   /// | ||||
|   typedef unsigned char       UINT8; | ||||
|   /// | ||||
|   /// 1-byte Character | ||||
|   /// | ||||
|   typedef char                CHAR8; | ||||
|   /// | ||||
|   /// 1-byte signed value | ||||
|   /// | ||||
|   typedef signed char         INT8; | ||||
| #endif | ||||
|  | ||||
| /// | ||||
| /// Unsigned value of native width.  (4 bytes on supported 32-bit processor instructions; | ||||
| /// 8 bytes on supported 64-bit processor instructions.) | ||||
| /// | ||||
| typedef UINT32  UINTN; | ||||
| /// | ||||
| /// Signed value of native width.  (4 bytes on supported 32-bit processor instructions; | ||||
| /// 8 bytes on supported 64-bit processor instructions.) | ||||
| /// | ||||
| typedef INT32   INTN; | ||||
|  | ||||
| // | ||||
| // Processor specific defines | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// A value of native width with the highest bit set. | ||||
| /// | ||||
| #define MAX_BIT     0x80000000 | ||||
| /// | ||||
| /// A value of native width with the two highest bits set. | ||||
| /// | ||||
| #define MAX_2_BITS  0xC0000000 | ||||
|  | ||||
| /// | ||||
| /// Maximum legal IA-32 address. | ||||
| /// | ||||
| #define MAX_ADDRESS   0xFFFFFFFF | ||||
|  | ||||
| /// | ||||
| /// Maximum legal IA-32 INTN and UINTN values. | ||||
| /// | ||||
| #define MAX_INTN   ((INTN)0x7FFFFFFF) | ||||
| #define MAX_UINTN  ((UINTN)0xFFFFFFFF) | ||||
|  | ||||
| /// | ||||
| /// The stack alignment required for IA-32. | ||||
| /// | ||||
| #define CPU_STACK_ALIGNMENT   sizeof(UINTN) | ||||
|  | ||||
| // | ||||
| // Modifier to ensure that all protocol member functions and EFI intrinsics | ||||
| // use the correct C calling convention. All protocol member functions and | ||||
| // EFI intrinsics are required to modify their member functions with EFIAPI. | ||||
| // | ||||
| #ifdef EFIAPI | ||||
|   /// | ||||
|   /// If EFIAPI is already defined, then we use that definition. | ||||
|   /// | ||||
| #elif defined(_MSC_EXTENSIONS) | ||||
|   /// | ||||
|   /// Microsoft* compiler specific method for EFIAPI calling convention. | ||||
|   /// | ||||
|   #define EFIAPI __cdecl | ||||
| #elif defined(__GNUC__) | ||||
|   /// | ||||
|   /// GCC specific method for EFIAPI calling convention. | ||||
|   /// | ||||
|   #define EFIAPI __attribute__((cdecl)) | ||||
| #else | ||||
|   /// | ||||
|   /// The default for a non Microsoft* or GCC compiler is to assume the EFI ABI | ||||
|   /// is the standard. | ||||
|   /// | ||||
|   #define EFIAPI | ||||
| #endif | ||||
|  | ||||
| #if defined(__GNUC__) | ||||
|   /// | ||||
|   /// For GNU assembly code, .global or .globl can declare global symbols. | ||||
|   /// Define this macro to unify the usage. | ||||
|   /// | ||||
|   #define ASM_GLOBAL .globl | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   Return the pointer to the first instruction of a function given a function pointer. | ||||
|   On IA-32 CPU architectures, these two pointer values are the same, | ||||
|   so the implementation of this macro is very simple. | ||||
|  | ||||
|   @param  FunctionPointer   A pointer to a function. | ||||
|  | ||||
|   @return The pointer to the first instruction of a function given a function pointer. | ||||
|  | ||||
| **/ | ||||
| #define FUNCTION_ENTRY_POINT(FunctionPointer) (VOID *)(UINTN)(FunctionPointer) | ||||
|  | ||||
| #ifndef __USER_LABEL_PREFIX__ | ||||
| #define __USER_LABEL_PREFIX__ _ | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,21 +0,0 @@ | ||||
| /** @file | ||||
|   This file contains the latest ACPI definitions that are | ||||
|   consumed by drivers that do not care about ACPI versions. | ||||
|  | ||||
|   Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _ACPI_H_ | ||||
| #define _ACPI_H_ | ||||
|  | ||||
| #include <IndustryStandard/Acpi60.h> | ||||
|  | ||||
| #endif | ||||
| @@ -1,661 +0,0 @@ | ||||
| /** @file | ||||
|   ACPI 1.0b definitions from the ACPI Specification, revision 1.0b | ||||
|  | ||||
| Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
| **/ | ||||
|  | ||||
| #ifndef _ACPI_1_0_H_ | ||||
| #define _ACPI_1_0_H_ | ||||
|  | ||||
| #include <IndustryStandard/AcpiAml.h> | ||||
|  | ||||
| /// | ||||
| /// Common table header, this prefaces all ACPI tables, including FACS, but | ||||
| /// excluding the RSD PTR structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
| } EFI_ACPI_COMMON_HEADER; | ||||
|  | ||||
| #pragma pack(1) | ||||
| /// | ||||
| /// The common ACPI description table header.  This structure prefaces most ACPI tables. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
|   UINT8   Revision; | ||||
|   UINT8   Checksum; | ||||
|   UINT8   OemId[6]; | ||||
|   UINT64  OemTableId; | ||||
|   UINT32  OemRevision; | ||||
|   UINT32  CreatorId; | ||||
|   UINT32  CreatorRevision; | ||||
| } EFI_ACPI_DESCRIPTION_HEADER; | ||||
| #pragma pack() | ||||
|  | ||||
| // | ||||
| // Define for Desriptor | ||||
| // | ||||
| #define ACPI_SMALL_ITEM_FLAG                   0x00 | ||||
| #define ACPI_LARGE_ITEM_FLAG                   0x01 | ||||
|  | ||||
| // | ||||
| // Small Item Descriptor Name | ||||
| // | ||||
| #define ACPI_SMALL_IRQ_DESCRIPTOR_NAME                       0x04 | ||||
| #define ACPI_SMALL_DMA_DESCRIPTOR_NAME                       0x05 | ||||
| #define ACPI_SMALL_START_DEPENDENT_DESCRIPTOR_NAME           0x06 | ||||
| #define ACPI_SMALL_END_DEPENDENT_DESCRIPTOR_NAME             0x07 | ||||
| #define ACPI_SMALL_IO_PORT_DESCRIPTOR_NAME                   0x08 | ||||
| #define ACPI_SMALL_FIXED_IO_PORT_DESCRIPTOR_NAME             0x09 | ||||
| #define ACPI_SMALL_VENDOR_DEFINED_DESCRIPTOR_NAME            0x0E | ||||
| #define ACPI_SMALL_END_TAG_DESCRIPTOR_NAME                   0x0F | ||||
|  | ||||
| // | ||||
| // Large Item Descriptor Name | ||||
| // | ||||
| #define ACPI_LARGE_24_BIT_MEMORY_RANGE_DESCRIPTOR_NAME       0x01 | ||||
| #define ACPI_LARGE_VENDOR_DEFINED_DESCRIPTOR_NAME            0x04 | ||||
| #define ACPI_LARGE_32_BIT_MEMORY_RANGE_DESCRIPTOR_NAME       0x05 | ||||
| #define ACPI_LARGE_32_BIT_FIXED_MEMORY_RANGE_DESCRIPTOR_NAME 0x06 | ||||
| #define ACPI_LARGE_DWORD_ADDRESS_SPACE_DESCRIPTOR_NAME       0x07 | ||||
| #define ACPI_LARGE_WORD_ADDRESS_SPACE_DESCRIPTOR_NAME        0x08 | ||||
| #define ACPI_LARGE_EXTENDED_IRQ_DESCRIPTOR_NAME              0x09 | ||||
| #define ACPI_LARGE_QWORD_ADDRESS_SPACE_DESCRIPTOR_NAME       0x0A | ||||
|  | ||||
| // | ||||
| // Small Item Descriptor Value | ||||
| // | ||||
| #define ACPI_IRQ_NOFLAG_DESCRIPTOR                0x22 | ||||
| #define ACPI_IRQ_DESCRIPTOR                       0x23 | ||||
| #define ACPI_DMA_DESCRIPTOR                       0x2A | ||||
| #define ACPI_START_DEPENDENT_DESCRIPTOR           0x30 | ||||
| #define ACPI_START_DEPENDENT_EX_DESCRIPTOR        0x31 | ||||
| #define ACPI_END_DEPENDENT_DESCRIPTOR             0x38 | ||||
| #define ACPI_IO_PORT_DESCRIPTOR                   0x47 | ||||
| #define ACPI_FIXED_LOCATION_IO_PORT_DESCRIPTOR    0x4B | ||||
| #define ACPI_END_TAG_DESCRIPTOR                   0x79 | ||||
|  | ||||
| // | ||||
| // Large Item Descriptor Value | ||||
| // | ||||
| #define ACPI_24_BIT_MEMORY_RANGE_DESCRIPTOR       0x81 | ||||
| #define ACPI_32_BIT_MEMORY_RANGE_DESCRIPTOR       0x85 | ||||
| #define ACPI_32_BIT_FIXED_MEMORY_RANGE_DESCRIPTOR 0x86 | ||||
| #define ACPI_DWORD_ADDRESS_SPACE_DESCRIPTOR       0x87 | ||||
| #define ACPI_WORD_ADDRESS_SPACE_DESCRIPTOR        0x88 | ||||
| #define ACPI_EXTENDED_INTERRUPT_DESCRIPTOR        0x89 | ||||
| #define ACPI_QWORD_ADDRESS_SPACE_DESCRIPTOR       0x8A | ||||
| #define ACPI_ADDRESS_SPACE_DESCRIPTOR             0x8A | ||||
|  | ||||
| // | ||||
| // Resource Type | ||||
| // | ||||
| #define ACPI_ADDRESS_SPACE_TYPE_MEM   0x00 | ||||
| #define ACPI_ADDRESS_SPACE_TYPE_IO    0x01 | ||||
| #define ACPI_ADDRESS_SPACE_TYPE_BUS   0x02 | ||||
|  | ||||
| /// | ||||
| /// Power Management Timer frequency is fixed at 3.579545MHz. | ||||
| /// | ||||
| #define ACPI_TIMER_FREQUENCY       3579545 | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// The commond definition of QWORD, DWORD, and WORD | ||||
| /// Address Space Descriptors. | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   UINT8   Desc; | ||||
|   UINT16  Len; | ||||
|   UINT8   ResType; | ||||
|   UINT8   GenFlag; | ||||
|   UINT8   SpecificFlag; | ||||
|   UINT64  AddrSpaceGranularity; | ||||
|   UINT64  AddrRangeMin; | ||||
|   UINT64  AddrRangeMax; | ||||
|   UINT64  AddrTranslationOffset; | ||||
|   UINT64  AddrLen; | ||||
| } EFI_ACPI_ADDRESS_SPACE_DESCRIPTOR; | ||||
|  | ||||
| typedef PACKED union { | ||||
|   UINT8     Byte; | ||||
|   PACKED struct { | ||||
|     UINT8 Length : 3; | ||||
|     UINT8 Name : 4; | ||||
|     UINT8 Type : 1; | ||||
|   } Bits; | ||||
| } ACPI_SMALL_RESOURCE_HEADER; | ||||
|  | ||||
| typedef PACKED struct { | ||||
|   PACKED union { | ||||
|     UINT8 Byte; | ||||
|     PACKED struct { | ||||
|       UINT8 Name : 7; | ||||
|       UINT8 Type : 1; | ||||
|     }Bits; | ||||
|   } Header; | ||||
|   UINT16 Length; | ||||
| } ACPI_LARGE_RESOURCE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// IRQ Descriptor. | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_SMALL_RESOURCE_HEADER   Header; | ||||
|   UINT16                       Mask; | ||||
| } EFI_ACPI_IRQ_NOFLAG_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// IRQ Descriptor. | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_SMALL_RESOURCE_HEADER   Header; | ||||
|   UINT16                       Mask; | ||||
|   UINT8                        Information; | ||||
| } EFI_ACPI_IRQ_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// DMA Descriptor. | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_SMALL_RESOURCE_HEADER   Header; | ||||
|   UINT8                        ChannelMask; | ||||
|   UINT8                        Information; | ||||
| } EFI_ACPI_DMA_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// I/O Port Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_SMALL_RESOURCE_HEADER   Header; | ||||
|   UINT8                        Information; | ||||
|   UINT16                       BaseAddressMin; | ||||
|   UINT16                       BaseAddressMax; | ||||
|   UINT8                        Alignment; | ||||
|   UINT8                        Length; | ||||
| } EFI_ACPI_IO_PORT_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// Fixed Location I/O Port Descriptor. | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_SMALL_RESOURCE_HEADER   Header; | ||||
|   UINT16                       BaseAddress; | ||||
|   UINT8                        Length; | ||||
| } EFI_ACPI_FIXED_LOCATION_IO_PORT_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// 24-Bit Memory Range Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         Information; | ||||
|   UINT16                        BaseAddressMin; | ||||
|   UINT16                        BaseAddressMax; | ||||
|   UINT16                        Alignment; | ||||
|   UINT16                        Length; | ||||
| } EFI_ACPI_24_BIT_MEMORY_RANGE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// 32-Bit Memory Range Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         Information; | ||||
|   UINT32                        BaseAddressMin; | ||||
|   UINT32                        BaseAddressMax; | ||||
|   UINT32                        Alignment; | ||||
|   UINT32                        Length; | ||||
| } EFI_ACPI_32_BIT_MEMORY_RANGE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// Fixed 32-Bit Fixed Memory Range Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         Information; | ||||
|   UINT32                        BaseAddress; | ||||
|   UINT32                        Length; | ||||
| } EFI_ACPI_32_BIT_FIXED_MEMORY_RANGE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// QWORD Address Space Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         ResType; | ||||
|   UINT8                         GenFlag; | ||||
|   UINT8                         SpecificFlag; | ||||
|   UINT64                        AddrSpaceGranularity; | ||||
|   UINT64                        AddrRangeMin; | ||||
|   UINT64                        AddrRangeMax; | ||||
|   UINT64                        AddrTranslationOffset; | ||||
|   UINT64                        AddrLen; | ||||
| } EFI_ACPI_QWORD_ADDRESS_SPACE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// DWORD Address Space Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         ResType; | ||||
|   UINT8                         GenFlag; | ||||
|   UINT8                         SpecificFlag; | ||||
|   UINT32                        AddrSpaceGranularity; | ||||
|   UINT32                        AddrRangeMin; | ||||
|   UINT32                        AddrRangeMax; | ||||
|   UINT32                        AddrTranslationOffset; | ||||
|   UINT32                        AddrLen; | ||||
| } EFI_ACPI_DWORD_ADDRESS_SPACE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// WORD Address Space Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         ResType; | ||||
|   UINT8                         GenFlag; | ||||
|   UINT8                         SpecificFlag; | ||||
|   UINT16                        AddrSpaceGranularity; | ||||
|   UINT16                        AddrRangeMin; | ||||
|   UINT16                        AddrRangeMax; | ||||
|   UINT16                        AddrTranslationOffset; | ||||
|   UINT16                        AddrLen; | ||||
| } EFI_ACPI_WORD_ADDRESS_SPACE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// Extended Interrupt Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         InterruptVectorFlags; | ||||
|   UINT8                         InterruptTableLength; | ||||
|   UINT32                        InterruptNumber[1]; | ||||
| } EFI_ACPI_EXTENDED_INTERRUPT_DESCRIPTOR; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| /// | ||||
| /// The End tag identifies an end of resource data. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Desc; | ||||
|   UINT8 Checksum; | ||||
| } EFI_ACPI_END_TAG_DESCRIPTOR; | ||||
|  | ||||
| // | ||||
| // General use definitions | ||||
| // | ||||
| #define EFI_ACPI_RESERVED_BYTE  0x00 | ||||
| #define EFI_ACPI_RESERVED_WORD  0x0000 | ||||
| #define EFI_ACPI_RESERVED_DWORD 0x00000000 | ||||
| #define EFI_ACPI_RESERVED_QWORD 0x0000000000000000 | ||||
|  | ||||
| // | ||||
| // Resource Type Specific Flags | ||||
| // Ref ACPI specification 6.4.3.5.5 | ||||
| // | ||||
| // Bit [0]    : Write Status, _RW | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_READ_WRITE                (1 << 0) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_READ_ONLY                 (0 << 0) | ||||
| // | ||||
| // Bit [2:1]  : Memory Attributes, _MEM | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_NON_CACHEABLE             (0 << 1) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_CACHEABLE                 (1 << 1) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_CACHEABLE_WRITE_COMBINING (2 << 1) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_CACHEABLE_PREFETCHABLE    (3 << 1) | ||||
| // | ||||
| // Bit [4:3]  : Memory Attributes, _MTP | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_ADDRESS_RANGE_MEMORY      (0 << 3) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_ADDRESS_RANGE_RESERVED    (1 << 3) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_ADDRESS_RANGE_ACPI        (2 << 3) | ||||
| #define EFI_APCI_MEMORY_RESOURCE_SPECIFIC_FLAG_ADDRESS_RANGE_NVS         (3 << 3) | ||||
| // | ||||
| // Bit [5]    : Memory to I/O Translation, _TTP | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_TYPE_TRANSLATION          (1 << 5) | ||||
| #define EFI_ACPI_MEMORY_RESOURCE_SPECIFIC_FLAG_TYPE_STATIC               (0 << 5) | ||||
|  | ||||
| // | ||||
| // IRQ Information | ||||
| // Ref ACPI specification 6.4.2.1 | ||||
| // | ||||
| #define EFI_ACPI_IRQ_SHARABLE_MASK                      0x10 | ||||
| #define   EFI_ACPI_IRQ_SHARABLE                         0x10 | ||||
|  | ||||
| #define EFI_ACPI_IRQ_POLARITY_MASK                      0x08 | ||||
| #define   EFI_ACPI_IRQ_HIGH_TRUE                        0x00 | ||||
| #define   EFI_ACPI_IRQ_LOW_FALSE                        0x08 | ||||
|  | ||||
| #define EFI_ACPI_IRQ_MODE                               0x01 | ||||
| #define   EFI_ACPI_IRQ_LEVEL_TRIGGERED                  0x00 | ||||
| #define   EFI_ACPI_IRQ_EDGE_TRIGGERED                   0x01 | ||||
|  | ||||
| // | ||||
| // DMA Information | ||||
| // Ref ACPI specification 6.4.2.2 | ||||
| // | ||||
| #define EFI_ACPI_DMA_SPEED_TYPE_MASK                    0x60 | ||||
| #define   EFI_ACPI_DMA_SPEED_TYPE_COMPATIBILITY         0x00 | ||||
| #define   EFI_ACPI_DMA_SPEED_TYPE_A                     0x20 | ||||
| #define   EFI_ACPI_DMA_SPEED_TYPE_B                     0x40 | ||||
| #define   EFI_ACPI_DMA_SPEED_TYPE_F                     0x60 | ||||
|  | ||||
| #define EFI_ACPI_DMA_BUS_MASTER_MASK                    0x04 | ||||
| #define   EFI_ACPI_DMA_BUS_MASTER                       0x04 | ||||
|  | ||||
| #define EFI_ACPI_DMA_TRANSFER_TYPE_MASK                 0x03 | ||||
| #define   EFI_ACPI_DMA_TRANSFER_TYPE_8_BIT              0x00 | ||||
| #define   EFI_ACPI_DMA_TRANSFER_TYPE_8_BIT_AND_16_BIT   0x01 | ||||
| #define   EFI_ACPI_DMA_TRANSFER_TYPE_16_BIT             0x10 | ||||
|  | ||||
| // | ||||
| // IO Information | ||||
| // Ref ACPI specification 6.4.2.5 | ||||
| // | ||||
| #define EFI_ACPI_IO_DECODE_MASK                         0x01 | ||||
| #define   EFI_ACPI_IO_DECODE_16_BIT                     0x01 | ||||
| #define   EFI_ACPI_IO_DECODE_10_BIT                     0x00 | ||||
|  | ||||
| // | ||||
| // Memory Information | ||||
| // Ref ACPI specification 6.4.3.4 | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_WRITE_STATUS_MASK               0x01 | ||||
| #define   EFI_ACPI_MEMORY_WRITABLE                      0x01 | ||||
| #define   EFI_ACPI_MEMORY_NON_WRITABLE                  0x00 | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
| // | ||||
| // ACPI 1.0b table structures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Root System Description Pointer Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT64  Signature; | ||||
|   UINT8   Checksum; | ||||
|   UINT8   OemId[6]; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  RsdtAddress; | ||||
| } EFI_ACPI_1_0_ROOT_SYSTEM_DESCRIPTION_POINTER; | ||||
|  | ||||
| // | ||||
| // Root System Description Table | ||||
| // No definition needed as it is a common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT32 table pointers. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// RSDT Revision (as defined in ACPI 1.0b specification). | ||||
| /// | ||||
| #define EFI_ACPI_1_0_ROOT_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Fixed ACPI Description Table Structure (FADT). | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      FirmwareCtrl; | ||||
|   UINT32                      Dsdt; | ||||
|   UINT8                       IntModel; | ||||
|   UINT8                       Reserved1; | ||||
|   UINT16                      SciInt; | ||||
|   UINT32                      SmiCmd; | ||||
|   UINT8                       AcpiEnable; | ||||
|   UINT8                       AcpiDisable; | ||||
|   UINT8                       S4BiosReq; | ||||
|   UINT8                       Reserved2; | ||||
|   UINT32                      Pm1aEvtBlk; | ||||
|   UINT32                      Pm1bEvtBlk; | ||||
|   UINT32                      Pm1aCntBlk; | ||||
|   UINT32                      Pm1bCntBlk; | ||||
|   UINT32                      Pm2CntBlk; | ||||
|   UINT32                      PmTmrBlk; | ||||
|   UINT32                      Gpe0Blk; | ||||
|   UINT32                      Gpe1Blk; | ||||
|   UINT8                       Pm1EvtLen; | ||||
|   UINT8                       Pm1CntLen; | ||||
|   UINT8                       Pm2CntLen; | ||||
|   UINT8                       PmTmLen; | ||||
|   UINT8                       Gpe0BlkLen; | ||||
|   UINT8                       Gpe1BlkLen; | ||||
|   UINT8                       Gpe1Base; | ||||
|   UINT8                       Reserved3; | ||||
|   UINT16                      PLvl2Lat; | ||||
|   UINT16                      PLvl3Lat; | ||||
|   UINT16                      FlushSize; | ||||
|   UINT16                      FlushStride; | ||||
|   UINT8                       DutyOffset; | ||||
|   UINT8                       DutyWidth; | ||||
|   UINT8                       DayAlrm; | ||||
|   UINT8                       MonAlrm; | ||||
|   UINT8                       Century; | ||||
|   UINT8                       Reserved4; | ||||
|   UINT8                       Reserved5; | ||||
|   UINT8                       Reserved6; | ||||
|   UINT32                      Flags; | ||||
| } EFI_ACPI_1_0_FIXED_ACPI_DESCRIPTION_TABLE; | ||||
|  | ||||
| /// | ||||
| /// FADT Version (as defined in ACPI 1.0b specification). | ||||
| /// | ||||
| #define EFI_ACPI_1_0_FIXED_ACPI_DESCRIPTION_TABLE_REVISION  0x01 | ||||
|  | ||||
| #define EFI_ACPI_1_0_INT_MODE_DUAL_PIC         0 | ||||
| #define EFI_ACPI_1_0_INT_MODE_MULTIPLE_APIC    1 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Fixed Feature Flags | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_1_0_WBINVD               BIT0 | ||||
| #define EFI_ACPI_1_0_WBINVD_FLUSH         BIT1 | ||||
| #define EFI_ACPI_1_0_PROC_C1              BIT2 | ||||
| #define EFI_ACPI_1_0_P_LVL2_UP            BIT3 | ||||
| #define EFI_ACPI_1_0_PWR_BUTTON           BIT4 | ||||
| #define EFI_ACPI_1_0_SLP_BUTTON           BIT5 | ||||
| #define EFI_ACPI_1_0_FIX_RTC              BIT6 | ||||
| #define EFI_ACPI_1_0_RTC_S4               BIT7 | ||||
| #define EFI_ACPI_1_0_TMR_VAL_EXT          BIT8 | ||||
| #define EFI_ACPI_1_0_DCK_CAP              BIT9 | ||||
|  | ||||
| /// | ||||
| /// Firmware ACPI Control Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
|   UINT32  HardwareSignature; | ||||
|   UINT32  FirmwareWakingVector; | ||||
|   UINT32  GlobalLock; | ||||
|   UINT32  Flags; | ||||
|   UINT8   Reserved[40]; | ||||
| } EFI_ACPI_1_0_FIRMWARE_ACPI_CONTROL_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Firmware Control Structure Feature Flags. | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_S4BIOS_F             BIT0 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Description Table header definition.  The rest of the table | ||||
| /// must be defined in a platform-specific manner. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      LocalApicAddress; | ||||
|   UINT32                      Flags; | ||||
| } EFI_ACPI_1_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// MADT Revision (as defined in ACPI 1.0b specification). | ||||
| /// | ||||
| #define EFI_ACPI_1_0_MULTIPLE_APIC_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Flags | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_PCAT_COMPAT           BIT0 | ||||
|  | ||||
| // | ||||
| // Multiple APIC Description Table APIC structure types | ||||
| // All other values between 0x05 an 0xFF are reserved and | ||||
| // will be ignored by OSPM. | ||||
| // | ||||
| #define EFI_ACPI_1_0_PROCESSOR_LOCAL_APIC           0x00 | ||||
| #define EFI_ACPI_1_0_IO_APIC                        0x01 | ||||
| #define EFI_ACPI_1_0_INTERRUPT_SOURCE_OVERRIDE      0x02 | ||||
| #define EFI_ACPI_1_0_NON_MASKABLE_INTERRUPT_SOURCE  0x03 | ||||
| #define EFI_ACPI_1_0_LOCAL_APIC_NMI                 0x04 | ||||
|  | ||||
| // | ||||
| // APIC Structure Definitions | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Processor Local APIC Structure Definition. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT8   ApicId; | ||||
|   UINT32  Flags; | ||||
| } EFI_ACPI_1_0_PROCESSOR_LOCAL_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC Flags.  All other bits are reserved and must be 0. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_LOCAL_APIC_ENABLED      BIT0 | ||||
|  | ||||
| /// | ||||
| /// IO APIC Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   IoApicId; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  IoApicAddress; | ||||
|   UINT32  SystemVectorBase; | ||||
| } EFI_ACPI_1_0_IO_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Interrupt Source Override Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   Bus; | ||||
|   UINT8   Source; | ||||
|   UINT32  GlobalSystemInterruptVector; | ||||
|   UINT16  Flags; | ||||
| } EFI_ACPI_1_0_INTERRUPT_SOURCE_OVERRIDE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Non-Maskable Interrupt Source Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT32  GlobalSystemInterruptVector; | ||||
| } EFI_ACPI_1_0_NON_MASKABLE_INTERRUPT_SOURCE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC NMI Structure. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT16  Flags; | ||||
|   UINT8   LocalApicInti; | ||||
| } EFI_ACPI_1_0_LOCAL_APIC_NMI_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Smart Battery Description Table (SBST) | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      WarningEnergyLevel; | ||||
|   UINT32                      LowEnergyLevel; | ||||
|   UINT32                      CriticalEnergyLevel; | ||||
| } EFI_ACPI_1_0_SMART_BATTERY_DESCRIPTION_TABLE; | ||||
|  | ||||
| // | ||||
| // Known table signatures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// "RSD PTR " Root System Description Pointer. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE  SIGNATURE_64('R', 'S', 'D', ' ', 'P', 'T', 'R', ' ') | ||||
|  | ||||
| /// | ||||
| /// "APIC" Multiple APIC Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_APIC_SIGNATURE  SIGNATURE_32('A', 'P', 'I', 'C') | ||||
|  | ||||
| /// | ||||
| /// "DSDT" Differentiated System Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('D', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "FACS" Firmware ACPI Control Structure. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'S') | ||||
|  | ||||
| /// | ||||
| /// "FACP" Fixed ACPI Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'P') | ||||
|  | ||||
| /// | ||||
| /// "PSDT" Persistent System Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_PERSISTENT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('P', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "RSDT" Root System Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_ROOT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('R', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SBST" Smart Battery Specification Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_SMART_BATTERY_SPECIFICATION_TABLE_SIGNATURE  SIGNATURE_32('S', 'B', 'S', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SSDT" Secondary System Description Table. | ||||
| /// | ||||
| #define EFI_ACPI_1_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('S', 'S', 'D', 'T') | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
| @@ -1,545 +0,0 @@ | ||||
| /** @file | ||||
|   ACPI 2.0 definitions from the ACPI Specification, revision 2.0 | ||||
|  | ||||
|   Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
| **/ | ||||
|  | ||||
| #ifndef _ACPI_2_0_H_ | ||||
| #define _ACPI_2_0_H_ | ||||
|  | ||||
| #include <IndustryStandard/Acpi10.h> | ||||
|  | ||||
| // | ||||
| // Define for Desriptor | ||||
| // | ||||
| #define ACPI_LARGE_GENERIC_REGISTER_DESCRIPTOR_NAME          0x02 | ||||
|  | ||||
| #define ACPI_GENERIC_REGISTER_DESCRIPTOR          0x82 | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// Generic Register Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         AddressSpaceId; | ||||
|   UINT8                         RegisterBitWidth; | ||||
|   UINT8                         RegisterBitOffset; | ||||
|   UINT8                         AddressSize; | ||||
|   UINT64                        RegisterAddress; | ||||
| } EFI_ACPI_GENERIC_REGISTER_DESCRIPTOR; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// ACPI 2.0 Generic Address Space definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   AddressSpaceId; | ||||
|   UINT8   RegisterBitWidth; | ||||
|   UINT8   RegisterBitOffset; | ||||
|   UINT8   Reserved; | ||||
|   UINT64  Address; | ||||
| } EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE; | ||||
|  | ||||
| // | ||||
| // Generic Address Space Address IDs | ||||
| // | ||||
| #define EFI_ACPI_2_0_SYSTEM_MEMORY              0 | ||||
| #define EFI_ACPI_2_0_SYSTEM_IO                  1 | ||||
| #define EFI_ACPI_2_0_PCI_CONFIGURATION_SPACE    2 | ||||
| #define EFI_ACPI_2_0_EMBEDDED_CONTROLLER        3 | ||||
| #define EFI_ACPI_2_0_SMBUS                      4 | ||||
| #define EFI_ACPI_2_0_FUNCTIONAL_FIXED_HARDWARE  0x7F | ||||
|  | ||||
| // | ||||
| // ACPI 2.0 table structures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Root System Description Pointer Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT64  Signature; | ||||
|   UINT8   Checksum; | ||||
|   UINT8   OemId[6]; | ||||
|   UINT8   Revision; | ||||
|   UINT32  RsdtAddress; | ||||
|   UINT32  Length; | ||||
|   UINT64  XsdtAddress; | ||||
|   UINT8   ExtendedChecksum; | ||||
|   UINT8   Reserved[3]; | ||||
| } EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER; | ||||
|  | ||||
| /// | ||||
| /// RSD_PTR Revision (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER_REVISION 0x02 | ||||
|  | ||||
| /// | ||||
| /// Common table header, this prefaces all ACPI tables, including FACS, but | ||||
| /// excluding the RSD PTR structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
| } EFI_ACPI_2_0_COMMON_HEADER; | ||||
|  | ||||
| // | ||||
| // Root System Description Table | ||||
| // No definition needed as it is a common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT32 table pointers. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// RSDT Revision (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| // | ||||
| // Extended System Description Table | ||||
| // No definition needed as it is a common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT64 table pointers. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// XSDT Revision (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Fixed ACPI Description Table Structure (FADT) | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER             Header; | ||||
|   UINT32                                  FirmwareCtrl; | ||||
|   UINT32                                  Dsdt; | ||||
|   UINT8                                   Reserved0; | ||||
|   UINT8                                   PreferredPmProfile; | ||||
|   UINT16                                  SciInt; | ||||
|   UINT32                                  SmiCmd; | ||||
|   UINT8                                   AcpiEnable; | ||||
|   UINT8                                   AcpiDisable; | ||||
|   UINT8                                   S4BiosReq; | ||||
|   UINT8                                   PstateCnt; | ||||
|   UINT32                                  Pm1aEvtBlk; | ||||
|   UINT32                                  Pm1bEvtBlk; | ||||
|   UINT32                                  Pm1aCntBlk; | ||||
|   UINT32                                  Pm1bCntBlk; | ||||
|   UINT32                                  Pm2CntBlk; | ||||
|   UINT32                                  PmTmrBlk; | ||||
|   UINT32                                  Gpe0Blk; | ||||
|   UINT32                                  Gpe1Blk; | ||||
|   UINT8                                   Pm1EvtLen; | ||||
|   UINT8                                   Pm1CntLen; | ||||
|   UINT8                                   Pm2CntLen; | ||||
|   UINT8                                   PmTmrLen; | ||||
|   UINT8                                   Gpe0BlkLen; | ||||
|   UINT8                                   Gpe1BlkLen; | ||||
|   UINT8                                   Gpe1Base; | ||||
|   UINT8                                   CstCnt; | ||||
|   UINT16                                  PLvl2Lat; | ||||
|   UINT16                                  PLvl3Lat; | ||||
|   UINT16                                  FlushSize; | ||||
|   UINT16                                  FlushStride; | ||||
|   UINT8                                   DutyOffset; | ||||
|   UINT8                                   DutyWidth; | ||||
|   UINT8                                   DayAlrm; | ||||
|   UINT8                                   MonAlrm; | ||||
|   UINT8                                   Century; | ||||
|   UINT16                                  IaPcBootArch; | ||||
|   UINT8                                   Reserved1; | ||||
|   UINT32                                  Flags; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  ResetReg; | ||||
|   UINT8                                   ResetValue; | ||||
|   UINT8                                   Reserved2[3]; | ||||
|   UINT64                                  XFirmwareCtrl; | ||||
|   UINT64                                  XDsdt; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPm1aEvtBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPm1bEvtBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPm1aCntBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPm1bCntBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPm2CntBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XPmTmrBlk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XGpe0Blk; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  XGpe1Blk; | ||||
| } EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE; | ||||
|  | ||||
| /// | ||||
| /// FADT Version (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE_REVISION  0x03 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Preferred Power Management Profile | ||||
| // | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_UNSPECIFIED         0 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_DESKTOP             1 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_MOBILE              2 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_WORKSTATION         3 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_ENTERPRISE_SERVER   4 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_SOHO_SERVER         5 | ||||
| #define EFI_ACPI_2_0_PM_PROFILE_APPLIANCE_PC        6 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Boot Architecture Flags | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_2_0_LEGACY_DEVICES          BIT0 | ||||
| #define EFI_ACPI_2_0_8042                    BIT1 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Fixed Feature Flags | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_2_0_WBINVD                  BIT0 | ||||
| #define EFI_ACPI_2_0_WBINVD_FLUSH            BIT1 | ||||
| #define EFI_ACPI_2_0_PROC_C1                 BIT2 | ||||
| #define EFI_ACPI_2_0_P_LVL2_UP               BIT3 | ||||
| #define EFI_ACPI_2_0_PWR_BUTTON              BIT4 | ||||
| #define EFI_ACPI_2_0_SLP_BUTTON              BIT5 | ||||
| #define EFI_ACPI_2_0_FIX_RTC                 BIT6 | ||||
| #define EFI_ACPI_2_0_RTC_S4                  BIT7 | ||||
| #define EFI_ACPI_2_0_TMR_VAL_EXT             BIT8 | ||||
| #define EFI_ACPI_2_0_DCK_CAP                 BIT9 | ||||
| #define EFI_ACPI_2_0_RESET_REG_SUP           BIT10 | ||||
| #define EFI_ACPI_2_0_SEALED_CASE             BIT11 | ||||
| #define EFI_ACPI_2_0_HEADLESS                BIT12 | ||||
| #define EFI_ACPI_2_0_CPU_SW_SLP              BIT13 | ||||
|  | ||||
| /// | ||||
| /// Firmware ACPI Control Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
|   UINT32  HardwareSignature; | ||||
|   UINT32  FirmwareWakingVector; | ||||
|   UINT32  GlobalLock; | ||||
|   UINT32  Flags; | ||||
|   UINT64  XFirmwareWakingVector; | ||||
|   UINT8   Version; | ||||
|   UINT8   Reserved[31]; | ||||
| } EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// FACS Version (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_VERSION  0x01 | ||||
|  | ||||
| /// | ||||
| /// Firmware Control Structure Feature Flags | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_2_0_S4BIOS_F        BIT0 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Description Table header definition.  The rest of the table | ||||
| /// must be defined in a platform specific manner. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      LocalApicAddress; | ||||
|   UINT32                      Flags; | ||||
| } EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// MADT Revision (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Flags | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_2_0_PCAT_COMPAT          BIT0 | ||||
|  | ||||
| // | ||||
| // Multiple APIC Description Table APIC structure types | ||||
| // All other values between 0x09 an 0xFF are reserved and | ||||
| // will be ignored by OSPM. | ||||
| // | ||||
| #define EFI_ACPI_2_0_PROCESSOR_LOCAL_APIC           0x00 | ||||
| #define EFI_ACPI_2_0_IO_APIC                        0x01 | ||||
| #define EFI_ACPI_2_0_INTERRUPT_SOURCE_OVERRIDE      0x02 | ||||
| #define EFI_ACPI_2_0_NON_MASKABLE_INTERRUPT_SOURCE  0x03 | ||||
| #define EFI_ACPI_2_0_LOCAL_APIC_NMI                 0x04 | ||||
| #define EFI_ACPI_2_0_LOCAL_APIC_ADDRESS_OVERRIDE    0x05 | ||||
| #define EFI_ACPI_2_0_IO_SAPIC                       0x06 | ||||
| #define EFI_ACPI_2_0_PROCESSOR_LOCAL_SAPIC          0x07 | ||||
| #define EFI_ACPI_2_0_PLATFORM_INTERRUPT_SOURCES     0x08 | ||||
|  | ||||
| // | ||||
| // APIC Structure Definitions | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Processor Local APIC Structure Definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT8   ApicId; | ||||
|   UINT32  Flags; | ||||
| } EFI_ACPI_2_0_PROCESSOR_LOCAL_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC Flags.  All other bits are reserved and must be 0. | ||||
| /// | ||||
| #define EFI_ACPI_2_0_LOCAL_APIC_ENABLED         BIT0 | ||||
|  | ||||
| /// | ||||
| /// IO APIC Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   IoApicId; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  IoApicAddress; | ||||
|   UINT32  GlobalSystemInterruptBase; | ||||
| } EFI_ACPI_2_0_IO_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Interrupt Source Override Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   Bus; | ||||
|   UINT8   Source; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
|   UINT16  Flags; | ||||
| } EFI_ACPI_2_0_INTERRUPT_SOURCE_OVERRIDE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Non-Maskable Interrupt Source Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
| } EFI_ACPI_2_0_NON_MASKABLE_INTERRUPT_SOURCE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC NMI Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT16  Flags; | ||||
|   UINT8   LocalApicLint; | ||||
| } EFI_ACPI_2_0_LOCAL_APIC_NMI_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC Address Override Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Reserved; | ||||
|   UINT64  LocalApicAddress; | ||||
| } EFI_ACPI_2_0_LOCAL_APIC_ADDRESS_OVERRIDE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// IO SAPIC Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   IoApicId; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  GlobalSystemInterruptBase; | ||||
|   UINT64  IoSapicAddress; | ||||
| } EFI_ACPI_2_0_IO_SAPIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local SAPIC Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT8   LocalSapicId; | ||||
|   UINT8   LocalSapicEid; | ||||
|   UINT8   Reserved[3]; | ||||
|   UINT32  Flags; | ||||
| } EFI_ACPI_2_0_PROCESSOR_LOCAL_SAPIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Platform Interrupt Sources Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT8   InterruptType; | ||||
|   UINT8   ProcessorId; | ||||
|   UINT8   ProcessorEid; | ||||
|   UINT8   IoSapicVector; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
|   UINT32  Reserved; | ||||
| } EFI_ACPI_2_0_PLATFORM_INTERRUPT_SOURCES_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Smart Battery Description Table (SBST) | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      WarningEnergyLevel; | ||||
|   UINT32                      LowEnergyLevel; | ||||
|   UINT32                      CriticalEnergyLevel; | ||||
| } EFI_ACPI_2_0_SMART_BATTERY_DESCRIPTION_TABLE; | ||||
|  | ||||
| /// | ||||
| /// SBST Version (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SMART_BATTERY_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Embedded Controller Boot Resources Table (ECDT) | ||||
| /// The table is followed by a null terminated ASCII string that contains | ||||
| /// a fully qualified reference to the name space object. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER             Header; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  EcControl; | ||||
|   EFI_ACPI_2_0_GENERIC_ADDRESS_STRUCTURE  EcData; | ||||
|   UINT32                                  Uid; | ||||
|   UINT8                                   GpeBit; | ||||
| } EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE; | ||||
|  | ||||
| /// | ||||
| /// ECDT Version (as defined in ACPI 2.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_REVISION  0x01 | ||||
|  | ||||
| // | ||||
| // Known table signatures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// "RSD PTR " Root System Description Pointer | ||||
| /// | ||||
| #define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE  SIGNATURE_64('R', 'S', 'D', ' ', 'P', 'T', 'R', ' ') | ||||
|  | ||||
| /// | ||||
| /// "SPIC" Multiple SAPIC Description Table | ||||
| /// | ||||
| /// BUGBUG: Don't know where this came from except SR870BN4 uses it. | ||||
| /// #define EFI_ACPI_2_0_MULTIPLE_SAPIC_DESCRIPTION_TABLE_SIGNATURE 0x43495053 | ||||
| /// | ||||
| #define EFI_ACPI_2_0_MULTIPLE_SAPIC_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('A', 'P', 'I', 'C') | ||||
|  | ||||
| /// | ||||
| /// "BOOT" MS Simple Boot Spec | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SIMPLE_BOOT_FLAG_TABLE_SIGNATURE  SIGNATURE_32('B', 'O', 'O', 'T') | ||||
|  | ||||
| /// | ||||
| /// "DBGP" MS Bebug Port Spec | ||||
| /// | ||||
| #define EFI_ACPI_2_0_DEBUG_PORT_TABLE_SIGNATURE  SIGNATURE_32('D', 'B', 'G', 'P') | ||||
|  | ||||
| /// | ||||
| /// "DSDT" Differentiated System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('D', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "ECDT" Embedded Controller Boot Resources Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_SIGNATURE  SIGNATURE_32('E', 'C', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "ETDT" Event Timer Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_EVENT_TIMER_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('E', 'T', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "FACS" Firmware ACPI Control Structure | ||||
| /// | ||||
| #define EFI_ACPI_2_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'S') | ||||
|  | ||||
| /// | ||||
| /// "FACP" Fixed ACPI Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'P') | ||||
|  | ||||
| /// | ||||
| /// "APIC" Multiple APIC Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_MULTIPLE_APIC_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('A', 'P', 'I', 'C') | ||||
|  | ||||
| /// | ||||
| /// "PSDT" Persistent System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_PERSISTENT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('P', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "RSDT" Root System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_ROOT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('R', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SBST" Smart Battery Specification Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SMART_BATTERY_SPECIFICATION_TABLE_SIGNATURE  SIGNATURE_32('S', 'B', 'S', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SLIT" System Locality Information Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SYSTEM_LOCALITY_INFORMATION_TABLE_SIGNATURE  SIGNATURE_32('S', 'L', 'I', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SPCR" Serial Port Concole Redirection Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SERIAL_PORT_CONSOLE_REDIRECTION_TABLE_SIGNATURE  SIGNATURE_32('S', 'P', 'C', 'R') | ||||
|  | ||||
| /// | ||||
| /// "SRAT" Static Resource Affinity Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_STATIC_RESOURCE_AFFINITY_TABLE_SIGNATURE  SIGNATURE_32('S', 'R', 'A', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SSDT" Secondary System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('S', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SPMI" Server Platform Management Interface Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_SERVER_PLATFORM_MANAGEMENT_INTERFACE_SIGNATURE  SIGNATURE_32('S', 'P', 'M', 'I') | ||||
|  | ||||
| /// | ||||
| /// "XSDT" Extended System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('X', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "MCFG" PCI Express Memory Mapped Configuration Space Base Address Description Table | ||||
| /// | ||||
| #define EFI_ACPI_2_0_MEMORY_MAPPED_CONFIGURATION_BASE_ADDRESS_TABLE_SIGNATURE  SIGNATURE_32('M', 'C', 'F', 'G') | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
| @@ -1,729 +0,0 @@ | ||||
| /** @file | ||||
|   ACPI 3.0 definitions from the ACPI Specification Revision 3.0b October 10, 2006 | ||||
|  | ||||
|   Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
| **/ | ||||
|  | ||||
| #ifndef _ACPI_3_0_H_ | ||||
| #define _ACPI_3_0_H_ | ||||
|  | ||||
| #include <IndustryStandard/Acpi20.h> | ||||
|  | ||||
| // | ||||
| // Define for Desriptor | ||||
| // | ||||
| #define ACPI_LARGE_EXTENDED_ADDRESS_SPACE_DESCRIPTOR_NAME    0x0B | ||||
|  | ||||
| #define ACPI_EXTENDED_ADDRESS_SPACE_DESCRIPTOR    0x8B | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// Extended Address Space Descriptor | ||||
| /// | ||||
| typedef PACKED struct { | ||||
|   ACPI_LARGE_RESOURCE_HEADER    Header; | ||||
|   UINT8                         ResType; | ||||
|   UINT8                         GenFlag; | ||||
|   UINT8                         SpecificFlag; | ||||
|   UINT8                         RevisionId; | ||||
|   UINT8                         Reserved; | ||||
|   UINT64                        AddrSpaceGranularity; | ||||
|   UINT64                        AddrRangeMin; | ||||
|   UINT64                        AddrRangeMax; | ||||
|   UINT64                        AddrTranslationOffset; | ||||
|   UINT64                        AddrLen; | ||||
|   UINT64                        TypeSpecificAttribute; | ||||
| } EFI_ACPI_EXTENDED_ADDRESS_SPACE_DESCRIPTOR; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| // | ||||
| // Memory Type Specific Flags | ||||
| // | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_UC  0x0000000000000001 | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_WC  0x0000000000000002 | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_WT  0x0000000000000004 | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_WB  0x0000000000000008 | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_UCE 0x0000000000000010 | ||||
| #define EFI_ACPI_MEMORY_TYPE_SPECIFIC_ATTRIBUTES_NV  0x0000000000008000 | ||||
|  | ||||
| // | ||||
| // Ensure proper structure formats | ||||
| // | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// ACPI 3.0 Generic Address Space definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   AddressSpaceId; | ||||
|   UINT8   RegisterBitWidth; | ||||
|   UINT8   RegisterBitOffset; | ||||
|   UINT8   AccessSize; | ||||
|   UINT64  Address; | ||||
| } EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE; | ||||
|  | ||||
| // | ||||
| // Generic Address Space Address IDs | ||||
| // | ||||
| #define EFI_ACPI_3_0_SYSTEM_MEMORY              0 | ||||
| #define EFI_ACPI_3_0_SYSTEM_IO                  1 | ||||
| #define EFI_ACPI_3_0_PCI_CONFIGURATION_SPACE    2 | ||||
| #define EFI_ACPI_3_0_EMBEDDED_CONTROLLER        3 | ||||
| #define EFI_ACPI_3_0_SMBUS                      4 | ||||
| #define EFI_ACPI_3_0_FUNCTIONAL_FIXED_HARDWARE  0x7F | ||||
|  | ||||
| // | ||||
| // Generic Address Space Access Sizes | ||||
| // | ||||
| #define EFI_ACPI_3_0_UNDEFINED  0 | ||||
| #define EFI_ACPI_3_0_BYTE       1 | ||||
| #define EFI_ACPI_3_0_WORD       2 | ||||
| #define EFI_ACPI_3_0_DWORD      3 | ||||
| #define EFI_ACPI_3_0_QWORD      4 | ||||
|  | ||||
| // | ||||
| // ACPI 3.0 table structures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Root System Description Pointer Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT64  Signature; | ||||
|   UINT8   Checksum; | ||||
|   UINT8   OemId[6]; | ||||
|   UINT8   Revision; | ||||
|   UINT32  RsdtAddress; | ||||
|   UINT32  Length; | ||||
|   UINT64  XsdtAddress; | ||||
|   UINT8   ExtendedChecksum; | ||||
|   UINT8   Reserved[3]; | ||||
| } EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER; | ||||
|  | ||||
| /// | ||||
| /// RSD_PTR Revision (as defined in ACPI 3.0b spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER_REVISION 0x02  ///< ACPISpec (Revision 3.0b) says current value is 2 | ||||
|  | ||||
| /// | ||||
| /// Common table header, this prefaces all ACPI tables, including FACS, but | ||||
| /// excluding the RSD PTR structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
| } EFI_ACPI_3_0_COMMON_HEADER; | ||||
|  | ||||
| // | ||||
| // Root System Description Table | ||||
| // No definition needed as it is a common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT32 table pointers. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// RSDT Revision (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| // | ||||
| // Extended System Description Table | ||||
| // No definition needed as it is a common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a variable number of UINT64 table pointers. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// XSDT Revision (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Fixed ACPI Description Table Structure (FADT) | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER             Header; | ||||
|   UINT32                                  FirmwareCtrl; | ||||
|   UINT32                                  Dsdt; | ||||
|   UINT8                                   Reserved0; | ||||
|   UINT8                                   PreferredPmProfile; | ||||
|   UINT16                                  SciInt; | ||||
|   UINT32                                  SmiCmd; | ||||
|   UINT8                                   AcpiEnable; | ||||
|   UINT8                                   AcpiDisable; | ||||
|   UINT8                                   S4BiosReq; | ||||
|   UINT8                                   PstateCnt; | ||||
|   UINT32                                  Pm1aEvtBlk; | ||||
|   UINT32                                  Pm1bEvtBlk; | ||||
|   UINT32                                  Pm1aCntBlk; | ||||
|   UINT32                                  Pm1bCntBlk; | ||||
|   UINT32                                  Pm2CntBlk; | ||||
|   UINT32                                  PmTmrBlk; | ||||
|   UINT32                                  Gpe0Blk; | ||||
|   UINT32                                  Gpe1Blk; | ||||
|   UINT8                                   Pm1EvtLen; | ||||
|   UINT8                                   Pm1CntLen; | ||||
|   UINT8                                   Pm2CntLen; | ||||
|   UINT8                                   PmTmrLen; | ||||
|   UINT8                                   Gpe0BlkLen; | ||||
|   UINT8                                   Gpe1BlkLen; | ||||
|   UINT8                                   Gpe1Base; | ||||
|   UINT8                                   CstCnt; | ||||
|   UINT16                                  PLvl2Lat; | ||||
|   UINT16                                  PLvl3Lat; | ||||
|   UINT16                                  FlushSize; | ||||
|   UINT16                                  FlushStride; | ||||
|   UINT8                                   DutyOffset; | ||||
|   UINT8                                   DutyWidth; | ||||
|   UINT8                                   DayAlrm; | ||||
|   UINT8                                   MonAlrm; | ||||
|   UINT8                                   Century; | ||||
|   UINT16                                  IaPcBootArch; | ||||
|   UINT8                                   Reserved1; | ||||
|   UINT32                                  Flags; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  ResetReg; | ||||
|   UINT8                                   ResetValue; | ||||
|   UINT8                                   Reserved2[3]; | ||||
|   UINT64                                  XFirmwareCtrl; | ||||
|   UINT64                                  XDsdt; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPm1aEvtBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPm1bEvtBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPm1aCntBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPm1bCntBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPm2CntBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XPmTmrBlk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XGpe0Blk; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  XGpe1Blk; | ||||
| } EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE; | ||||
|  | ||||
| /// | ||||
| /// FADT Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE_REVISION  0x04 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Preferred Power Management Profile | ||||
| // | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_UNSPECIFIED         0 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_DESKTOP             1 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_MOBILE              2 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_WORKSTATION         3 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_ENTERPRISE_SERVER   4 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_SOHO_SERVER         5 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_APPLIANCE_PC        6 | ||||
| #define EFI_ACPI_3_0_PM_PROFILE_PERFORMANCE_SERVER  7 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Boot Architecture Flags | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_3_0_LEGACY_DEVICES              BIT0 | ||||
| #define EFI_ACPI_3_0_8042                        BIT1 | ||||
| #define EFI_ACPI_3_0_VGA_NOT_PRESENT             BIT2 | ||||
| #define EFI_ACPI_3_0_MSI_NOT_SUPPORTED           BIT3 | ||||
| #define EFI_ACPI_3_0_PCIE_ASPM_CONTROLS          BIT4 | ||||
|  | ||||
| // | ||||
| // Fixed ACPI Description Table Fixed Feature Flags | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_3_0_WBINVD                                 BIT0 | ||||
| #define EFI_ACPI_3_0_WBINVD_FLUSH                           BIT1 | ||||
| #define EFI_ACPI_3_0_PROC_C1                                BIT2 | ||||
| #define EFI_ACPI_3_0_P_LVL2_UP                              BIT3 | ||||
| #define EFI_ACPI_3_0_PWR_BUTTON                             BIT4 | ||||
| #define EFI_ACPI_3_0_SLP_BUTTON                             BIT5 | ||||
| #define EFI_ACPI_3_0_FIX_RTC                                BIT6 | ||||
| #define EFI_ACPI_3_0_RTC_S4                                 BIT7 | ||||
| #define EFI_ACPI_3_0_TMR_VAL_EXT                            BIT8 | ||||
| #define EFI_ACPI_3_0_DCK_CAP                                BIT9 | ||||
| #define EFI_ACPI_3_0_RESET_REG_SUP                          BIT10 | ||||
| #define EFI_ACPI_3_0_SEALED_CASE                            BIT11 | ||||
| #define EFI_ACPI_3_0_HEADLESS                               BIT12 | ||||
| #define EFI_ACPI_3_0_CPU_SW_SLP                             BIT13 | ||||
| #define EFI_ACPI_3_0_PCI_EXP_WAK                            BIT14 | ||||
| #define EFI_ACPI_3_0_USE_PLATFORM_CLOCK                     BIT15 | ||||
| #define EFI_ACPI_3_0_S4_RTC_STS_VALID                       BIT16 | ||||
| #define EFI_ACPI_3_0_REMOTE_POWER_ON_CAPABLE                BIT17 | ||||
| #define EFI_ACPI_3_0_FORCE_APIC_CLUSTER_MODEL               BIT18 | ||||
| #define EFI_ACPI_3_0_FORCE_APIC_PHYSICAL_DESTINATION_MODE   BIT19 | ||||
|  | ||||
| /// | ||||
| /// Firmware ACPI Control Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Signature; | ||||
|   UINT32  Length; | ||||
|   UINT32  HardwareSignature; | ||||
|   UINT32  FirmwareWakingVector; | ||||
|   UINT32  GlobalLock; | ||||
|   UINT32  Flags; | ||||
|   UINT64  XFirmwareWakingVector; | ||||
|   UINT8   Version; | ||||
|   UINT8   Reserved[31]; | ||||
| } EFI_ACPI_3_0_FIRMWARE_ACPI_CONTROL_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// FACS Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_VERSION  0x01 | ||||
|  | ||||
| /// | ||||
| /// Firmware Control Structure Feature Flags | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_3_0_S4BIOS_F       BIT0 | ||||
|  | ||||
| // | ||||
| // Differentiated System Description Table, | ||||
| // Secondary System Description Table | ||||
| // and Persistent System Description Table, | ||||
| // no definition needed as they are common description table header, the same with | ||||
| // EFI_ACPI_DESCRIPTION_HEADER, followed by a definition block. | ||||
| // | ||||
| #define EFI_ACPI_3_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_REVISION   0x02 | ||||
| #define EFI_ACPI_3_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_REVISION        0x02 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Description Table header definition.  The rest of the table | ||||
| /// must be defined in a platform specific manner. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      LocalApicAddress; | ||||
|   UINT32                      Flags; | ||||
| } EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// MADT Revision (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_REVISION 0x02 | ||||
|  | ||||
| /// | ||||
| /// Multiple APIC Flags | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_3_0_PCAT_COMPAT         BIT0 | ||||
|  | ||||
| // | ||||
| // Multiple APIC Description Table APIC structure types | ||||
| // All other values between 0x09 an 0xFF are reserved and | ||||
| // will be ignored by OSPM. | ||||
| // | ||||
| #define EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC           0x00 | ||||
| #define EFI_ACPI_3_0_IO_APIC                        0x01 | ||||
| #define EFI_ACPI_3_0_INTERRUPT_SOURCE_OVERRIDE      0x02 | ||||
| #define EFI_ACPI_3_0_NON_MASKABLE_INTERRUPT_SOURCE  0x03 | ||||
| #define EFI_ACPI_3_0_LOCAL_APIC_NMI                 0x04 | ||||
| #define EFI_ACPI_3_0_LOCAL_APIC_ADDRESS_OVERRIDE    0x05 | ||||
| #define EFI_ACPI_3_0_IO_SAPIC                       0x06 | ||||
| #define EFI_ACPI_3_0_LOCAL_SAPIC                    0x07 | ||||
| #define EFI_ACPI_3_0_PLATFORM_INTERRUPT_SOURCES     0x08 | ||||
|  | ||||
| // | ||||
| // APIC Structure Definitions | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Processor Local APIC Structure Definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT8   ApicId; | ||||
|   UINT32  Flags; | ||||
| } EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC Flags.  All other bits are reserved and must be 0. | ||||
| /// | ||||
| #define EFI_ACPI_3_0_LOCAL_APIC_ENABLED        BIT0 | ||||
|  | ||||
| /// | ||||
| /// IO APIC Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   IoApicId; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  IoApicAddress; | ||||
|   UINT32  GlobalSystemInterruptBase; | ||||
| } EFI_ACPI_3_0_IO_APIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Interrupt Source Override Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   Bus; | ||||
|   UINT8   Source; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
|   UINT16  Flags; | ||||
| } EFI_ACPI_3_0_INTERRUPT_SOURCE_OVERRIDE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Platform Interrupt Sources Structure Definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT8   InterruptType; | ||||
|   UINT8   ProcessorId; | ||||
|   UINT8   ProcessorEid; | ||||
|   UINT8   IoSapicVector; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
|   UINT32  PlatformInterruptSourceFlags; | ||||
|   UINT8   CpeiProcessorOverride; | ||||
|   UINT8   Reserved[31]; | ||||
| } EFI_ACPI_3_0_PLATFORM_INTERRUPT_APIC_STRUCTURE; | ||||
|  | ||||
| // | ||||
| // MPS INTI flags. | ||||
| // All other bits are reserved and must be set to 0. | ||||
| // | ||||
| #define EFI_ACPI_3_0_POLARITY      (3 << 0) | ||||
| #define EFI_ACPI_3_0_TRIGGER_MODE  (3 << 2) | ||||
|  | ||||
| /// | ||||
| /// Non-Maskable Interrupt Source Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
| } EFI_ACPI_3_0_NON_MASKABLE_INTERRUPT_SOURCE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC NMI Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT16  Flags; | ||||
|   UINT8   LocalApicLint; | ||||
| } EFI_ACPI_3_0_LOCAL_APIC_NMI_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC Address Override Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Reserved; | ||||
|   UINT64  LocalApicAddress; | ||||
| } EFI_ACPI_3_0_LOCAL_APIC_ADDRESS_OVERRIDE_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// IO SAPIC Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   IoApicId; | ||||
|   UINT8   Reserved; | ||||
|   UINT32  GlobalSystemInterruptBase; | ||||
|   UINT64  IoSapicAddress; | ||||
| } EFI_ACPI_3_0_IO_SAPIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local SAPIC Structure | ||||
| /// This struct followed by a null-terminated ASCII string - ACPI Processor UID String | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   AcpiProcessorId; | ||||
|   UINT8   LocalSapicId; | ||||
|   UINT8   LocalSapicEid; | ||||
|   UINT8   Reserved[3]; | ||||
|   UINT32  Flags; | ||||
|   UINT32  ACPIProcessorUIDValue; | ||||
| } EFI_ACPI_3_0_PROCESSOR_LOCAL_SAPIC_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Platform Interrupt Sources Structure | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT16  Flags; | ||||
|   UINT8   InterruptType; | ||||
|   UINT8   ProcessorId; | ||||
|   UINT8   ProcessorEid; | ||||
|   UINT8   IoSapicVector; | ||||
|   UINT32  GlobalSystemInterrupt; | ||||
|   UINT32  PlatformInterruptSourceFlags; | ||||
| } EFI_ACPI_3_0_PLATFORM_INTERRUPT_SOURCES_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Platform Interrupt Source Flags. | ||||
| /// All other bits are reserved and must be set to 0. | ||||
| /// | ||||
| #define EFI_ACPI_3_0_CPEI_PROCESSOR_OVERRIDE          BIT0 | ||||
|  | ||||
| /// | ||||
| /// Smart Battery Description Table (SBST) | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      WarningEnergyLevel; | ||||
|   UINT32                      LowEnergyLevel; | ||||
|   UINT32                      CriticalEnergyLevel; | ||||
| } EFI_ACPI_3_0_SMART_BATTERY_DESCRIPTION_TABLE; | ||||
|  | ||||
| /// | ||||
| /// SBST Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SMART_BATTERY_DESCRIPTION_TABLE_REVISION 0x01 | ||||
|  | ||||
| /// | ||||
| /// Embedded Controller Boot Resources Table (ECDT) | ||||
| /// The table is followed by a null terminated ASCII string that contains | ||||
| /// a fully qualified reference to the name space object. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER             Header; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  EcControl; | ||||
|   EFI_ACPI_3_0_GENERIC_ADDRESS_STRUCTURE  EcData; | ||||
|   UINT32                                  Uid; | ||||
|   UINT8                                   GpeBit; | ||||
| } EFI_ACPI_3_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE; | ||||
|  | ||||
| /// | ||||
| /// ECDT Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_REVISION  0x01 | ||||
|  | ||||
| /// | ||||
| /// System Resource Affinity Table (SRAT.  The rest of the table | ||||
| /// must be defined in a platform specific manner. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT32                      Reserved1;  ///< Must be set to 1 | ||||
|   UINT64                      Reserved2; | ||||
| } EFI_ACPI_3_0_SYSTEM_RESOURCE_AFFINITY_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// SRAT Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SYSTEM_RESOURCE_AFFINITY_TABLE_REVISION  0x02 | ||||
|  | ||||
| // | ||||
| // SRAT structure types. | ||||
| // All other values between 0x02 an 0xFF are reserved and | ||||
| // will be ignored by OSPM. | ||||
| // | ||||
| #define EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC_SAPIC_AFFINITY  0x00 | ||||
| #define EFI_ACPI_3_0_MEMORY_AFFINITY                      0x01 | ||||
|  | ||||
| /// | ||||
| /// Processor Local APIC/SAPIC Affinity Structure Definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT8   ProximityDomain7To0; | ||||
|   UINT8   ApicId; | ||||
|   UINT32  Flags; | ||||
|   UINT8   LocalSapicEid; | ||||
|   UINT8   ProximityDomain31To8[3]; | ||||
|   UINT8   Reserved[4]; | ||||
| } EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC_SAPIC_AFFINITY_STRUCTURE; | ||||
|  | ||||
| /// | ||||
| /// Local APIC/SAPIC Flags.  All other bits are reserved and must be 0. | ||||
| /// | ||||
| #define EFI_ACPI_3_0_PROCESSOR_LOCAL_APIC_SAPIC_ENABLED (1 << 0) | ||||
|  | ||||
| /// | ||||
| /// Memory Affinity Structure Definition | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8   Type; | ||||
|   UINT8   Length; | ||||
|   UINT32  ProximityDomain; | ||||
|   UINT16  Reserved1; | ||||
|   UINT32  AddressBaseLow; | ||||
|   UINT32  AddressBaseHigh; | ||||
|   UINT32  LengthLow; | ||||
|   UINT32  LengthHigh; | ||||
|   UINT32  Reserved2; | ||||
|   UINT32  Flags; | ||||
|   UINT64  Reserved3; | ||||
| } EFI_ACPI_3_0_MEMORY_AFFINITY_STRUCTURE; | ||||
|  | ||||
| // | ||||
| // Memory Flags.  All other bits are reserved and must be 0. | ||||
| // | ||||
| #define EFI_ACPI_3_0_MEMORY_ENABLED       (1 << 0) | ||||
| #define EFI_ACPI_3_0_MEMORY_HOT_PLUGGABLE (1 << 1) | ||||
| #define EFI_ACPI_3_0_MEMORY_NONVOLATILE   (1 << 2) | ||||
|  | ||||
| /// | ||||
| /// System Locality Distance Information Table (SLIT). | ||||
| /// The rest of the table is a matrix. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_ACPI_DESCRIPTION_HEADER Header; | ||||
|   UINT64                      NumberOfSystemLocalities; | ||||
| } EFI_ACPI_3_0_SYSTEM_LOCALITY_DISTANCE_INFORMATION_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// SLIT Version (as defined in ACPI 3.0 spec.) | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SYSTEM_LOCALITY_DISTANCE_INFORMATION_TABLE_REVISION  0x01 | ||||
|  | ||||
| // | ||||
| // Known table signatures | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// "RSD PTR " Root System Description Pointer | ||||
| /// | ||||
| #define EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_POINTER_SIGNATURE  SIGNATURE_64('R', 'S', 'D', ' ', 'P', 'T', 'R', ' ') | ||||
|  | ||||
| /// | ||||
| /// "APIC" Multiple APIC Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_MULTIPLE_APIC_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('A', 'P', 'I', 'C') | ||||
|  | ||||
| /// | ||||
| /// "DSDT" Differentiated System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_DIFFERENTIATED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('D', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "ECDT" Embedded Controller Boot Resources Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_EMBEDDED_CONTROLLER_BOOT_RESOURCES_TABLE_SIGNATURE  SIGNATURE_32('E', 'C', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "FACP" Fixed ACPI Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_FIXED_ACPI_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'P') | ||||
|  | ||||
| /// | ||||
| /// "FACS" Firmware ACPI Control Structure | ||||
| /// | ||||
| #define EFI_ACPI_3_0_FIRMWARE_ACPI_CONTROL_STRUCTURE_SIGNATURE  SIGNATURE_32('F', 'A', 'C', 'S') | ||||
|  | ||||
| /// | ||||
| /// "PSDT" Persistent System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_PERSISTENT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('P', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "RSDT" Root System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_ROOT_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('R', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SBST" Smart Battery Specification Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SMART_BATTERY_SPECIFICATION_TABLE_SIGNATURE  SIGNATURE_32('S', 'B', 'S', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SLIT" System Locality Information Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SYSTEM_LOCALITY_INFORMATION_TABLE_SIGNATURE  SIGNATURE_32('S', 'L', 'I', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SRAT" System Resource Affinity Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SYSTEM_RESOURCE_AFFINITY_TABLE_SIGNATURE  SIGNATURE_32('S', 'R', 'A', 'T') | ||||
|  | ||||
| /// | ||||
| /// "SSDT" Secondary System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SECONDARY_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('S', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "XSDT" Extended System Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_EXTENDED_SYSTEM_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('X', 'S', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "BOOT" MS Simple Boot Spec | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SIMPLE_BOOT_FLAG_TABLE_SIGNATURE  SIGNATURE_32('B', 'O', 'O', 'T') | ||||
|  | ||||
| /// | ||||
| /// "CPEP" Corrected Platform Error Polling Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_CORRECTED_PLATFORM_ERROR_POLLING_TABLE_SIGNATURE  SIGNATURE_32('C', 'P', 'E', 'P') | ||||
|  | ||||
| /// | ||||
| /// "DBGP" MS Debug Port Spec | ||||
| /// | ||||
| #define EFI_ACPI_3_0_DEBUG_PORT_TABLE_SIGNATURE  SIGNATURE_32('D', 'B', 'G', 'P') | ||||
|  | ||||
| /// | ||||
| /// "ETDT" Event Timer Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_EVENT_TIMER_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('E', 'T', 'D', 'T') | ||||
|  | ||||
| /// | ||||
| /// "HPET" IA-PC High Precision Event Timer Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_HIGH_PRECISION_EVENT_TIMER_TABLE_SIGNATURE  SIGNATURE_32('H', 'P', 'E', 'T') | ||||
|  | ||||
| /// | ||||
| /// "MCFG" PCI Express Memory Mapped Configuration Space Base Address Description Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_PCI_EXPRESS_MEMORY_MAPPED_CONFIGURATION_SPACE_BASE_ADDRESS_DESCRIPTION_TABLE_SIGNATURE  SIGNATURE_32('M', 'C', 'F', 'G') | ||||
|  | ||||
| /// | ||||
| /// "SPCR" Serial Port Concole Redirection Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SERIAL_PORT_CONSOLE_REDIRECTION_TABLE_SIGNATURE  SIGNATURE_32('S', 'P', 'C', 'R') | ||||
|  | ||||
| /// | ||||
| /// "SPMI" Server Platform Management Interface Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_SERVER_PLATFORM_MANAGEMENT_INTERFACE_TABLE_SIGNATURE  SIGNATURE_32('S', 'P', 'M', 'I') | ||||
|  | ||||
| /// | ||||
| /// "TCPA" Trusted Computing Platform Alliance Capabilities Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_TRUSTED_COMPUTING_PLATFORM_ALLIANCE_CAPABILITIES_TABLE_SIGNATURE  SIGNATURE_32('T', 'C', 'P', 'A') | ||||
|  | ||||
| /// | ||||
| /// "WDRT" Watchdog Resource Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_WATCHDOG_RESOURCE_TABLE_SIGNATURE  SIGNATURE_32('W', 'D', 'R', 'T') | ||||
|  | ||||
| /// | ||||
| /// "WDAT" Watchdog Action Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_WATCHDOG_ACTION_TABLE_SIGNATURE  SIGNATURE_32('W', 'D', 'A', 'T') | ||||
|  | ||||
| /// | ||||
| /// "WSPT" Windows Specific Properties Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_WINDOWS_SPECIFIC_PROPERTIES_TABLE_SIGNATURE  SIGNATURE_32('W', 'S', 'P', 'T') | ||||
|  | ||||
| /// | ||||
| /// "iBFT" iSCSI Boot Firmware Table | ||||
| /// | ||||
| #define EFI_ACPI_3_0_ISCSI_BOOT_FIRMWARE_TABLE_SIGNATURE  SIGNATURE_32('i', 'B', 'F', 'T') | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,175 +0,0 @@ | ||||
| /** @file | ||||
|   This file contains AML code definition in the latest ACPI spec. | ||||
|  | ||||
|   Copyright (c) 2011, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _ACPI_AML_H_ | ||||
| #define _ACPI_AML_H_ | ||||
|  | ||||
| // | ||||
| // ACPI AML definition | ||||
| // | ||||
|  | ||||
| // | ||||
| // Primary OpCode | ||||
| // | ||||
| #define AML_ZERO_OP                  0x00 | ||||
| #define AML_ONE_OP                   0x01 | ||||
| #define AML_ALIAS_OP                 0x06 | ||||
| #define AML_NAME_OP                  0x08 | ||||
| #define AML_BYTE_PREFIX              0x0a | ||||
| #define AML_WORD_PREFIX              0x0b | ||||
| #define AML_DWORD_PREFIX             0x0c | ||||
| #define AML_STRING_PREFIX            0x0d | ||||
| #define AML_QWORD_PREFIX             0x0e | ||||
| #define AML_SCOPE_OP                 0x10 | ||||
| #define AML_BUFFER_OP                0x11 | ||||
| #define AML_PACKAGE_OP               0x12 | ||||
| #define AML_VAR_PACKAGE_OP           0x13 | ||||
| #define AML_METHOD_OP                0x14 | ||||
| #define AML_DUAL_NAME_PREFIX         0x2e | ||||
| #define AML_MULTI_NAME_PREFIX        0x2f | ||||
| #define AML_NAME_CHAR_A              0x41 | ||||
| #define AML_NAME_CHAR_B              0x42 | ||||
| #define AML_NAME_CHAR_C              0x43 | ||||
| #define AML_NAME_CHAR_D              0x44 | ||||
| #define AML_NAME_CHAR_E              0x45 | ||||
| #define AML_NAME_CHAR_F              0x46 | ||||
| #define AML_NAME_CHAR_G              0x47 | ||||
| #define AML_NAME_CHAR_H              0x48 | ||||
| #define AML_NAME_CHAR_I              0x49 | ||||
| #define AML_NAME_CHAR_J              0x4a | ||||
| #define AML_NAME_CHAR_K              0x4b | ||||
| #define AML_NAME_CHAR_L              0x4c | ||||
| #define AML_NAME_CHAR_M              0x4d | ||||
| #define AML_NAME_CHAR_N              0x4e | ||||
| #define AML_NAME_CHAR_O              0x4f | ||||
| #define AML_NAME_CHAR_P              0x50 | ||||
| #define AML_NAME_CHAR_Q              0x51 | ||||
| #define AML_NAME_CHAR_R              0x52 | ||||
| #define AML_NAME_CHAR_S              0x53 | ||||
| #define AML_NAME_CHAR_T              0x54 | ||||
| #define AML_NAME_CHAR_U              0x55 | ||||
| #define AML_NAME_CHAR_V              0x56 | ||||
| #define AML_NAME_CHAR_W              0x57 | ||||
| #define AML_NAME_CHAR_X              0x58 | ||||
| #define AML_NAME_CHAR_Y              0x59 | ||||
| #define AML_NAME_CHAR_Z              0x5a | ||||
| #define AML_ROOT_CHAR                0x5c | ||||
| #define AML_PARENT_PREFIX_CHAR       0x5e | ||||
| #define AML_NAME_CHAR__              0x5f | ||||
| #define AML_LOCAL0                   0x60 | ||||
| #define AML_LOCAL1                   0x61 | ||||
| #define AML_LOCAL2                   0x62 | ||||
| #define AML_LOCAL3                   0x63 | ||||
| #define AML_LOCAL4                   0x64 | ||||
| #define AML_LOCAL5                   0x65 | ||||
| #define AML_LOCAL6                   0x66 | ||||
| #define AML_LOCAL7                   0x67 | ||||
| #define AML_ARG0                     0x68 | ||||
| #define AML_ARG1                     0x69 | ||||
| #define AML_ARG2                     0x6a | ||||
| #define AML_ARG3                     0x6b | ||||
| #define AML_ARG4                     0x6c | ||||
| #define AML_ARG5                     0x6d | ||||
| #define AML_ARG6                     0x6e | ||||
| #define AML_STORE_OP                 0x70 | ||||
| #define AML_REF_OF_OP                0x71 | ||||
| #define AML_ADD_OP                   0x72 | ||||
| #define AML_CONCAT_OP                0x73 | ||||
| #define AML_SUBTRACT_OP              0x74 | ||||
| #define AML_INCREMENT_OP             0x75 | ||||
| #define AML_DECREMENT_OP             0x76 | ||||
| #define AML_MULTIPLY_OP              0x77 | ||||
| #define AML_DIVIDE_OP                0x78 | ||||
| #define AML_SHIFT_LEFT_OP            0x79 | ||||
| #define AML_SHIFT_RIGHT_OP           0x7a | ||||
| #define AML_AND_OP                   0x7b | ||||
| #define AML_NAND_OP                  0x7c | ||||
| #define AML_OR_OP                    0x7d | ||||
| #define AML_NOR_OP                   0x7e | ||||
| #define AML_XOR_OP                   0x7f | ||||
| #define AML_NOT_OP                   0x80 | ||||
| #define AML_FIND_SET_LEFT_BIT_OP     0x81 | ||||
| #define AML_FIND_SET_RIGHT_BIT_OP    0x82 | ||||
| #define AML_DEREF_OF_OP              0x83 | ||||
| #define AML_CONCAT_RES_OP            0x84 | ||||
| #define AML_MOD_OP                   0x85 | ||||
| #define AML_NOTIFY_OP                0x86 | ||||
| #define AML_SIZE_OF_OP               0x87 | ||||
| #define AML_INDEX_OP                 0x88 | ||||
| #define AML_MATCH_OP                 0x89 | ||||
| #define AML_CREATE_DWORD_FIELD_OP    0x8a | ||||
| #define AML_CREATE_WORD_FIELD_OP     0x8b | ||||
| #define AML_CREATE_BYTE_FIELD_OP     0x8c | ||||
| #define AML_CREATE_BIT_FIELD_OP      0x8d | ||||
| #define AML_OBJECT_TYPE_OP           0x8e | ||||
| #define AML_CREATE_QWORD_FIELD_OP    0x8f | ||||
| #define AML_LAND_OP                  0x90 | ||||
| #define AML_LOR_OP                   0x91 | ||||
| #define AML_LNOT_OP                  0x92 | ||||
| #define AML_LEQUAL_OP                0x93 | ||||
| #define AML_LGREATER_OP              0x94 | ||||
| #define AML_LLESS_OP                 0x95 | ||||
| #define AML_TO_BUFFER_OP             0x96 | ||||
| #define AML_TO_DEC_STRING_OP         0x97 | ||||
| #define AML_TO_HEX_STRING_OP         0x98 | ||||
| #define AML_TO_INTEGER_OP            0x99 | ||||
| #define AML_TO_STRING_OP             0x9c | ||||
| #define AML_COPY_OBJECT_OP           0x9d | ||||
| #define AML_MID_OP                   0x9e | ||||
| #define AML_CONTINUE_OP              0x9f | ||||
| #define AML_IF_OP                    0xa0 | ||||
| #define AML_ELSE_OP                  0xa1 | ||||
| #define AML_WHILE_OP                 0xa2 | ||||
| #define AML_NOOP_OP                  0xa3 | ||||
| #define AML_RETURN_OP                0xa4 | ||||
| #define AML_BREAK_OP                 0xa5 | ||||
| #define AML_BREAK_POINT_OP           0xcc | ||||
| #define AML_ONES_OP                  0xff | ||||
|  | ||||
| // | ||||
| // Extended OpCode | ||||
| // | ||||
| #define AML_EXT_OP                   0x5b | ||||
|  | ||||
| #define AML_EXT_MUTEX_OP             0x01 | ||||
| #define AML_EXT_EVENT_OP             0x02 | ||||
| #define AML_EXT_COND_REF_OF_OP       0x12 | ||||
| #define AML_EXT_CREATE_FIELD_OP      0x13 | ||||
| #define AML_EXT_LOAD_TABLE_OP        0x1f | ||||
| #define AML_EXT_LOAD_OP              0x20 | ||||
| #define AML_EXT_STALL_OP             0x21 | ||||
| #define AML_EXT_SLEEP_OP             0x22 | ||||
| #define AML_EXT_ACQUIRE_OP           0x23 | ||||
| #define AML_EXT_SIGNAL_OP            0x24 | ||||
| #define AML_EXT_WAIT_OP              0x25 | ||||
| #define AML_EXT_RESET_OP             0x26 | ||||
| #define AML_EXT_RELEASE_OP           0x27 | ||||
| #define AML_EXT_FROM_BCD_OP          0x28 | ||||
| #define AML_EXT_TO_BCD_OP            0x29 | ||||
| #define AML_EXT_UNLOAD_OP            0x2a | ||||
| #define AML_EXT_REVISION_OP          0x30 | ||||
| #define AML_EXT_DEBUG_OP             0x31 | ||||
| #define AML_EXT_FATAL_OP             0x32 | ||||
| #define AML_EXT_TIMER_OP             0x33 | ||||
| #define AML_EXT_REGION_OP            0x80 | ||||
| #define AML_EXT_FIELD_OP             0x81 | ||||
| #define AML_EXT_DEVICE_OP            0x82 | ||||
| #define AML_EXT_PROCESSOR_OP         0x83 | ||||
| #define AML_EXT_POWER_RES_OP         0x84 | ||||
| #define AML_EXT_THERMAL_ZONE_OP      0x85 | ||||
| #define AML_EXT_INDEX_FIELD_OP       0x86 | ||||
| #define AML_EXT_BANK_FIELD_OP        0x87 | ||||
| #define AML_EXT_DATA_REGION_OP       0x88 | ||||
|  | ||||
| #endif | ||||
| @@ -1,47 +0,0 @@ | ||||
| /** @file | ||||
|   This file contains the Bluetooth definitions that are consumed by drivers. | ||||
|   These definitions are from Bluetooth Core Specification Version 4.0 June, 2010 | ||||
|  | ||||
|   Copyright (c) 2015, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef _BLUETOOTH_H_ | ||||
| #define _BLUETOOTH_H_ | ||||
|  | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// BLUETOOTH_ADDRESS | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// 48bit Bluetooth device address. | ||||
|   /// | ||||
|   UINT8      Address[6]; | ||||
| } BLUETOOTH_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// BLUETOOTH_CLASS_OF_DEVICE. See Bluetooth specification for detail. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8      FormatType:2; | ||||
|   UINT8      MinorDeviceClass: 6; | ||||
|   UINT16     MajorDeviceClass: 5; | ||||
|   UINT16     MajorServiceClass:11; | ||||
| } BLUETOOTH_CLASS_OF_DEVICE; | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #define BLUETOOTH_HCI_COMMAND_LOCAL_READABLE_NAME_MAX_SIZE    248 | ||||
|  | ||||
| #define BLUETOOTH_HCI_LINK_KEY_SIZE                           16 | ||||
|  | ||||
| #endif | ||||
| @@ -1,756 +0,0 @@ | ||||
| /** @file | ||||
|   EFI image format for PE32, PE32+ and TE. Please note some data structures are | ||||
|   different for PE32 and PE32+. EFI_IMAGE_NT_HEADERS32 is for PE32 and | ||||
|   EFI_IMAGE_NT_HEADERS64 is for PE32+. | ||||
|  | ||||
|   This file is coded to the Visual Studio, Microsoft Portable Executable and | ||||
|   Common Object File Format Specification, Revision 8.3 - February 6, 2013. | ||||
|   This file also includes some definitions in PI Specification, Revision 1.0. | ||||
|  | ||||
| Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR> | ||||
| Portions copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PE_IMAGE_H__ | ||||
| #define __PE_IMAGE_H__ | ||||
|  | ||||
| // | ||||
| // PE32+ Subsystem type for EFI images | ||||
| // | ||||
| #define EFI_IMAGE_SUBSYSTEM_EFI_APPLICATION         10 | ||||
| #define EFI_IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER 11 | ||||
| #define EFI_IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER      12 | ||||
| #define EFI_IMAGE_SUBSYSTEM_SAL_RUNTIME_DRIVER      13 ///< defined PI Specification, 1.0 | ||||
|  | ||||
|  | ||||
| // | ||||
| // PE32+ Machine type for EFI images | ||||
| // | ||||
| #define IMAGE_FILE_MACHINE_I386            0x014c | ||||
| #define IMAGE_FILE_MACHINE_IA64            0x0200 | ||||
| #define IMAGE_FILE_MACHINE_EBC             0x0EBC | ||||
| #define IMAGE_FILE_MACHINE_X64             0x8664 | ||||
| #define IMAGE_FILE_MACHINE_ARMTHUMB_MIXED  0x01c2 | ||||
| #define IMAGE_FILE_MACHINE_ARM64           0xAA64 | ||||
|  | ||||
| // | ||||
| // EXE file formats | ||||
| // | ||||
| #define EFI_IMAGE_DOS_SIGNATURE     SIGNATURE_16('M', 'Z') | ||||
| #define EFI_IMAGE_OS2_SIGNATURE     SIGNATURE_16('N', 'E') | ||||
| #define EFI_IMAGE_OS2_SIGNATURE_LE  SIGNATURE_16('L', 'E') | ||||
| #define EFI_IMAGE_NT_SIGNATURE      SIGNATURE_32('P', 'E', '\0', '\0') | ||||
|  | ||||
| /// | ||||
| /// PE images can start with an optional DOS header, so if an image is run | ||||
| /// under DOS it can print an error message. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  e_magic;    ///< Magic number. | ||||
|   UINT16  e_cblp;     ///< Bytes on last page of file. | ||||
|   UINT16  e_cp;       ///< Pages in file. | ||||
|   UINT16  e_crlc;     ///< Relocations. | ||||
|   UINT16  e_cparhdr;  ///< Size of header in paragraphs. | ||||
|   UINT16  e_minalloc; ///< Minimum extra paragraphs needed. | ||||
|   UINT16  e_maxalloc; ///< Maximum extra paragraphs needed. | ||||
|   UINT16  e_ss;       ///< Initial (relative) SS value. | ||||
|   UINT16  e_sp;       ///< Initial SP value. | ||||
|   UINT16  e_csum;     ///< Checksum. | ||||
|   UINT16  e_ip;       ///< Initial IP value. | ||||
|   UINT16  e_cs;       ///< Initial (relative) CS value. | ||||
|   UINT16  e_lfarlc;   ///< File address of relocation table. | ||||
|   UINT16  e_ovno;     ///< Overlay number. | ||||
|   UINT16  e_res[4];   ///< Reserved words. | ||||
|   UINT16  e_oemid;    ///< OEM identifier (for e_oeminfo). | ||||
|   UINT16  e_oeminfo;  ///< OEM information; e_oemid specific. | ||||
|   UINT16  e_res2[10]; ///< Reserved words. | ||||
|   UINT32  e_lfanew;   ///< File address of new exe header. | ||||
| } EFI_IMAGE_DOS_HEADER; | ||||
|  | ||||
| /// | ||||
| /// COFF File Header (Object and Image). | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  Machine; | ||||
|   UINT16  NumberOfSections; | ||||
|   UINT32  TimeDateStamp; | ||||
|   UINT32  PointerToSymbolTable; | ||||
|   UINT32  NumberOfSymbols; | ||||
|   UINT16  SizeOfOptionalHeader; | ||||
|   UINT16  Characteristics; | ||||
| } EFI_IMAGE_FILE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_FILE_HEADER. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_FILE_HEADER        20 | ||||
|  | ||||
| // | ||||
| // Characteristics | ||||
| // | ||||
| #define EFI_IMAGE_FILE_RELOCS_STRIPPED      BIT0     ///< 0x0001  Relocation info stripped from file. | ||||
| #define EFI_IMAGE_FILE_EXECUTABLE_IMAGE     BIT1     ///< 0x0002  File is executable  (i.e. no unresolved externel references). | ||||
| #define EFI_IMAGE_FILE_LINE_NUMS_STRIPPED   BIT2     ///< 0x0004  Line nunbers stripped from file. | ||||
| #define EFI_IMAGE_FILE_LOCAL_SYMS_STRIPPED  BIT3     ///< 0x0008  Local symbols stripped from file. | ||||
| #define EFI_IMAGE_FILE_BYTES_REVERSED_LO    BIT7     ///< 0x0080  Bytes of machine word are reversed. | ||||
| #define EFI_IMAGE_FILE_32BIT_MACHINE        BIT8     ///< 0x0100  32 bit word machine. | ||||
| #define EFI_IMAGE_FILE_DEBUG_STRIPPED       BIT9     ///< 0x0200  Debugging info stripped from file in .DBG file. | ||||
| #define EFI_IMAGE_FILE_SYSTEM               BIT12    ///< 0x1000  System File. | ||||
| #define EFI_IMAGE_FILE_DLL                  BIT13    ///< 0x2000  File is a DLL. | ||||
| #define EFI_IMAGE_FILE_BYTES_REVERSED_HI    BIT15    ///< 0x8000  Bytes of machine word are reversed. | ||||
|  | ||||
| /// | ||||
| /// Header Data Directories. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  VirtualAddress; | ||||
|   UINT32  Size; | ||||
| } EFI_IMAGE_DATA_DIRECTORY; | ||||
|  | ||||
| // | ||||
| // Directory Entries | ||||
| // | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_EXPORT      0 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_IMPORT      1 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_RESOURCE    2 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_EXCEPTION   3 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_SECURITY    4 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_BASERELOC   5 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_DEBUG       6 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_COPYRIGHT   7 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_GLOBALPTR   8 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_TLS         9 | ||||
| #define EFI_IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG 10 | ||||
|  | ||||
| #define EFI_IMAGE_NUMBER_OF_DIRECTORY_ENTRIES 16 | ||||
|  | ||||
| /// | ||||
| /// @attention | ||||
| /// EFI_IMAGE_NT_OPTIONAL_HDR32_MAGIC means PE32 and | ||||
| /// EFI_IMAGE_OPTIONAL_HEADER32 must be used. The data structures only vary | ||||
| /// after NT additional fields. | ||||
| /// | ||||
| #define EFI_IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x10b | ||||
|  | ||||
| /// | ||||
| /// Optional Header Standard Fields for PE32. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Standard fields. | ||||
|   /// | ||||
|   UINT16                    Magic; | ||||
|   UINT8                     MajorLinkerVersion; | ||||
|   UINT8                     MinorLinkerVersion; | ||||
|   UINT32                    SizeOfCode; | ||||
|   UINT32                    SizeOfInitializedData; | ||||
|   UINT32                    SizeOfUninitializedData; | ||||
|   UINT32                    AddressOfEntryPoint; | ||||
|   UINT32                    BaseOfCode; | ||||
|   UINT32                    BaseOfData;  ///< PE32 contains this additional field, which is absent in PE32+. | ||||
|   /// | ||||
|   /// Optional Header Windows-Specific Fields. | ||||
|   /// | ||||
|   UINT32                    ImageBase; | ||||
|   UINT32                    SectionAlignment; | ||||
|   UINT32                    FileAlignment; | ||||
|   UINT16                    MajorOperatingSystemVersion; | ||||
|   UINT16                    MinorOperatingSystemVersion; | ||||
|   UINT16                    MajorImageVersion; | ||||
|   UINT16                    MinorImageVersion; | ||||
|   UINT16                    MajorSubsystemVersion; | ||||
|   UINT16                    MinorSubsystemVersion; | ||||
|   UINT32                    Win32VersionValue; | ||||
|   UINT32                    SizeOfImage; | ||||
|   UINT32                    SizeOfHeaders; | ||||
|   UINT32                    CheckSum; | ||||
|   UINT16                    Subsystem; | ||||
|   UINT16                    DllCharacteristics; | ||||
|   UINT32                    SizeOfStackReserve; | ||||
|   UINT32                    SizeOfStackCommit; | ||||
|   UINT32                    SizeOfHeapReserve; | ||||
|   UINT32                    SizeOfHeapCommit; | ||||
|   UINT32                    LoaderFlags; | ||||
|   UINT32                    NumberOfRvaAndSizes; | ||||
|   EFI_IMAGE_DATA_DIRECTORY  DataDirectory[EFI_IMAGE_NUMBER_OF_DIRECTORY_ENTRIES]; | ||||
| } EFI_IMAGE_OPTIONAL_HEADER32; | ||||
|  | ||||
| /// | ||||
| /// @attention | ||||
| /// EFI_IMAGE_NT_OPTIONAL_HDR64_MAGIC means PE32+ and | ||||
| /// EFI_IMAGE_OPTIONAL_HEADER64 must be used. The data structures only vary | ||||
| /// after NT additional fields. | ||||
| /// | ||||
| #define EFI_IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x20b | ||||
|  | ||||
| /// | ||||
| /// Optional Header Standard Fields for PE32+. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Standard fields. | ||||
|   /// | ||||
|   UINT16                    Magic; | ||||
|   UINT8                     MajorLinkerVersion; | ||||
|   UINT8                     MinorLinkerVersion; | ||||
|   UINT32                    SizeOfCode; | ||||
|   UINT32                    SizeOfInitializedData; | ||||
|   UINT32                    SizeOfUninitializedData; | ||||
|   UINT32                    AddressOfEntryPoint; | ||||
|   UINT32                    BaseOfCode; | ||||
|   /// | ||||
|   /// Optional Header Windows-Specific Fields. | ||||
|   /// | ||||
|   UINT64                    ImageBase; | ||||
|   UINT32                    SectionAlignment; | ||||
|   UINT32                    FileAlignment; | ||||
|   UINT16                    MajorOperatingSystemVersion; | ||||
|   UINT16                    MinorOperatingSystemVersion; | ||||
|   UINT16                    MajorImageVersion; | ||||
|   UINT16                    MinorImageVersion; | ||||
|   UINT16                    MajorSubsystemVersion; | ||||
|   UINT16                    MinorSubsystemVersion; | ||||
|   UINT32                    Win32VersionValue; | ||||
|   UINT32                    SizeOfImage; | ||||
|   UINT32                    SizeOfHeaders; | ||||
|   UINT32                    CheckSum; | ||||
|   UINT16                    Subsystem; | ||||
|   UINT16                    DllCharacteristics; | ||||
|   UINT64                    SizeOfStackReserve; | ||||
|   UINT64                    SizeOfStackCommit; | ||||
|   UINT64                    SizeOfHeapReserve; | ||||
|   UINT64                    SizeOfHeapCommit; | ||||
|   UINT32                    LoaderFlags; | ||||
|   UINT32                    NumberOfRvaAndSizes; | ||||
|   EFI_IMAGE_DATA_DIRECTORY  DataDirectory[EFI_IMAGE_NUMBER_OF_DIRECTORY_ENTRIES]; | ||||
| } EFI_IMAGE_OPTIONAL_HEADER64; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// @attention | ||||
| /// EFI_IMAGE_NT_HEADERS32 is for use ONLY by tools. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32                      Signature; | ||||
|   EFI_IMAGE_FILE_HEADER       FileHeader; | ||||
|   EFI_IMAGE_OPTIONAL_HEADER32 OptionalHeader; | ||||
| } EFI_IMAGE_NT_HEADERS32; | ||||
|  | ||||
| #define EFI_IMAGE_SIZEOF_NT_OPTIONAL32_HEADER sizeof (EFI_IMAGE_NT_HEADERS32) | ||||
|  | ||||
| /// | ||||
| /// @attention | ||||
| /// EFI_IMAGE_HEADERS64 is for use ONLY by tools. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32                      Signature; | ||||
|   EFI_IMAGE_FILE_HEADER       FileHeader; | ||||
|   EFI_IMAGE_OPTIONAL_HEADER64 OptionalHeader; | ||||
| } EFI_IMAGE_NT_HEADERS64; | ||||
|  | ||||
| #define EFI_IMAGE_SIZEOF_NT_OPTIONAL64_HEADER sizeof (EFI_IMAGE_NT_HEADERS64) | ||||
|  | ||||
| // | ||||
| // Other Windows Subsystem Values | ||||
| // | ||||
| #define EFI_IMAGE_SUBSYSTEM_UNKNOWN     0 | ||||
| #define EFI_IMAGE_SUBSYSTEM_NATIVE      1 | ||||
| #define EFI_IMAGE_SUBSYSTEM_WINDOWS_GUI 2 | ||||
| #define EFI_IMAGE_SUBSYSTEM_WINDOWS_CUI 3 | ||||
| #define EFI_IMAGE_SUBSYSTEM_OS2_CUI     5 | ||||
| #define EFI_IMAGE_SUBSYSTEM_POSIX_CUI   7 | ||||
|  | ||||
| /// | ||||
| /// Length of ShortName. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_SHORT_NAME 8 | ||||
|  | ||||
| /// | ||||
| /// Section Table. This table immediately follows the optional header. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Name[EFI_IMAGE_SIZEOF_SHORT_NAME]; | ||||
|   union { | ||||
|     UINT32  PhysicalAddress; | ||||
|     UINT32  VirtualSize; | ||||
|   } Misc; | ||||
|   UINT32  VirtualAddress; | ||||
|   UINT32  SizeOfRawData; | ||||
|   UINT32  PointerToRawData; | ||||
|   UINT32  PointerToRelocations; | ||||
|   UINT32  PointerToLinenumbers; | ||||
|   UINT16  NumberOfRelocations; | ||||
|   UINT16  NumberOfLinenumbers; | ||||
|   UINT32  Characteristics; | ||||
| } EFI_IMAGE_SECTION_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_SECTION_HEADER. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_SECTION_HEADER       40 | ||||
|  | ||||
| // | ||||
| // Section Flags Values | ||||
| // | ||||
| #define EFI_IMAGE_SCN_TYPE_NO_PAD                  BIT3   ///< 0x00000008  ///< Reserved. | ||||
| #define EFI_IMAGE_SCN_CNT_CODE                     BIT5   ///< 0x00000020 | ||||
| #define EFI_IMAGE_SCN_CNT_INITIALIZED_DATA         BIT6   ///< 0x00000040 | ||||
| #define EFI_IMAGE_SCN_CNT_UNINITIALIZED_DATA       BIT7   ///< 0x00000080 | ||||
|  | ||||
| #define EFI_IMAGE_SCN_LNK_OTHER                    BIT8   ///< 0x00000100  ///< Reserved. | ||||
| #define EFI_IMAGE_SCN_LNK_INFO                     BIT9   ///< 0x00000200  ///< Section contains comments or some other type of information. | ||||
| #define EFI_IMAGE_SCN_LNK_REMOVE                   BIT11  ///< 0x00000800  ///< Section contents will not become part of image. | ||||
| #define EFI_IMAGE_SCN_LNK_COMDAT                   BIT12  ///< 0x00001000 | ||||
|  | ||||
| #define EFI_IMAGE_SCN_ALIGN_1BYTES                 BIT20  ///< 0x00100000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_2BYTES                 BIT21  ///< 0x00200000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_4BYTES          (BIT20|BIT21) ///< 0x00300000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_8BYTES                 BIT22  ///< 0x00400000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_16BYTES         (BIT20|BIT22) ///< 0x00500000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_32BYTES         (BIT21|BIT22) ///< 0x00600000 | ||||
| #define EFI_IMAGE_SCN_ALIGN_64BYTES   (BIT20|BIT21|BIT22) ///< 0x00700000 | ||||
|  | ||||
| #define EFI_IMAGE_SCN_MEM_DISCARDABLE              BIT25  ///< 0x02000000 | ||||
| #define EFI_IMAGE_SCN_MEM_NOT_CACHED               BIT26  ///< 0x04000000 | ||||
| #define EFI_IMAGE_SCN_MEM_NOT_PAGED                BIT27  ///< 0x08000000 | ||||
| #define EFI_IMAGE_SCN_MEM_SHARED                   BIT28  ///< 0x10000000 | ||||
| #define EFI_IMAGE_SCN_MEM_EXECUTE                  BIT29  ///< 0x20000000 | ||||
| #define EFI_IMAGE_SCN_MEM_READ                     BIT30  ///< 0x40000000 | ||||
| #define EFI_IMAGE_SCN_MEM_WRITE                    BIT31  ///< 0x80000000 | ||||
|  | ||||
| /// | ||||
| /// Size of a Symbol Table Record. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_SYMBOL 18 | ||||
|  | ||||
| // | ||||
| // Symbols have a section number of the section in which they are | ||||
| // defined. Otherwise, section numbers have the following meanings: | ||||
| // | ||||
| #define EFI_IMAGE_SYM_UNDEFINED (UINT16) 0  ///< Symbol is undefined or is common. | ||||
| #define EFI_IMAGE_SYM_ABSOLUTE  (UINT16) -1 ///< Symbol is an absolute value. | ||||
| #define EFI_IMAGE_SYM_DEBUG     (UINT16) -2 ///< Symbol is a special debug item. | ||||
|  | ||||
| // | ||||
| // Symbol Type (fundamental) values. | ||||
| // | ||||
| #define EFI_IMAGE_SYM_TYPE_NULL   0   ///< no type. | ||||
| #define EFI_IMAGE_SYM_TYPE_VOID   1   ///< no valid type. | ||||
| #define EFI_IMAGE_SYM_TYPE_CHAR   2   ///< type character. | ||||
| #define EFI_IMAGE_SYM_TYPE_SHORT  3   ///< type short integer. | ||||
| #define EFI_IMAGE_SYM_TYPE_INT    4 | ||||
| #define EFI_IMAGE_SYM_TYPE_LONG   5 | ||||
| #define EFI_IMAGE_SYM_TYPE_FLOAT  6 | ||||
| #define EFI_IMAGE_SYM_TYPE_DOUBLE 7 | ||||
| #define EFI_IMAGE_SYM_TYPE_STRUCT 8 | ||||
| #define EFI_IMAGE_SYM_TYPE_UNION  9 | ||||
| #define EFI_IMAGE_SYM_TYPE_ENUM   10  ///< enumeration. | ||||
| #define EFI_IMAGE_SYM_TYPE_MOE    11  ///< member of enumeration. | ||||
| #define EFI_IMAGE_SYM_TYPE_BYTE   12 | ||||
| #define EFI_IMAGE_SYM_TYPE_WORD   13 | ||||
| #define EFI_IMAGE_SYM_TYPE_UINT   14 | ||||
| #define EFI_IMAGE_SYM_TYPE_DWORD  15 | ||||
|  | ||||
| // | ||||
| // Symbol Type (derived) values. | ||||
| // | ||||
| #define EFI_IMAGE_SYM_DTYPE_NULL      0 ///< no derived type. | ||||
| #define EFI_IMAGE_SYM_DTYPE_POINTER   1 | ||||
| #define EFI_IMAGE_SYM_DTYPE_FUNCTION  2 | ||||
| #define EFI_IMAGE_SYM_DTYPE_ARRAY     3 | ||||
|  | ||||
| // | ||||
| // Storage classes. | ||||
| // | ||||
| #define EFI_IMAGE_SYM_CLASS_END_OF_FUNCTION   ((UINT8) -1) | ||||
| #define EFI_IMAGE_SYM_CLASS_NULL              0 | ||||
| #define EFI_IMAGE_SYM_CLASS_AUTOMATIC         1 | ||||
| #define EFI_IMAGE_SYM_CLASS_EXTERNAL          2 | ||||
| #define EFI_IMAGE_SYM_CLASS_STATIC            3 | ||||
| #define EFI_IMAGE_SYM_CLASS_REGISTER          4 | ||||
| #define EFI_IMAGE_SYM_CLASS_EXTERNAL_DEF      5 | ||||
| #define EFI_IMAGE_SYM_CLASS_LABEL             6 | ||||
| #define EFI_IMAGE_SYM_CLASS_UNDEFINED_LABEL   7 | ||||
| #define EFI_IMAGE_SYM_CLASS_MEMBER_OF_STRUCT  8 | ||||
| #define EFI_IMAGE_SYM_CLASS_ARGUMENT          9 | ||||
| #define EFI_IMAGE_SYM_CLASS_STRUCT_TAG        10 | ||||
| #define EFI_IMAGE_SYM_CLASS_MEMBER_OF_UNION   11 | ||||
| #define EFI_IMAGE_SYM_CLASS_UNION_TAG         12 | ||||
| #define EFI_IMAGE_SYM_CLASS_TYPE_DEFINITION   13 | ||||
| #define EFI_IMAGE_SYM_CLASS_UNDEFINED_STATIC  14 | ||||
| #define EFI_IMAGE_SYM_CLASS_ENUM_TAG          15 | ||||
| #define EFI_IMAGE_SYM_CLASS_MEMBER_OF_ENUM    16 | ||||
| #define EFI_IMAGE_SYM_CLASS_REGISTER_PARAM    17 | ||||
| #define EFI_IMAGE_SYM_CLASS_BIT_FIELD         18 | ||||
| #define EFI_IMAGE_SYM_CLASS_BLOCK             100 | ||||
| #define EFI_IMAGE_SYM_CLASS_FUNCTION          101 | ||||
| #define EFI_IMAGE_SYM_CLASS_END_OF_STRUCT     102 | ||||
| #define EFI_IMAGE_SYM_CLASS_FILE              103 | ||||
| #define EFI_IMAGE_SYM_CLASS_SECTION           104 | ||||
| #define EFI_IMAGE_SYM_CLASS_WEAK_EXTERNAL     105 | ||||
|  | ||||
| // | ||||
| // type packing constants | ||||
| // | ||||
| #define EFI_IMAGE_N_BTMASK  017 | ||||
| #define EFI_IMAGE_N_TMASK   060 | ||||
| #define EFI_IMAGE_N_TMASK1  0300 | ||||
| #define EFI_IMAGE_N_TMASK2  0360 | ||||
| #define EFI_IMAGE_N_BTSHFT  4 | ||||
| #define EFI_IMAGE_N_TSHIFT  2 | ||||
|  | ||||
| // | ||||
| // Communal selection types. | ||||
| // | ||||
| #define EFI_IMAGE_COMDAT_SELECT_NODUPLICATES    1 | ||||
| #define EFI_IMAGE_COMDAT_SELECT_ANY             2 | ||||
| #define EFI_IMAGE_COMDAT_SELECT_SAME_SIZE       3 | ||||
| #define EFI_IMAGE_COMDAT_SELECT_EXACT_MATCH     4 | ||||
| #define EFI_IMAGE_COMDAT_SELECT_ASSOCIATIVE     5 | ||||
|  | ||||
| // | ||||
| // the following values only be referred in PeCoff, not defined in PECOFF. | ||||
| // | ||||
| #define EFI_IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY  1 | ||||
| #define EFI_IMAGE_WEAK_EXTERN_SEARCH_LIBRARY    2 | ||||
| #define EFI_IMAGE_WEAK_EXTERN_SEARCH_ALIAS      3 | ||||
|  | ||||
| /// | ||||
| /// Relocation format. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  VirtualAddress; | ||||
|   UINT32  SymbolTableIndex; | ||||
|   UINT16  Type; | ||||
| } EFI_IMAGE_RELOCATION; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_RELOCATION | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_RELOCATION 10 | ||||
|  | ||||
| // | ||||
| // I386 relocation types. | ||||
| // | ||||
| #define EFI_IMAGE_REL_I386_ABSOLUTE 0x0000  ///< Reference is absolute, no relocation is necessary. | ||||
| #define EFI_IMAGE_REL_I386_DIR16    0x0001  ///< Direct 16-bit reference to the symbols virtual address. | ||||
| #define EFI_IMAGE_REL_I386_REL16    0x0002  ///< PC-relative 16-bit reference to the symbols virtual address. | ||||
| #define EFI_IMAGE_REL_I386_DIR32    0x0006  ///< Direct 32-bit reference to the symbols virtual address. | ||||
| #define EFI_IMAGE_REL_I386_DIR32NB  0x0007  ///< Direct 32-bit reference to the symbols virtual address, base not included. | ||||
| #define EFI_IMAGE_REL_I386_SEG12    0x0009  ///< Direct 16-bit reference to the segment-selector bits of a 32-bit virtual address. | ||||
| #define EFI_IMAGE_REL_I386_SECTION  0x000A | ||||
| #define EFI_IMAGE_REL_I386_SECREL   0x000B | ||||
| #define EFI_IMAGE_REL_I386_REL32    0x0014  ///< PC-relative 32-bit reference to the symbols virtual address. | ||||
|  | ||||
| // | ||||
| // x64 processor relocation types. | ||||
| // | ||||
| #define IMAGE_REL_AMD64_ABSOLUTE  0x0000 | ||||
| #define IMAGE_REL_AMD64_ADDR64    0x0001 | ||||
| #define IMAGE_REL_AMD64_ADDR32    0x0002 | ||||
| #define IMAGE_REL_AMD64_ADDR32NB  0x0003 | ||||
| #define IMAGE_REL_AMD64_REL32     0x0004 | ||||
| #define IMAGE_REL_AMD64_REL32_1   0x0005 | ||||
| #define IMAGE_REL_AMD64_REL32_2   0x0006 | ||||
| #define IMAGE_REL_AMD64_REL32_3   0x0007 | ||||
| #define IMAGE_REL_AMD64_REL32_4   0x0008 | ||||
| #define IMAGE_REL_AMD64_REL32_5   0x0009 | ||||
| #define IMAGE_REL_AMD64_SECTION   0x000A | ||||
| #define IMAGE_REL_AMD64_SECREL    0x000B | ||||
| #define IMAGE_REL_AMD64_SECREL7   0x000C | ||||
| #define IMAGE_REL_AMD64_TOKEN     0x000D | ||||
| #define IMAGE_REL_AMD64_SREL32    0x000E | ||||
| #define IMAGE_REL_AMD64_PAIR      0x000F | ||||
| #define IMAGE_REL_AMD64_SSPAN32   0x0010 | ||||
|  | ||||
| /// | ||||
| /// Based relocation format. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  VirtualAddress; | ||||
|   UINT32  SizeOfBlock; | ||||
| } EFI_IMAGE_BASE_RELOCATION; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_BASE_RELOCATION. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_BASE_RELOCATION  8 | ||||
|  | ||||
| // | ||||
| // Based relocation types. | ||||
| // | ||||
| #define EFI_IMAGE_REL_BASED_ABSOLUTE        0 | ||||
| #define EFI_IMAGE_REL_BASED_HIGH            1 | ||||
| #define EFI_IMAGE_REL_BASED_LOW             2 | ||||
| #define EFI_IMAGE_REL_BASED_HIGHLOW         3 | ||||
| #define EFI_IMAGE_REL_BASED_HIGHADJ         4 | ||||
| #define EFI_IMAGE_REL_BASED_MIPS_JMPADDR    5 | ||||
| #define EFI_IMAGE_REL_BASED_ARM_MOV32A      5 | ||||
| #define EFI_IMAGE_REL_BASED_ARM_MOV32T      7 | ||||
| #define EFI_IMAGE_REL_BASED_IA64_IMM64      9 | ||||
| #define EFI_IMAGE_REL_BASED_MIPS_JMPADDR16  9 | ||||
| #define EFI_IMAGE_REL_BASED_DIR64           10 | ||||
|  | ||||
| /// | ||||
| /// Line number format. | ||||
| /// | ||||
| typedef struct { | ||||
|   union { | ||||
|     UINT32  SymbolTableIndex; ///< Symbol table index of function name if Linenumber is 0. | ||||
|     UINT32  VirtualAddress;   ///< Virtual address of line number. | ||||
|   } Type; | ||||
|   UINT16  Linenumber;         ///< Line number. | ||||
| } EFI_IMAGE_LINENUMBER; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_LINENUMBER. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_LINENUMBER 6 | ||||
|  | ||||
| // | ||||
| // Archive format. | ||||
| // | ||||
| #define EFI_IMAGE_ARCHIVE_START_SIZE        8 | ||||
| #define EFI_IMAGE_ARCHIVE_START             "!<arch>\n" | ||||
| #define EFI_IMAGE_ARCHIVE_END               "`\n" | ||||
| #define EFI_IMAGE_ARCHIVE_PAD               "\n" | ||||
| #define EFI_IMAGE_ARCHIVE_LINKER_MEMBER     "/               " | ||||
| #define EFI_IMAGE_ARCHIVE_LONGNAMES_MEMBER  "//              " | ||||
|  | ||||
| /// | ||||
| /// Archive Member Headers | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Name[16];     ///< File member name - `/' terminated. | ||||
|   UINT8 Date[12];     ///< File member date - decimal. | ||||
|   UINT8 UserID[6];    ///< File member user id - decimal. | ||||
|   UINT8 GroupID[6];   ///< File member group id - decimal. | ||||
|   UINT8 Mode[8];      ///< File member mode - octal. | ||||
|   UINT8 Size[10];     ///< File member size - decimal. | ||||
|   UINT8 EndHeader[2]; ///< String to end header. (0x60 0x0A). | ||||
| } EFI_IMAGE_ARCHIVE_MEMBER_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Size of EFI_IMAGE_ARCHIVE_MEMBER_HEADER. | ||||
| /// | ||||
| #define EFI_IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60 | ||||
|  | ||||
|  | ||||
| // | ||||
| // DLL Support | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// Export Directory Table. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Characteristics; | ||||
|   UINT32  TimeDateStamp; | ||||
|   UINT16  MajorVersion; | ||||
|   UINT16  MinorVersion; | ||||
|   UINT32  Name; | ||||
|   UINT32  Base; | ||||
|   UINT32  NumberOfFunctions; | ||||
|   UINT32  NumberOfNames; | ||||
|   UINT32  AddressOfFunctions; | ||||
|   UINT32  AddressOfNames; | ||||
|   UINT32  AddressOfNameOrdinals; | ||||
| } EFI_IMAGE_EXPORT_DIRECTORY; | ||||
|  | ||||
| /// | ||||
| /// Hint/Name Table. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  Hint; | ||||
|   UINT8   Name[1]; | ||||
| } EFI_IMAGE_IMPORT_BY_NAME; | ||||
|  | ||||
| /// | ||||
| /// Import Address Table RVA (Thunk Table). | ||||
| /// | ||||
| typedef struct { | ||||
|   union { | ||||
|     UINT32                    Function; | ||||
|     UINT32                    Ordinal; | ||||
|     EFI_IMAGE_IMPORT_BY_NAME  *AddressOfData; | ||||
|   } u1; | ||||
| } EFI_IMAGE_THUNK_DATA; | ||||
|  | ||||
| #define EFI_IMAGE_ORDINAL_FLAG              BIT31    ///< Flag for PE32. | ||||
| #define EFI_IMAGE_SNAP_BY_ORDINAL(Ordinal)  ((Ordinal & EFI_IMAGE_ORDINAL_FLAG) != 0) | ||||
| #define EFI_IMAGE_ORDINAL(Ordinal)          (Ordinal & 0xffff) | ||||
|  | ||||
| /// | ||||
| /// Import Directory Table | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32                Characteristics; | ||||
|   UINT32                TimeDateStamp; | ||||
|   UINT32                ForwarderChain; | ||||
|   UINT32                Name; | ||||
|   EFI_IMAGE_THUNK_DATA  *FirstThunk; | ||||
| } EFI_IMAGE_IMPORT_DESCRIPTOR; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Debug Directory Format. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Characteristics; | ||||
|   UINT32  TimeDateStamp; | ||||
|   UINT16  MajorVersion; | ||||
|   UINT16  MinorVersion; | ||||
|   UINT32  Type; | ||||
|   UINT32  SizeOfData; | ||||
|   UINT32  RVA;           ///< The address of the debug data when loaded, relative to the image base. | ||||
|   UINT32  FileOffset;    ///< The file pointer to the debug data. | ||||
| } EFI_IMAGE_DEBUG_DIRECTORY_ENTRY; | ||||
|  | ||||
| #define EFI_IMAGE_DEBUG_TYPE_CODEVIEW 2     ///< The Visual C++ debug information. | ||||
|  | ||||
| /// | ||||
| /// Debug Data Structure defined in Microsoft C++. | ||||
| /// | ||||
| #define CODEVIEW_SIGNATURE_NB10  SIGNATURE_32('N', 'B', '1', '0') | ||||
| typedef struct { | ||||
|   UINT32  Signature;                        ///< "NB10" | ||||
|   UINT32  Unknown; | ||||
|   UINT32  Unknown2; | ||||
|   UINT32  Unknown3; | ||||
|   // | ||||
|   // Filename of .PDB goes here | ||||
|   // | ||||
| } EFI_IMAGE_DEBUG_CODEVIEW_NB10_ENTRY; | ||||
|  | ||||
| /// | ||||
| /// Debug Data Structure defined in Microsoft C++. | ||||
| /// | ||||
| #define CODEVIEW_SIGNATURE_RSDS  SIGNATURE_32('R', 'S', 'D', 'S') | ||||
| typedef struct { | ||||
|   UINT32  Signature;                        ///< "RSDS". | ||||
|   UINT32  Unknown; | ||||
|   UINT32  Unknown2; | ||||
|   UINT32  Unknown3; | ||||
|   UINT32  Unknown4; | ||||
|   UINT32  Unknown5; | ||||
|   // | ||||
|   // Filename of .PDB goes here | ||||
|   // | ||||
| } EFI_IMAGE_DEBUG_CODEVIEW_RSDS_ENTRY; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Debug Data Structure defined by Apple Mach-O to Coff utility. | ||||
| /// | ||||
| #define CODEVIEW_SIGNATURE_MTOC  SIGNATURE_32('M', 'T', 'O', 'C') | ||||
| typedef struct { | ||||
|   UINT32    Signature;                       ///< "MTOC". | ||||
|   GUID      MachOUuid; | ||||
|   // | ||||
|   //  Filename of .DLL (Mach-O with debug info) goes here | ||||
|   // | ||||
| } EFI_IMAGE_DEBUG_CODEVIEW_MTOC_ENTRY; | ||||
|  | ||||
| /// | ||||
| /// Resource format. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  Characteristics; | ||||
|   UINT32  TimeDateStamp; | ||||
|   UINT16  MajorVersion; | ||||
|   UINT16  MinorVersion; | ||||
|   UINT16  NumberOfNamedEntries; | ||||
|   UINT16  NumberOfIdEntries; | ||||
|   // | ||||
|   // Array of EFI_IMAGE_RESOURCE_DIRECTORY_ENTRY entries goes here. | ||||
|   // | ||||
| } EFI_IMAGE_RESOURCE_DIRECTORY; | ||||
|  | ||||
| /// | ||||
| /// Resource directory entry format. | ||||
| /// | ||||
| typedef struct { | ||||
|   union { | ||||
|     struct { | ||||
|       UINT32  NameOffset:31; | ||||
|       UINT32  NameIsString:1; | ||||
|     } s; | ||||
|     UINT32  Id; | ||||
|   } u1; | ||||
|   union { | ||||
|     UINT32  OffsetToData; | ||||
|     struct { | ||||
|       UINT32  OffsetToDirectory:31; | ||||
|       UINT32  DataIsDirectory:1; | ||||
|     } s; | ||||
|   } u2; | ||||
| } EFI_IMAGE_RESOURCE_DIRECTORY_ENTRY; | ||||
|  | ||||
| /// | ||||
| /// Resource directory entry for string. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  Length; | ||||
|   CHAR16  String[1]; | ||||
| } EFI_IMAGE_RESOURCE_DIRECTORY_STRING; | ||||
|  | ||||
| /// | ||||
| /// Resource directory entry for data array. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT32  OffsetToData; | ||||
|   UINT32  Size; | ||||
|   UINT32  CodePage; | ||||
|   UINT32  Reserved; | ||||
| } EFI_IMAGE_RESOURCE_DATA_ENTRY; | ||||
|  | ||||
| /// | ||||
| /// Header format for TE images, defined in the PI Specification, 1.0. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16                    Signature;            ///< The signature for TE format = "VZ". | ||||
|   UINT16                    Machine;              ///< From the original file header. | ||||
|   UINT8                     NumberOfSections;     ///< From the original file header. | ||||
|   UINT8                     Subsystem;            ///< From original optional header. | ||||
|   UINT16                    StrippedSize;         ///< Number of bytes we removed from the header. | ||||
|   UINT32                    AddressOfEntryPoint;  ///< Offset to entry point -- from original optional header. | ||||
|   UINT32                    BaseOfCode;           ///< From original image -- required for ITP debug. | ||||
|   UINT64                    ImageBase;            ///< From original file header. | ||||
|   EFI_IMAGE_DATA_DIRECTORY  DataDirectory[2];     ///< Only base relocation and debug directory. | ||||
| } EFI_TE_IMAGE_HEADER; | ||||
|  | ||||
|  | ||||
| #define EFI_TE_IMAGE_HEADER_SIGNATURE  SIGNATURE_16('V', 'Z') | ||||
|  | ||||
| // | ||||
| // Data directory indexes in our TE image header | ||||
| // | ||||
| #define EFI_TE_IMAGE_DIRECTORY_ENTRY_BASERELOC  0 | ||||
| #define EFI_TE_IMAGE_DIRECTORY_ENTRY_DEBUG      1 | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Union of PE32, PE32+, and TE headers. | ||||
| /// | ||||
| typedef union { | ||||
|   EFI_IMAGE_NT_HEADERS32   Pe32; | ||||
|   EFI_IMAGE_NT_HEADERS64   Pe32Plus; | ||||
|   EFI_TE_IMAGE_HEADER      Te; | ||||
| } EFI_IMAGE_OPTIONAL_HEADER_UNION; | ||||
|  | ||||
| typedef union { | ||||
|   EFI_IMAGE_NT_HEADERS32            *Pe32; | ||||
|   EFI_IMAGE_NT_HEADERS64            *Pe32Plus; | ||||
|   EFI_TE_IMAGE_HEADER               *Te; | ||||
|   EFI_IMAGE_OPTIONAL_HEADER_UNION   *Union; | ||||
| } EFI_IMAGE_OPTIONAL_HEADER_PTR_UNION; | ||||
|  | ||||
| #endif | ||||
| @@ -1,532 +0,0 @@ | ||||
| /** @file | ||||
|   Provides services to create and parse HOBs. Only available for PEI | ||||
|   and DXE module types. | ||||
|  | ||||
|   The HOB Library supports the efficient creation and searching of HOBs | ||||
|   defined in the PI Specification. | ||||
|   A HOB is a Hand-Off Block, defined in the Framework architecture, that | ||||
|   allows the PEI phase to pass information to the DXE phase. HOBs are position | ||||
|   independent and can be relocated easily to different memory memory locations. | ||||
|  | ||||
| Copyright (c) 2006 - 2014, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __HOB_LIB_H__ | ||||
| #define __HOB_LIB_H__ | ||||
|  | ||||
| /** | ||||
|   Returns the pointer to the HOB list. | ||||
|  | ||||
|   This function returns the pointer to first HOB in the list. | ||||
|   For PEI phase, the PEI service GetHobList() can be used to retrieve the pointer | ||||
|   to the HOB list.  For the DXE phase, the HOB list pointer can be retrieved through | ||||
|   the EFI System Table by looking up theHOB list GUID in the System Configuration Table. | ||||
|   Since the System Configuration Table does not exist that the time the DXE Core is | ||||
|   launched, the DXE Core uses a global variable from the DXE Core Entry Point Library | ||||
|   to manage the pointer to the HOB list. | ||||
|  | ||||
|   If the pointer to the HOB list is NULL, then ASSERT(). | ||||
|  | ||||
|   @return The pointer to the HOB list. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| GetHobList ( | ||||
|   VOID | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns the next instance of a HOB type from the starting HOB. | ||||
|  | ||||
|   This function searches the first instance of a HOB type from the starting HOB pointer. | ||||
|   If there does not exist such HOB type from the starting HOB pointer, it will return NULL. | ||||
|   In contrast with macro GET_NEXT_HOB(), this function does not skip the starting HOB pointer | ||||
|   unconditionally: it returns HobStart back if HobStart itself meets the requirement; | ||||
|   caller is required to use GET_NEXT_HOB() if it wishes to skip current HobStart. | ||||
|  | ||||
|   If HobStart is NULL, then ASSERT(). | ||||
|  | ||||
|   @param  Type          The HOB type to return. | ||||
|   @param  HobStart      The starting HOB pointer to search from. | ||||
|  | ||||
|   @return The next instance of a HOB type from the starting HOB. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| GetNextHob ( | ||||
|   IN UINT16                 Type, | ||||
|   IN CONST VOID             *HobStart | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns the first instance of a HOB type among the whole HOB list. | ||||
|  | ||||
|   This function searches the first instance of a HOB type among the whole HOB list. | ||||
|   If there does not exist such HOB type in the HOB list, it will return NULL. | ||||
|  | ||||
|   If the pointer to the HOB list is NULL, then ASSERT(). | ||||
|  | ||||
|   @param  Type          The HOB type to return. | ||||
|  | ||||
|   @return The next instance of a HOB type from the starting HOB. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| GetFirstHob ( | ||||
|   IN UINT16                 Type | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns the next instance of the matched GUID HOB from the starting HOB. | ||||
|  | ||||
|   This function searches the first instance of a HOB from the starting HOB pointer. | ||||
|   Such HOB should satisfy two conditions: | ||||
|   its HOB type is EFI_HOB_TYPE_GUID_EXTENSION and its GUID Name equals to the input Guid. | ||||
|   If there does not exist such HOB from the starting HOB pointer, it will return NULL. | ||||
|   Caller is required to apply GET_GUID_HOB_DATA () and GET_GUID_HOB_DATA_SIZE () | ||||
|   to extract the data section and its size info respectively. | ||||
|   In contrast with macro GET_NEXT_HOB(), this function does not skip the starting HOB pointer | ||||
|   unconditionally: it returns HobStart back if HobStart itself meets the requirement; | ||||
|   caller is required to use GET_NEXT_HOB() if it wishes to skip current HobStart. | ||||
|  | ||||
|   If Guid is NULL, then ASSERT(). | ||||
|   If HobStart is NULL, then ASSERT(). | ||||
|  | ||||
|   @param  Guid          The GUID to match with in the HOB list. | ||||
|   @param  HobStart      A pointer to a Guid. | ||||
|  | ||||
|   @return The next instance of the matched GUID HOB from the starting HOB. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| GetNextGuidHob ( | ||||
|   IN CONST EFI_GUID         *Guid, | ||||
|   IN CONST VOID             *HobStart | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns the first instance of the matched GUID HOB among the whole HOB list. | ||||
|  | ||||
|   This function searches the first instance of a HOB among the whole HOB list. | ||||
|   Such HOB should satisfy two conditions: | ||||
|   its HOB type is EFI_HOB_TYPE_GUID_EXTENSION and its GUID Name equals to the input Guid. | ||||
|   If there does not exist such HOB from the starting HOB pointer, it will return NULL. | ||||
|   Caller is required to apply GET_GUID_HOB_DATA () and GET_GUID_HOB_DATA_SIZE () | ||||
|   to extract the data section and its size info respectively. | ||||
|  | ||||
|   If the pointer to the HOB list is NULL, then ASSERT(). | ||||
|   If Guid is NULL, then ASSERT(). | ||||
|  | ||||
|   @param  Guid          The GUID to match with in the HOB list. | ||||
|  | ||||
|   @return The first instance of the matched GUID HOB among the whole HOB list. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| GetFirstGuidHob ( | ||||
|   IN CONST EFI_GUID         *Guid | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Get the system boot mode from the HOB list. | ||||
|  | ||||
|   This function returns the system boot mode information from the | ||||
|   PHIT HOB in HOB list. | ||||
|  | ||||
|   If the pointer to the HOB list is NULL, then ASSERT(). | ||||
|  | ||||
|   @param  VOID | ||||
|  | ||||
|   @return The Boot Mode. | ||||
|  | ||||
| **/ | ||||
| EFI_BOOT_MODE | ||||
| EFIAPI | ||||
| GetBootModeHob ( | ||||
|   VOID | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB for a loaded PE32 module. | ||||
|  | ||||
|   This function builds a HOB for a loaded PE32 module. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If ModuleName is NULL, then ASSERT(). | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  ModuleName              The GUID File Name of the module. | ||||
|   @param  MemoryAllocationModule  The 64 bit physical address of the module. | ||||
|   @param  ModuleLength            The length of the module in bytes. | ||||
|   @param  EntryPoint              The 64 bit physical address of the module entry point. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildModuleHob ( | ||||
|   IN CONST EFI_GUID         *ModuleName, | ||||
|   IN EFI_PHYSICAL_ADDRESS   MemoryAllocationModule, | ||||
|   IN UINT64                 ModuleLength, | ||||
|   IN EFI_PHYSICAL_ADDRESS   EntryPoint | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB that describes a chunk of system memory with Owner GUID. | ||||
|  | ||||
|   This function builds a HOB that describes a chunk of system memory. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  ResourceType        The type of resource described by this HOB. | ||||
|   @param  ResourceAttribute   The resource attributes of the memory described by this HOB. | ||||
|   @param  PhysicalStart       The 64 bit physical address of memory described by this HOB. | ||||
|   @param  NumberOfBytes       The length of the memory described by this HOB in bytes. | ||||
|   @param  OwnerGUID           GUID for the owner of this resource. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildResourceDescriptorWithOwnerHob ( | ||||
|   IN EFI_RESOURCE_TYPE            ResourceType, | ||||
|   IN EFI_RESOURCE_ATTRIBUTE_TYPE  ResourceAttribute, | ||||
|   IN EFI_PHYSICAL_ADDRESS         PhysicalStart, | ||||
|   IN UINT64                       NumberOfBytes, | ||||
|   IN EFI_GUID                     *OwnerGUID | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB that describes a chunk of system memory. | ||||
|  | ||||
|   This function builds a HOB that describes a chunk of system memory. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  ResourceType        The type of resource described by this HOB. | ||||
|   @param  ResourceAttribute   The resource attributes of the memory described by this HOB. | ||||
|   @param  PhysicalStart       The 64 bit physical address of memory described by this HOB. | ||||
|   @param  NumberOfBytes       The length of the memory described by this HOB in bytes. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildResourceDescriptorHob ( | ||||
|   IN EFI_RESOURCE_TYPE            ResourceType, | ||||
|   IN EFI_RESOURCE_ATTRIBUTE_TYPE  ResourceAttribute, | ||||
|   IN EFI_PHYSICAL_ADDRESS         PhysicalStart, | ||||
|   IN UINT64                       NumberOfBytes | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a customized HOB tagged with a GUID for identification and returns | ||||
|   the start address of GUID HOB data. | ||||
|  | ||||
|   This function builds a customized HOB tagged with a GUID for identification | ||||
|   and returns the start address of GUID HOB data so that caller can fill the customized data. | ||||
|   The HOB Header and Name field is already stripped. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If Guid is NULL, then ASSERT(). | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|   If DataLength > (0xFFF8 - sizeof (EFI_HOB_GUID_TYPE)), then ASSERT(). | ||||
|   HobLength is UINT16 and multiples of 8 bytes, so the max HobLength is 0xFFF8. | ||||
|  | ||||
|   @param  Guid          The GUID to tag the customized HOB. | ||||
|   @param  DataLength    The size of the data payload for the GUID HOB. | ||||
|  | ||||
|   @retval  NULL         The GUID HOB could not be allocated. | ||||
|   @retval  others       The start address of GUID HOB data. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| BuildGuidHob ( | ||||
|   IN CONST EFI_GUID              *Guid, | ||||
|   IN UINTN                       DataLength | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a customized HOB tagged with a GUID for identification, copies the input data to the HOB | ||||
|   data field, and returns the start address of the GUID HOB data. | ||||
|  | ||||
|   This function builds a customized HOB tagged with a GUID for identification and copies the input | ||||
|   data to the HOB data field and returns the start address of the GUID HOB data.  It can only be | ||||
|   invoked during PEI phase; for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|   The HOB Header and Name field is already stripped. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If Guid is NULL, then ASSERT(). | ||||
|   If Data is NULL and DataLength > 0, then ASSERT(). | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|   If DataLength > (0xFFF8 - sizeof (EFI_HOB_GUID_TYPE)), then ASSERT(). | ||||
|   HobLength is UINT16 and multiples of 8 bytes, so the max HobLength is 0xFFF8. | ||||
|  | ||||
|   @param  Guid          The GUID to tag the customized HOB. | ||||
|   @param  Data          The data to be copied into the data field of the GUID HOB. | ||||
|   @param  DataLength    The size of the data payload for the GUID HOB. | ||||
|  | ||||
|   @retval  NULL         The GUID HOB could not be allocated. | ||||
|   @retval  others       The start address of GUID HOB data. | ||||
|  | ||||
| **/ | ||||
| VOID * | ||||
| EFIAPI | ||||
| BuildGuidDataHob ( | ||||
|   IN CONST EFI_GUID              *Guid, | ||||
|   IN VOID                        *Data, | ||||
|   IN UINTN                       DataLength | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a Firmware Volume HOB. | ||||
|  | ||||
|   This function builds a Firmware Volume HOB. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The base address of the Firmware Volume. | ||||
|   @param  Length        The size of the Firmware Volume in bytes. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildFvHob ( | ||||
|   IN EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN UINT64                      Length | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a EFI_HOB_TYPE_FV2 HOB. | ||||
|  | ||||
|   This function builds a EFI_HOB_TYPE_FV2 HOB. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The base address of the Firmware Volume. | ||||
|   @param  Length        The size of the Firmware Volume in bytes. | ||||
|   @param  FvName        The name of the Firmware Volume. | ||||
|   @param  FileName      The name of the file. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildFv2Hob ( | ||||
|   IN          EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN          UINT64                      Length, | ||||
|   IN CONST    EFI_GUID                    *FvName, | ||||
|   IN CONST    EFI_GUID                    *FileName | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a Capsule Volume HOB. | ||||
|  | ||||
|   This function builds a Capsule Volume HOB. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If the platform does not support Capsule Volume HOBs, then ASSERT(). | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The base address of the Capsule Volume. | ||||
|   @param  Length        The size of the Capsule Volume in bytes. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildCvHob ( | ||||
|   IN EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN UINT64                      Length | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB for the CPU. | ||||
|  | ||||
|   This function builds a HOB for the CPU. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  SizeOfMemorySpace   The maximum physical memory addressability of the processor. | ||||
|   @param  SizeOfIoSpace       The maximum physical I/O addressability of the processor. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildCpuHob ( | ||||
|   IN UINT8                       SizeOfMemorySpace, | ||||
|   IN UINT8                       SizeOfIoSpace | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB for the Stack. | ||||
|  | ||||
|   This function builds a HOB for the stack. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The 64 bit physical address of the Stack. | ||||
|   @param  Length        The length of the stack in bytes. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildStackHob ( | ||||
|   IN EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN UINT64                      Length | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB for the BSP store. | ||||
|  | ||||
|   This function builds a HOB for BSP store. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The 64 bit physical address of the BSP. | ||||
|   @param  Length        The length of the BSP store in bytes. | ||||
|   @param  MemoryType    Type of memory allocated by this HOB. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildBspStoreHob ( | ||||
|   IN EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN UINT64                      Length, | ||||
|   IN EFI_MEMORY_TYPE             MemoryType | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Builds a HOB for the memory allocation. | ||||
|  | ||||
|   This function builds a HOB for the memory allocation. | ||||
|   It can only be invoked during PEI phase; | ||||
|   for DXE phase, it will ASSERT() since PEI HOB is read-only for DXE phase. | ||||
|  | ||||
|   If there is no additional space for HOB creation, then ASSERT(). | ||||
|  | ||||
|   @param  BaseAddress   The 64 bit physical address of the memory. | ||||
|   @param  Length        The length of the memory allocation in bytes. | ||||
|   @param  MemoryType    Type of memory allocated by this HOB. | ||||
|  | ||||
| **/ | ||||
| VOID | ||||
| EFIAPI | ||||
| BuildMemoryAllocationHob ( | ||||
|   IN EFI_PHYSICAL_ADDRESS        BaseAddress, | ||||
|   IN UINT64                      Length, | ||||
|   IN EFI_MEMORY_TYPE             MemoryType | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns the type of a HOB. | ||||
|  | ||||
|   This macro returns the HobType field from the HOB header for the | ||||
|   HOB specified by HobStart. | ||||
|  | ||||
|   @param  HobStart   A pointer to a HOB. | ||||
|  | ||||
|   @return HobType. | ||||
|  | ||||
| **/ | ||||
| #define GET_HOB_TYPE(HobStart) \ | ||||
|   ((*(EFI_HOB_GENERIC_HEADER **)&(HobStart))->HobType) | ||||
|  | ||||
| /** | ||||
|   Returns the length, in bytes, of a HOB. | ||||
|  | ||||
|   This macro returns the HobLength field from the HOB header for the | ||||
|   HOB specified by HobStart. | ||||
|  | ||||
|   @param  HobStart   A pointer to a HOB. | ||||
|  | ||||
|   @return HobLength. | ||||
|  | ||||
| **/ | ||||
| #define GET_HOB_LENGTH(HobStart) \ | ||||
|   ((*(EFI_HOB_GENERIC_HEADER **)&(HobStart))->HobLength) | ||||
|  | ||||
| /** | ||||
|   Returns a pointer to the next HOB in the HOB list. | ||||
|  | ||||
|   This macro returns a pointer to HOB that follows the | ||||
|   HOB specified by HobStart in the HOB List. | ||||
|  | ||||
|   @param  HobStart   A pointer to a HOB. | ||||
|  | ||||
|   @return A pointer to the next HOB in the HOB list. | ||||
|  | ||||
| **/ | ||||
| #define GET_NEXT_HOB(HobStart) \ | ||||
|   (VOID *)(*(UINT8 **)&(HobStart) + GET_HOB_LENGTH (HobStart)) | ||||
|  | ||||
| /** | ||||
|   Determines if a HOB is the last HOB in the HOB list. | ||||
|  | ||||
|   This macro determine if the HOB specified by HobStart is the | ||||
|   last HOB in the HOB list.  If HobStart is last HOB in the HOB list, | ||||
|   then TRUE is returned.  Otherwise, FALSE is returned. | ||||
|  | ||||
|   @param  HobStart   A pointer to a HOB. | ||||
|  | ||||
|   @retval TRUE       The HOB specified by HobStart is the last HOB in the HOB list. | ||||
|   @retval FALSE      The HOB specified by HobStart is not the last HOB in the HOB list. | ||||
|  | ||||
| **/ | ||||
| #define END_OF_HOB_LIST(HobStart)  (GET_HOB_TYPE (HobStart) == (UINT16)EFI_HOB_TYPE_END_OF_HOB_LIST) | ||||
|  | ||||
| /** | ||||
|   Returns a pointer to data buffer from a HOB of type EFI_HOB_TYPE_GUID_EXTENSION. | ||||
|  | ||||
|   This macro returns a pointer to the data buffer in a HOB specified by HobStart. | ||||
|   HobStart is assumed to be a HOB of type EFI_HOB_TYPE_GUID_EXTENSION. | ||||
|  | ||||
|   @param   GuidHob   A pointer to a HOB. | ||||
|  | ||||
|   @return  A pointer to the data buffer in a HOB. | ||||
|  | ||||
| **/ | ||||
| #define GET_GUID_HOB_DATA(HobStart) \ | ||||
|   (VOID *)(*(UINT8 **)&(HobStart) + sizeof (EFI_HOB_GUID_TYPE)) | ||||
|  | ||||
| /** | ||||
|   Returns the size of the data buffer from a HOB of type EFI_HOB_TYPE_GUID_EXTENSION. | ||||
|  | ||||
|   This macro returns the size, in bytes, of the data buffer in a HOB specified by HobStart. | ||||
|   HobStart is assumed to be a HOB of type EFI_HOB_TYPE_GUID_EXTENSION. | ||||
|  | ||||
|   @param   GuidHob   A pointer to a HOB. | ||||
|  | ||||
|   @return  The size of the data buffer. | ||||
| **/ | ||||
| #define GET_GUID_HOB_DATA_SIZE(HobStart) \ | ||||
|   (UINT16)(GET_HOB_LENGTH (HobStart) - sizeof (EFI_HOB_GUID_TYPE)) | ||||
|  | ||||
| #endif | ||||
| @@ -1,42 +0,0 @@ | ||||
| /** @file | ||||
|   Present the boot mode values in PI. | ||||
|  | ||||
|   Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   PI Version 1.2.1A | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PI_BOOT_MODE_H__ | ||||
| #define __PI_BOOT_MODE_H__ | ||||
|  | ||||
| /// | ||||
| /// EFI boot mode | ||||
| /// | ||||
| typedef UINT32  EFI_BOOT_MODE; | ||||
|  | ||||
| // | ||||
| // 0x21 - 0xf..f are reserved. | ||||
| // | ||||
| #define BOOT_WITH_FULL_CONFIGURATION                  0x00 | ||||
| #define BOOT_WITH_MINIMAL_CONFIGURATION               0x01 | ||||
| #define BOOT_ASSUMING_NO_CONFIGURATION_CHANGES        0x02 | ||||
| #define BOOT_WITH_FULL_CONFIGURATION_PLUS_DIAGNOSTICS 0x03 | ||||
| #define BOOT_WITH_DEFAULT_SETTINGS                    0x04 | ||||
| #define BOOT_ON_S4_RESUME                             0x05 | ||||
| #define BOOT_ON_S5_RESUME                             0x06 | ||||
| #define BOOT_WITH_MFG_MODE_SETTINGS                   0x07 | ||||
| #define BOOT_ON_S2_RESUME                             0x10 | ||||
| #define BOOT_ON_S3_RESUME                             0x11 | ||||
| #define BOOT_ON_FLASH_UPDATE                          0x12 | ||||
| #define BOOT_IN_RECOVERY_MODE                         0x20 | ||||
|  | ||||
| #endif | ||||
| @@ -1,494 +0,0 @@ | ||||
| /** @file | ||||
|   The firmware file related definitions in PI. | ||||
|  | ||||
| Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   PI Version 1.4. | ||||
|  | ||||
| **/ | ||||
|  | ||||
|  | ||||
| #ifndef __PI_FIRMWARE_FILE_H__ | ||||
| #define __PI_FIRMWARE_FILE_H__ | ||||
|  | ||||
| #pragma pack(1) | ||||
| /// | ||||
| /// Used to verify the integrity of the file. | ||||
| /// | ||||
| typedef union { | ||||
|   struct { | ||||
|     /// | ||||
|     /// The IntegrityCheck.Checksum.Header field is an 8-bit checksum of the file | ||||
|     /// header. The State and IntegrityCheck.Checksum.File fields are assumed | ||||
|     /// to be zero and the checksum is calculated such that the entire header sums to zero. | ||||
|     /// | ||||
|     UINT8   Header; | ||||
|     /// | ||||
|     /// If the FFS_ATTRIB_CHECKSUM (see definition below) bit of the Attributes | ||||
|     /// field is set to one, the IntegrityCheck.Checksum.File field is an 8-bit | ||||
|     /// checksum of the file data. | ||||
|     /// If the FFS_ATTRIB_CHECKSUM bit of the Attributes field is cleared to zero, | ||||
|     /// the IntegrityCheck.Checksum.File field must be initialized with a value of | ||||
|     /// 0xAA. The IntegrityCheck.Checksum.File field is valid any time the | ||||
|     /// EFI_FILE_DATA_VALID bit is set in the State field. | ||||
|     /// | ||||
|     UINT8   File; | ||||
|   } Checksum; | ||||
|   /// | ||||
|   /// This is the full 16 bits of the IntegrityCheck field. | ||||
|   /// | ||||
|   UINT16    Checksum16; | ||||
| } EFI_FFS_INTEGRITY_CHECK; | ||||
|  | ||||
| /// | ||||
| /// FFS_FIXED_CHECKSUM is the checksum value used when the | ||||
| /// FFS_ATTRIB_CHECKSUM attribute bit is clear. | ||||
| /// | ||||
| #define FFS_FIXED_CHECKSUM  0xAA | ||||
|  | ||||
| typedef UINT8 EFI_FV_FILETYPE; | ||||
| typedef UINT8 EFI_FFS_FILE_ATTRIBUTES; | ||||
| typedef UINT8 EFI_FFS_FILE_STATE; | ||||
|  | ||||
| /// | ||||
| /// File Types Definitions | ||||
| /// | ||||
| #define EFI_FV_FILETYPE_ALL                   0x00 | ||||
| #define EFI_FV_FILETYPE_RAW                   0x01 | ||||
| #define EFI_FV_FILETYPE_FREEFORM              0x02 | ||||
| #define EFI_FV_FILETYPE_SECURITY_CORE         0x03 | ||||
| #define EFI_FV_FILETYPE_PEI_CORE              0x04 | ||||
| #define EFI_FV_FILETYPE_DXE_CORE              0x05 | ||||
| #define EFI_FV_FILETYPE_PEIM                  0x06 | ||||
| #define EFI_FV_FILETYPE_DRIVER                0x07 | ||||
| #define EFI_FV_FILETYPE_COMBINED_PEIM_DRIVER  0x08 | ||||
| #define EFI_FV_FILETYPE_APPLICATION           0x09 | ||||
| #define EFI_FV_FILETYPE_SMM                   0x0A | ||||
| #define EFI_FV_FILETYPE_FIRMWARE_VOLUME_IMAGE 0x0B | ||||
| #define EFI_FV_FILETYPE_COMBINED_SMM_DXE      0x0C | ||||
| #define EFI_FV_FILETYPE_SMM_CORE              0x0D | ||||
| #define EFI_FV_FILETYPE_OEM_MIN               0xc0 | ||||
| #define EFI_FV_FILETYPE_OEM_MAX               0xdf | ||||
| #define EFI_FV_FILETYPE_DEBUG_MIN             0xe0 | ||||
| #define EFI_FV_FILETYPE_DEBUG_MAX             0xef | ||||
| #define EFI_FV_FILETYPE_FFS_MIN               0xf0 | ||||
| #define EFI_FV_FILETYPE_FFS_MAX               0xff | ||||
| #define EFI_FV_FILETYPE_FFS_PAD               0xf0 | ||||
| /// | ||||
| /// FFS File Attributes. | ||||
| /// | ||||
| #define FFS_ATTRIB_LARGE_FILE         0x01 | ||||
| #define FFS_ATTRIB_FIXED              0x04 | ||||
| #define FFS_ATTRIB_DATA_ALIGNMENT     0x38 | ||||
| #define FFS_ATTRIB_CHECKSUM           0x40 | ||||
|  | ||||
| /// | ||||
| /// FFS File State Bits. | ||||
| /// | ||||
| #define EFI_FILE_HEADER_CONSTRUCTION  0x01 | ||||
| #define EFI_FILE_HEADER_VALID         0x02 | ||||
| #define EFI_FILE_DATA_VALID           0x04 | ||||
| #define EFI_FILE_MARKED_FOR_UPDATE    0x08 | ||||
| #define EFI_FILE_DELETED              0x10 | ||||
| #define EFI_FILE_HEADER_INVALID       0x20 | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Each file begins with the header that describe the | ||||
| /// contents and state of the files. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// This GUID is the file name. It is used to uniquely identify the file. | ||||
|   /// | ||||
|   EFI_GUID                Name; | ||||
|   /// | ||||
|   /// Used to verify the integrity of the file. | ||||
|   /// | ||||
|   EFI_FFS_INTEGRITY_CHECK IntegrityCheck; | ||||
|   /// | ||||
|   /// Identifies the type of file. | ||||
|   /// | ||||
|   EFI_FV_FILETYPE         Type; | ||||
|   /// | ||||
|   /// Declares various file attribute bits. | ||||
|   /// | ||||
|   EFI_FFS_FILE_ATTRIBUTES Attributes; | ||||
|   /// | ||||
|   /// The length of the file in bytes, including the FFS header. | ||||
|   /// | ||||
|   UINT8                   Size[3]; | ||||
|   /// | ||||
|   /// Used to track the state of the file throughout the life of the file from creation to deletion. | ||||
|   /// | ||||
|   EFI_FFS_FILE_STATE      State; | ||||
| } EFI_FFS_FILE_HEADER; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// This GUID is the file name. It is used to uniquely identify the file. There may be only | ||||
|   /// one instance of a file with the file name GUID of Name in any given firmware | ||||
|   /// volume, except if the file type is EFI_FV_FILETYPE_FFS_PAD. | ||||
|   /// | ||||
|   EFI_GUID                  Name; | ||||
|  | ||||
|   /// | ||||
|   /// Used to verify the integrity of the file. | ||||
|   /// | ||||
|   EFI_FFS_INTEGRITY_CHECK   IntegrityCheck; | ||||
|  | ||||
|   /// | ||||
|   /// Identifies the type of file. | ||||
|   /// | ||||
|   EFI_FV_FILETYPE           Type; | ||||
|  | ||||
|   /// | ||||
|   /// Declares various file attribute bits. | ||||
|   /// | ||||
|   EFI_FFS_FILE_ATTRIBUTES   Attributes; | ||||
|  | ||||
|   /// | ||||
|   /// The length of the file in bytes, including the FFS header. | ||||
|   /// The length of the file data is either (Size - sizeof(EFI_FFS_FILE_HEADER)). This calculation means a | ||||
|   /// zero-length file has a Size of 24 bytes, which is sizeof(EFI_FFS_FILE_HEADER). | ||||
|   /// Size is not required to be a multiple of 8 bytes. Given a file F, the next file header is | ||||
|   /// located at the next 8-byte aligned firmware volume offset following the last byte of the file F. | ||||
|   /// | ||||
|   UINT8                     Size[3]; | ||||
|  | ||||
|   /// | ||||
|   /// Used to track the state of the file throughout the life of the file from creation to deletion. | ||||
|   /// | ||||
|   EFI_FFS_FILE_STATE        State; | ||||
|  | ||||
|   /// | ||||
|   /// If FFS_ATTRIB_LARGE_FILE is set in Attributes, then ExtendedSize exists and Size must be set to zero. | ||||
|   /// If FFS_ATTRIB_LARGE_FILE is not set then EFI_FFS_FILE_HEADER is used. | ||||
|   /// | ||||
|   UINT64                    ExtendedSize; | ||||
| } EFI_FFS_FILE_HEADER2; | ||||
|  | ||||
| #define IS_FFS_FILE2(FfsFileHeaderPtr) \ | ||||
|     (((((EFI_FFS_FILE_HEADER *) (UINTN) FfsFileHeaderPtr)->Attributes) & FFS_ATTRIB_LARGE_FILE) == FFS_ATTRIB_LARGE_FILE) | ||||
|  | ||||
| #define FFS_FILE_SIZE(FfsFileHeaderPtr) \ | ||||
|     ((UINT32) (*((UINT32 *) ((EFI_FFS_FILE_HEADER *) (UINTN) FfsFileHeaderPtr)->Size) & 0x00ffffff)) | ||||
|  | ||||
| #define FFS_FILE2_SIZE(FfsFileHeaderPtr) \ | ||||
|     ((UINT32) (((EFI_FFS_FILE_HEADER2 *) (UINTN) FfsFileHeaderPtr)->ExtendedSize)) | ||||
|  | ||||
| typedef UINT8 EFI_SECTION_TYPE; | ||||
|  | ||||
| /// | ||||
| /// Pseudo type. It is used as a wild card when retrieving sections. | ||||
| ///  The section type EFI_SECTION_ALL matches all section types. | ||||
| /// | ||||
| #define EFI_SECTION_ALL                   0x00 | ||||
|  | ||||
| /// | ||||
| /// Encapsulation section Type values. | ||||
| /// | ||||
| #define EFI_SECTION_COMPRESSION           0x01 | ||||
|  | ||||
| #define EFI_SECTION_GUID_DEFINED          0x02 | ||||
|  | ||||
| #define EFI_SECTION_DISPOSABLE            0x03 | ||||
|  | ||||
| /// | ||||
| /// Leaf section Type values. | ||||
| /// | ||||
| #define EFI_SECTION_PE32                  0x10 | ||||
| #define EFI_SECTION_PIC                   0x11 | ||||
| #define EFI_SECTION_TE                    0x12 | ||||
| #define EFI_SECTION_DXE_DEPEX             0x13 | ||||
| #define EFI_SECTION_VERSION               0x14 | ||||
| #define EFI_SECTION_USER_INTERFACE        0x15 | ||||
| #define EFI_SECTION_COMPATIBILITY16       0x16 | ||||
| #define EFI_SECTION_FIRMWARE_VOLUME_IMAGE 0x17 | ||||
| #define EFI_SECTION_FREEFORM_SUBTYPE_GUID 0x18 | ||||
| #define EFI_SECTION_RAW                   0x19 | ||||
| #define EFI_SECTION_PEI_DEPEX             0x1B | ||||
| #define EFI_SECTION_SMM_DEPEX             0x1C | ||||
|  | ||||
| /// | ||||
| /// Common section header. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// A 24-bit unsigned integer that contains the total size of the section in bytes, | ||||
|   /// including the EFI_COMMON_SECTION_HEADER. | ||||
|   /// | ||||
|   UINT8             Size[3]; | ||||
|   EFI_SECTION_TYPE  Type; | ||||
|   /// | ||||
|   /// Declares the section type. | ||||
|   /// | ||||
| } EFI_COMMON_SECTION_HEADER; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// A 24-bit unsigned integer that contains the total size of the section in bytes, | ||||
|   /// including the EFI_COMMON_SECTION_HEADER. | ||||
|   /// | ||||
|   UINT8             Size[3]; | ||||
|  | ||||
|   EFI_SECTION_TYPE  Type; | ||||
|  | ||||
|   /// | ||||
|   /// If Size is 0xFFFFFF, then ExtendedSize contains the size of the section. If | ||||
|   /// Size is not equal to 0xFFFFFF, then this field does not exist. | ||||
|   /// | ||||
|   UINT32            ExtendedSize; | ||||
| } EFI_COMMON_SECTION_HEADER2; | ||||
|  | ||||
| /// | ||||
| /// Leaf section type that contains an | ||||
| /// IA-32 16-bit executable image. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER  EFI_COMPATIBILITY16_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2 EFI_COMPATIBILITY16_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// CompressionType of EFI_COMPRESSION_SECTION. | ||||
| /// | ||||
| #define EFI_NOT_COMPRESSED        0x00 | ||||
| #define EFI_STANDARD_COMPRESSION  0x01 | ||||
| /// | ||||
| /// An encapsulation section type in which the | ||||
| /// section data is compressed. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Usual common section header. CommonHeader.Type = EFI_SECTION_COMPRESSION. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER   CommonHeader; | ||||
|   /// | ||||
|   /// The UINT32 that indicates the size of the section data after decompression. | ||||
|   /// | ||||
|   UINT32                      UncompressedLength; | ||||
|   /// | ||||
|   /// Indicates which compression algorithm is used. | ||||
|   /// | ||||
|   UINT8                       CompressionType; | ||||
| } EFI_COMPRESSION_SECTION; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Usual common section header. CommonHeader.Type = EFI_SECTION_COMPRESSION. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER2    CommonHeader; | ||||
|   /// | ||||
|   /// UINT32 that indicates the size of the section data after decompression. | ||||
|   /// | ||||
|   UINT32                        UncompressedLength; | ||||
|   /// | ||||
|   /// Indicates which compression algorithm is used. | ||||
|   /// | ||||
|   UINT8                         CompressionType; | ||||
| } EFI_COMPRESSION_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// An encapsulation section type in which the section data is disposable. | ||||
| /// A disposable section is an encapsulation section in which the section data may be disposed of during | ||||
| /// the process of creating or updating a firmware image without significant impact on the usefulness of | ||||
| /// the file. The Type field in the section header is set to EFI_SECTION_DISPOSABLE. This | ||||
| /// allows optional or descriptive data to be included with the firmware file which can be removed in | ||||
| /// order to conserve space. The contents of this section are implementation specific, but might contain | ||||
| /// debug data or detailed integration instructions. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_DISPOSABLE_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_DISPOSABLE_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which could be used to determine the dispatch order of DXEs. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_DXE_DEPEX_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_DXE_DEPEX_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains a PI FV. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_FIRMWARE_VOLUME_IMAGE_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_FIRMWARE_VOLUME_IMAGE_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains a single GUID. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Common section header. CommonHeader.Type = EFI_SECTION_FREEFORM_SUBTYPE_GUID. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER   CommonHeader; | ||||
|   /// | ||||
|   /// This GUID is defined by the creator of the file. It is a vendor-defined file type. | ||||
|   /// | ||||
|   EFI_GUID                    SubTypeGuid; | ||||
| } EFI_FREEFORM_SUBTYPE_GUID_SECTION; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The common section header. CommonHeader.Type = EFI_SECTION_FREEFORM_SUBTYPE_GUID. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER2    CommonHeader; | ||||
|   /// | ||||
|   /// This GUID is defined by the creator of the file. It is a vendor-defined file type. | ||||
|   /// | ||||
|   EFI_GUID                      SubTypeGuid; | ||||
| } EFI_FREEFORM_SUBTYPE_GUID_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// Attributes of EFI_GUID_DEFINED_SECTION. | ||||
| /// | ||||
| #define EFI_GUIDED_SECTION_PROCESSING_REQUIRED  0x01 | ||||
| #define EFI_GUIDED_SECTION_AUTH_STATUS_VALID    0x02 | ||||
| /// | ||||
| /// The leaf section which is encapsulation defined by specific GUID. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The common section header. CommonHeader.Type = EFI_SECTION_GUID_DEFINED. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER   CommonHeader; | ||||
|   /// | ||||
|   /// The GUID that defines the format of the data that follows. It is a vendor-defined section type. | ||||
|   /// | ||||
|   EFI_GUID                    SectionDefinitionGuid; | ||||
|   /// | ||||
|   /// Contains the offset in bytes from the beginning of the common header to the first byte of the data. | ||||
|   /// | ||||
|   UINT16                      DataOffset; | ||||
|   /// | ||||
|   /// The bit field that declares some specific characteristics of the section contents. | ||||
|   /// | ||||
|   UINT16                      Attributes; | ||||
| } EFI_GUID_DEFINED_SECTION; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The common section header. CommonHeader.Type = EFI_SECTION_GUID_DEFINED. | ||||
|   /// | ||||
|   EFI_COMMON_SECTION_HEADER2    CommonHeader; | ||||
|   /// | ||||
|   /// The GUID that defines the format of the data that follows. It is a vendor-defined section type. | ||||
|   /// | ||||
|   EFI_GUID                      SectionDefinitionGuid; | ||||
|   /// | ||||
|   /// Contains the offset in bytes from the beginning of the common header to the first byte of the data. | ||||
|   /// | ||||
|   UINT16                        DataOffset; | ||||
|   /// | ||||
|   /// The bit field that declares some specific characteristics of the section contents. | ||||
|   /// | ||||
|   UINT16                        Attributes; | ||||
| } EFI_GUID_DEFINED_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains PE32+ image. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_PE32_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_PE32_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section used to determine the dispatch order of PEIMs. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_PEI_DEPEX_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_PEI_DEPEX_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// A leaf section type that contains a position-independent-code (PIC) image. | ||||
| /// A PIC image section is a leaf section that contains a position-independent-code (PIC) image. | ||||
| /// In addition to normal PE32+ images that contain relocation information, PEIM executables may be | ||||
| /// PIC and are referred to as PIC images. A PIC image is the same as a PE32+ image except that all | ||||
| /// relocation information has been stripped from the image and the image can be moved and will | ||||
| /// execute correctly without performing any relocation or other fix-ups. EFI_PIC_SECTION2 must | ||||
| /// be used if the section is 16MB or larger. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_PIC_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_PIC_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which constains the position-independent-code image. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_TE_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_TE_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains an array of zero or more bytes. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER   EFI_RAW_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2  EFI_RAW_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The SMM dependency expression section is a leaf section that contains a dependency expression that | ||||
| /// is used to determine the dispatch order for SMM drivers. Before the SMRAM invocation of the | ||||
| /// SMM driver's entry point, this dependency expression must evaluate to TRUE. See the Platform | ||||
| /// Initialization Specification, Volume 2, for details regarding the format of the dependency expression. | ||||
| /// The dependency expression may refer to protocols installed in either the UEFI or the SMM protocol | ||||
| /// database. EFI_SMM_DEPEX_SECTION2 must be used if the section is 16MB or larger. | ||||
| /// | ||||
| typedef EFI_COMMON_SECTION_HEADER EFI_SMM_DEPEX_SECTION; | ||||
| typedef EFI_COMMON_SECTION_HEADER2 EFI_SMM_DEPEX_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains a unicode string that | ||||
| /// is human readable file name. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_COMMON_SECTION_HEADER   CommonHeader; | ||||
|  | ||||
|   /// | ||||
|   /// Array of unicode string. | ||||
|   /// | ||||
|   CHAR16                      FileNameString[1]; | ||||
| } EFI_USER_INTERFACE_SECTION; | ||||
|  | ||||
| typedef struct { | ||||
|   EFI_COMMON_SECTION_HEADER2    CommonHeader; | ||||
|   CHAR16                        FileNameString[1]; | ||||
| } EFI_USER_INTERFACE_SECTION2; | ||||
|  | ||||
| /// | ||||
| /// The leaf section which contains a numeric build number and | ||||
| /// an optional unicode string that represents the file revision. | ||||
| /// | ||||
| typedef struct { | ||||
|   EFI_COMMON_SECTION_HEADER   CommonHeader; | ||||
|   UINT16                      BuildNumber; | ||||
|  | ||||
|   /// | ||||
|   /// Array of unicode string. | ||||
|   /// | ||||
|   CHAR16                      VersionString[1]; | ||||
| } EFI_VERSION_SECTION; | ||||
|  | ||||
| typedef struct { | ||||
|   EFI_COMMON_SECTION_HEADER2    CommonHeader; | ||||
|   /// | ||||
|   /// A UINT16 that represents a particular build. Subsequent builds have monotonically | ||||
|   /// increasing build numbers relative to earlier builds. | ||||
|   /// | ||||
|   UINT16                        BuildNumber; | ||||
|   CHAR16                        VersionString[1]; | ||||
| } EFI_VERSION_SECTION2; | ||||
|  | ||||
| #define IS_SECTION2(SectionHeaderPtr) \ | ||||
|     ((UINT32) (*((UINT32 *) ((EFI_COMMON_SECTION_HEADER *) (UINTN) SectionHeaderPtr)->Size) & 0x00ffffff) == 0x00ffffff) | ||||
|  | ||||
| #define SECTION_SIZE(SectionHeaderPtr) \ | ||||
|     ((UINT32) (*((UINT32 *) ((EFI_COMMON_SECTION_HEADER *) (UINTN) SectionHeaderPtr)->Size) & 0x00ffffff)) | ||||
|  | ||||
| #define SECTION2_SIZE(SectionHeaderPtr) \ | ||||
|     (((EFI_COMMON_SECTION_HEADER2 *) (UINTN) SectionHeaderPtr)->ExtendedSize) | ||||
|  | ||||
| #pragma pack() | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,234 +0,0 @@ | ||||
| /** @file | ||||
|   The firmware volume related definitions in PI. | ||||
|  | ||||
|   Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   PI Version 1.3 | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PI_FIRMWAREVOLUME_H__ | ||||
| #define __PI_FIRMWAREVOLUME_H__ | ||||
|  | ||||
| /// | ||||
| /// EFI_FV_FILE_ATTRIBUTES | ||||
| /// | ||||
| typedef UINT32  EFI_FV_FILE_ATTRIBUTES; | ||||
|  | ||||
| // | ||||
| // Value of EFI_FV_FILE_ATTRIBUTES. | ||||
| // | ||||
| #define EFI_FV_FILE_ATTRIB_ALIGNMENT      0x0000001F | ||||
| #define EFI_FV_FILE_ATTRIB_FIXED          0x00000100 | ||||
| #define EFI_FV_FILE_ATTRIB_MEMORY_MAPPED  0x00000200 | ||||
|  | ||||
| /// | ||||
| /// type of EFI FVB attribute | ||||
| /// | ||||
| typedef UINT32  EFI_FVB_ATTRIBUTES_2; | ||||
|  | ||||
| // | ||||
| // Attributes bit definitions | ||||
| // | ||||
| #define EFI_FVB2_READ_DISABLED_CAP  0x00000001 | ||||
| #define EFI_FVB2_READ_ENABLED_CAP   0x00000002 | ||||
| #define EFI_FVB2_READ_STATUS        0x00000004 | ||||
| #define EFI_FVB2_WRITE_DISABLED_CAP 0x00000008 | ||||
| #define EFI_FVB2_WRITE_ENABLED_CAP  0x00000010 | ||||
| #define EFI_FVB2_WRITE_STATUS       0x00000020 | ||||
| #define EFI_FVB2_LOCK_CAP           0x00000040 | ||||
| #define EFI_FVB2_LOCK_STATUS        0x00000080 | ||||
| #define EFI_FVB2_STICKY_WRITE       0x00000200 | ||||
| #define EFI_FVB2_MEMORY_MAPPED      0x00000400 | ||||
| #define EFI_FVB2_ERASE_POLARITY     0x00000800 | ||||
| #define EFI_FVB2_READ_LOCK_CAP      0x00001000 | ||||
| #define EFI_FVB2_READ_LOCK_STATUS   0x00002000 | ||||
| #define EFI_FVB2_WRITE_LOCK_CAP     0x00004000 | ||||
| #define EFI_FVB2_WRITE_LOCK_STATUS  0x00008000 | ||||
| #define EFI_FVB2_ALIGNMENT          0x001F0000 | ||||
| #define EFI_FVB2_ALIGNMENT_1        0x00000000 | ||||
| #define EFI_FVB2_ALIGNMENT_2        0x00010000 | ||||
| #define EFI_FVB2_ALIGNMENT_4        0x00020000 | ||||
| #define EFI_FVB2_ALIGNMENT_8        0x00030000 | ||||
| #define EFI_FVB2_ALIGNMENT_16       0x00040000 | ||||
| #define EFI_FVB2_ALIGNMENT_32       0x00050000 | ||||
| #define EFI_FVB2_ALIGNMENT_64       0x00060000 | ||||
| #define EFI_FVB2_ALIGNMENT_128      0x00070000 | ||||
| #define EFI_FVB2_ALIGNMENT_256      0x00080000 | ||||
| #define EFI_FVB2_ALIGNMENT_512      0x00090000 | ||||
| #define EFI_FVB2_ALIGNMENT_1K       0x000A0000 | ||||
| #define EFI_FVB2_ALIGNMENT_2K       0x000B0000 | ||||
| #define EFI_FVB2_ALIGNMENT_4K       0x000C0000 | ||||
| #define EFI_FVB2_ALIGNMENT_8K       0x000D0000 | ||||
| #define EFI_FVB2_ALIGNMENT_16K      0x000E0000 | ||||
| #define EFI_FVB2_ALIGNMENT_32K      0x000F0000 | ||||
| #define EFI_FVB2_ALIGNMENT_64K      0x00100000 | ||||
| #define EFI_FVB2_ALIGNMENT_128K     0x00110000 | ||||
| #define EFI_FVB2_ALIGNMENT_256K     0x00120000 | ||||
| #define EFI_FVB2_ALIGNMENT_512K     0x00130000 | ||||
| #define EFI_FVB2_ALIGNMENT_1M       0x00140000 | ||||
| #define EFI_FVB2_ALIGNMENT_2M       0x00150000 | ||||
| #define EFI_FVB2_ALIGNMENT_4M       0x00160000 | ||||
| #define EFI_FVB2_ALIGNMENT_8M       0x00170000 | ||||
| #define EFI_FVB2_ALIGNMENT_16M      0x00180000 | ||||
| #define EFI_FVB2_ALIGNMENT_32M      0x00190000 | ||||
| #define EFI_FVB2_ALIGNMENT_64M      0x001A0000 | ||||
| #define EFI_FVB2_ALIGNMENT_128M     0x001B0000 | ||||
| #define EFI_FVB2_ALIGNMENT_256M     0x001C0000 | ||||
| #define EFI_FVB2_ALIGNMENT_512M     0x001D0000 | ||||
| #define EFI_FVB2_ALIGNMENT_1G       0x001E0000 | ||||
| #define EFI_FVB2_ALIGNMENT_2G       0x001F0000 | ||||
| #define EFI_FVB2_WEAK_ALIGNMENT     0x80000000 | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The number of sequential blocks which are of the same size. | ||||
|   /// | ||||
|   UINT32 NumBlocks; | ||||
|   /// | ||||
|   /// The size of the blocks. | ||||
|   /// | ||||
|   UINT32 Length; | ||||
| } EFI_FV_BLOCK_MAP_ENTRY; | ||||
|  | ||||
| /// | ||||
| /// Describes the features and layout of the firmware volume. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The first 16 bytes are reserved to allow for the reset vector of | ||||
|   /// processors whose reset vector is at address 0. | ||||
|   /// | ||||
|   UINT8                     ZeroVector[16]; | ||||
|   /// | ||||
|   /// Declares the file system with which the firmware volume is formatted. | ||||
|   /// | ||||
|   EFI_GUID                  FileSystemGuid; | ||||
|   /// | ||||
|   /// Length in bytes of the complete firmware volume, including the header. | ||||
|   /// | ||||
|   UINT64                    FvLength; | ||||
|   /// | ||||
|   /// Set to EFI_FVH_SIGNATURE | ||||
|   /// | ||||
|   UINT32                    Signature; | ||||
|   /// | ||||
|   /// Declares capabilities and power-on defaults for the firmware volume. | ||||
|   /// | ||||
|   EFI_FVB_ATTRIBUTES_2      Attributes; | ||||
|   /// | ||||
|   /// Length in bytes of the complete firmware volume header. | ||||
|   /// | ||||
|   UINT16                    HeaderLength; | ||||
|   /// | ||||
|   /// A 16-bit checksum of the firmware volume header. A valid header sums to zero. | ||||
|   /// | ||||
|   UINT16                    Checksum; | ||||
|   /// | ||||
|   /// Offset, relative to the start of the header, of the extended header | ||||
|   /// (EFI_FIRMWARE_VOLUME_EXT_HEADER) or zero if there is no extended header. | ||||
|   /// | ||||
|   UINT16                    ExtHeaderOffset; | ||||
|   /// | ||||
|   /// This field must always be set to zero. | ||||
|   /// | ||||
|   UINT8                     Reserved[1]; | ||||
|   /// | ||||
|   /// Set to 2. Future versions of this specification may define new header fields and will | ||||
|   /// increment the Revision field accordingly. | ||||
|   /// | ||||
|   UINT8                     Revision; | ||||
|   /// | ||||
|   /// An array of run-length encoded FvBlockMapEntry structures. The array is | ||||
|   /// terminated with an entry of {0,0}. | ||||
|   /// | ||||
|   EFI_FV_BLOCK_MAP_ENTRY    BlockMap[1]; | ||||
| } EFI_FIRMWARE_VOLUME_HEADER; | ||||
|  | ||||
| #define EFI_FVH_SIGNATURE SIGNATURE_32 ('_', 'F', 'V', 'H') | ||||
|  | ||||
| /// | ||||
| /// Firmware Volume Header Revision definition | ||||
| /// | ||||
| #define EFI_FVH_REVISION  0x02 | ||||
|  | ||||
| /// | ||||
| /// Extension header pointed by ExtHeaderOffset of volume header. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Firmware volume name. | ||||
|   /// | ||||
|   EFI_GUID  FvName; | ||||
|   /// | ||||
|   /// Size of the rest of the extension header, including this structure. | ||||
|   /// | ||||
|   UINT32    ExtHeaderSize; | ||||
| } EFI_FIRMWARE_VOLUME_EXT_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Entry struture for describing FV extension header | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Size of this header extension. | ||||
|   /// | ||||
|   UINT16    ExtEntrySize; | ||||
|   /// | ||||
|   /// Type of the header. | ||||
|   /// | ||||
|   UINT16    ExtEntryType; | ||||
| } EFI_FIRMWARE_VOLUME_EXT_ENTRY; | ||||
|  | ||||
| #define EFI_FV_EXT_TYPE_OEM_TYPE  0x01 | ||||
| /// | ||||
| /// This extension header provides a mapping between a GUID and an OEM file type. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE. | ||||
|   /// | ||||
|   EFI_FIRMWARE_VOLUME_EXT_ENTRY Hdr; | ||||
|   /// | ||||
|   /// A bit mask, one bit for each file type between 0xC0 (bit 0) and 0xDF (bit 31). If a bit | ||||
|   /// is '1', then the GUID entry exists in Types. If a bit is '0' then no GUID entry exists in Types. | ||||
|   /// | ||||
|   UINT32    TypeMask; | ||||
|   /// | ||||
|   /// An array of GUIDs, each GUID representing an OEM file type. | ||||
|   /// | ||||
|   /// EFI_GUID  Types[1]; | ||||
|   /// | ||||
| } EFI_FIRMWARE_VOLUME_EXT_ENTRY_OEM_TYPE; | ||||
|  | ||||
| #define EFI_FV_EXT_TYPE_GUID_TYPE 0x0002 | ||||
|  | ||||
| /// | ||||
| /// This extension header EFI_FIRMWARE_VOLUME_EXT_ENTRY_GUID_TYPE provides a vendor specific | ||||
| /// GUID FormatType type which includes a length and a successive series of data bytes. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Standard extension entry, with the type EFI_FV_EXT_TYPE_OEM_TYPE. | ||||
|   /// | ||||
|   EFI_FIRMWARE_VOLUME_EXT_ENTRY     Hdr; | ||||
|   /// | ||||
|   /// Vendor-specific GUID. | ||||
|   /// | ||||
|   EFI_GUID                          FormatType; | ||||
|   /// | ||||
|   /// An arry of bytes of length Length. | ||||
|   /// | ||||
|   /// UINT8                             Data[1]; | ||||
|   /// | ||||
| } EFI_FIRMWARE_VOLUME_EXT_ENTRY_GUID_TYPE; | ||||
|  | ||||
| #endif | ||||
| @@ -1,479 +0,0 @@ | ||||
| /** @file | ||||
|   HOB related definitions in PI. | ||||
|  | ||||
| Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
|   @par Revision Reference: | ||||
|   PI Version 1.4 | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PI_HOB_H__ | ||||
| #define __PI_HOB_H__ | ||||
|  | ||||
| // | ||||
| // HobType of EFI_HOB_GENERIC_HEADER. | ||||
| // | ||||
| #define EFI_HOB_TYPE_HANDOFF              0x0001 | ||||
| #define EFI_HOB_TYPE_MEMORY_ALLOCATION    0x0002 | ||||
| #define EFI_HOB_TYPE_RESOURCE_DESCRIPTOR  0x0003 | ||||
| #define EFI_HOB_TYPE_GUID_EXTENSION       0x0004 | ||||
| #define EFI_HOB_TYPE_FV                   0x0005 | ||||
| #define EFI_HOB_TYPE_CPU                  0x0006 | ||||
| #define EFI_HOB_TYPE_MEMORY_POOL          0x0007 | ||||
| #define EFI_HOB_TYPE_FV2                  0x0009 | ||||
| #define EFI_HOB_TYPE_LOAD_PEIM_UNUSED     0x000A | ||||
| #define EFI_HOB_TYPE_UEFI_CAPSULE         0x000B | ||||
| #define EFI_HOB_TYPE_UNUSED               0xFFFE | ||||
| #define EFI_HOB_TYPE_END_OF_HOB_LIST      0xFFFF | ||||
|  | ||||
| /// | ||||
| /// Describes the format and size of the data inside the HOB. | ||||
| /// All HOBs must contain this generic HOB header. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Identifies the HOB data structure type. | ||||
|   /// | ||||
|   UINT16    HobType; | ||||
|   /// | ||||
|   /// The length in bytes of the HOB. | ||||
|   /// | ||||
|   UINT16    HobLength; | ||||
|   /// | ||||
|   /// This field must always be set to zero. | ||||
|   /// | ||||
|   UINT32    Reserved; | ||||
| } EFI_HOB_GENERIC_HEADER; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Value of version  in EFI_HOB_HANDOFF_INFO_TABLE. | ||||
| /// | ||||
| #define EFI_HOB_HANDOFF_TABLE_VERSION 0x0009 | ||||
|  | ||||
| /// | ||||
| /// Contains general state information used by the HOB producer phase. | ||||
| /// This HOB must be the first one in the HOB list. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_HANDOFF. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER  Header; | ||||
|   /// | ||||
|   /// The version number pertaining to the PHIT HOB definition. | ||||
|   /// This value is four bytes in length to provide an 8-byte aligned entry | ||||
|   /// when it is combined with the 4-byte BootMode. | ||||
|   /// | ||||
|   UINT32                  Version; | ||||
|   /// | ||||
|   /// The system boot mode as determined during the HOB producer phase. | ||||
|   /// | ||||
|   EFI_BOOT_MODE           BootMode; | ||||
|   /// | ||||
|   /// The highest address location of memory that is allocated for use by the HOB producer | ||||
|   /// phase. This address must be 4-KB aligned to meet page restrictions of UEFI. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    EfiMemoryTop; | ||||
|   /// | ||||
|   /// The lowest address location of memory that is allocated for use by the HOB producer phase. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    EfiMemoryBottom; | ||||
|   /// | ||||
|   /// The highest address location of free memory that is currently available | ||||
|   /// for use by the HOB producer phase. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    EfiFreeMemoryTop; | ||||
|   /// | ||||
|   /// The lowest address location of free memory that is available for use by the HOB producer phase. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    EfiFreeMemoryBottom; | ||||
|   /// | ||||
|   /// The end of the HOB list. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    EfiEndOfHobList; | ||||
| } EFI_HOB_HANDOFF_INFO_TABLE; | ||||
|  | ||||
| /// | ||||
| /// EFI_HOB_MEMORY_ALLOCATION_HEADER describes the | ||||
| /// various attributes of the logical memory allocation. The type field will be used for | ||||
| /// subsequent inclusion in the UEFI memory map. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// A GUID that defines the memory allocation region's type and purpose, as well as | ||||
|   /// other fields within the memory allocation HOB. This GUID is used to define the | ||||
|   /// additional data within the HOB that may be present for the memory allocation HOB. | ||||
|   /// Type EFI_GUID is defined in InstallProtocolInterface() in the UEFI 2.0 | ||||
|   /// specification. | ||||
|   /// | ||||
|   EFI_GUID              Name; | ||||
|  | ||||
|   /// | ||||
|   /// The base address of memory allocated by this HOB. Type | ||||
|   /// EFI_PHYSICAL_ADDRESS is defined in AllocatePages() in the UEFI 2.0 | ||||
|   /// specification. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS  MemoryBaseAddress; | ||||
|  | ||||
|   /// | ||||
|   /// The length in bytes of memory allocated by this HOB. | ||||
|   /// | ||||
|   UINT64                MemoryLength; | ||||
|  | ||||
|   /// | ||||
|   /// Defines the type of memory allocated by this HOB. The memory type definition | ||||
|   /// follows the EFI_MEMORY_TYPE definition. Type EFI_MEMORY_TYPE is defined | ||||
|   /// in AllocatePages() in the UEFI 2.0 specification. | ||||
|   /// | ||||
|   EFI_MEMORY_TYPE       MemoryType; | ||||
|  | ||||
|   /// | ||||
|   /// Padding for Itanium processor family | ||||
|   /// | ||||
|   UINT8                 Reserved[4]; | ||||
| } EFI_HOB_MEMORY_ALLOCATION_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Describes all memory ranges used during the HOB producer | ||||
| /// phase that exist outside the HOB list. This HOB type | ||||
| /// describes how memory is used, not the physical attributes of memory. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_MEMORY_ALLOCATION. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER            Header; | ||||
|   /// | ||||
|   /// An instance of the EFI_HOB_MEMORY_ALLOCATION_HEADER that describes the | ||||
|   /// various attributes of the logical memory allocation. | ||||
|   /// | ||||
|   EFI_HOB_MEMORY_ALLOCATION_HEADER  AllocDescriptor; | ||||
|   // | ||||
|   // Additional data pertaining to the "Name" Guid memory | ||||
|   // may go here. | ||||
|   // | ||||
| } EFI_HOB_MEMORY_ALLOCATION; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Describes the memory stack that is produced by the HOB producer | ||||
| /// phase and upon which all post-memory-installed executable | ||||
| /// content in the HOB producer phase is executing. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_MEMORY_ALLOCATION. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER            Header; | ||||
|   /// | ||||
|   /// An instance of the EFI_HOB_MEMORY_ALLOCATION_HEADER that describes the | ||||
|   /// various attributes of the logical memory allocation. | ||||
|   /// | ||||
|   EFI_HOB_MEMORY_ALLOCATION_HEADER  AllocDescriptor; | ||||
| } EFI_HOB_MEMORY_ALLOCATION_STACK; | ||||
|  | ||||
| /// | ||||
| /// Defines the location of the boot-strap | ||||
| /// processor (BSP) BSPStore ("Backing Store Pointer Store"). | ||||
| /// This HOB is valid for the Itanium processor family only | ||||
| /// register overflow store. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_MEMORY_ALLOCATION. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER            Header; | ||||
|   /// | ||||
|   /// An instance of the EFI_HOB_MEMORY_ALLOCATION_HEADER that describes the | ||||
|   /// various attributes of the logical memory allocation. | ||||
|   /// | ||||
|   EFI_HOB_MEMORY_ALLOCATION_HEADER  AllocDescriptor; | ||||
| } EFI_HOB_MEMORY_ALLOCATION_BSP_STORE; | ||||
|  | ||||
| /// | ||||
| /// Defines the location and entry point of the HOB consumer phase. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_MEMORY_ALLOCATION. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER            Header; | ||||
|   /// | ||||
|   /// An instance of the EFI_HOB_MEMORY_ALLOCATION_HEADER that describes the | ||||
|   /// various attributes of the logical memory allocation. | ||||
|   /// | ||||
|   EFI_HOB_MEMORY_ALLOCATION_HEADER  MemoryAllocationHeader; | ||||
|   /// | ||||
|   /// The GUID specifying the values of the firmware file system name | ||||
|   /// that contains the HOB consumer phase component. | ||||
|   /// | ||||
|   EFI_GUID                          ModuleName; | ||||
|   /// | ||||
|   /// The address of the memory-mapped firmware volume | ||||
|   /// that contains the HOB consumer phase firmware file. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS              EntryPoint; | ||||
| } EFI_HOB_MEMORY_ALLOCATION_MODULE; | ||||
|  | ||||
| /// | ||||
| /// The resource type. | ||||
| /// | ||||
| typedef UINT32 EFI_RESOURCE_TYPE; | ||||
|  | ||||
| // | ||||
| // Value of ResourceType in EFI_HOB_RESOURCE_DESCRIPTOR. | ||||
| // | ||||
| #define EFI_RESOURCE_SYSTEM_MEMORY          0x00000000 | ||||
| #define EFI_RESOURCE_MEMORY_MAPPED_IO       0x00000001 | ||||
| #define EFI_RESOURCE_IO                     0x00000002 | ||||
| #define EFI_RESOURCE_FIRMWARE_DEVICE        0x00000003 | ||||
| #define EFI_RESOURCE_MEMORY_MAPPED_IO_PORT  0x00000004 | ||||
| #define EFI_RESOURCE_MEMORY_RESERVED        0x00000005 | ||||
| #define EFI_RESOURCE_IO_RESERVED            0x00000006 | ||||
| #define EFI_RESOURCE_MAX_MEMORY_TYPE        0x00000007 | ||||
|  | ||||
| /// | ||||
| /// A type of recount attribute type. | ||||
| /// | ||||
| typedef UINT32 EFI_RESOURCE_ATTRIBUTE_TYPE; | ||||
|  | ||||
| // | ||||
| // These types can be ORed together as needed. | ||||
| // | ||||
| // The following attributes are used to describe settings | ||||
| // | ||||
| #define EFI_RESOURCE_ATTRIBUTE_PRESENT                  0x00000001 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_INITIALIZED              0x00000002 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_TESTED                   0x00000004 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_READ_PROTECTED           0x00000080 | ||||
| // | ||||
| // This is typically used as memory cacheability attribute today. | ||||
| // NOTE: Since PI spec 1.4, please use EFI_RESOURCE_ATTRIBUTE_READ_ONLY_PROTECTED | ||||
| // as Physical write protected attribute, and EFI_RESOURCE_ATTRIBUTE_WRITE_PROTECTED | ||||
| // means Memory cacheability attribute: The memory supports being programmed with | ||||
| // a writeprotected cacheable attribute. | ||||
| // | ||||
| #define EFI_RESOURCE_ATTRIBUTE_WRITE_PROTECTED          0x00000100 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_EXECUTION_PROTECTED      0x00000200 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_PERSISTENT               0x00800000 | ||||
| // | ||||
| // The rest of the attributes are used to describe capabilities | ||||
| // | ||||
| #define EFI_RESOURCE_ATTRIBUTE_SINGLE_BIT_ECC           0x00000008 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_MULTIPLE_BIT_ECC         0x00000010 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_ECC_RESERVED_1           0x00000020 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_ECC_RESERVED_2           0x00000040 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_UNCACHEABLE              0x00000400 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_WRITE_COMBINEABLE        0x00000800 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_WRITE_THROUGH_CACHEABLE  0x00001000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_WRITE_BACK_CACHEABLE     0x00002000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_16_BIT_IO                0x00004000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_32_BIT_IO                0x00008000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_64_BIT_IO                0x00010000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_UNCACHED_EXPORTED        0x00020000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_READ_PROTECTABLE         0x00100000 | ||||
| // | ||||
| // This is typically used as memory cacheability attribute today. | ||||
| // NOTE: Since PI spec 1.4, please use EFI_RESOURCE_ATTRIBUTE_READ_ONLY_PROTECTABLE | ||||
| // as Memory capability attribute: The memory supports being protected from processor | ||||
| // writes, and EFI_RESOURCE_ATTRIBUTE_WRITE_PROTEC TABLE means Memory cacheability attribute: | ||||
| // The memory supports being programmed with a writeprotected cacheable attribute. | ||||
| // | ||||
| #define EFI_RESOURCE_ATTRIBUTE_WRITE_PROTECTABLE        0x00200000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_EXECUTION_PROTECTABLE    0x00400000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_PERSISTABLE              0x01000000 | ||||
|  | ||||
| #define EFI_RESOURCE_ATTRIBUTE_READ_ONLY_PROTECTED      0x00040000 | ||||
| #define EFI_RESOURCE_ATTRIBUTE_READ_ONLY_PROTECTABLE    0x00800000 | ||||
|  | ||||
| // | ||||
| // Physical memory relative reliability attribute. This | ||||
| // memory provides higher reliability relative to other | ||||
| // memory in the system. If all memory has the same | ||||
| // reliability, then this bit is not used. | ||||
| // | ||||
| #define EFI_RESOURCE_ATTRIBUTE_MORE_RELIABLE            0x02000000 | ||||
|  | ||||
| /// | ||||
| /// Describes the resource properties of all fixed, | ||||
| /// nonrelocatable resource ranges found on the processor | ||||
| /// host bus during the HOB producer phase. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_RESOURCE_DESCRIPTOR. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER      Header; | ||||
|   /// | ||||
|   /// A GUID representing the owner of the resource. This GUID is used by HOB | ||||
|   /// consumer phase components to correlate device ownership of a resource. | ||||
|   /// | ||||
|   EFI_GUID                    Owner; | ||||
|   /// | ||||
|   /// The resource type enumeration as defined by EFI_RESOURCE_TYPE. | ||||
|   /// | ||||
|   EFI_RESOURCE_TYPE           ResourceType; | ||||
|   /// | ||||
|   /// Resource attributes as defined by EFI_RESOURCE_ATTRIBUTE_TYPE. | ||||
|   /// | ||||
|   EFI_RESOURCE_ATTRIBUTE_TYPE ResourceAttribute; | ||||
|   /// | ||||
|   /// The physical start address of the resource region. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS        PhysicalStart; | ||||
|   /// | ||||
|   /// The number of bytes of the resource region. | ||||
|   /// | ||||
|   UINT64                      ResourceLength; | ||||
| } EFI_HOB_RESOURCE_DESCRIPTOR; | ||||
|  | ||||
| /// | ||||
| /// Allows writers of executable content in the HOB producer phase to | ||||
| /// maintain and manage HOBs with specific GUID. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_GUID_EXTENSION. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER      Header; | ||||
|   /// | ||||
|   /// A GUID that defines the contents of this HOB. | ||||
|   /// | ||||
|   EFI_GUID                    Name; | ||||
|   // | ||||
|   // Guid specific data goes here | ||||
|   // | ||||
| } EFI_HOB_GUID_TYPE; | ||||
|  | ||||
| /// | ||||
| /// Details the location of firmware volumes that contain firmware files. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_FV. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER Header; | ||||
|   /// | ||||
|   /// The physical memory-mapped base address of the firmware volume. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS   BaseAddress; | ||||
|   /// | ||||
|   /// The length in bytes of the firmware volume. | ||||
|   /// | ||||
|   UINT64                 Length; | ||||
| } EFI_HOB_FIRMWARE_VOLUME; | ||||
|  | ||||
| /// | ||||
| /// Details the location of a firmware volume that was extracted | ||||
| /// from a file within another firmware volume. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_FV2. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER  Header; | ||||
|   /// | ||||
|   /// The physical memory-mapped base address of the firmware volume. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS    BaseAddress; | ||||
|   /// | ||||
|   /// The length in bytes of the firmware volume. | ||||
|   /// | ||||
|   UINT64                  Length; | ||||
|   /// | ||||
|   /// The name of the firmware volume. | ||||
|   /// | ||||
|   EFI_GUID                FvName; | ||||
|   /// | ||||
|   /// The name of the firmware file that contained this firmware volume. | ||||
|   /// | ||||
|   EFI_GUID                FileName; | ||||
| } EFI_HOB_FIRMWARE_VOLUME2; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Describes processor information, such as address space and I/O space capabilities. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_CPU. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER  Header; | ||||
|   /// | ||||
|   /// Identifies the maximum physical memory addressability of the processor. | ||||
|   /// | ||||
|   UINT8                   SizeOfMemorySpace; | ||||
|   /// | ||||
|   /// Identifies the maximum physical I/O addressability of the processor. | ||||
|   /// | ||||
|   UINT8                   SizeOfIoSpace; | ||||
|   /// | ||||
|   /// This field will always be set to zero. | ||||
|   /// | ||||
|   UINT8                   Reserved[6]; | ||||
| } EFI_HOB_CPU; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Describes pool memory allocations. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header. Header.HobType = EFI_HOB_TYPE_MEMORY_POOL. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER  Header; | ||||
| } EFI_HOB_MEMORY_POOL; | ||||
|  | ||||
| /// | ||||
| /// Each UEFI capsule HOB details the location of a UEFI capsule. It includes a base address and length | ||||
| /// which is based upon memory blocks with a EFI_CAPSULE_HEADER and the associated | ||||
| /// CapsuleImageSize-based payloads. These HOB's shall be created by the PEI PI firmware | ||||
| /// sometime after the UEFI UpdateCapsule service invocation with the | ||||
| /// CAPSULE_FLAGS_POPULATE_SYSTEM_TABLE flag set in the EFI_CAPSULE_HEADER. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The HOB generic header where Header.HobType = EFI_HOB_TYPE_UEFI_CAPSULE. | ||||
|   /// | ||||
|   EFI_HOB_GENERIC_HEADER Header; | ||||
|  | ||||
|   /// | ||||
|   /// The physical memory-mapped base address of an UEFI capsule. This value is set to | ||||
|   /// point to the base of the contiguous memory of the UEFI capsule. | ||||
|   /// The length of the contiguous memory in bytes. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS   BaseAddress; | ||||
|   UINT64                 Length; | ||||
| } EFI_HOB_UEFI_CAPSULE; | ||||
|  | ||||
| /// | ||||
| /// Union of all the possible HOB Types. | ||||
| /// | ||||
| typedef union { | ||||
|   EFI_HOB_GENERIC_HEADER              *Header; | ||||
|   EFI_HOB_HANDOFF_INFO_TABLE          *HandoffInformationTable; | ||||
|   EFI_HOB_MEMORY_ALLOCATION           *MemoryAllocation; | ||||
|   EFI_HOB_MEMORY_ALLOCATION_BSP_STORE *MemoryAllocationBspStore; | ||||
|   EFI_HOB_MEMORY_ALLOCATION_STACK     *MemoryAllocationStack; | ||||
|   EFI_HOB_MEMORY_ALLOCATION_MODULE    *MemoryAllocationModule; | ||||
|   EFI_HOB_RESOURCE_DESCRIPTOR         *ResourceDescriptor; | ||||
|   EFI_HOB_GUID_TYPE                   *Guid; | ||||
|   EFI_HOB_FIRMWARE_VOLUME             *FirmwareVolume; | ||||
|   EFI_HOB_FIRMWARE_VOLUME2            *FirmwareVolume2; | ||||
|   EFI_HOB_CPU                         *Cpu; | ||||
|   EFI_HOB_MEMORY_POOL                 *Pool; | ||||
|   EFI_HOB_UEFI_CAPSULE                *Capsule; | ||||
|   UINT8                               *Raw; | ||||
| } EFI_PEI_HOB_POINTERS; | ||||
|  | ||||
|  | ||||
| #endif | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,276 +0,0 @@ | ||||
| /** @file | ||||
|   Graphics Output Protocol from the UEFI 2.0 specification. | ||||
|  | ||||
|   Abstraction of a very simple graphics device. | ||||
|  | ||||
|   Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __GRAPHICS_OUTPUT_H__ | ||||
| #define __GRAPHICS_OUTPUT_H__ | ||||
|  | ||||
| #define EFI_GRAPHICS_OUTPUT_PROTOCOL_GUID \ | ||||
|   { \ | ||||
|     0x9042a9de, 0x23dc, 0x4a38, {0x96, 0xfb, 0x7a, 0xde, 0xd0, 0x80, 0x51, 0x6a } \ | ||||
|   } | ||||
|  | ||||
| typedef struct _EFI_GRAPHICS_OUTPUT_PROTOCOL EFI_GRAPHICS_OUTPUT_PROTOCOL; | ||||
|  | ||||
| typedef struct { | ||||
|   UINT32            RedMask; | ||||
|   UINT32            GreenMask; | ||||
|   UINT32            BlueMask; | ||||
|   UINT32            ReservedMask; | ||||
| } EFI_PIXEL_BITMASK; | ||||
|  | ||||
| typedef enum { | ||||
|   /// | ||||
|   /// A pixel is 32-bits and byte zero represents red, byte one represents green, | ||||
|   /// byte two represents blue, and byte three is reserved. This is the definition | ||||
|   /// for the physical frame buffer. The byte values for the red, green, and blue | ||||
|   /// components represent the color intensity. This color intensity value range | ||||
|   /// from a minimum intensity of 0 to maximum intensity of 255. | ||||
|   /// | ||||
|   PixelRedGreenBlueReserved8BitPerColor, | ||||
|   /// | ||||
|   /// A pixel is 32-bits and byte zero represents blue, byte one represents green, | ||||
|   /// byte two represents red, and byte three is reserved. This is the definition | ||||
|   /// for the physical frame buffer. The byte values for the red, green, and blue | ||||
|   /// components represent the color intensity. This color intensity value range | ||||
|   /// from a minimum intensity of 0 to maximum intensity of 255. | ||||
|   /// | ||||
|   PixelBlueGreenRedReserved8BitPerColor, | ||||
|   /// | ||||
|   /// The Pixel definition of the physical frame buffer. | ||||
|   /// | ||||
|   PixelBitMask, | ||||
|   /// | ||||
|   /// This mode does not support a physical frame buffer. | ||||
|   /// | ||||
|   PixelBltOnly, | ||||
|   /// | ||||
|   /// Valid EFI_GRAPHICS_PIXEL_FORMAT enum values are less than this value. | ||||
|   /// | ||||
|   PixelFormatMax | ||||
| } EFI_GRAPHICS_PIXEL_FORMAT; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The version of this data structure. A value of zero represents the | ||||
|   /// EFI_GRAPHICS_OUTPUT_MODE_INFORMATION structure as defined in this specification. | ||||
|   /// | ||||
|   UINT32                     Version; | ||||
|   /// | ||||
|   /// The size of video screen in pixels in the X dimension. | ||||
|   /// | ||||
|   UINT32                     HorizontalResolution; | ||||
|   /// | ||||
|   /// The size of video screen in pixels in the Y dimension. | ||||
|   /// | ||||
|   UINT32                     VerticalResolution; | ||||
|   /// | ||||
|   /// Enumeration that defines the physical format of the pixel. A value of PixelBltOnly | ||||
|   /// implies that a linear frame buffer is not available for this mode. | ||||
|   /// | ||||
|   EFI_GRAPHICS_PIXEL_FORMAT  PixelFormat; | ||||
|   /// | ||||
|   /// This bit-mask is only valid if PixelFormat is set to PixelPixelBitMask. | ||||
|   /// A bit being set defines what bits are used for what purpose such as Red, Green, Blue, or Reserved. | ||||
|   /// | ||||
|   EFI_PIXEL_BITMASK          PixelInformation; | ||||
|   /// | ||||
|   /// Defines the number of pixel elements per video memory line. | ||||
|   /// | ||||
|   UINT32                     PixelsPerScanLine; | ||||
| } EFI_GRAPHICS_OUTPUT_MODE_INFORMATION; | ||||
|  | ||||
| /** | ||||
|   Returns information for an available graphics mode that the graphics device | ||||
|   and the set of active video output devices supports. | ||||
|  | ||||
|   @param  This                  The EFI_GRAPHICS_OUTPUT_PROTOCOL instance. | ||||
|   @param  ModeNumber            The mode number to return information on. | ||||
|   @param  SizeOfInfo            A pointer to the size, in bytes, of the Info buffer. | ||||
|   @param  Info                  A pointer to callee allocated buffer that returns information about ModeNumber. | ||||
|  | ||||
|   @retval EFI_SUCCESS           Valid mode information was returned. | ||||
|   @retval EFI_DEVICE_ERROR      A hardware error occurred trying to retrieve the video mode. | ||||
|   @retval EFI_INVALID_PARAMETER ModeNumber is not valid. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_GRAPHICS_OUTPUT_PROTOCOL_QUERY_MODE)( | ||||
|   IN  EFI_GRAPHICS_OUTPUT_PROTOCOL          *This, | ||||
|   IN  UINT32                                ModeNumber, | ||||
|   OUT UINTN                                 *SizeOfInfo, | ||||
|   OUT EFI_GRAPHICS_OUTPUT_MODE_INFORMATION  **Info | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Set the video device into the specified mode and clears the visible portions of | ||||
|   the output display to black. | ||||
|  | ||||
|   @param  This              The EFI_GRAPHICS_OUTPUT_PROTOCOL instance. | ||||
|   @param  ModeNumber        Abstraction that defines the current video mode. | ||||
|  | ||||
|   @retval EFI_SUCCESS       The graphics mode specified by ModeNumber was selected. | ||||
|   @retval EFI_DEVICE_ERROR  The device had an error and could not complete the request. | ||||
|   @retval EFI_UNSUPPORTED   ModeNumber is not supported by this device. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_GRAPHICS_OUTPUT_PROTOCOL_SET_MODE)( | ||||
|   IN  EFI_GRAPHICS_OUTPUT_PROTOCOL *This, | ||||
|   IN  UINT32                       ModeNumber | ||||
|   ); | ||||
|  | ||||
| typedef struct { | ||||
|   UINT8 Blue; | ||||
|   UINT8 Green; | ||||
|   UINT8 Red; | ||||
|   UINT8 Reserved; | ||||
| } EFI_GRAPHICS_OUTPUT_BLT_PIXEL; | ||||
|  | ||||
| typedef union { | ||||
|   EFI_GRAPHICS_OUTPUT_BLT_PIXEL Pixel; | ||||
|   UINT32                        Raw; | ||||
| } EFI_GRAPHICS_OUTPUT_BLT_PIXEL_UNION; | ||||
|  | ||||
| /// | ||||
| /// actions for BltOperations | ||||
| /// | ||||
| typedef enum { | ||||
|   /// | ||||
|   /// Write data from the BltBuffer pixel (0, 0) | ||||
|   /// directly to every pixel of the video display rectangle | ||||
|   /// (DestinationX, DestinationY) (DestinationX + Width, DestinationY + Height). | ||||
|   /// Only one pixel will be used from the BltBuffer. Delta is NOT used. | ||||
|   /// | ||||
|   EfiBltVideoFill, | ||||
|  | ||||
|   /// | ||||
|   /// Read data from the video display rectangle | ||||
|   /// (SourceX, SourceY) (SourceX + Width, SourceY + Height) and place it in | ||||
|   /// the BltBuffer rectangle (DestinationX, DestinationY ) | ||||
|   /// (DestinationX + Width, DestinationY + Height). If DestinationX or | ||||
|   /// DestinationY is not zero then Delta must be set to the length in bytes | ||||
|   /// of a row in the BltBuffer. | ||||
|   /// | ||||
|   EfiBltVideoToBltBuffer, | ||||
|  | ||||
|   /// | ||||
|   /// Write data from the BltBuffer rectangle | ||||
|   /// (SourceX, SourceY) (SourceX + Width, SourceY + Height) directly to the | ||||
|   /// video display rectangle (DestinationX, DestinationY) | ||||
|   /// (DestinationX + Width, DestinationY + Height). If SourceX or SourceY is | ||||
|   /// not zero then Delta must be set to the length in bytes of a row in the | ||||
|   /// BltBuffer. | ||||
|   /// | ||||
|   EfiBltBufferToVideo, | ||||
|  | ||||
|   /// | ||||
|   /// Copy from the video display rectangle (SourceX, SourceY) | ||||
|   /// (SourceX + Width, SourceY + Height) to the video display rectangle | ||||
|   /// (DestinationX, DestinationY) (DestinationX + Width, DestinationY + Height). | ||||
|   /// The BltBuffer and Delta are not used in this mode. | ||||
|   /// | ||||
|   EfiBltVideoToVideo, | ||||
|  | ||||
|   EfiGraphicsOutputBltOperationMax | ||||
| } EFI_GRAPHICS_OUTPUT_BLT_OPERATION; | ||||
|  | ||||
| /** | ||||
|   Blt a rectangle of pixels on the graphics screen. Blt stands for BLock Transfer. | ||||
|  | ||||
|   @param  This         Protocol instance pointer. | ||||
|   @param  BltBuffer    The data to transfer to the graphics screen. | ||||
|                        Size is at least Width*Height*sizeof(EFI_GRAPHICS_OUTPUT_BLT_PIXEL). | ||||
|   @param  BltOperation The operation to perform when copying BltBuffer on to the graphics screen. | ||||
|   @param  SourceX      The X coordinate of source for the BltOperation. | ||||
|   @param  SourceY      The Y coordinate of source for the BltOperation. | ||||
|   @param  DestinationX The X coordinate of destination for the BltOperation. | ||||
|   @param  DestinationY The Y coordinate of destination for the BltOperation. | ||||
|   @param  Width        The width of a rectangle in the blt rectangle in pixels. | ||||
|   @param  Height       The height of a rectangle in the blt rectangle in pixels. | ||||
|   @param  Delta        Not used for EfiBltVideoFill or the EfiBltVideoToVideo operation. | ||||
|                        If a Delta of zero is used, the entire BltBuffer is being operated on. | ||||
|                        If a subrectangle of the BltBuffer is being used then Delta | ||||
|                        represents the number of bytes in a row of the BltBuffer. | ||||
|  | ||||
|   @retval EFI_SUCCESS           BltBuffer was drawn to the graphics screen. | ||||
|   @retval EFI_INVALID_PARAMETER BltOperation is not valid. | ||||
|   @retval EFI_DEVICE_ERROR      The device had an error and could not complete the request. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_GRAPHICS_OUTPUT_PROTOCOL_BLT)( | ||||
|   IN  EFI_GRAPHICS_OUTPUT_PROTOCOL            *This, | ||||
|   IN  EFI_GRAPHICS_OUTPUT_BLT_PIXEL           *BltBuffer,   OPTIONAL | ||||
|   IN  EFI_GRAPHICS_OUTPUT_BLT_OPERATION       BltOperation, | ||||
|   IN  UINTN                                   SourceX, | ||||
|   IN  UINTN                                   SourceY, | ||||
|   IN  UINTN                                   DestinationX, | ||||
|   IN  UINTN                                   DestinationY, | ||||
|   IN  UINTN                                   Width, | ||||
|   IN  UINTN                                   Height, | ||||
|   IN  UINTN                                   Delta         OPTIONAL | ||||
|   ); | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The number of modes supported by QueryMode() and SetMode(). | ||||
|   /// | ||||
|   UINT32                                 MaxMode; | ||||
|   /// | ||||
|   /// Current Mode of the graphics device. Valid mode numbers are 0 to MaxMode -1. | ||||
|   /// | ||||
|   UINT32                                 Mode; | ||||
|   /// | ||||
|   /// Pointer to read-only EFI_GRAPHICS_OUTPUT_MODE_INFORMATION data. | ||||
|   /// | ||||
|   EFI_GRAPHICS_OUTPUT_MODE_INFORMATION   *Info; | ||||
|   /// | ||||
|   /// Size of Info structure in bytes. | ||||
|   /// | ||||
|   UINTN                                  SizeOfInfo; | ||||
|   /// | ||||
|   /// Base address of graphics linear frame buffer. | ||||
|   /// Offset zero in FrameBufferBase represents the upper left pixel of the display. | ||||
|   /// | ||||
|   EFI_PHYSICAL_ADDRESS                   FrameBufferBase; | ||||
|   /// | ||||
|   /// Amount of frame buffer needed to support the active mode as defined by | ||||
|   /// PixelsPerScanLine xVerticalResolution x PixelElementSize. | ||||
|   /// | ||||
|   UINTN                                  FrameBufferSize; | ||||
| } EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE; | ||||
|  | ||||
| /// | ||||
| /// Provides a basic abstraction to set video modes and copy pixels to and from | ||||
| /// the graphics controller's frame buffer. The linear address of the hardware | ||||
| /// frame buffer is also exposed so software can write directly to the video hardware. | ||||
| /// | ||||
| struct _EFI_GRAPHICS_OUTPUT_PROTOCOL { | ||||
|   EFI_GRAPHICS_OUTPUT_PROTOCOL_QUERY_MODE  QueryMode; | ||||
|   EFI_GRAPHICS_OUTPUT_PROTOCOL_SET_MODE    SetMode; | ||||
|   EFI_GRAPHICS_OUTPUT_PROTOCOL_BLT         Blt; | ||||
|   /// | ||||
|   /// Pointer to EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE data. | ||||
|   /// | ||||
|   EFI_GRAPHICS_OUTPUT_PROTOCOL_MODE        *Mode; | ||||
| }; | ||||
|  | ||||
| extern EFI_GUID gEfiGraphicsOutputProtocolGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,134 +0,0 @@ | ||||
| /** @file | ||||
|   Simple Text Input protocol from the UEFI 2.0 specification. | ||||
|  | ||||
|   Abstraction of a very simple input device like a keyboard or serial | ||||
|   terminal. | ||||
|  | ||||
|   Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __SIMPLE_TEXT_IN_PROTOCOL_H__ | ||||
| #define __SIMPLE_TEXT_IN_PROTOCOL_H__ | ||||
|  | ||||
| #define EFI_SIMPLE_TEXT_INPUT_PROTOCOL_GUID \ | ||||
|   { \ | ||||
|     0x387477c1, 0x69c7, 0x11d2, {0x8e, 0x39, 0x0, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \ | ||||
|   } | ||||
|  | ||||
| typedef struct _EFI_SIMPLE_TEXT_INPUT_PROTOCOL  EFI_SIMPLE_TEXT_INPUT_PROTOCOL; | ||||
|  | ||||
| /// | ||||
| /// Protocol GUID name defined in EFI1.1. | ||||
| /// | ||||
| #define SIMPLE_INPUT_PROTOCOL   EFI_SIMPLE_TEXT_INPUT_PROTOCOL_GUID | ||||
|  | ||||
| /// | ||||
| /// Protocol name in EFI1.1 for backward-compatible. | ||||
| /// | ||||
| typedef struct _EFI_SIMPLE_TEXT_INPUT_PROTOCOL  SIMPLE_INPUT_INTERFACE; | ||||
|  | ||||
| /// | ||||
| /// The keystroke information for the key that was pressed. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  ScanCode; | ||||
|   CHAR16  UnicodeChar; | ||||
| } EFI_INPUT_KEY; | ||||
|  | ||||
| // | ||||
| // Required unicode control chars | ||||
| // | ||||
| #define CHAR_NULL             0x0000 | ||||
| #define CHAR_BACKSPACE        0x0008 | ||||
| #define CHAR_TAB              0x0009 | ||||
| #define CHAR_LINEFEED         0x000A | ||||
| #define CHAR_CARRIAGE_RETURN  0x000D | ||||
|  | ||||
| // | ||||
| // EFI Scan codes | ||||
| // | ||||
| #define SCAN_NULL       0x0000 | ||||
| #define SCAN_UP         0x0001 | ||||
| #define SCAN_DOWN       0x0002 | ||||
| #define SCAN_RIGHT      0x0003 | ||||
| #define SCAN_LEFT       0x0004 | ||||
| #define SCAN_HOME       0x0005 | ||||
| #define SCAN_END        0x0006 | ||||
| #define SCAN_INSERT     0x0007 | ||||
| #define SCAN_DELETE     0x0008 | ||||
| #define SCAN_PAGE_UP    0x0009 | ||||
| #define SCAN_PAGE_DOWN  0x000A | ||||
| #define SCAN_F1         0x000B | ||||
| #define SCAN_F2         0x000C | ||||
| #define SCAN_F3         0x000D | ||||
| #define SCAN_F4         0x000E | ||||
| #define SCAN_F5         0x000F | ||||
| #define SCAN_F6         0x0010 | ||||
| #define SCAN_F7         0x0011 | ||||
| #define SCAN_F8         0x0012 | ||||
| #define SCAN_F9         0x0013 | ||||
| #define SCAN_F10        0x0014 | ||||
| #define SCAN_ESC        0x0017 | ||||
|  | ||||
| /** | ||||
|   Reset the input device and optionally run diagnostics | ||||
|  | ||||
|   @param  This                 Protocol instance pointer. | ||||
|   @param  ExtendedVerification Driver may perform diagnostics on reset. | ||||
|  | ||||
|   @retval EFI_SUCCESS          The device was reset. | ||||
|   @retval EFI_DEVICE_ERROR     The device is not functioning properly and could not be reset. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_INPUT_RESET)( | ||||
|   IN EFI_SIMPLE_TEXT_INPUT_PROTOCOL       *This, | ||||
|   IN BOOLEAN                              ExtendedVerification | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Reads the next keystroke from the input device. The WaitForKey Event can | ||||
|   be used to test for existence of a keystroke via WaitForEvent () call. | ||||
|  | ||||
|   @param  This  Protocol instance pointer. | ||||
|   @param  Key   A pointer to a buffer that is filled in with the keystroke | ||||
|                 information for the key that was pressed. | ||||
|  | ||||
|   @retval EFI_SUCCESS      The keystroke information was returned. | ||||
|   @retval EFI_NOT_READY    There was no keystroke data available. | ||||
|   @retval EFI_DEVICE_ERROR The keystroke information was not returned due to | ||||
|                            hardware errors. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_INPUT_READ_KEY)( | ||||
|   IN EFI_SIMPLE_TEXT_INPUT_PROTOCOL       *This, | ||||
|   OUT EFI_INPUT_KEY                       *Key | ||||
|   ); | ||||
|  | ||||
| /// | ||||
| /// The EFI_SIMPLE_TEXT_INPUT_PROTOCOL is used on the ConsoleIn device. | ||||
| /// It is the minimum required protocol for ConsoleIn. | ||||
| /// | ||||
| struct _EFI_SIMPLE_TEXT_INPUT_PROTOCOL { | ||||
|   EFI_INPUT_RESET     Reset; | ||||
|   EFI_INPUT_READ_KEY  ReadKeyStroke; | ||||
|   /// | ||||
|   /// Event to use with WaitForEvent() to wait for a key to be available | ||||
|   /// | ||||
|   EFI_EVENT           WaitForKey; | ||||
| }; | ||||
|  | ||||
| extern EFI_GUID gEfiSimpleTextInProtocolGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,325 +0,0 @@ | ||||
| /** @file | ||||
|   Simple Text Input Ex protocol from the UEFI 2.0 specification. | ||||
|  | ||||
|   This protocol defines an extension to the EFI_SIMPLE_TEXT_INPUT_PROTOCOL | ||||
|   which exposes much more state and modifier information from the input device, | ||||
|   also allows one to register a notification for a particular keystroke. | ||||
|  | ||||
|   Copyright (c) 2006 - 2012, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __SIMPLE_TEXT_IN_EX_H__ | ||||
| #define __SIMPLE_TEXT_IN_EX_H__ | ||||
|  | ||||
| #include <Protocol/SimpleTextIn.h> | ||||
|  | ||||
| #define EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL_GUID \ | ||||
|   {0xdd9e7534, 0x7762, 0x4698, { 0x8c, 0x14, 0xf5, 0x85, 0x17, 0xa6, 0x25, 0xaa } } | ||||
|  | ||||
|  | ||||
| typedef struct _EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL; | ||||
|  | ||||
| /** | ||||
|   The Reset() function resets the input device hardware. As part | ||||
|   of initialization process, the firmware/device will make a quick | ||||
|   but reasonable attempt to verify that the device is functioning. | ||||
|   If the ExtendedVerification flag is TRUE the firmware may take | ||||
|   an extended amount of time to verify the device is operating on | ||||
|   reset. Otherwise the reset operation is to occur as quickly as | ||||
|   possible. The hardware verification process is not defined by | ||||
|   this specification and is left up to the platform firmware or | ||||
|   driver to implement. | ||||
|  | ||||
|   @param This                 A pointer to the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL instance. | ||||
|  | ||||
|   @param ExtendedVerification Indicates that the driver may | ||||
|                               perform a more exhaustive | ||||
|                               verification operation of the | ||||
|                               device during reset. | ||||
|  | ||||
|  | ||||
|   @retval EFI_SUCCESS       The device was reset. | ||||
|  | ||||
|   @retval EFI_DEVICE_ERROR  The device is not functioning | ||||
|                             correctly and could not be reset. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_INPUT_RESET_EX)( | ||||
|   IN EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL *This, | ||||
|   IN BOOLEAN                           ExtendedVerification | ||||
| ); | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// EFI_KEY_TOGGLE_STATE. The toggle states are defined. | ||||
| /// They are: EFI_TOGGLE_STATE_VALID, EFI_SCROLL_LOCK_ACTIVE | ||||
| /// EFI_NUM_LOCK_ACTIVE, EFI_CAPS_LOCK_ACTIVE | ||||
| /// | ||||
| typedef UINT8 EFI_KEY_TOGGLE_STATE; | ||||
|  | ||||
| typedef struct _EFI_KEY_STATE { | ||||
|   /// | ||||
|   /// Reflects the currently pressed shift | ||||
|   /// modifiers for the input device. The | ||||
|   /// returned value is valid only if the high | ||||
|   /// order bit has been set. | ||||
|   /// | ||||
|   UINT32                KeyShiftState; | ||||
|   /// | ||||
|   /// Reflects the current internal state of | ||||
|   /// various toggled attributes. The returned | ||||
|   /// value is valid only if the high order | ||||
|   /// bit has been set. | ||||
|   /// | ||||
|   EFI_KEY_TOGGLE_STATE  KeyToggleState; | ||||
| } EFI_KEY_STATE; | ||||
|  | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The EFI scan code and Unicode value returned from the input device. | ||||
|   /// | ||||
|   EFI_INPUT_KEY   Key; | ||||
|   /// | ||||
|   /// The current state of various toggled attributes as well as input modifier values. | ||||
|   /// | ||||
|   EFI_KEY_STATE   KeyState; | ||||
| } EFI_KEY_DATA; | ||||
|  | ||||
| // | ||||
| // Any Shift or Toggle State that is valid should have | ||||
| // high order bit set. | ||||
| // | ||||
| // Shift state | ||||
| // | ||||
| #define EFI_SHIFT_STATE_VALID     0x80000000 | ||||
| #define EFI_RIGHT_SHIFT_PRESSED   0x00000001 | ||||
| #define EFI_LEFT_SHIFT_PRESSED    0x00000002 | ||||
| #define EFI_RIGHT_CONTROL_PRESSED 0x00000004 | ||||
| #define EFI_LEFT_CONTROL_PRESSED  0x00000008 | ||||
| #define EFI_RIGHT_ALT_PRESSED     0x00000010 | ||||
| #define EFI_LEFT_ALT_PRESSED      0x00000020 | ||||
| #define EFI_RIGHT_LOGO_PRESSED    0x00000040 | ||||
| #define EFI_LEFT_LOGO_PRESSED     0x00000080 | ||||
| #define EFI_MENU_KEY_PRESSED      0x00000100 | ||||
| #define EFI_SYS_REQ_PRESSED       0x00000200 | ||||
|  | ||||
| // | ||||
| // Toggle state | ||||
| // | ||||
| #define EFI_TOGGLE_STATE_VALID    0x80 | ||||
| #define EFI_KEY_STATE_EXPOSED     0x40 | ||||
| #define EFI_SCROLL_LOCK_ACTIVE    0x01 | ||||
| #define EFI_NUM_LOCK_ACTIVE       0x02 | ||||
| #define EFI_CAPS_LOCK_ACTIVE      0x04 | ||||
|  | ||||
| // | ||||
| // EFI Scan codes | ||||
| // | ||||
| #define SCAN_F11                  0x0015 | ||||
| #define SCAN_F12                  0x0016 | ||||
| #define SCAN_PAUSE                0x0048 | ||||
| #define SCAN_F13                  0x0068 | ||||
| #define SCAN_F14                  0x0069 | ||||
| #define SCAN_F15                  0x006A | ||||
| #define SCAN_F16                  0x006B | ||||
| #define SCAN_F17                  0x006C | ||||
| #define SCAN_F18                  0x006D | ||||
| #define SCAN_F19                  0x006E | ||||
| #define SCAN_F20                  0x006F | ||||
| #define SCAN_F21                  0x0070 | ||||
| #define SCAN_F22                  0x0071 | ||||
| #define SCAN_F23                  0x0072 | ||||
| #define SCAN_F24                  0x0073 | ||||
| #define SCAN_MUTE                 0x007F | ||||
| #define SCAN_VOLUME_UP            0x0080 | ||||
| #define SCAN_VOLUME_DOWN          0x0081 | ||||
| #define SCAN_BRIGHTNESS_UP        0x0100 | ||||
| #define SCAN_BRIGHTNESS_DOWN      0x0101 | ||||
| #define SCAN_SUSPEND              0x0102 | ||||
| #define SCAN_HIBERNATE            0x0103 | ||||
| #define SCAN_TOGGLE_DISPLAY       0x0104 | ||||
| #define SCAN_RECOVERY             0x0105 | ||||
| #define SCAN_EJECT                0x0106 | ||||
|  | ||||
| /** | ||||
|   The function reads the next keystroke from the input device. If | ||||
|   there is no pending keystroke the function returns | ||||
|   EFI_NOT_READY. If there is a pending keystroke, then | ||||
|   KeyData.Key.ScanCode is the EFI scan code defined in Error! | ||||
|   Reference source not found. The KeyData.Key.UnicodeChar is the | ||||
|   actual printable character or is zero if the key does not | ||||
|   represent a printable character (control key, function key, | ||||
|   etc.). The KeyData.KeyState is shift state for the character | ||||
|   reflected in KeyData.Key.UnicodeChar or KeyData.Key.ScanCode . | ||||
|   When interpreting the data from this function, it should be | ||||
|   noted that if a class of printable characters that are | ||||
|   normally adjusted by shift modifiers (e.g. Shift Key + "f" | ||||
|   key) would be presented solely as a KeyData.Key.UnicodeChar | ||||
|   without the associated shift state. So in the previous example | ||||
|   of a Shift Key + "f" key being pressed, the only pertinent | ||||
|   data returned would be KeyData.Key.UnicodeChar with the value | ||||
|   of "F". This of course would not typically be the case for | ||||
|   non-printable characters such as the pressing of the Right | ||||
|   Shift Key + F10 key since the corresponding returned data | ||||
|   would be reflected both in the KeyData.KeyState.KeyShiftState | ||||
|   and KeyData.Key.ScanCode values. UEFI drivers which implement | ||||
|   the EFI_SIMPLE_TEXT_INPUT_EX protocol are required to return | ||||
|   KeyData.Key and KeyData.KeyState values. These drivers must | ||||
|   always return the most current state of | ||||
|   KeyData.KeyState.KeyShiftState and | ||||
|   KeyData.KeyState.KeyToggleState. It should also be noted that | ||||
|   certain input devices may not be able to produce shift or toggle | ||||
|   state information, and in those cases the high order bit in the | ||||
|   respective Toggle and Shift state fields should not be active. | ||||
|  | ||||
|  | ||||
|   @param This     A pointer to the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL instance. | ||||
|  | ||||
|   @param KeyData  A pointer to a buffer that is filled in with | ||||
|                   the keystroke state data for the key that was | ||||
|                   pressed. | ||||
|  | ||||
|  | ||||
|   @retval EFI_SUCCESS     The keystroke information was | ||||
|                           returned. | ||||
|  | ||||
|   @retval EFI_NOT_READY   There was no keystroke data available. | ||||
|                           EFI_DEVICE_ERROR The keystroke | ||||
|                           information was not returned due to | ||||
|                           hardware errors. | ||||
|  | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_INPUT_READ_KEY_EX)( | ||||
|   IN  EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL *This, | ||||
|   OUT EFI_KEY_DATA                      *KeyData | ||||
| ); | ||||
|  | ||||
| /** | ||||
|   The SetState() function allows the input device hardware to | ||||
|   have state settings adjusted. | ||||
|  | ||||
|   @param This           A pointer to the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL instance. | ||||
|  | ||||
|   @param KeyToggleState Pointer to the EFI_KEY_TOGGLE_STATE to | ||||
|                         set the state for the input device. | ||||
|  | ||||
|  | ||||
|   @retval EFI_SUCCESS       The device state was set appropriately. | ||||
|  | ||||
|   @retval EFI_DEVICE_ERROR  The device is not functioning | ||||
|                             correctly and could not have the | ||||
|                             setting adjusted. | ||||
|  | ||||
|   @retval EFI_UNSUPPORTED   The device does not support the | ||||
|                             ability to have its state set. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_SET_STATE)( | ||||
|   IN EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL *This, | ||||
|   IN EFI_KEY_TOGGLE_STATE              *KeyToggleState | ||||
| ); | ||||
|  | ||||
| /// | ||||
| /// The function will be called when the key sequence is typed specified by KeyData. | ||||
| /// | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_KEY_NOTIFY_FUNCTION)( | ||||
|   IN EFI_KEY_DATA *KeyData | ||||
| ); | ||||
|  | ||||
| /** | ||||
|   The RegisterKeystrokeNotify() function registers a function | ||||
|   which will be called when a specified keystroke will occur. | ||||
|  | ||||
|   @param This                     A pointer to the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL instance. | ||||
|  | ||||
|   @param KeyData                  A pointer to a buffer that is filled in with | ||||
|                                   the keystroke information for the key that was | ||||
|                                   pressed. | ||||
|  | ||||
|   @param KeyNotificationFunction  Points to the function to be | ||||
|                                   called when the key sequence | ||||
|                                   is typed specified by KeyData. | ||||
|  | ||||
|  | ||||
|   @param NotifyHandle             Points to the unique handle assigned to | ||||
|                                   the registered notification. | ||||
|  | ||||
|   @retval EFI_SUCCESS           The device state was set | ||||
|                                 appropriately. | ||||
|  | ||||
|   @retval EFI_OUT_OF_RESOURCES  Unable to allocate necessary | ||||
|                                 data structures. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_REGISTER_KEYSTROKE_NOTIFY)( | ||||
|   IN  EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL *This, | ||||
|   IN  EFI_KEY_DATA                      *KeyData, | ||||
|   IN  EFI_KEY_NOTIFY_FUNCTION           KeyNotificationFunction, | ||||
|   OUT VOID                              **NotifyHandle | ||||
| ); | ||||
|  | ||||
| /** | ||||
|   The UnregisterKeystrokeNotify() function removes the | ||||
|   notification which was previously registered. | ||||
|  | ||||
|   @param This               A pointer to the EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL instance. | ||||
|  | ||||
|   @param NotificationHandle The handle of the notification | ||||
|                             function being unregistered. | ||||
|  | ||||
|   @retval EFI_SUCCESS The device state was set appropriately. | ||||
|  | ||||
|   @retval EFI_INVALID_PARAMETER The NotificationHandle is | ||||
|                                 invalid. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_UNREGISTER_KEYSTROKE_NOTIFY)( | ||||
|   IN EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL  *This, | ||||
|   IN VOID                               *NotificationHandle | ||||
| ); | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// The EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL is used on the ConsoleIn | ||||
| /// device. It is an extension to the Simple Text Input protocol | ||||
| /// which allows a variety of extended shift state information to be | ||||
| /// returned. | ||||
| /// | ||||
| struct _EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL{ | ||||
|   EFI_INPUT_RESET_EX              Reset; | ||||
|   EFI_INPUT_READ_KEY_EX           ReadKeyStrokeEx; | ||||
|   /// | ||||
|   /// Event to use with WaitForEvent() to wait for a key to be available. | ||||
|   /// | ||||
|   EFI_EVENT                       WaitForKeyEx; | ||||
|   EFI_SET_STATE                   SetState; | ||||
|   EFI_REGISTER_KEYSTROKE_NOTIFY   RegisterKeyNotify; | ||||
|   EFI_UNREGISTER_KEYSTROKE_NOTIFY UnregisterKeyNotify; | ||||
| }; | ||||
|  | ||||
|  | ||||
| extern EFI_GUID gEfiSimpleTextInputExProtocolGuid; | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,415 +0,0 @@ | ||||
| /** @file | ||||
|   Simple Text Out protocol from the UEFI 2.0 specification. | ||||
|  | ||||
|   Abstraction of a very simple text based output device like VGA text mode or | ||||
|   a serial terminal. The Simple Text Out protocol instance can represent | ||||
|   a single hardware device or a virtual device that is an aggregation | ||||
|   of multiple physical devices. | ||||
|  | ||||
| Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __SIMPLE_TEXT_OUT_H__ | ||||
| #define __SIMPLE_TEXT_OUT_H__ | ||||
|  | ||||
| #define EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL_GUID \ | ||||
|   { \ | ||||
|     0x387477c2, 0x69c7, 0x11d2, {0x8e, 0x39, 0x0, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \ | ||||
|   } | ||||
|  | ||||
| /// | ||||
| /// Protocol GUID defined in EFI1.1. | ||||
| /// | ||||
| #define SIMPLE_TEXT_OUTPUT_PROTOCOL   EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL_GUID | ||||
|  | ||||
| typedef struct _EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL; | ||||
|  | ||||
| /// | ||||
| /// Backward-compatible with EFI1.1. | ||||
| /// | ||||
| typedef EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL   SIMPLE_TEXT_OUTPUT_INTERFACE; | ||||
|  | ||||
| // | ||||
| // Define's for required EFI Unicode Box Draw characters | ||||
| // | ||||
| #define BOXDRAW_HORIZONTAL                  0x2500 | ||||
| #define BOXDRAW_VERTICAL                    0x2502 | ||||
| #define BOXDRAW_DOWN_RIGHT                  0x250c | ||||
| #define BOXDRAW_DOWN_LEFT                   0x2510 | ||||
| #define BOXDRAW_UP_RIGHT                    0x2514 | ||||
| #define BOXDRAW_UP_LEFT                     0x2518 | ||||
| #define BOXDRAW_VERTICAL_RIGHT              0x251c | ||||
| #define BOXDRAW_VERTICAL_LEFT               0x2524 | ||||
| #define BOXDRAW_DOWN_HORIZONTAL             0x252c | ||||
| #define BOXDRAW_UP_HORIZONTAL               0x2534 | ||||
| #define BOXDRAW_VERTICAL_HORIZONTAL         0x253c | ||||
| #define BOXDRAW_DOUBLE_HORIZONTAL           0x2550 | ||||
| #define BOXDRAW_DOUBLE_VERTICAL             0x2551 | ||||
| #define BOXDRAW_DOWN_RIGHT_DOUBLE           0x2552 | ||||
| #define BOXDRAW_DOWN_DOUBLE_RIGHT           0x2553 | ||||
| #define BOXDRAW_DOUBLE_DOWN_RIGHT           0x2554 | ||||
| #define BOXDRAW_DOWN_LEFT_DOUBLE            0x2555 | ||||
| #define BOXDRAW_DOWN_DOUBLE_LEFT            0x2556 | ||||
| #define BOXDRAW_DOUBLE_DOWN_LEFT            0x2557 | ||||
| #define BOXDRAW_UP_RIGHT_DOUBLE             0x2558 | ||||
| #define BOXDRAW_UP_DOUBLE_RIGHT             0x2559 | ||||
| #define BOXDRAW_DOUBLE_UP_RIGHT             0x255a | ||||
| #define BOXDRAW_UP_LEFT_DOUBLE              0x255b | ||||
| #define BOXDRAW_UP_DOUBLE_LEFT              0x255c | ||||
| #define BOXDRAW_DOUBLE_UP_LEFT              0x255d | ||||
| #define BOXDRAW_VERTICAL_RIGHT_DOUBLE       0x255e | ||||
| #define BOXDRAW_VERTICAL_DOUBLE_RIGHT       0x255f | ||||
| #define BOXDRAW_DOUBLE_VERTICAL_RIGHT       0x2560 | ||||
| #define BOXDRAW_VERTICAL_LEFT_DOUBLE        0x2561 | ||||
| #define BOXDRAW_VERTICAL_DOUBLE_LEFT        0x2562 | ||||
| #define BOXDRAW_DOUBLE_VERTICAL_LEFT        0x2563 | ||||
| #define BOXDRAW_DOWN_HORIZONTAL_DOUBLE      0x2564 | ||||
| #define BOXDRAW_DOWN_DOUBLE_HORIZONTAL      0x2565 | ||||
| #define BOXDRAW_DOUBLE_DOWN_HORIZONTAL      0x2566 | ||||
| #define BOXDRAW_UP_HORIZONTAL_DOUBLE        0x2567 | ||||
| #define BOXDRAW_UP_DOUBLE_HORIZONTAL        0x2568 | ||||
| #define BOXDRAW_DOUBLE_UP_HORIZONTAL        0x2569 | ||||
| #define BOXDRAW_VERTICAL_HORIZONTAL_DOUBLE  0x256a | ||||
| #define BOXDRAW_VERTICAL_DOUBLE_HORIZONTAL  0x256b | ||||
| #define BOXDRAW_DOUBLE_VERTICAL_HORIZONTAL  0x256c | ||||
|  | ||||
| // | ||||
| // EFI Required Block Elements Code Chart | ||||
| // | ||||
| #define BLOCKELEMENT_FULL_BLOCK   0x2588 | ||||
| #define BLOCKELEMENT_LIGHT_SHADE  0x2591 | ||||
|  | ||||
| // | ||||
| // EFI Required Geometric Shapes Code Chart | ||||
| // | ||||
| #define GEOMETRICSHAPE_UP_TRIANGLE    0x25b2 | ||||
| #define GEOMETRICSHAPE_RIGHT_TRIANGLE 0x25ba | ||||
| #define GEOMETRICSHAPE_DOWN_TRIANGLE  0x25bc | ||||
| #define GEOMETRICSHAPE_LEFT_TRIANGLE  0x25c4 | ||||
|  | ||||
| // | ||||
| // EFI Required Arrow shapes | ||||
| // | ||||
| #define ARROW_LEFT  0x2190 | ||||
| #define ARROW_UP    0x2191 | ||||
| #define ARROW_RIGHT 0x2192 | ||||
| #define ARROW_DOWN  0x2193 | ||||
|  | ||||
| // | ||||
| // EFI Console Colours | ||||
| // | ||||
| #define EFI_BLACK                 0x00 | ||||
| #define EFI_BLUE                  0x01 | ||||
| #define EFI_GREEN                 0x02 | ||||
| #define EFI_CYAN                  (EFI_BLUE | EFI_GREEN) | ||||
| #define EFI_RED                   0x04 | ||||
| #define EFI_MAGENTA               (EFI_BLUE | EFI_RED) | ||||
| #define EFI_BROWN                 (EFI_GREEN | EFI_RED) | ||||
| #define EFI_LIGHTGRAY             (EFI_BLUE | EFI_GREEN | EFI_RED) | ||||
| #define EFI_BRIGHT                0x08 | ||||
| #define EFI_DARKGRAY              (EFI_BLACK | EFI_BRIGHT) | ||||
| #define EFI_LIGHTBLUE             (EFI_BLUE | EFI_BRIGHT) | ||||
| #define EFI_LIGHTGREEN            (EFI_GREEN | EFI_BRIGHT) | ||||
| #define EFI_LIGHTCYAN             (EFI_CYAN | EFI_BRIGHT) | ||||
| #define EFI_LIGHTRED              (EFI_RED | EFI_BRIGHT) | ||||
| #define EFI_LIGHTMAGENTA          (EFI_MAGENTA | EFI_BRIGHT) | ||||
| #define EFI_YELLOW                (EFI_BROWN | EFI_BRIGHT) | ||||
| #define EFI_WHITE                 (EFI_BLUE | EFI_GREEN | EFI_RED | EFI_BRIGHT) | ||||
|  | ||||
| // | ||||
| // Macro to accept color values in their raw form to create | ||||
| // a value that represents both a foreground and background | ||||
| // color in a single byte. | ||||
| // For Foreground, and EFI_* value is valid from EFI_BLACK(0x00) to | ||||
| // EFI_WHITE (0x0F). | ||||
| // For Background, only EFI_BLACK, EFI_BLUE, EFI_GREEN, EFI_CYAN, | ||||
| // EFI_RED, EFI_MAGENTA, EFI_BROWN, and EFI_LIGHTGRAY are acceptable | ||||
| // | ||||
| // Do not use EFI_BACKGROUND_xxx values with this macro. | ||||
| // | ||||
| #define EFI_TEXT_ATTR(Foreground,Background) ((Foreground) | ((Background) << 4)) | ||||
|  | ||||
| #define EFI_BACKGROUND_BLACK      0x00 | ||||
| #define EFI_BACKGROUND_BLUE       0x10 | ||||
| #define EFI_BACKGROUND_GREEN      0x20 | ||||
| #define EFI_BACKGROUND_CYAN       (EFI_BACKGROUND_BLUE | EFI_BACKGROUND_GREEN) | ||||
| #define EFI_BACKGROUND_RED        0x40 | ||||
| #define EFI_BACKGROUND_MAGENTA    (EFI_BACKGROUND_BLUE | EFI_BACKGROUND_RED) | ||||
| #define EFI_BACKGROUND_BROWN      (EFI_BACKGROUND_GREEN | EFI_BACKGROUND_RED) | ||||
| #define EFI_BACKGROUND_LIGHTGRAY  (EFI_BACKGROUND_BLUE | EFI_BACKGROUND_GREEN | EFI_BACKGROUND_RED) | ||||
|  | ||||
| // | ||||
| // We currently define attributes from 0 - 7F for color manipulations | ||||
| // To internally handle the local display characteristics for a particular character, | ||||
| // Bit 7 signifies the local glyph representation for a character.  If turned on, glyphs will be | ||||
| // pulled from the wide glyph database and will display locally as a wide character (16 X 19 versus 8 X 19) | ||||
| // If bit 7 is off, the narrow glyph database will be used.  This does NOT affect information that is sent to | ||||
| // non-local displays, such as serial or LAN consoles. | ||||
| // | ||||
| #define EFI_WIDE_ATTRIBUTE  0x80 | ||||
|  | ||||
| /** | ||||
|   Reset the text output device hardware and optionaly run diagnostics | ||||
|  | ||||
|   @param  This                 The protocol instance pointer. | ||||
|   @param  ExtendedVerification Driver may perform more exhaustive verfication | ||||
|                                operation of the device during reset. | ||||
|  | ||||
|   @retval EFI_SUCCESS          The text output device was reset. | ||||
|   @retval EFI_DEVICE_ERROR     The text output device is not functioning correctly and | ||||
|                                could not be reset. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_RESET)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN BOOLEAN                                ExtendedVerification | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Write a string to the output device. | ||||
|  | ||||
|   @param  This   The protocol instance pointer. | ||||
|   @param  String The NULL-terminated string to be displayed on the output | ||||
|                  device(s). All output devices must also support the Unicode | ||||
|                  drawing character codes defined in this file. | ||||
|  | ||||
|   @retval EFI_SUCCESS             The string was output to the device. | ||||
|   @retval EFI_DEVICE_ERROR        The device reported an error while attempting to output | ||||
|                                   the text. | ||||
|   @retval EFI_UNSUPPORTED         The output device's mode is not currently in a | ||||
|                                   defined text mode. | ||||
|   @retval EFI_WARN_UNKNOWN_GLYPH  This warning code indicates that some of the | ||||
|                                   characters in the string could not be | ||||
|                                   rendered and were skipped. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_STRING)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN CHAR16                                 *String | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Verifies that all characters in a string can be output to the | ||||
|   target device. | ||||
|  | ||||
|   @param  This   The protocol instance pointer. | ||||
|   @param  String The NULL-terminated string to be examined for the output | ||||
|                  device(s). | ||||
|  | ||||
|   @retval EFI_SUCCESS      The device(s) are capable of rendering the output string. | ||||
|   @retval EFI_UNSUPPORTED  Some of the characters in the string cannot be | ||||
|                            rendered by one or more of the output devices mapped | ||||
|                            by the EFI handle. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_TEST_STRING)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN CHAR16                                 *String | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Returns information for an available text mode that the output device(s) | ||||
|   supports. | ||||
|  | ||||
|   @param  This       The protocol instance pointer. | ||||
|   @param  ModeNumber The mode number to return information on. | ||||
|   @param  Columns    Returns the geometry of the text output device for the | ||||
|                      requested ModeNumber. | ||||
|   @param  Rows       Returns the geometry of the text output device for the | ||||
|                      requested ModeNumber. | ||||
|  | ||||
|   @retval EFI_SUCCESS      The requested mode information was returned. | ||||
|   @retval EFI_DEVICE_ERROR The device had an error and could not complete the request. | ||||
|   @retval EFI_UNSUPPORTED  The mode number was not valid. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_QUERY_MODE)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN UINTN                                  ModeNumber, | ||||
|   OUT UINTN                                 *Columns, | ||||
|   OUT UINTN                                 *Rows | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Sets the output device(s) to a specified mode. | ||||
|  | ||||
|   @param  This       The protocol instance pointer. | ||||
|   @param  ModeNumber The mode number to set. | ||||
|  | ||||
|   @retval EFI_SUCCESS      The requested text mode was set. | ||||
|   @retval EFI_DEVICE_ERROR The device had an error and could not complete the request. | ||||
|   @retval EFI_UNSUPPORTED  The mode number was not valid. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_SET_MODE)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN UINTN                                  ModeNumber | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Sets the background and foreground colors for the OutputString () and | ||||
|   ClearScreen () functions. | ||||
|  | ||||
|   @param  This      The protocol instance pointer. | ||||
|   @param  Attribute The attribute to set. Bits 0..3 are the foreground color, and | ||||
|                     bits 4..6 are the background color. All other bits are undefined | ||||
|                     and must be zero. The valid Attributes are defined in this file. | ||||
|  | ||||
|   @retval EFI_SUCCESS       The attribute was set. | ||||
|   @retval EFI_DEVICE_ERROR  The device had an error and could not complete the request. | ||||
|   @retval EFI_UNSUPPORTED   The attribute requested is not defined. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_SET_ATTRIBUTE)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN UINTN                                  Attribute | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Clears the output device(s) display to the currently selected background | ||||
|   color. | ||||
|  | ||||
|   @param  This              The protocol instance pointer. | ||||
|  | ||||
|   @retval  EFI_SUCCESS      The operation completed successfully. | ||||
|   @retval  EFI_DEVICE_ERROR The device had an error and could not complete the request. | ||||
|   @retval  EFI_UNSUPPORTED  The output device is not in a valid text mode. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_CLEAR_SCREEN)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL   *This | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Sets the current coordinates of the cursor position | ||||
|  | ||||
|   @param  This        The protocol instance pointer. | ||||
|   @param  Column      The position to set the cursor to. Must be greater than or | ||||
|                       equal to zero and less than the number of columns and rows | ||||
|                       by QueryMode (). | ||||
|   @param  Row         The position to set the cursor to. Must be greater than or | ||||
|                       equal to zero and less than the number of columns and rows | ||||
|                       by QueryMode (). | ||||
|  | ||||
|   @retval EFI_SUCCESS      The operation completed successfully. | ||||
|   @retval EFI_DEVICE_ERROR The device had an error and could not complete the request. | ||||
|   @retval EFI_UNSUPPORTED  The output device is not in a valid text mode, or the | ||||
|                            cursor position is invalid for the current mode. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_SET_CURSOR_POSITION)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN UINTN                                  Column, | ||||
|   IN UINTN                                  Row | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   Makes the cursor visible or invisible | ||||
|  | ||||
|   @param  This    The protocol instance pointer. | ||||
|   @param  Visible If TRUE, the cursor is set to be visible. If FALSE, the cursor is | ||||
|                   set to be invisible. | ||||
|  | ||||
|   @retval EFI_SUCCESS      The operation completed successfully. | ||||
|   @retval EFI_DEVICE_ERROR The device had an error and could not complete the | ||||
|                            request, or the device does not support changing | ||||
|                            the cursor mode. | ||||
|   @retval EFI_UNSUPPORTED  The output device is not in a valid text mode. | ||||
|  | ||||
| **/ | ||||
| typedef | ||||
| EFI_STATUS | ||||
| (EFIAPI *EFI_TEXT_ENABLE_CURSOR)( | ||||
|   IN EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL        *This, | ||||
|   IN BOOLEAN                                Visible | ||||
|   ); | ||||
|  | ||||
| /** | ||||
|   @par Data Structure Description: | ||||
|   Mode Structure pointed to by Simple Text Out protocol. | ||||
| **/ | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The number of modes supported by QueryMode () and SetMode (). | ||||
|   /// | ||||
|   INT32   MaxMode; | ||||
|  | ||||
|   // | ||||
|   // current settings | ||||
|   // | ||||
|  | ||||
|   /// | ||||
|   /// The text mode of the output device(s). | ||||
|   /// | ||||
|   INT32   Mode; | ||||
|   /// | ||||
|   /// The current character output attribute. | ||||
|   /// | ||||
|   INT32   Attribute; | ||||
|   /// | ||||
|   /// The cursor's column. | ||||
|   /// | ||||
|   INT32   CursorColumn; | ||||
|   /// | ||||
|   /// The cursor's row. | ||||
|   /// | ||||
|   INT32   CursorRow; | ||||
|   /// | ||||
|   /// The cursor is currently visbile or not. | ||||
|   /// | ||||
|   BOOLEAN CursorVisible; | ||||
| } EFI_SIMPLE_TEXT_OUTPUT_MODE; | ||||
|  | ||||
| /// | ||||
| /// The SIMPLE_TEXT_OUTPUT protocol is used to control text-based output devices. | ||||
| /// It is the minimum required protocol for any handle supplied as the ConsoleOut | ||||
| /// or StandardError device. In addition, the minimum supported text mode of such | ||||
| /// devices is at least 80 x 25 characters. | ||||
| /// | ||||
| struct _EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL { | ||||
|   EFI_TEXT_RESET                Reset; | ||||
|  | ||||
|   EFI_TEXT_STRING               OutputString; | ||||
|   EFI_TEXT_TEST_STRING          TestString; | ||||
|  | ||||
|   EFI_TEXT_QUERY_MODE           QueryMode; | ||||
|   EFI_TEXT_SET_MODE             SetMode; | ||||
|   EFI_TEXT_SET_ATTRIBUTE        SetAttribute; | ||||
|  | ||||
|   EFI_TEXT_CLEAR_SCREEN         ClearScreen; | ||||
|   EFI_TEXT_SET_CURSOR_POSITION  SetCursorPosition; | ||||
|   EFI_TEXT_ENABLE_CURSOR        EnableCursor; | ||||
|  | ||||
|   /// | ||||
|   /// Pointer to SIMPLE_TEXT_OUTPUT_MODE data. | ||||
|   /// | ||||
|   EFI_SIMPLE_TEXT_OUTPUT_MODE   *Mode; | ||||
| }; | ||||
|  | ||||
| extern EFI_GUID gEfiSimpleTextOutProtocolGuid; | ||||
|  | ||||
| #endif | ||||
| @@ -1,27 +0,0 @@ | ||||
| /** @file | ||||
|  | ||||
|   Root include file for Mde Package UEFI, UEFI_APPLICATION type modules. | ||||
|  | ||||
|   This is the include file for any module of type UEFI and UEFI_APPLICATION. Uefi modules only use | ||||
|   types defined via this include file and can be ported easily to any | ||||
|   environment. | ||||
|  | ||||
| Copyright (c) 2006 - 2010, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PI_UEFI_H__ | ||||
| #define __PI_UEFI_H__ | ||||
|  | ||||
| #include <Uefi/UefiBaseType.h> | ||||
| #include <Uefi/UefiSpec.h> | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @@ -1,301 +0,0 @@ | ||||
| /** @file | ||||
|   Defines data types and constants introduced in UEFI. | ||||
|  | ||||
| Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
| Portions copyright (c) 2011 - 2013, ARM Ltd. All rights reserved.<BR> | ||||
|  | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __UEFI_BASETYPE_H__ | ||||
| #define __UEFI_BASETYPE_H__ | ||||
|  | ||||
| #include <Base.h> | ||||
|  | ||||
| // | ||||
| // Basic data type definitions introduced in UEFI. | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// 128-bit buffer containing a unique identifier value. | ||||
| /// | ||||
| typedef GUID                      EFI_GUID; | ||||
| /// | ||||
| /// Function return status for EFI API. | ||||
| /// | ||||
| typedef RETURN_STATUS             EFI_STATUS; | ||||
| /// | ||||
| /// A collection of related interfaces. | ||||
| /// | ||||
| typedef VOID                      *EFI_HANDLE; | ||||
| /// | ||||
| /// Handle to an event structure. | ||||
| /// | ||||
| typedef VOID                      *EFI_EVENT; | ||||
| /// | ||||
| /// Task priority level. | ||||
| /// | ||||
| typedef UINTN                     EFI_TPL; | ||||
| /// | ||||
| /// Logical block address. | ||||
| /// | ||||
| typedef UINT64                    EFI_LBA; | ||||
|  | ||||
| /// | ||||
| /// 64-bit physical memory address. | ||||
| /// | ||||
| typedef UINT64                    EFI_PHYSICAL_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// 64-bit virtual memory address. | ||||
| /// | ||||
| typedef UINT64                    EFI_VIRTUAL_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// EFI Time Abstraction: | ||||
| ///  Year:       1900 - 9999 | ||||
| ///  Month:      1 - 12 | ||||
| ///  Day:        1 - 31 | ||||
| ///  Hour:       0 - 23 | ||||
| ///  Minute:     0 - 59 | ||||
| ///  Second:     0 - 59 | ||||
| ///  Nanosecond: 0 - 999,999,999 | ||||
| ///  TimeZone:   -1440 to 1440 or 2047 | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT16  Year; | ||||
|   UINT8   Month; | ||||
|   UINT8   Day; | ||||
|   UINT8   Hour; | ||||
|   UINT8   Minute; | ||||
|   UINT8   Second; | ||||
|   UINT8   Pad1; | ||||
|   UINT32  Nanosecond; | ||||
|   INT16   TimeZone; | ||||
|   UINT8   Daylight; | ||||
|   UINT8   Pad2; | ||||
| } EFI_TIME; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// 4-byte buffer. An IPv4 internet protocol address. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Addr[4]; | ||||
| } EFI_IPv4_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// 16-byte buffer. An IPv6 internet protocol address. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Addr[16]; | ||||
| } EFI_IPv6_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// 32-byte buffer containing a network Media Access Control address. | ||||
| /// | ||||
| typedef struct { | ||||
|   UINT8 Addr[32]; | ||||
| } EFI_MAC_ADDRESS; | ||||
|  | ||||
| /// | ||||
| /// 16-byte buffer aligned on a 4-byte boundary. | ||||
| /// An IPv4 or IPv6 internet protocol address. | ||||
| /// | ||||
| typedef union { | ||||
|   UINT32            Addr[4]; | ||||
|   EFI_IPv4_ADDRESS  v4; | ||||
|   EFI_IPv6_ADDRESS  v6; | ||||
| } EFI_IP_ADDRESS; | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// Enumeration of EFI_STATUS. | ||||
| ///@{ | ||||
| #define EFI_SUCCESS               RETURN_SUCCESS | ||||
| #define EFI_LOAD_ERROR            RETURN_LOAD_ERROR | ||||
| #define EFI_INVALID_PARAMETER     RETURN_INVALID_PARAMETER | ||||
| #define EFI_UNSUPPORTED           RETURN_UNSUPPORTED | ||||
| #define EFI_BAD_BUFFER_SIZE       RETURN_BAD_BUFFER_SIZE | ||||
| #define EFI_BUFFER_TOO_SMALL      RETURN_BUFFER_TOO_SMALL | ||||
| #define EFI_NOT_READY             RETURN_NOT_READY | ||||
| #define EFI_DEVICE_ERROR          RETURN_DEVICE_ERROR | ||||
| #define EFI_WRITE_PROTECTED       RETURN_WRITE_PROTECTED | ||||
| #define EFI_OUT_OF_RESOURCES      RETURN_OUT_OF_RESOURCES | ||||
| #define EFI_VOLUME_CORRUPTED      RETURN_VOLUME_CORRUPTED | ||||
| #define EFI_VOLUME_FULL           RETURN_VOLUME_FULL | ||||
| #define EFI_NO_MEDIA              RETURN_NO_MEDIA | ||||
| #define EFI_MEDIA_CHANGED         RETURN_MEDIA_CHANGED | ||||
| #define EFI_NOT_FOUND             RETURN_NOT_FOUND | ||||
| #define EFI_ACCESS_DENIED         RETURN_ACCESS_DENIED | ||||
| #define EFI_NO_RESPONSE           RETURN_NO_RESPONSE | ||||
| #define EFI_NO_MAPPING            RETURN_NO_MAPPING | ||||
| #define EFI_TIMEOUT               RETURN_TIMEOUT | ||||
| #define EFI_NOT_STARTED           RETURN_NOT_STARTED | ||||
| #define EFI_ALREADY_STARTED       RETURN_ALREADY_STARTED | ||||
| #define EFI_ABORTED               RETURN_ABORTED | ||||
| #define EFI_ICMP_ERROR            RETURN_ICMP_ERROR | ||||
| #define EFI_TFTP_ERROR            RETURN_TFTP_ERROR | ||||
| #define EFI_PROTOCOL_ERROR        RETURN_PROTOCOL_ERROR | ||||
| #define EFI_INCOMPATIBLE_VERSION  RETURN_INCOMPATIBLE_VERSION | ||||
| #define EFI_SECURITY_VIOLATION    RETURN_SECURITY_VIOLATION | ||||
| #define EFI_CRC_ERROR             RETURN_CRC_ERROR | ||||
| #define EFI_END_OF_MEDIA          RETURN_END_OF_MEDIA | ||||
| #define EFI_END_OF_FILE           RETURN_END_OF_FILE | ||||
| #define EFI_INVALID_LANGUAGE      RETURN_INVALID_LANGUAGE | ||||
| #define EFI_COMPROMISED_DATA      RETURN_COMPROMISED_DATA | ||||
|  | ||||
| #define EFI_WARN_UNKNOWN_GLYPH    RETURN_WARN_UNKNOWN_GLYPH | ||||
| #define EFI_WARN_DELETE_FAILURE   RETURN_WARN_DELETE_FAILURE | ||||
| #define EFI_WARN_WRITE_FAILURE    RETURN_WARN_WRITE_FAILURE | ||||
| #define EFI_WARN_BUFFER_TOO_SMALL RETURN_WARN_BUFFER_TOO_SMALL | ||||
| #define EFI_WARN_STALE_DATA       RETURN_WARN_STALE_DATA | ||||
| ///@} | ||||
|  | ||||
| /// | ||||
| /// Define macro to encode the status code. | ||||
| /// | ||||
| #define EFIERR(_a)                ENCODE_ERROR(_a) | ||||
|  | ||||
| #define EFI_ERROR(A)              RETURN_ERROR(A) | ||||
|  | ||||
| /// | ||||
| /// ICMP error definitions | ||||
| ///@{ | ||||
| #define EFI_NETWORK_UNREACHABLE   EFIERR(100) | ||||
| #define EFI_HOST_UNREACHABLE      EFIERR(101) | ||||
| #define EFI_PROTOCOL_UNREACHABLE  EFIERR(102) | ||||
| #define EFI_PORT_UNREACHABLE      EFIERR(103) | ||||
| ///@} | ||||
|  | ||||
| /// | ||||
| /// Tcp connection status definitions | ||||
| ///@{ | ||||
| #define EFI_CONNECTION_FIN        EFIERR(104) | ||||
| #define EFI_CONNECTION_RESET      EFIERR(105) | ||||
| #define EFI_CONNECTION_REFUSED    EFIERR(106) | ||||
| ///@} | ||||
|  | ||||
| // | ||||
| // The EFI memory allocation functions work in units of EFI_PAGEs that are | ||||
| // 4KB. This should in no way be confused with the page size of the processor. | ||||
| // An EFI_PAGE is just the quanta of memory in EFI. | ||||
| // | ||||
| #define EFI_PAGE_SIZE             SIZE_4KB | ||||
| #define EFI_PAGE_MASK             0xFFF | ||||
| #define EFI_PAGE_SHIFT            12 | ||||
|  | ||||
| /** | ||||
|   Macro that converts a size, in bytes, to a number of EFI_PAGESs. | ||||
|  | ||||
|   @param  Size      A size in bytes.  This parameter is assumed to be type UINTN. | ||||
|                     Passing in a parameter that is larger than UINTN may produce | ||||
|                     unexpected results. | ||||
|  | ||||
|   @return  The number of EFI_PAGESs associated with the number of bytes specified | ||||
|            by Size. | ||||
|  | ||||
| **/ | ||||
| #define EFI_SIZE_TO_PAGES(Size)  (((Size) >> EFI_PAGE_SHIFT) + (((Size) & EFI_PAGE_MASK) ? 1 : 0)) | ||||
|  | ||||
| /** | ||||
|   Macro that converts a number of EFI_PAGEs to a size in bytes. | ||||
|  | ||||
|   @param  Pages     The number of EFI_PAGES.  This parameter is assumed to be | ||||
|                     type UINTN.  Passing in a parameter that is larger than | ||||
|                     UINTN may produce unexpected results. | ||||
|  | ||||
|   @return  The number of bytes associated with the number of EFI_PAGEs specified | ||||
|            by Pages. | ||||
|  | ||||
| **/ | ||||
| #define EFI_PAGES_TO_SIZE(Pages)  ((Pages) << EFI_PAGE_SHIFT) | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for IA32 UEFI images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_IA32            0x014C | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for IA64 UEFI images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_IA64            0x0200 | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for EBC UEFI images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_EBC             0x0EBC | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for X64 UEFI images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_X64             0x8664 | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for ARM mixed ARM and Thumb/Thumb2 images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_ARMTHUMB_MIXED  0x01C2 | ||||
|  | ||||
| /// | ||||
| /// PE32+ Machine type for AARCH64 A64 images. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_AARCH64  0xAA64 | ||||
|  | ||||
|  | ||||
| #if   defined (MDE_CPU_IA32) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) \ | ||||
|   (((Machine) == EFI_IMAGE_MACHINE_IA32) || ((Machine) == EFI_IMAGE_MACHINE_EBC)) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) ((Machine) == EFI_IMAGE_MACHINE_X64) | ||||
|  | ||||
| #elif defined (MDE_CPU_IPF) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) \ | ||||
|   (((Machine) == EFI_IMAGE_MACHINE_IA64) || ((Machine) == EFI_IMAGE_MACHINE_EBC)) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) (FALSE) | ||||
|  | ||||
| #elif defined (MDE_CPU_X64) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) \ | ||||
|   (((Machine) == EFI_IMAGE_MACHINE_X64) || ((Machine) == EFI_IMAGE_MACHINE_EBC)) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) ((Machine) == EFI_IMAGE_MACHINE_IA32) | ||||
|  | ||||
| #elif defined (MDE_CPU_ARM) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) \ | ||||
|   (((Machine) == EFI_IMAGE_MACHINE_ARMTHUMB_MIXED) || ((Machine) == EFI_IMAGE_MACHINE_EBC)) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) ((Machine) == EFI_IMAGE_MACHINE_ARMTHUMB_MIXED) | ||||
|  | ||||
| #elif defined (MDE_CPU_AARCH64) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) \ | ||||
|   (((Machine) == EFI_IMAGE_MACHINE_AARCH64) || ((Machine) == EFI_IMAGE_MACHINE_EBC)) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) (FALSE) | ||||
|  | ||||
| #elif defined (MDE_CPU_EBC) | ||||
|  | ||||
| /// | ||||
| /// This is just to make sure you can cross compile with the EBC compiler. | ||||
| /// It does not make sense to have a PE loader coded in EBC. | ||||
| /// | ||||
| #define EFI_IMAGE_MACHINE_TYPE_SUPPORTED(Machine) ((Machine) == EFI_IMAGE_MACHINE_EBC) | ||||
|  | ||||
| #define EFI_IMAGE_MACHINE_CROSS_TYPE_SUPPORTED(Machine) (FALSE) | ||||
|  | ||||
| #else | ||||
| #error Unknown Processor Type | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
| @@ -1,141 +0,0 @@ | ||||
| /** @file | ||||
|   EFI Guid Partition Table Format Definition. | ||||
|  | ||||
| Copyright (c) 2006 - 2011, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __UEFI_GPT_H__ | ||||
| #define __UEFI_GPT_H__ | ||||
|  | ||||
| /// | ||||
| /// The primary GUID Partition Table Header must be | ||||
| /// located in LBA 1 (i.e., the second logical block). | ||||
| /// | ||||
| #define PRIMARY_PART_HEADER_LBA 1 | ||||
| /// | ||||
| /// EFI Partition Table Signature: "EFI PART". | ||||
| /// | ||||
| #define EFI_PTAB_HEADER_ID      SIGNATURE_64 ('E','F','I',' ','P','A','R','T') | ||||
|  | ||||
| #pragma pack(1) | ||||
|  | ||||
| /// | ||||
| /// GPT Partition Table Header. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// The table header for the GPT partition Table. | ||||
|   /// This header contains EFI_PTAB_HEADER_ID. | ||||
|   /// | ||||
|   EFI_TABLE_HEADER  Header; | ||||
|   /// | ||||
|   /// The LBA that contains this data structure. | ||||
|   /// | ||||
|   EFI_LBA           MyLBA; | ||||
|   /// | ||||
|   /// LBA address of the alternate GUID Partition Table Header. | ||||
|   /// | ||||
|   EFI_LBA           AlternateLBA; | ||||
|   /// | ||||
|   /// The first usable logical block that may be used | ||||
|   /// by a partition described by a GUID Partition Entry. | ||||
|   /// | ||||
|   EFI_LBA           FirstUsableLBA; | ||||
|   /// | ||||
|   /// The last usable logical block that may be used | ||||
|   /// by a partition described by a GUID Partition Entry. | ||||
|   /// | ||||
|   EFI_LBA           LastUsableLBA; | ||||
|   /// | ||||
|   /// GUID that can be used to uniquely identify the disk. | ||||
|   /// | ||||
|   EFI_GUID          DiskGUID; | ||||
|   /// | ||||
|   /// The starting LBA of the GUID Partition Entry array. | ||||
|   /// | ||||
|   EFI_LBA           PartitionEntryLBA; | ||||
|   /// | ||||
|   /// The number of Partition Entries in the GUID Partition Entry array. | ||||
|   /// | ||||
|   UINT32            NumberOfPartitionEntries; | ||||
|   /// | ||||
|   /// The size, in bytes, of each the GUID Partition | ||||
|   /// Entry structures in the GUID Partition Entry | ||||
|   /// array. This field shall be set to a value of 128 x 2^n where n is | ||||
|   /// an integer greater than or equal to zero (e.g., 128, 256, 512, etc.). | ||||
|   /// | ||||
|   UINT32            SizeOfPartitionEntry; | ||||
|   /// | ||||
|   /// The CRC32 of the GUID Partition Entry array. | ||||
|   /// Starts at PartitionEntryLBA and is | ||||
|   /// computed over a byte length of | ||||
|   /// NumberOfPartitionEntries * SizeOfPartitionEntry. | ||||
|   /// | ||||
|   UINT32            PartitionEntryArrayCRC32; | ||||
| } EFI_PARTITION_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// GPT Partition Entry. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Unique ID that defines the purpose and type of this Partition. A value of | ||||
|   /// zero defines that this partition entry is not being used. | ||||
|   /// | ||||
|   EFI_GUID  PartitionTypeGUID; | ||||
|   /// | ||||
|   /// GUID that is unique for every partition entry. Every partition ever | ||||
|   /// created will have a unique GUID. | ||||
|   /// This GUID must be assigned when the GUID Partition Entry is created. | ||||
|   /// | ||||
|   EFI_GUID  UniquePartitionGUID; | ||||
|   /// | ||||
|   /// Starting LBA of the partition defined by this entry | ||||
|   /// | ||||
|   EFI_LBA   StartingLBA; | ||||
|   /// | ||||
|   /// Ending LBA of the partition defined by this entry. | ||||
|   /// | ||||
|   EFI_LBA   EndingLBA; | ||||
|   /// | ||||
|   /// Attribute bits, all bits reserved by UEFI | ||||
|   /// Bit 0:      If this bit is set, the partition is required for the platform to function. The owner/creator of the | ||||
|   ///             partition indicates that deletion or modification of the contents can result in loss of platform | ||||
|   ///             features or failure for the platform to boot or operate. The system cannot function normally if | ||||
|   ///             this partition is removed, and it should be considered part of the hardware of the system. | ||||
|   ///             Actions such as running diagnostics, system recovery, or even OS install or boot, could | ||||
|   ///             potentially stop working if this partition is removed. Unless OS software or firmware | ||||
|   ///             recognizes this partition, it should never be removed or modified as the UEFI firmware or | ||||
|   ///             platform hardware may become non-functional. | ||||
|   /// Bit 1:      If this bit is set, then firmware must not produce an EFI_BLOCK_IO_PROTOCOL device for | ||||
|   ///             this partition. By not producing an EFI_BLOCK_IO_PROTOCOL partition, file system | ||||
|   ///             mappings will not be created for this partition in UEFI. | ||||
|   /// Bit 2:      This bit is set aside to let systems with traditional PC-AT BIOS firmware implementations | ||||
|   ///             inform certain limited, special-purpose software running on these systems that a GPT | ||||
|   ///             partition may be bootable. The UEFI boot manager must ignore this bit when selecting | ||||
|   ///             a UEFI-compliant application, e.g., an OS loader. | ||||
|   /// Bits 3-47:  Undefined and must be zero. Reserved for expansion by future versions of the UEFI | ||||
|   ///             specification. | ||||
|   /// Bits 48-63: Reserved for GUID specific use. The use of these bits will vary depending on the | ||||
|   ///             PartitionTypeGUID. Only the owner of the PartitionTypeGUID is allowed | ||||
|   ///             to modify these bits. They must be preserved if Bits 0-47 are modified.. | ||||
|   /// | ||||
|   UINT64    Attributes; | ||||
|   /// | ||||
|   /// Null-terminated name of the partition. | ||||
|   /// | ||||
|   CHAR16    PartitionName[36]; | ||||
| } EFI_PARTITION_ENTRY; | ||||
|  | ||||
| #pragma pack() | ||||
| #endif | ||||
|  | ||||
|  | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,231 +0,0 @@ | ||||
| /** @file | ||||
|   This includes some definitions introduced in UEFI that will be used in both PEI and DXE phases. | ||||
|  | ||||
| Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
| This file and the accompanying materials are licensed and made available under are licensed and made available under | ||||
| the terms and conditions of the BSD License. | ||||
| The full text of the license may be found at | ||||
| http://opensource.org/licenses/bsd-license.php. | ||||
|  | ||||
| THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __UEFI_MULTIPHASE_H__ | ||||
| #define __UEFI_MULTIPHASE_H__ | ||||
|  | ||||
| #include <Guid/WinCertificate.h> | ||||
| /// | ||||
| /// Enumeration of memory types introduced in UEFI. | ||||
| /// | ||||
| typedef enum { | ||||
|   /// | ||||
|   /// Not used. | ||||
|   /// | ||||
|   EfiReservedMemoryType, | ||||
|   /// | ||||
|   /// The code portions of a loaded application. | ||||
|   /// (Note that UEFI OS loaders are UEFI applications.) | ||||
|   /// | ||||
|   EfiLoaderCode, | ||||
|   /// | ||||
|   /// The data portions of a loaded application and the default data allocation | ||||
|   /// type used by an application to allocate pool memory. | ||||
|   /// | ||||
|   EfiLoaderData, | ||||
|   /// | ||||
|   /// The code portions of a loaded Boot Services Driver. | ||||
|   /// | ||||
|   EfiBootServicesCode, | ||||
|   /// | ||||
|   /// The data portions of a loaded Boot Serves Driver, and the default data | ||||
|   /// allocation type used by a Boot Services Driver to allocate pool memory. | ||||
|   /// | ||||
|   EfiBootServicesData, | ||||
|   /// | ||||
|   /// The code portions of a loaded Runtime Services Driver. | ||||
|   /// | ||||
|   EfiRuntimeServicesCode, | ||||
|   /// | ||||
|   /// The data portions of a loaded Runtime Services Driver and the default | ||||
|   /// data allocation type used by a Runtime Services Driver to allocate pool memory. | ||||
|   /// | ||||
|   EfiRuntimeServicesData, | ||||
|   /// | ||||
|   /// Free (unallocated) memory. | ||||
|   /// | ||||
|   EfiConventionalMemory, | ||||
|   /// | ||||
|   /// Memory in which errors have been detected. | ||||
|   /// | ||||
|   EfiUnusableMemory, | ||||
|   /// | ||||
|   /// Memory that holds the ACPI tables. | ||||
|   /// | ||||
|   EfiACPIReclaimMemory, | ||||
|   /// | ||||
|   /// Address space reserved for use by the firmware. | ||||
|   /// | ||||
|   EfiACPIMemoryNVS, | ||||
|   /// | ||||
|   /// Used by system firmware to request that a memory-mapped IO region | ||||
|   /// be mapped by the OS to a virtual address so it can be accessed by EFI runtime services. | ||||
|   /// | ||||
|   EfiMemoryMappedIO, | ||||
|   /// | ||||
|   /// System memory-mapped IO region that is used to translate memory | ||||
|   /// cycles to IO cycles by the processor. | ||||
|   /// | ||||
|   EfiMemoryMappedIOPortSpace, | ||||
|   /// | ||||
|   /// Address space reserved by the firmware for code that is part of the processor. | ||||
|   /// | ||||
|   EfiPalCode, | ||||
|   /// | ||||
|   /// A memory region that operates as EfiConventionalMemory, | ||||
|   /// however it happens to also support byte-addressable non-volatility. | ||||
|   /// | ||||
|   EfiPersistentMemory, | ||||
|   EfiMaxMemoryType | ||||
| } EFI_MEMORY_TYPE; | ||||
|  | ||||
| /// | ||||
| /// Enumeration of reset types. | ||||
| /// | ||||
| typedef enum { | ||||
|   /// | ||||
|   /// Used to induce a system-wide reset. This sets all circuitry within the | ||||
|   /// system to its initial state.  This type of reset is asynchronous to system | ||||
|   /// operation and operates withgout regard to cycle boundaries.  EfiColdReset | ||||
|   /// is tantamount to a system power cycle. | ||||
|   /// | ||||
|   EfiResetCold, | ||||
|   /// | ||||
|   /// Used to induce a system-wide initialization. The processors are set to their | ||||
|   /// initial state, and pending cycles are not corrupted.  If the system does | ||||
|   /// not support this reset type, then an EfiResetCold must be performed. | ||||
|   /// | ||||
|   EfiResetWarm, | ||||
|   /// | ||||
|   /// Used to induce an entry into a power state equivalent to the ACPI G2/S5 or G3 | ||||
|   /// state.  If the system does not support this reset type, then when the system | ||||
|   /// is rebooted, it should exhibit the EfiResetCold attributes. | ||||
|   /// | ||||
|   EfiResetShutdown, | ||||
|   /// | ||||
|   /// Used to induce a system-wide reset. The exact type of the reset is defined by | ||||
|   /// the EFI_GUID that follows the Null-terminated Unicode string passed into | ||||
|   /// ResetData. If the platform does not recognize the EFI_GUID in ResetData the | ||||
|   /// platform must pick a supported reset type to perform. The platform may | ||||
|   /// optionally log the parameters from any non-normal reset that occurs. | ||||
|   /// | ||||
|   EfiResetPlatformSpecific | ||||
| } EFI_RESET_TYPE; | ||||
|  | ||||
| /// | ||||
| /// Data structure that precedes all of the standard EFI table types. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// A 64-bit signature that identifies the type of table that follows. | ||||
|   /// Unique signatures have been generated for the EFI System Table, | ||||
|   /// the EFI Boot Services Table, and the EFI Runtime Services Table. | ||||
|   /// | ||||
|   UINT64  Signature; | ||||
|   /// | ||||
|   /// The revision of the EFI Specification to which this table | ||||
|   /// conforms. The upper 16 bits of this field contain the major | ||||
|   /// revision value, and the lower 16 bits contain the minor revision | ||||
|   /// value. The minor revision values are limited to the range of 00..99. | ||||
|   /// | ||||
|   UINT32  Revision; | ||||
|   /// | ||||
|   /// The size, in bytes, of the entire table including the EFI_TABLE_HEADER. | ||||
|   /// | ||||
|   UINT32  HeaderSize; | ||||
|   /// | ||||
|   /// The 32-bit CRC for the entire table. This value is computed by | ||||
|   /// setting this field to 0, and computing the 32-bit CRC for HeaderSize bytes. | ||||
|   /// | ||||
|   UINT32  CRC32; | ||||
|   /// | ||||
|   /// Reserved field that must be set to 0. | ||||
|   /// | ||||
|   UINT32  Reserved; | ||||
| } EFI_TABLE_HEADER; | ||||
|  | ||||
| /// | ||||
| /// Attributes of variable. | ||||
| /// | ||||
| #define EFI_VARIABLE_NON_VOLATILE                            0x00000001 | ||||
| #define EFI_VARIABLE_BOOTSERVICE_ACCESS                      0x00000002 | ||||
| #define EFI_VARIABLE_RUNTIME_ACCESS                          0x00000004 | ||||
| /// | ||||
| /// This attribute is identified by the mnemonic 'HR' | ||||
| /// elsewhere in this specification. | ||||
| /// | ||||
| #define EFI_VARIABLE_HARDWARE_ERROR_RECORD                   0x00000008 | ||||
| /// | ||||
| /// Attributes of Authenticated Variable | ||||
| /// | ||||
| #define EFI_VARIABLE_AUTHENTICATED_WRITE_ACCESS              0x00000010 | ||||
| #define EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS   0x00000020 | ||||
| #define EFI_VARIABLE_APPEND_WRITE                            0x00000040 | ||||
|  | ||||
|  | ||||
| /// | ||||
| /// AuthInfo is a WIN_CERTIFICATE using the wCertificateType | ||||
| /// WIN_CERTIFICATE_UEFI_GUID and the CertType | ||||
| /// EFI_CERT_TYPE_RSA2048_SHA256_GUID. If the attribute specifies | ||||
| /// authenticated access, then the Data buffer should begin with an | ||||
| /// authentication descriptor prior to the data payload and DataSize | ||||
| /// should reflect the data.and descriptor size. The caller | ||||
| /// shall digest the Monotonic Count value and the associated data | ||||
| /// for the variable update using the SHA-256 1-way hash algorithm. | ||||
| /// The ensuing the 32-byte digest will be signed using the private | ||||
| /// key associated w/ the public/private 2048-bit RSA key-pair. The | ||||
| /// WIN_CERTIFICATE shall be used to describe the signature of the | ||||
| /// Variable data *Data. In addition, the signature will also | ||||
| /// include the MonotonicCount value to guard against replay attacks. | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// Included in the signature of | ||||
|   /// AuthInfo.Used to ensure freshness/no | ||||
|   /// replay. Incremented during each | ||||
|   /// "Write" access. | ||||
|   /// | ||||
|   UINT64                      MonotonicCount; | ||||
|   /// | ||||
|   /// Provides the authorization for the variable | ||||
|   /// access. It is a signature across the | ||||
|   /// variable data and the  Monotonic Count | ||||
|   /// value. Caller uses Private key that is | ||||
|   /// associated with a public key that has been | ||||
|   /// provisioned via the key exchange. | ||||
|   /// | ||||
|   WIN_CERTIFICATE_UEFI_GUID   AuthInfo; | ||||
| } EFI_VARIABLE_AUTHENTICATION; | ||||
|  | ||||
| /// | ||||
| /// When the attribute EFI_VARIABLE_TIME_BASED_AUTHENTICATED_WRITE_ACCESS is | ||||
| /// set, then the Data buffer shall begin with an instance of a complete (and serialized) | ||||
| /// EFI_VARIABLE_AUTHENTICATION_2 descriptor. The descriptor shall be followed by the new | ||||
| /// variable value and DataSize shall reflect the combined size of the descriptor and the new | ||||
| /// variable value. The authentication descriptor is not part of the variable data and is not | ||||
| /// returned by subsequent calls to GetVariable(). | ||||
| /// | ||||
| typedef struct { | ||||
|   /// | ||||
|   /// For the TimeStamp value, components Pad1, Nanosecond, TimeZone, Daylight and | ||||
|   /// Pad2 shall be set to 0. This means that the time shall always be expressed in GMT. | ||||
|   /// | ||||
|   EFI_TIME                    TimeStamp; | ||||
|   /// | ||||
|   /// Only a CertType of  EFI_CERT_TYPE_PKCS7_GUID is accepted. | ||||
|   /// | ||||
|   WIN_CERTIFICATE_UEFI_GUID   AuthInfo; | ||||
|  } EFI_VARIABLE_AUTHENTICATION_2; | ||||
|  | ||||
| #endif | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,318 +0,0 @@ | ||||
| /** @file | ||||
|   Processor or Compiler specific defines and types x64 (Intel 64, AMD64). | ||||
|  | ||||
|   Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> | ||||
|   This file and the accompanying materials are licensed and made available under | ||||
|   the terms and conditions of the BSD License. | ||||
|   The full text of the license may be found at | ||||
|   http://opensource.org/licenses/bsd-license.php | ||||
|  | ||||
|   THIS FILE IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | ||||
|   WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #ifndef __PROCESSOR_BIND_H__ | ||||
| #define __PROCESSOR_BIND_H__ | ||||
|  | ||||
| /// | ||||
| /// Define the processor type so other code can make processor based choices | ||||
| /// | ||||
| #define MDE_CPU_X64 | ||||
|  | ||||
| // | ||||
| // Make sure we are using the correct packing rules per EFI specification | ||||
| // | ||||
| #if !defined(__GNUC__) | ||||
| #pragma pack() | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(__INTEL_COMPILER) | ||||
| // | ||||
| // Disable ICC's remark #869: "Parameter" was never referenced warning. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with -Wall | ||||
| // | ||||
| #pragma warning ( disable : 869 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #1418: external function definition with no prior declaration. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 1418 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #1419: external declaration in primary source file | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 1419 ) | ||||
|  | ||||
| // | ||||
| // Disable ICC's remark #593: "Variable" was set but never used. | ||||
| // This is legal ANSI C code so we disable the remark that is turned on with /W4 | ||||
| // | ||||
| #pragma warning ( disable : 593 ) | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(_MSC_EXTENSIONS) | ||||
|  | ||||
| // | ||||
| // Disable warning that make it impossible to compile at /W4 | ||||
| // This only works for Microsoft* tools | ||||
| // | ||||
|  | ||||
| // | ||||
| // Disabling bitfield type checking warnings. | ||||
| // | ||||
| #pragma warning ( disable : 4214 ) | ||||
|  | ||||
| // | ||||
| // Disabling the unreferenced formal parameter warnings. | ||||
| // | ||||
| #pragma warning ( disable : 4100 ) | ||||
|  | ||||
| // | ||||
| // Disable slightly different base types warning as CHAR8 * can not be set | ||||
| // to a constant string. | ||||
| // | ||||
| #pragma warning ( disable : 4057 ) | ||||
|  | ||||
| // | ||||
| // ASSERT(FALSE) or while (TRUE) are legal constructes so supress this warning | ||||
| // | ||||
| #pragma warning ( disable : 4127 ) | ||||
|  | ||||
| // | ||||
| // This warning is caused by functions defined but not used. For precompiled header only. | ||||
| // | ||||
| #pragma warning ( disable : 4505 ) | ||||
|  | ||||
| // | ||||
| // This warning is caused by empty (after preprocessing) source file. For precompiled header only. | ||||
| // | ||||
| #pragma warning ( disable : 4206 ) | ||||
|  | ||||
| #if _MSC_VER == 1800 || _MSC_VER == 1900 | ||||
|  | ||||
| // | ||||
| // Disable these warnings for VS2013. | ||||
| // | ||||
|  | ||||
| // | ||||
| // This warning is for potentially uninitialized local variable, and it may cause false | ||||
| // positive issues in VS2013 and VS2015 build | ||||
| // | ||||
| #pragma warning ( disable : 4701 ) | ||||
|  | ||||
| // | ||||
| // This warning is for potentially uninitialized local pointer variable, and it may cause | ||||
| // false positive issues in VS2013 and VS2015 build | ||||
| // | ||||
| #pragma warning ( disable : 4703 ) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #if defined(_MSC_EXTENSIONS) | ||||
|   // | ||||
|   // use Microsoft C complier dependent integer width types | ||||
|   // | ||||
|  | ||||
|   /// | ||||
|   /// 8-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned __int64    UINT64; | ||||
|   /// | ||||
|   /// 8-byte signed value | ||||
|   /// | ||||
|   typedef __int64             INT64; | ||||
|   /// | ||||
|   /// 4-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned __int32    UINT32; | ||||
|   /// | ||||
|   /// 4-byte signed value | ||||
|   /// | ||||
|   typedef __int32             INT32; | ||||
|   /// | ||||
|   /// 2-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned short      UINT16; | ||||
|   /// | ||||
|   /// 2-byte Character.  Unless otherwise specified all strings are stored in the | ||||
|   /// UTF-16 encoding format as defined by Unicode 2.1 and ISO/IEC 10646 standards. | ||||
|   /// | ||||
|   typedef unsigned short      CHAR16; | ||||
|   /// | ||||
|   /// 2-byte signed value | ||||
|   /// | ||||
|   typedef short               INT16; | ||||
|   /// | ||||
|   /// Logical Boolean.  1-byte value containing 0 for FALSE or a 1 for TRUE.  Other | ||||
|   /// values are undefined. | ||||
|   /// | ||||
|   typedef unsigned char       BOOLEAN; | ||||
|   /// | ||||
|   /// 1-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned char       UINT8; | ||||
|   /// | ||||
|   /// 1-byte Character | ||||
|   /// | ||||
|   typedef char                CHAR8; | ||||
|   /// | ||||
|   /// 1-byte signed value | ||||
|   /// | ||||
|   typedef signed char         INT8; | ||||
| #else | ||||
|   /// | ||||
|   /// 8-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned long long  UINT64; | ||||
|   /// | ||||
|   /// 8-byte signed value | ||||
|   /// | ||||
|   typedef long long           INT64; | ||||
|   /// | ||||
|   /// 4-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned int        UINT32; | ||||
|   /// | ||||
|   /// 4-byte signed value | ||||
|   /// | ||||
|   typedef int                 INT32; | ||||
|   /// | ||||
|   /// 2-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned short      UINT16; | ||||
|   /// | ||||
|   /// 2-byte Character.  Unless otherwise specified all strings are stored in the | ||||
|   /// UTF-16 encoding format as defined by Unicode 2.1 and ISO/IEC 10646 standards. | ||||
|   /// | ||||
|   typedef unsigned short      CHAR16; | ||||
|   /// | ||||
|   /// 2-byte signed value | ||||
|   /// | ||||
|   typedef short               INT16; | ||||
|   /// | ||||
|   /// Logical Boolean.  1-byte value containing 0 for FALSE or a 1 for TRUE.  Other | ||||
|   /// values are undefined. | ||||
|   /// | ||||
|   typedef unsigned char       BOOLEAN; | ||||
|   /// | ||||
|   /// 1-byte unsigned value | ||||
|   /// | ||||
|   typedef unsigned char       UINT8; | ||||
|   /// | ||||
|   /// 1-byte Character | ||||
|   /// | ||||
|   typedef char                CHAR8; | ||||
|   /// | ||||
|   /// 1-byte signed value | ||||
|   /// | ||||
|   typedef signed char         INT8; | ||||
| #endif | ||||
|  | ||||
| /// | ||||
| /// Unsigned value of native width.  (4 bytes on supported 32-bit processor instructions, | ||||
| /// 8 bytes on supported 64-bit processor instructions) | ||||
| /// | ||||
| typedef UINT64  UINTN; | ||||
| /// | ||||
| /// Signed value of native width.  (4 bytes on supported 32-bit processor instructions, | ||||
| /// 8 bytes on supported 64-bit processor instructions) | ||||
| /// | ||||
| typedef INT64   INTN; | ||||
|  | ||||
|  | ||||
| // | ||||
| // Processor specific defines | ||||
| // | ||||
|  | ||||
| /// | ||||
| /// A value of native width with the highest bit set. | ||||
| /// | ||||
| #define MAX_BIT     0x8000000000000000ULL | ||||
| /// | ||||
| /// A value of native width with the two highest bits set. | ||||
| /// | ||||
| #define MAX_2_BITS  0xC000000000000000ULL | ||||
|  | ||||
| /// | ||||
| /// Maximum legal x64 address | ||||
| /// | ||||
| #define MAX_ADDRESS   0xFFFFFFFFFFFFFFFFULL | ||||
|  | ||||
| /// | ||||
| /// Maximum legal x64 INTN and UINTN values. | ||||
| /// | ||||
| #define MAX_INTN   ((INTN)0x7FFFFFFFFFFFFFFFULL) | ||||
| #define MAX_UINTN  ((UINTN)0xFFFFFFFFFFFFFFFFULL) | ||||
|  | ||||
| /// | ||||
| /// The stack alignment required for x64 | ||||
| /// | ||||
| #define CPU_STACK_ALIGNMENT   16 | ||||
|  | ||||
| // | ||||
| // Modifier to ensure that all protocol member functions and EFI intrinsics | ||||
| // use the correct C calling convention. All protocol member functions and | ||||
| // EFI intrinsics are required to modify their member functions with EFIAPI. | ||||
| // | ||||
| #ifdef EFIAPI | ||||
|   /// | ||||
|   /// If EFIAPI is already defined, then we use that definition. | ||||
|   /// | ||||
| #elif defined(_MSC_EXTENSIONS) | ||||
|   /// | ||||
|   /// Microsoft* compiler specific method for EFIAPI calling convention. | ||||
|   /// | ||||
|   #define EFIAPI __cdecl | ||||
| #elif defined(__GNUC__) | ||||
|   /// | ||||
|   /// Define the standard calling convention regardless of optimization level. | ||||
|   /// The GCC support assumes a GCC compiler that supports the EFI ABI. The EFI | ||||
|   /// ABI is much closer to the x64 Microsoft* ABI than standard x64 (x86-64) | ||||
|   /// GCC ABI. Thus a standard x64 (x86-64) GCC compiler can not be used for | ||||
|   /// x64. Warning the assembly code in the MDE x64 does not follow the correct | ||||
|   /// ABI for the standard x64 (x86-64) GCC. | ||||
|   /// | ||||
|   #define EFIAPI | ||||
| #else | ||||
|   /// | ||||
|   /// The default for a non Microsoft* or GCC compiler is to assume the EFI ABI | ||||
|   /// is the standard. | ||||
|   /// | ||||
|   #define EFIAPI | ||||
| #endif | ||||
|  | ||||
| #if defined(__GNUC__) | ||||
|   /// | ||||
|   /// For GNU assembly code, .global or .globl can declare global symbols. | ||||
|   /// Define this macro to unify the usage. | ||||
|   /// | ||||
|   #define ASM_GLOBAL .globl | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   Return the pointer to the first instruction of a function given a function pointer. | ||||
|   On x64 CPU architectures, these two pointer values are the same, | ||||
|   so the implementation of this macro is very simple. | ||||
|  | ||||
|   @param  FunctionPointer   A pointer to a function. | ||||
|  | ||||
|   @return The pointer to the first instruction of a function given a function pointer. | ||||
|  | ||||
| **/ | ||||
| #define FUNCTION_ENTRY_POINT(FunctionPointer) (VOID *)(UINTN)(FunctionPointer) | ||||
|  | ||||
| #ifndef __USER_LABEL_PREFIX__ | ||||
| #define __USER_LABEL_PREFIX__ | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
		Reference in New Issue
	
	Block a user