25#if defined (_MSC_EXTENSIONS)
29 #pragma warning ( disable : 4200 )
37#if defined (_MSC_VER) && _MSC_VER < 1800 && !defined (MDE_CPU_EBC)
43#define GLOBAL_REMOVE_IF_UNREFERENCED __declspec(selectany)
50#define GLOBAL_REMOVE_IF_UNREFERENCED
63#define UNREACHABLE() __builtin_unreachable ()
64 #elif defined (__has_builtin) && defined (__has_feature)
65 #if __has_builtin (__builtin_unreachable)
70#define UNREACHABLE() __builtin_unreachable ()
89 #if defined (__GNUC__) || defined (__clang__)
95#define NORETURN __attribute__((noreturn))
96 #elif defined (_MSC_EXTENSIONS) && !defined (MDE_CPU_EBC)
102#define NORETURN __declspec(noreturn)
117#ifndef ANALYZER_UNREACHABLE
118 #ifdef __clang_analyzer__
119 #if __has_builtin (__builtin_unreachable)
124#define ANALYZER_UNREACHABLE() __builtin_unreachable ()
128 #ifndef ANALYZER_UNREACHABLE
133#define ANALYZER_UNREACHABLE()
143#ifndef ANALYZER_NORETURN
145 #if __has_feature (attribute_analyzer_noreturn)
150#define ANALYZER_NORETURN __attribute__((analyzer_noreturn))
154 #ifndef ANALYZER_NORETURN
159#define ANALYZER_NORETURN
168 #if defined (__GNUC__) || defined (__clang__)
173#define RETURNS_TWICE __attribute__((returns_twice))
190#define _CONCATENATE(a, b) __CONCATENATE(a, b)
191#define __CONCATENATE(a, b) a ## b
197#define ASM_PFX(name) _CONCATENATE (__USER_LABEL_PREFIX__, name)
204#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED .subsections_via_symbols
206#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED
303#define TRUE ((BOOLEAN)(1==1))
309#define FALSE ((BOOLEAN)(0==1))
314#if defined (__cplusplus)
315 #if defined (_MSC_EXTENSIONS)
321#define NULL ((VOID *) 0)
327#define CHAR_NULL 0x0000
332#define MAX_INT8 ((INT8)0x7F)
333#define MAX_UINT8 ((UINT8)0xFF)
334#define MAX_INT16 ((INT16)0x7FFF)
335#define MAX_UINT16 ((UINT16)0xFFFF)
336#define MAX_INT32 ((INT32)0x7FFFFFFF)
337#define MAX_UINT32 ((UINT32)0xFFFFFFFF)
338#define MAX_INT64 ((INT64)0x7FFFFFFFFFFFFFFFULL)
339#define MAX_UINT64 ((UINT64)0xFFFFFFFFFFFFFFFFULL)
344#define MIN_INT8 (((INT8) -127) - 1)
345#define MIN_INT16 (((INT16) -32767) - 1)
346#define MIN_INT32 (((INT32) -2147483647) - 1)
347#define MIN_INT64 (((INT64) -9223372036854775807LL) - 1)
349#define BIT0 0x00000001
350#define BIT1 0x00000002
351#define BIT2 0x00000004
352#define BIT3 0x00000008
353#define BIT4 0x00000010
354#define BIT5 0x00000020
355#define BIT6 0x00000040
356#define BIT7 0x00000080
357#define BIT8 0x00000100
358#define BIT9 0x00000200
359#define BIT10 0x00000400
360#define BIT11 0x00000800
361#define BIT12 0x00001000
362#define BIT13 0x00002000
363#define BIT14 0x00004000
364#define BIT15 0x00008000
365#define BIT16 0x00010000
366#define BIT17 0x00020000
367#define BIT18 0x00040000
368#define BIT19 0x00080000
369#define BIT20 0x00100000
370#define BIT21 0x00200000
371#define BIT22 0x00400000
372#define BIT23 0x00800000
373#define BIT24 0x01000000
374#define BIT25 0x02000000
375#define BIT26 0x04000000
376#define BIT27 0x08000000
377#define BIT28 0x10000000
378#define BIT29 0x20000000
379#define BIT30 0x40000000
380#define BIT31 0x80000000
381#define BIT32 0x0000000100000000ULL
382#define BIT33 0x0000000200000000ULL
383#define BIT34 0x0000000400000000ULL
384#define BIT35 0x0000000800000000ULL
385#define BIT36 0x0000001000000000ULL
386#define BIT37 0x0000002000000000ULL
387#define BIT38 0x0000004000000000ULL
388#define BIT39 0x0000008000000000ULL
389#define BIT40 0x0000010000000000ULL
390#define BIT41 0x0000020000000000ULL
391#define BIT42 0x0000040000000000ULL
392#define BIT43 0x0000080000000000ULL
393#define BIT44 0x0000100000000000ULL
394#define BIT45 0x0000200000000000ULL
395#define BIT46 0x0000400000000000ULL
396#define BIT47 0x0000800000000000ULL
397#define BIT48 0x0001000000000000ULL
398#define BIT49 0x0002000000000000ULL
399#define BIT50 0x0004000000000000ULL
400#define BIT51 0x0008000000000000ULL
401#define BIT52 0x0010000000000000ULL
402#define BIT53 0x0020000000000000ULL
403#define BIT54 0x0040000000000000ULL
404#define BIT55 0x0080000000000000ULL
405#define BIT56 0x0100000000000000ULL
406#define BIT57 0x0200000000000000ULL
407#define BIT58 0x0400000000000000ULL
408#define BIT59 0x0800000000000000ULL
409#define BIT60 0x1000000000000000ULL
410#define BIT61 0x2000000000000000ULL
411#define BIT62 0x4000000000000000ULL
412#define BIT63 0x8000000000000000ULL
414#define SIZE_1KB 0x00000400
415#define SIZE_2KB 0x00000800
416#define SIZE_4KB 0x00001000
417#define SIZE_8KB 0x00002000
418#define SIZE_16KB 0x00004000
419#define SIZE_32KB 0x00008000
420#define SIZE_64KB 0x00010000
421#define SIZE_128KB 0x00020000
422#define SIZE_256KB 0x00040000
423#define SIZE_512KB 0x00080000
424#define SIZE_1MB 0x00100000
425#define SIZE_2MB 0x00200000
426#define SIZE_4MB 0x00400000
427#define SIZE_8MB 0x00800000
428#define SIZE_16MB 0x01000000
429#define SIZE_32MB 0x02000000
430#define SIZE_64MB 0x04000000
431#define SIZE_128MB 0x08000000
432#define SIZE_256MB 0x10000000
433#define SIZE_512MB 0x20000000
434#define SIZE_1GB 0x40000000
435#define SIZE_2GB 0x80000000
436#define SIZE_4GB 0x0000000100000000ULL
437#define SIZE_8GB 0x0000000200000000ULL
438#define SIZE_16GB 0x0000000400000000ULL
439#define SIZE_32GB 0x0000000800000000ULL
440#define SIZE_64GB 0x0000001000000000ULL
441#define SIZE_128GB 0x0000002000000000ULL
442#define SIZE_256GB 0x0000004000000000ULL
443#define SIZE_512GB 0x0000008000000000ULL
444#define SIZE_1TB 0x0000010000000000ULL
445#define SIZE_2TB 0x0000020000000000ULL
446#define SIZE_4TB 0x0000040000000000ULL
447#define SIZE_8TB 0x0000080000000000ULL
448#define SIZE_16TB 0x0000100000000000ULL
449#define SIZE_32TB 0x0000200000000000ULL
450#define SIZE_64TB 0x0000400000000000ULL
451#define SIZE_128TB 0x0000800000000000ULL
452#define SIZE_256TB 0x0001000000000000ULL
453#define SIZE_512TB 0x0002000000000000ULL
454#define SIZE_1PB 0x0004000000000000ULL
455#define SIZE_2PB 0x0008000000000000ULL
456#define SIZE_4PB 0x0010000000000000ULL
457#define SIZE_8PB 0x0020000000000000ULL
458#define SIZE_16PB 0x0040000000000000ULL
459#define SIZE_32PB 0x0080000000000000ULL
460#define SIZE_64PB 0x0100000000000000ULL
461#define SIZE_128PB 0x0200000000000000ULL
462#define SIZE_256PB 0x0400000000000000ULL
463#define SIZE_512PB 0x0800000000000000ULL
464#define SIZE_1EB 0x1000000000000000ULL
465#define SIZE_2EB 0x2000000000000000ULL
466#define SIZE_4EB 0x4000000000000000ULL
467#define SIZE_8EB 0x8000000000000000ULL
469#define BASE_1KB 0x00000400
470#define BASE_2KB 0x00000800
471#define BASE_4KB 0x00001000
472#define BASE_8KB 0x00002000
473#define BASE_16KB 0x00004000
474#define BASE_32KB 0x00008000
475#define BASE_64KB 0x00010000
476#define BASE_128KB 0x00020000
477#define BASE_256KB 0x00040000
478#define BASE_512KB 0x00080000
479#define BASE_1MB 0x00100000
480#define BASE_2MB 0x00200000
481#define BASE_4MB 0x00400000
482#define BASE_8MB 0x00800000
483#define BASE_16MB 0x01000000
484#define BASE_32MB 0x02000000
485#define BASE_64MB 0x04000000
486#define BASE_128MB 0x08000000
487#define BASE_256MB 0x10000000
488#define BASE_512MB 0x20000000
489#define BASE_1GB 0x40000000
490#define BASE_2GB 0x80000000
491#define BASE_4GB 0x0000000100000000ULL
492#define BASE_8GB 0x0000000200000000ULL
493#define BASE_16GB 0x0000000400000000ULL
494#define BASE_32GB 0x0000000800000000ULL
495#define BASE_64GB 0x0000001000000000ULL
496#define BASE_128GB 0x0000002000000000ULL
497#define BASE_256GB 0x0000004000000000ULL
498#define BASE_512GB 0x0000008000000000ULL
499#define BASE_1TB 0x0000010000000000ULL
500#define BASE_2TB 0x0000020000000000ULL
501#define BASE_4TB 0x0000040000000000ULL
502#define BASE_8TB 0x0000080000000000ULL
503#define BASE_16TB 0x0000100000000000ULL
504#define BASE_32TB 0x0000200000000000ULL
505#define BASE_64TB 0x0000400000000000ULL
506#define BASE_128TB 0x0000800000000000ULL
507#define BASE_256TB 0x0001000000000000ULL
508#define BASE_512TB 0x0002000000000000ULL
509#define BASE_1PB 0x0004000000000000ULL
510#define BASE_2PB 0x0008000000000000ULL
511#define BASE_4PB 0x0010000000000000ULL
512#define BASE_8PB 0x0020000000000000ULL
513#define BASE_16PB 0x0040000000000000ULL
514#define BASE_32PB 0x0080000000000000ULL
515#define BASE_64PB 0x0100000000000000ULL
516#define BASE_128PB 0x0200000000000000ULL
517#define BASE_256PB 0x0400000000000000ULL
518#define BASE_512PB 0x0800000000000000ULL
519#define BASE_1EB 0x1000000000000000ULL
520#define BASE_2EB 0x2000000000000000ULL
521#define BASE_4EB 0x4000000000000000ULL
522#define BASE_8EB 0x8000000000000000ULL
581#define _INT_SIZE_OF(n) ((sizeof (n) + sizeof (UINTN) - 1) &~(sizeof (UINTN) - 1))
583#if defined (_M_ARM64)
590#define VA_START(Marker, Parameter) __va_start (&Marker, &Parameter, _INT_SIZE_OF (Parameter), __alignof(Parameter), &Parameter)
591#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE) + ((-(INTN)Marker) & (sizeof(TYPE) - 1))) - _INT_SIZE_OF (TYPE)))
592#define VA_END(Marker) (Marker = (VA_LIST) 0)
593#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
595#elif defined (__GNUC__) || defined (__clang__)
597 #if defined (MDE_CPU_X64) && !defined (NO_MSABI_VA_FUNCS)
609typedef __builtin_ms_va_list
VA_LIST;
611#define VA_START(Marker, Parameter) __builtin_ms_va_start (Marker, Parameter)
613#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
615#define VA_END(Marker) __builtin_ms_va_end (Marker)
617#define VA_COPY(Dest, Start) __builtin_ms_va_copy (Dest, Start)
628typedef __builtin_va_list
VA_LIST;
630#define VA_START(Marker, Parameter) __builtin_va_start (Marker, Parameter)
632#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
634#define VA_END(Marker) __builtin_va_end (Marker)
636#define VA_COPY(Dest, Start) __builtin_va_copy (Dest, Start)
663#define VA_START(Marker, Parameter) (Marker = (VA_LIST) ((UINTN) & (Parameter) + _INT_SIZE_OF (Parameter)))
681#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE)) - _INT_SIZE_OF (TYPE)))
693#define VA_END(Marker) (Marker = (VA_LIST) 0)
706#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
722#define _BASE_INT_SIZE_OF(TYPE) ((sizeof (TYPE) + sizeof (UINTN) - 1) / sizeof (UINTN))
740#define BASE_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _BASE_INT_SIZE_OF (TYPE)) - _BASE_INT_SIZE_OF (TYPE)))
755#if (defined (__GNUC__) && __GNUC__ >= 4) || defined (__clang__)
756#define OFFSET_OF(TYPE, Field) ((UINTN) __builtin_offsetof(TYPE, Field))
760#define OFFSET_OF(TYPE, Field) ((UINTN) &(((TYPE *)0)->Field))
770#if defined (__cplusplus)
774#define ALIGNOF(TYPE) alignof (TYPE)
775#elif defined (__GNUC__) || defined (__clang__) || (defined (_MSC_VER) && _MSC_VER >= 1900)
780#define ALIGNOF(TYPE) _Alignof (TYPE)
781#elif defined (_MSC_EXTENSIONS)
786#define ALIGNOF(TYPE) __alignof (TYPE)
794#define ALIGNOF(TYPE) OFFSET_OF (struct { CHAR8 C; TYPE A; }, A)
805#if defined (__cplusplus)
806#define STATIC_ASSERT static_assert
807#elif defined (__GNUC__) || defined (__clang__)
808#define STATIC_ASSERT _Static_assert
809#elif defined (_MSC_EXTENSIONS)
810#define STATIC_ASSERT static_assert
818STATIC_ASSERT (
sizeof (
BOOLEAN) == 1,
"sizeof (BOOLEAN) does not meet UEFI Specification Data Type requirements");
819STATIC_ASSERT (
sizeof (
INT8) == 1,
"sizeof (INT8) does not meet UEFI Specification Data Type requirements");
820STATIC_ASSERT (
sizeof (
UINT8) == 1,
"sizeof (UINT8) does not meet UEFI Specification Data Type requirements");
821STATIC_ASSERT (
sizeof (
INT16) == 2,
"sizeof (INT16) does not meet UEFI Specification Data Type requirements");
822STATIC_ASSERT (
sizeof (
UINT16) == 2,
"sizeof (UINT16) does not meet UEFI Specification Data Type requirements");
823STATIC_ASSERT (
sizeof (
INT32) == 4,
"sizeof (INT32) does not meet UEFI Specification Data Type requirements");
824STATIC_ASSERT (
sizeof (
UINT32) == 4,
"sizeof (UINT32) does not meet UEFI Specification Data Type requirements");
825STATIC_ASSERT (
sizeof (
INT64) == 8,
"sizeof (INT64) does not meet UEFI Specification Data Type requirements");
826STATIC_ASSERT (
sizeof (
UINT64) == 8,
"sizeof (UINT64) does not meet UEFI Specification Data Type requirements");
827STATIC_ASSERT (
sizeof (
CHAR8) == 1,
"sizeof (CHAR8) does not meet UEFI Specification Data Type requirements");
828STATIC_ASSERT (
sizeof (
CHAR16) == 2,
"sizeof (CHAR16) does not meet UEFI Specification Data Type requirements");
829STATIC_ASSERT (
sizeof (L
'A') == 2,
"sizeof (L'A') does not meet UEFI Specification Data Type requirements");
830STATIC_ASSERT (
sizeof (L
"A") == 4,
"sizeof (L\"A\") does not meet UEFI Specification Data Type requirements");
893#define BASE_CR(Record, TYPE, Field) ((TYPE *) (VOID *) ((CHAR8 *) (Record) - OFFSET_OF (TYPE, Field)))
903#define IS_POW2(Value) ((Value) != 0U && ((Value) & ((Value) - 1U)) == 0U)
914#define IS_ALIGNED(Value, Alignment) (((Value) & ((Alignment) - 1U)) == 0U)
925#define ADDRESS_IS_ALIGNED(Address, Alignment) IS_ALIGNED ((UINTN) (Address), Alignment)
936#define ALIGN_VALUE_ADDEND(Value, Alignment) (((Alignment) - (Value)) & ((Alignment) - 1U))
950#define ALIGN_VALUE(Value, Alignment) ((Value) + ALIGN_VALUE_ADDEND (Value, Alignment))
965#define ALIGN_POINTER(Pointer, Alignment) ((VOID *) (ALIGN_VALUE ((UINTN)(Pointer), (Alignment))))
979#define ALIGN_VARIABLE(Value) ALIGN_VALUE ((Value), sizeof (UINTN))
995 (((a) > (b)) ? (a) : (b))
1010 (((a) < (b)) ? (a) : (b))
1023 (((a) < 0) ? (-(a)) : (a))
1039#define ENCODE_ERROR(StatusCode) ((RETURN_STATUS)(MAX_BIT | (StatusCode)))
1050#define ENCODE_WARNING(StatusCode) ((RETURN_STATUS)(StatusCode))
1063#define RETURN_ERROR(StatusCode) (((RETURN_STATUS)(StatusCode)) >= MAX_BIT)
1068#define RETURN_SUCCESS (RETURN_STATUS)(0)
1073#define RETURN_LOAD_ERROR ENCODE_ERROR (1)
1078#define RETURN_INVALID_PARAMETER ENCODE_ERROR (2)
1083#define RETURN_UNSUPPORTED ENCODE_ERROR (3)
1088#define RETURN_BAD_BUFFER_SIZE ENCODE_ERROR (4)
1095#define RETURN_BUFFER_TOO_SMALL ENCODE_ERROR (5)
1100#define RETURN_NOT_READY ENCODE_ERROR (6)
1106#define RETURN_DEVICE_ERROR ENCODE_ERROR (7)
1111#define RETURN_WRITE_PROTECTED ENCODE_ERROR (8)
1116#define RETURN_OUT_OF_RESOURCES ENCODE_ERROR (9)
1122#define RETURN_VOLUME_CORRUPTED ENCODE_ERROR (10)
1127#define RETURN_VOLUME_FULL ENCODE_ERROR (11)
1133#define RETURN_NO_MEDIA ENCODE_ERROR (12)
1139#define RETURN_MEDIA_CHANGED ENCODE_ERROR (13)
1144#define RETURN_NOT_FOUND ENCODE_ERROR (14)
1149#define RETURN_ACCESS_DENIED ENCODE_ERROR (15)
1154#define RETURN_NO_RESPONSE ENCODE_ERROR (16)
1159#define RETURN_NO_MAPPING ENCODE_ERROR (17)
1164#define RETURN_TIMEOUT ENCODE_ERROR (18)
1169#define RETURN_NOT_STARTED ENCODE_ERROR (19)
1174#define RETURN_ALREADY_STARTED ENCODE_ERROR (20)
1179#define RETURN_ABORTED ENCODE_ERROR (21)
1184#define RETURN_ICMP_ERROR ENCODE_ERROR (22)
1189#define RETURN_TFTP_ERROR ENCODE_ERROR (23)
1194#define RETURN_PROTOCOL_ERROR ENCODE_ERROR (24)
1200#define RETURN_INCOMPATIBLE_VERSION ENCODE_ERROR (25)
1205#define RETURN_SECURITY_VIOLATION ENCODE_ERROR (26)
1210#define RETURN_CRC_ERROR ENCODE_ERROR (27)
1215#define RETURN_END_OF_MEDIA ENCODE_ERROR (28)
1220#define RETURN_END_OF_FILE ENCODE_ERROR (31)
1225#define RETURN_INVALID_LANGUAGE ENCODE_ERROR (32)
1232#define RETURN_COMPROMISED_DATA ENCODE_ERROR (33)
1237#define RETURN_IP_ADDRESS_CONFLICT ENCODE_ERROR (34)
1242#define RETURN_HTTP_ERROR ENCODE_ERROR (35)
1248#define RETURN_WARN_UNKNOWN_GLYPH ENCODE_WARNING (1)
1253#define RETURN_WARN_DELETE_FAILURE ENCODE_WARNING (2)
1259#define RETURN_WARN_WRITE_FAILURE ENCODE_WARNING (3)
1265#define RETURN_WARN_BUFFER_TOO_SMALL ENCODE_WARNING (4)
1271#define RETURN_WARN_STALE_DATA ENCODE_WARNING (5)
1276#define RETURN_WARN_FILE_SYSTEM ENCODE_WARNING (6)
1281#define RETURN_WARN_RESET_REQUIRED ENCODE_WARNING (7)
1295#define SIGNATURE_16(A, B) ((A) | (B << 8))
1312#define SIGNATURE_32(A, B, C, D) (SIGNATURE_16 (A, B) | (SIGNATURE_16 (C, D) << 16))
1333#define SIGNATURE_64(A, B, C, D, E, F, G, H) \
1334 (SIGNATURE_32 (A, B, C, D) | ((UINT64) (SIGNATURE_32 (E, F, G, H)) << 32))
1336#if defined (_MSC_EXTENSIONS) && !defined (__INTEL_COMPILER) && !defined (MDE_CPU_EBC)
1342 #pragma intrinsic(_ReturnAddress)
1356#define RETURN_ADDRESS(L) ((L == 0) ? _ReturnAddress() : (VOID *) 0)
1357#elif defined (__GNUC__) || defined (__clang__)
1370#define RETURN_ADDRESS(L) __builtin_return_address (L)
1381#define RETURN_ADDRESS(L) ((VOID *) 0)
1395#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.