mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-26 02:57:14 +00:00 
			
		
		
		
	 8778ee616a
			
		
	
	
		8778ee616a
		
	
	
	
	
		
			
			Signed-off-by: Zhiguang Liu <zhiguang.liu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
		
			
				
	
	
		
			323 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			323 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
|   Processor or Compiler specific defines and types for IA-32 architecture.
 | |
| 
 | |
| Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
 | |
| SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| 
 | |
| **/
 | |
| 
 | |
| #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 constructs so suppress 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 defined(_MSC_VER) && _MSC_VER >= 1800
 | |
| 
 | |
| //
 | |
| // 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 compiler 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 usable address at boot time
 | |
| ///
 | |
| #define MAX_ALLOC_ADDRESS   MAX_ADDRESS
 | |
| 
 | |
| ///
 | |
| /// Maximum legal IA-32 INTN and UINTN values.
 | |
| ///
 | |
| #define MAX_INTN   ((INTN)0x7FFFFFFF)
 | |
| #define MAX_UINTN  ((UINTN)0xFFFFFFFF)
 | |
| 
 | |
| ///
 | |
| /// Minimum legal IA-32 INTN value.
 | |
| ///
 | |
| #define MIN_INTN   (((INTN)-2147483647) - 1)
 | |
| 
 | |
| ///
 | |
| /// The stack alignment required for IA-32.
 | |
| ///
 | |
| #define CPU_STACK_ALIGNMENT   sizeof(UINTN)
 | |
| 
 | |
| ///
 | |
| /// Page allocation granularity for IA-32.
 | |
| ///
 | |
| #define DEFAULT_PAGE_ALLOCATION_GRANULARITY   (0x1000)
 | |
| #define RUNTIME_PAGE_ALLOCATION_GRANULARITY   (0x1000)
 | |
| 
 | |
| //
 | |
| // 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__) || defined(__clang__)
 | |
|   ///
 | |
|   /// 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__) || defined(__clang__)
 | |
|   ///
 | |
|   /// 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
 | |
| 
 |