Data Structures | |
struct | EFI_PLABEL |
struct | PAL_CALL_RETURN |
Defines | |
#define | MDE_CPU_IPF |
#define | MAX_BIT 0x8000000000000000ULL |
#define | MAX_2_BITS 0xC000000000000000ULL |
#define | MAX_ADDRESS 0xFFFFFFFFFFFFFFFFULL |
#define | MAX_INTN ((INTN)0x7FFFFFFFFFFFFFFFULL) |
#define | MAX_UINTN ((UINTN)0xFFFFFFFFFFFFFFFFULL) |
#define | CPU_STACK_ALIGNMENT 16 |
#define | EFIAPI __cdecl |
#define | ASM_GLOBAL .globl |
#define | FUNCTION_ENTRY_POINT(FunctionPointer) (VOID *)(UINTN)(((EFI_PLABEL *)(FunctionPointer))->EntryPoint) |
Typedefs | |
typedef unsigned __int64 | UINT64 |
typedef __int64 | INT64 |
typedef unsigned __int32 | UINT32 |
typedef __int32 | INT32 |
typedef unsigned short | UINT16 |
typedef unsigned short | CHAR16 |
typedef short | INT16 |
typedef unsigned char | BOOLEAN |
typedef unsigned char | UINT8 |
typedef char | CHAR8 |
typedef signed char | INT8 |
typedef UINT64 | UINTN |
typedef INT64 | INTN |
Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.
This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php.
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
#define ASM_GLOBAL .globl |
For GNU assembly code, .global or .globl can declare global symbols. Define this macro to unify the usage.
#define CPU_STACK_ALIGNMENT 16 |
Per the Itanium Software Conventions and Runtime Architecture Guide, section 3.3.4, IPF stack must always be 16-byte aligned.
#define EFIAPI __cdecl |
Microsoft* compiler-specific method for EFIAPI calling convention.
#define FUNCTION_ENTRY_POINT | ( | FunctionPointer | ) | (VOID *)(UINTN)(((EFI_PLABEL *)(FunctionPointer))->EntryPoint) |
Return the pointer to the first instruction of a function given a function pointer. For Itanium processors, all function calls are made through a PLABEL, so a pointer to a function is actually a pointer to a PLABEL. The pointer to the first instruction of the function is contained within the PLABEL. This macro may be used to retrieve a pointer to the first instruction of a function independent of the CPU architecture being used. This is very useful when printing function addresses through DEBUG() macros.
FunctionPointer | A pointer to a function. |
#define MAX_2_BITS 0xC000000000000000ULL |
A value of native width with the two highest bits set.
#define MAX_ADDRESS 0xFFFFFFFFFFFFFFFFULL |
The maximum legal Itanium-based address
#define MAX_BIT 0x8000000000000000ULL |
A value of native width with the highest bit set.
#define MAX_INTN ((INTN)0x7FFFFFFFFFFFFFFFULL) |
Maximum legal Itanium-based INTN and UINTN values.
#define MAX_UINTN ((UINTN)0xFFFFFFFFFFFFFFFFULL) |
#define MDE_CPU_IPF |
Define the processor type so other code can make processor-based choices.
typedef unsigned char BOOLEAN |
Logical Boolean. 1-byte value containing 0 for FALSE or a 1 for TRUE. Other values are undefined.
typedef unsigned short CHAR16 |
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 char CHAR8 |
1-byte Character.
typedef short INT16 |
2-byte signed value.
typedef __int32 INT32 |
4-byte signed value.
typedef __int64 INT64 |
8-byte signed value.
typedef signed char INT8 |
1-byte signed value.
Signed value of native width. (4 bytes on supported 32-bit processor instructions; 8 bytes on supported 64-bit processor instructions.)
typedef unsigned short UINT16 |
2-byte unsigned value.
typedef unsigned __int32 UINT32 |
4-byte unsigned value.
typedef unsigned __int64 UINT64 |
8-byte unsigned value.
typedef unsigned char UINT8 |
1-byte unsigned value.
typedef UINT64 UINTN |
Unsigned value of native width. (4 bytes on supported 32-bit processor instructions; 8 bytes on supported 64-bit processor instructions.)