26#if defined (_MSC_EXTENSIONS)
30 #pragma warning ( disable : 4200 )
38#if defined (_MSC_VER) && _MSC_VER < 1800 && !defined (MDE_CPU_EBC)
44#define GLOBAL_REMOVE_IF_UNREFERENCED __declspec(selectany)
51#define GLOBAL_REMOVE_IF_UNREFERENCED
64#define UNREACHABLE() __builtin_unreachable ()
65 #elif defined (__has_builtin) && defined (__has_feature)
66 #if __has_builtin (__builtin_unreachable)
71#define UNREACHABLE() __builtin_unreachable ()
90 #if defined (__GNUC__) || defined (__clang__)
96#define NORETURN __attribute__((noreturn))
97 #elif defined (_MSC_EXTENSIONS) && !defined (MDE_CPU_EBC)
103#define NORETURN __declspec(noreturn)
118#ifndef ANALYZER_UNREACHABLE
119 #ifdef __clang_analyzer__
120 #if __has_builtin (__builtin_unreachable)
125#define ANALYZER_UNREACHABLE() __builtin_unreachable ()
129 #ifndef ANALYZER_UNREACHABLE
134#define ANALYZER_UNREACHABLE()
144#ifndef ANALYZER_NORETURN
146 #if __has_feature (attribute_analyzer_noreturn)
151#define ANALYZER_NORETURN __attribute__((analyzer_noreturn))
155 #ifndef ANALYZER_NORETURN
160#define ANALYZER_NORETURN
169 #if defined (__GNUC__) || defined (__clang__)
174#define RETURNS_TWICE __attribute__((returns_twice))
191#define _CONCATENATE(a, b) __CONCATENATE(a, b)
192#define __CONCATENATE(a, b) a ## b
198#define ASM_PFX(name) _CONCATENATE (__USER_LABEL_PREFIX__, name)
205#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED .subsections_via_symbols
207#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED
304#define TRUE ((BOOLEAN)(1==1))
310#define FALSE ((BOOLEAN)(0==1))
315#if defined (__cplusplus)
316 #if defined (_MSC_EXTENSIONS)
322#define NULL ((VOID *) 0)
328#define CHAR_NULL 0x0000
333#define MAX_INT8 ((INT8)0x7F)
334#define MAX_UINT8 ((UINT8)0xFF)
335#define MAX_INT16 ((INT16)0x7FFF)
336#define MAX_UINT16 ((UINT16)0xFFFF)
337#define MAX_INT32 ((INT32)0x7FFFFFFF)
338#define MAX_UINT32 ((UINT32)0xFFFFFFFF)
339#define MAX_INT64 ((INT64)0x7FFFFFFFFFFFFFFFULL)
340#define MAX_UINT64 ((UINT64)0xFFFFFFFFFFFFFFFFULL)
345#define MIN_INT8 (((INT8) -127) - 1)
346#define MIN_INT16 (((INT16) -32767) - 1)
347#define MIN_INT32 (((INT32) -2147483647) - 1)
348#define MIN_INT64 (((INT64) -9223372036854775807LL) - 1)
350#define BIT0 0x00000001
351#define BIT1 0x00000002
352#define BIT2 0x00000004
353#define BIT3 0x00000008
354#define BIT4 0x00000010
355#define BIT5 0x00000020
356#define BIT6 0x00000040
357#define BIT7 0x00000080
358#define BIT8 0x00000100
359#define BIT9 0x00000200
360#define BIT10 0x00000400
361#define BIT11 0x00000800
362#define BIT12 0x00001000
363#define BIT13 0x00002000
364#define BIT14 0x00004000
365#define BIT15 0x00008000
366#define BIT16 0x00010000
367#define BIT17 0x00020000
368#define BIT18 0x00040000
369#define BIT19 0x00080000
370#define BIT20 0x00100000
371#define BIT21 0x00200000
372#define BIT22 0x00400000
373#define BIT23 0x00800000
374#define BIT24 0x01000000
375#define BIT25 0x02000000
376#define BIT26 0x04000000
377#define BIT27 0x08000000
378#define BIT28 0x10000000
379#define BIT29 0x20000000
380#define BIT30 0x40000000
381#define BIT31 0x80000000
382#define BIT32 0x0000000100000000ULL
383#define BIT33 0x0000000200000000ULL
384#define BIT34 0x0000000400000000ULL
385#define BIT35 0x0000000800000000ULL
386#define BIT36 0x0000001000000000ULL
387#define BIT37 0x0000002000000000ULL
388#define BIT38 0x0000004000000000ULL
389#define BIT39 0x0000008000000000ULL
390#define BIT40 0x0000010000000000ULL
391#define BIT41 0x0000020000000000ULL
392#define BIT42 0x0000040000000000ULL
393#define BIT43 0x0000080000000000ULL
394#define BIT44 0x0000100000000000ULL
395#define BIT45 0x0000200000000000ULL
396#define BIT46 0x0000400000000000ULL
397#define BIT47 0x0000800000000000ULL
398#define BIT48 0x0001000000000000ULL
399#define BIT49 0x0002000000000000ULL
400#define BIT50 0x0004000000000000ULL
401#define BIT51 0x0008000000000000ULL
402#define BIT52 0x0010000000000000ULL
403#define BIT53 0x0020000000000000ULL
404#define BIT54 0x0040000000000000ULL
405#define BIT55 0x0080000000000000ULL
406#define BIT56 0x0100000000000000ULL
407#define BIT57 0x0200000000000000ULL
408#define BIT58 0x0400000000000000ULL
409#define BIT59 0x0800000000000000ULL
410#define BIT60 0x1000000000000000ULL
411#define BIT61 0x2000000000000000ULL
412#define BIT62 0x4000000000000000ULL
413#define BIT63 0x8000000000000000ULL
415#define SIZE_1KB 0x00000400
416#define SIZE_2KB 0x00000800
417#define SIZE_4KB 0x00001000
418#define SIZE_8KB 0x00002000
419#define SIZE_16KB 0x00004000
420#define SIZE_32KB 0x00008000
421#define SIZE_64KB 0x00010000
422#define SIZE_128KB 0x00020000
423#define SIZE_256KB 0x00040000
424#define SIZE_512KB 0x00080000
425#define SIZE_1MB 0x00100000
426#define SIZE_2MB 0x00200000
427#define SIZE_4MB 0x00400000
428#define SIZE_8MB 0x00800000
429#define SIZE_16MB 0x01000000
430#define SIZE_32MB 0x02000000
431#define SIZE_64MB 0x04000000
432#define SIZE_128MB 0x08000000
433#define SIZE_256MB 0x10000000
434#define SIZE_512MB 0x20000000
435#define SIZE_1GB 0x40000000
436#define SIZE_2GB 0x80000000
437#define SIZE_4GB 0x0000000100000000ULL
438#define SIZE_8GB 0x0000000200000000ULL
439#define SIZE_16GB 0x0000000400000000ULL
440#define SIZE_32GB 0x0000000800000000ULL
441#define SIZE_64GB 0x0000001000000000ULL
442#define SIZE_128GB 0x0000002000000000ULL
443#define SIZE_256GB 0x0000004000000000ULL
444#define SIZE_512GB 0x0000008000000000ULL
445#define SIZE_1TB 0x0000010000000000ULL
446#define SIZE_2TB 0x0000020000000000ULL
447#define SIZE_4TB 0x0000040000000000ULL
448#define SIZE_8TB 0x0000080000000000ULL
449#define SIZE_16TB 0x0000100000000000ULL
450#define SIZE_32TB 0x0000200000000000ULL
451#define SIZE_64TB 0x0000400000000000ULL
452#define SIZE_128TB 0x0000800000000000ULL
453#define SIZE_256TB 0x0001000000000000ULL
454#define SIZE_512TB 0x0002000000000000ULL
455#define SIZE_1PB 0x0004000000000000ULL
456#define SIZE_2PB 0x0008000000000000ULL
457#define SIZE_4PB 0x0010000000000000ULL
458#define SIZE_8PB 0x0020000000000000ULL
459#define SIZE_16PB 0x0040000000000000ULL
460#define SIZE_32PB 0x0080000000000000ULL
461#define SIZE_64PB 0x0100000000000000ULL
462#define SIZE_128PB 0x0200000000000000ULL
463#define SIZE_256PB 0x0400000000000000ULL
464#define SIZE_512PB 0x0800000000000000ULL
465#define SIZE_1EB 0x1000000000000000ULL
466#define SIZE_2EB 0x2000000000000000ULL
467#define SIZE_4EB 0x4000000000000000ULL
468#define SIZE_8EB 0x8000000000000000ULL
470#define BASE_1KB 0x00000400
471#define BASE_2KB 0x00000800
472#define BASE_4KB 0x00001000
473#define BASE_8KB 0x00002000
474#define BASE_16KB 0x00004000
475#define BASE_32KB 0x00008000
476#define BASE_64KB 0x00010000
477#define BASE_128KB 0x00020000
478#define BASE_256KB 0x00040000
479#define BASE_512KB 0x00080000
480#define BASE_1MB 0x00100000
481#define BASE_2MB 0x00200000
482#define BASE_4MB 0x00400000
483#define BASE_8MB 0x00800000
484#define BASE_16MB 0x01000000
485#define BASE_32MB 0x02000000
486#define BASE_64MB 0x04000000
487#define BASE_128MB 0x08000000
488#define BASE_256MB 0x10000000
489#define BASE_512MB 0x20000000
490#define BASE_1GB 0x40000000
491#define BASE_2GB 0x80000000
492#define BASE_4GB 0x0000000100000000ULL
493#define BASE_8GB 0x0000000200000000ULL
494#define BASE_16GB 0x0000000400000000ULL
495#define BASE_32GB 0x0000000800000000ULL
496#define BASE_64GB 0x0000001000000000ULL
497#define BASE_128GB 0x0000002000000000ULL
498#define BASE_256GB 0x0000004000000000ULL
499#define BASE_512GB 0x0000008000000000ULL
500#define BASE_1TB 0x0000010000000000ULL
501#define BASE_2TB 0x0000020000000000ULL
502#define BASE_4TB 0x0000040000000000ULL
503#define BASE_8TB 0x0000080000000000ULL
504#define BASE_16TB 0x0000100000000000ULL
505#define BASE_32TB 0x0000200000000000ULL
506#define BASE_64TB 0x0000400000000000ULL
507#define BASE_128TB 0x0000800000000000ULL
508#define BASE_256TB 0x0001000000000000ULL
509#define BASE_512TB 0x0002000000000000ULL
510#define BASE_1PB 0x0004000000000000ULL
511#define BASE_2PB 0x0008000000000000ULL
512#define BASE_4PB 0x0010000000000000ULL
513#define BASE_8PB 0x0020000000000000ULL
514#define BASE_16PB 0x0040000000000000ULL
515#define BASE_32PB 0x0080000000000000ULL
516#define BASE_64PB 0x0100000000000000ULL
517#define BASE_128PB 0x0200000000000000ULL
518#define BASE_256PB 0x0400000000000000ULL
519#define BASE_512PB 0x0800000000000000ULL
520#define BASE_1EB 0x1000000000000000ULL
521#define BASE_2EB 0x2000000000000000ULL
522#define BASE_4EB 0x4000000000000000ULL
523#define BASE_8EB 0x8000000000000000ULL
582#define _INT_SIZE_OF(n) ((sizeof (n) + sizeof (UINTN) - 1) &~(sizeof (UINTN) - 1))
584#if defined (_M_ARM64)
591#define VA_START(Marker, Parameter) __va_start (&Marker, &Parameter, _INT_SIZE_OF (Parameter), __alignof(Parameter), &Parameter)
592#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE) + ((-(INTN)Marker) & (sizeof(TYPE) - 1))) - _INT_SIZE_OF (TYPE)))
593#define VA_END(Marker) (Marker = (VA_LIST) 0)
594#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
596#elif defined (__GNUC__) || defined (__clang__)
598 #if defined (MDE_CPU_X64) && !defined (NO_MSABI_VA_FUNCS)
610typedef __builtin_ms_va_list
VA_LIST;
612#define VA_START(Marker, Parameter) __builtin_ms_va_start (Marker, Parameter)
614#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
616#define VA_END(Marker) __builtin_ms_va_end (Marker)
618#define VA_COPY(Dest, Start) __builtin_ms_va_copy (Dest, Start)
629typedef __builtin_va_list
VA_LIST;
631#define VA_START(Marker, Parameter) __builtin_va_start (Marker, Parameter)
633#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
635#define VA_END(Marker) __builtin_va_end (Marker)
637#define VA_COPY(Dest, Start) __builtin_va_copy (Dest, Start)
664#define VA_START(Marker, Parameter) (Marker = (VA_LIST) ((UINTN) & (Parameter) + _INT_SIZE_OF (Parameter)))
682#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE)) - _INT_SIZE_OF (TYPE)))
694#define VA_END(Marker) (Marker = (VA_LIST) 0)
707#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
723#define _BASE_INT_SIZE_OF(TYPE) ((sizeof (TYPE) + sizeof (UINTN) - 1) / sizeof (UINTN))
741#define BASE_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _BASE_INT_SIZE_OF (TYPE)) - _BASE_INT_SIZE_OF (TYPE)))
756#if (defined (__GNUC__) && __GNUC__ >= 4) || defined (__clang__)
757#define OFFSET_OF(TYPE, Field) ((UINTN) __builtin_offsetof(TYPE, Field))
761#define OFFSET_OF(TYPE, Field) ((UINTN) &(((TYPE *)0)->Field))
771#if defined (__cplusplus)
775#define ALIGNOF(TYPE) alignof (TYPE)
776#elif defined (__GNUC__) || defined (__clang__) || (defined (_MSC_VER) && _MSC_VER >= 1900)
781#define ALIGNOF(TYPE) _Alignof (TYPE)
782#elif defined (_MSC_EXTENSIONS)
787#define ALIGNOF(TYPE) __alignof (TYPE)
795#define ALIGNOF(TYPE) OFFSET_OF (struct { CHAR8 C; TYPE A; }, A)
806#if defined (__cplusplus)
807#define STATIC_ASSERT static_assert
808#elif defined (__GNUC__) || defined (__clang__)
809#define STATIC_ASSERT _Static_assert
810#elif defined (_MSC_EXTENSIONS)
811#define STATIC_ASSERT static_assert
819STATIC_ASSERT (
sizeof (
BOOLEAN) == 1,
"sizeof (BOOLEAN) does not meet UEFI Specification Data Type requirements");
820STATIC_ASSERT (
sizeof (
INT8) == 1,
"sizeof (INT8) does not meet UEFI Specification Data Type requirements");
821STATIC_ASSERT (
sizeof (
UINT8) == 1,
"sizeof (UINT8) does not meet UEFI Specification Data Type requirements");
822STATIC_ASSERT (
sizeof (
INT16) == 2,
"sizeof (INT16) does not meet UEFI Specification Data Type requirements");
823STATIC_ASSERT (
sizeof (
UINT16) == 2,
"sizeof (UINT16) does not meet UEFI Specification Data Type requirements");
824STATIC_ASSERT (
sizeof (
INT32) == 4,
"sizeof (INT32) does not meet UEFI Specification Data Type requirements");
825STATIC_ASSERT (
sizeof (
UINT32) == 4,
"sizeof (UINT32) does not meet UEFI Specification Data Type requirements");
826STATIC_ASSERT (
sizeof (
INT64) == 8,
"sizeof (INT64) does not meet UEFI Specification Data Type requirements");
827STATIC_ASSERT (
sizeof (
UINT64) == 8,
"sizeof (UINT64) does not meet UEFI Specification Data Type requirements");
828STATIC_ASSERT (
sizeof (
CHAR8) == 1,
"sizeof (CHAR8) does not meet UEFI Specification Data Type requirements");
829STATIC_ASSERT (
sizeof (
CHAR16) == 2,
"sizeof (CHAR16) does not meet UEFI Specification Data Type requirements");
830STATIC_ASSERT (
sizeof (L
'A') == 2,
"sizeof (L'A') does not meet UEFI Specification Data Type requirements");
831STATIC_ASSERT (
sizeof (L
"A") == 4,
"sizeof (L\"A\") does not meet UEFI Specification Data Type requirements");
894#define BASE_CR(Record, TYPE, Field) ((TYPE *) (VOID *) ((CHAR8 *) (Record) - OFFSET_OF (TYPE, Field)))
904#define IS_POW2(Value) ((Value) != 0U && ((Value) & ((Value) - 1U)) == 0U)
915#define IS_ALIGNED(Value, Alignment) (((Value) & ((Alignment) - 1U)) == 0U)
926#define ADDRESS_IS_ALIGNED(Address, Alignment) IS_ALIGNED ((UINTN) (Address), Alignment)
937#define ALIGN_VALUE_ADDEND(Value, Alignment) (((Alignment) - (Value)) & ((Alignment) - 1U))
951#define ALIGN_VALUE(Value, Alignment) ((Value) + ALIGN_VALUE_ADDEND (Value, Alignment))
966#define ALIGN_POINTER(Pointer, Alignment) ((VOID *) (ALIGN_VALUE ((UINTN)(Pointer), (Alignment))))
980#define ALIGN_VARIABLE(Value) ALIGN_VALUE ((Value), sizeof (UINTN))
996 (((a) > (b)) ? (a) : (b))
1011 (((a) < (b)) ? (a) : (b))
1024 (((a) < 0) ? (-(a)) : (a))
1040#define ENCODE_ERROR(StatusCode) ((RETURN_STATUS)(MAX_BIT | (StatusCode)))
1051#define ENCODE_WARNING(StatusCode) ((RETURN_STATUS)(StatusCode))
1064#define RETURN_ERROR(StatusCode) (((RETURN_STATUS)(StatusCode)) >= MAX_BIT)
1069#define RETURN_SUCCESS (RETURN_STATUS)(0)
1074#define RETURN_LOAD_ERROR ENCODE_ERROR (1)
1079#define RETURN_INVALID_PARAMETER ENCODE_ERROR (2)
1084#define RETURN_UNSUPPORTED ENCODE_ERROR (3)
1089#define RETURN_BAD_BUFFER_SIZE ENCODE_ERROR (4)
1096#define RETURN_BUFFER_TOO_SMALL ENCODE_ERROR (5)
1101#define RETURN_NOT_READY ENCODE_ERROR (6)
1107#define RETURN_DEVICE_ERROR ENCODE_ERROR (7)
1112#define RETURN_WRITE_PROTECTED ENCODE_ERROR (8)
1117#define RETURN_OUT_OF_RESOURCES ENCODE_ERROR (9)
1123#define RETURN_VOLUME_CORRUPTED ENCODE_ERROR (10)
1128#define RETURN_VOLUME_FULL ENCODE_ERROR (11)
1134#define RETURN_NO_MEDIA ENCODE_ERROR (12)
1140#define RETURN_MEDIA_CHANGED ENCODE_ERROR (13)
1145#define RETURN_NOT_FOUND ENCODE_ERROR (14)
1150#define RETURN_ACCESS_DENIED ENCODE_ERROR (15)
1155#define RETURN_NO_RESPONSE ENCODE_ERROR (16)
1160#define RETURN_NO_MAPPING ENCODE_ERROR (17)
1165#define RETURN_TIMEOUT ENCODE_ERROR (18)
1170#define RETURN_NOT_STARTED ENCODE_ERROR (19)
1175#define RETURN_ALREADY_STARTED ENCODE_ERROR (20)
1180#define RETURN_ABORTED ENCODE_ERROR (21)
1185#define RETURN_ICMP_ERROR ENCODE_ERROR (22)
1190#define RETURN_TFTP_ERROR ENCODE_ERROR (23)
1195#define RETURN_PROTOCOL_ERROR ENCODE_ERROR (24)
1201#define RETURN_INCOMPATIBLE_VERSION ENCODE_ERROR (25)
1206#define RETURN_SECURITY_VIOLATION ENCODE_ERROR (26)
1211#define RETURN_CRC_ERROR ENCODE_ERROR (27)
1216#define RETURN_END_OF_MEDIA ENCODE_ERROR (28)
1221#define RETURN_END_OF_FILE ENCODE_ERROR (31)
1226#define RETURN_INVALID_LANGUAGE ENCODE_ERROR (32)
1233#define RETURN_COMPROMISED_DATA ENCODE_ERROR (33)
1238#define RETURN_IP_ADDRESS_CONFLICT ENCODE_ERROR (34)
1243#define RETURN_HTTP_ERROR ENCODE_ERROR (35)
1249#define RETURN_WARN_UNKNOWN_GLYPH ENCODE_WARNING (1)
1254#define RETURN_WARN_DELETE_FAILURE ENCODE_WARNING (2)
1260#define RETURN_WARN_WRITE_FAILURE ENCODE_WARNING (3)
1266#define RETURN_WARN_BUFFER_TOO_SMALL ENCODE_WARNING (4)
1272#define RETURN_WARN_STALE_DATA ENCODE_WARNING (5)
1277#define RETURN_WARN_FILE_SYSTEM ENCODE_WARNING (6)
1282#define RETURN_WARN_RESET_REQUIRED ENCODE_WARNING (7)
1296#define SIGNATURE_16(A, B) ((A) | (B << 8))
1313#define SIGNATURE_32(A, B, C, D) (SIGNATURE_16 (A, B) | (SIGNATURE_16 (C, D) << 16))
1334#define SIGNATURE_64(A, B, C, D, E, F, G, H) \
1335 (SIGNATURE_32 (A, B, C, D) | ((UINT64) (SIGNATURE_32 (E, F, G, H)) << 32))
1337#if defined (_MSC_EXTENSIONS) && !defined (__INTEL_COMPILER) && !defined (MDE_CPU_EBC)
1343 #pragma intrinsic(_ReturnAddress)
1357#define RETURN_ADDRESS(L) ((L == 0) ? _ReturnAddress() : (VOID *) 0)
1358#elif defined (__GNUC__) || defined (__clang__)
1371#define RETURN_ADDRESS(L) __builtin_return_address (L)
1382#define RETURN_ADDRESS(L) ((VOID *) 0)
1396#define ARRAY_SIZE(Array) (sizeof (Array) / sizeof ((Array)[0]))
unsigned short UINT16
2-byte unsigned value.
unsigned char BOOLEAN
Logical Boolean.
char CHAR8
1-byte Character
UINT64 UINTN
Unsigned value of native width.
unsigned long long UINT64
8-byte unsigned value.
short INT16
2-byte signed value.
int INT32
4-byte signed value.
long long INT64
8-byte signed value.
unsigned short CHAR16
2-byte Character.
signed char INT8
1-byte signed value
INT64 INTN
Signed value of native width.
unsigned char UINT8
1-byte unsigned value.
unsigned int UINT32
4-byte unsigned value.
STATIC_ASSERT(sizeof(BOOLEAN)==1, "sizeof (BOOLEAN) does not meet UEFI Specification Data Type requirements")
Portable definition for compile time assertions.
__VERIFY_UINT16_ENUM_SIZE
@ __VerifyUint16EnumValue
#define VOID
Undeclared type.
CHAR8 * VA_LIST
Variable used to traverse the list of arguments.
UINTN * BASE_LIST
Pointer to the start of a variable argument list stored in a memory buffer.
#define ALIGNOF(TYPE)
Returns the alignment requirement of a type.
struct _LIST_ENTRY LIST_ENTRY
LIST_ENTRY structure definition.
#define FILE_LICENCE(_licence)
Declare a particular licence as applying to a file.
#define FILE_SECBOOT(_status)
Declare a file's UEFI Secure Boot permission status.
128 bit buffer containing a unique identifier value.
_LIST_ENTRY structure definition.