TianoCore EDK2 master
Loading...
Searching...
No Matches
Base.h
Go to the documentation of this file.
1
15#ifndef __BASE_H__
16#define __BASE_H__
17
18//
19// Include processor specific binding
20//
21#include <ProcessorBind.h>
22
23#if defined (_MSC_EXTENSIONS)
24//
25// Disable warning when last field of data structure is a zero sized array.
26//
27 #pragma warning ( disable : 4200 )
28#endif
29
30//
31// The Microsoft* C compiler can removed references to unreferenced data items
32// if the /OPT:REF linker option is used. We defined a macro as this is a
33// a non standard extension
34//
35#if defined (_MSC_VER) && _MSC_VER < 1800 && !defined (MDE_CPU_EBC)
41#define GLOBAL_REMOVE_IF_UNREFERENCED __declspec(selectany)
42#else
48#define GLOBAL_REMOVE_IF_UNREFERENCED
49#endif
50
51//
52// Should be used in combination with NORETURN to avoid 'noreturn' returns
53// warnings.
54//
55#ifndef UNREACHABLE
56 #ifdef __GNUC__
61#define UNREACHABLE() __builtin_unreachable ()
62 #elif defined (__has_builtin) && defined (__has_feature)
63 #if __has_builtin (__builtin_unreachable)
68#define UNREACHABLE() __builtin_unreachable ()
69 #endif
70 #endif
71
72 #ifndef UNREACHABLE
77#define UNREACHABLE()
78 #endif
79#endif
80
81//
82// Signaling compilers and analyzers that a certain function cannot return may
83// remove all following code and thus lead to better optimization and less
84// false positives.
85//
86#ifndef NORETURN
87 #if defined (__GNUC__) || defined (__clang__)
93#define NORETURN __attribute__((noreturn))
94 #elif defined (_MSC_EXTENSIONS) && !defined (MDE_CPU_EBC)
100#define NORETURN __declspec(noreturn)
101 #else
107#define NORETURN
108 #endif
109#endif
110
111//
112// Should be used in combination with ANALYZER_NORETURN to avoid 'noreturn'
113// returns warnings.
114//
115#ifndef ANALYZER_UNREACHABLE
116 #ifdef __clang_analyzer__
117 #if __has_builtin (__builtin_unreachable)
122#define ANALYZER_UNREACHABLE() __builtin_unreachable ()
123 #endif
124 #endif
125
126 #ifndef ANALYZER_UNREACHABLE
131#define ANALYZER_UNREACHABLE()
132 #endif
133#endif
134
135//
136// Static Analyzers may issue errors about potential NULL-dereferences when
137// dereferencing a pointer, that has been checked before, outside of a
138// NULL-check. This may lead to false positives, such as when using ASSERT()
139// for verification.
140//
141#ifndef ANALYZER_NORETURN
142 #ifdef __has_feature
143 #if __has_feature (attribute_analyzer_noreturn)
148#define ANALYZER_NORETURN __attribute__((analyzer_noreturn))
149 #endif
150 #endif
151
152 #ifndef ANALYZER_NORETURN
157#define ANALYZER_NORETURN
158 #endif
159#endif
160
165#ifndef RETURNS_TWICE
166 #if defined (__GNUC__) || defined (__clang__)
171#define RETURNS_TWICE __attribute__((returns_twice))
172 #else
177#define RETURNS_TWICE
178 #endif
179#endif
180
181//
182// For symbol name in assembly code, an extra "_" is sometimes necessary
183//
184
188#define _CONCATENATE(a, b) __CONCATENATE(a, b)
189#define __CONCATENATE(a, b) a ## b
190
195#define ASM_PFX(name) _CONCATENATE (__USER_LABEL_PREFIX__, name)
196
197#ifdef __APPLE__
198//
199// Apple extension that is used by the linker to optimize code size
200// with assembly functions. Put at the end of your .S files
201//
202#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED .subsections_via_symbols
203#else
204#define ASM_FUNCTION_REMOVE_IF_UNREFERENCED
205#endif
206
207#define PACKED
208
213typedef struct {
214 UINT32 Data1;
215 UINT16 Data2;
216 UINT16 Data3;
217 UINT8 Data4[8];
218} GUID;
219
223typedef struct {
224 UINT8 Addr[4];
226
230typedef struct {
231 UINT8 Addr[16];
233
234//
235// 8-bytes unsigned value that represents a physical system address.
236//
237typedef UINT64 PHYSICAL_ADDRESS;
238
242typedef struct _LIST_ENTRY LIST_ENTRY;
243
248 LIST_ENTRY *ForwardLink;
249 LIST_ENTRY *BackLink;
250};
251
252//
253// Modifiers to abstract standard types to aid in debug of problems
254//
255
259#define CONST const
260
264#define STATIC static
265
269#define VOID void
270
271//
272// Modifiers for Data Types used to self document code.
273// This concept is borrowed for UEFI specification.
274//
275
279#define IN
280
284#define OUT
285
290#define OPTIONAL
291
292//
293// UEFI specification claims 1 and 0. We are concerned about the
294// compiler portability so we did it this way.
295//
296
301#define TRUE ((BOOLEAN)(1==1))
302
307#define FALSE ((BOOLEAN)(0==1))
308
312#if defined (__cplusplus)
313 #if defined (_MSC_EXTENSIONS)
314#define NULL nullptr
315 #else
316#define NULL __null
317 #endif
318#else
319#define NULL ((VOID *) 0)
320#endif
321
322//
323// Null character
324//
325#define CHAR_NULL 0x0000
326
330#define MAX_INT8 ((INT8)0x7F)
331#define MAX_UINT8 ((UINT8)0xFF)
332#define MAX_INT16 ((INT16)0x7FFF)
333#define MAX_UINT16 ((UINT16)0xFFFF)
334#define MAX_INT32 ((INT32)0x7FFFFFFF)
335#define MAX_UINT32 ((UINT32)0xFFFFFFFF)
336#define MAX_INT64 ((INT64)0x7FFFFFFFFFFFFFFFULL)
337#define MAX_UINT64 ((UINT64)0xFFFFFFFFFFFFFFFFULL)
338
342#define MIN_INT8 (((INT8) -127) - 1)
343#define MIN_INT16 (((INT16) -32767) - 1)
344#define MIN_INT32 (((INT32) -2147483647) - 1)
345#define MIN_INT64 (((INT64) -9223372036854775807LL) - 1)
346
347#define BIT0 0x00000001
348#define BIT1 0x00000002
349#define BIT2 0x00000004
350#define BIT3 0x00000008
351#define BIT4 0x00000010
352#define BIT5 0x00000020
353#define BIT6 0x00000040
354#define BIT7 0x00000080
355#define BIT8 0x00000100
356#define BIT9 0x00000200
357#define BIT10 0x00000400
358#define BIT11 0x00000800
359#define BIT12 0x00001000
360#define BIT13 0x00002000
361#define BIT14 0x00004000
362#define BIT15 0x00008000
363#define BIT16 0x00010000
364#define BIT17 0x00020000
365#define BIT18 0x00040000
366#define BIT19 0x00080000
367#define BIT20 0x00100000
368#define BIT21 0x00200000
369#define BIT22 0x00400000
370#define BIT23 0x00800000
371#define BIT24 0x01000000
372#define BIT25 0x02000000
373#define BIT26 0x04000000
374#define BIT27 0x08000000
375#define BIT28 0x10000000
376#define BIT29 0x20000000
377#define BIT30 0x40000000
378#define BIT31 0x80000000
379#define BIT32 0x0000000100000000ULL
380#define BIT33 0x0000000200000000ULL
381#define BIT34 0x0000000400000000ULL
382#define BIT35 0x0000000800000000ULL
383#define BIT36 0x0000001000000000ULL
384#define BIT37 0x0000002000000000ULL
385#define BIT38 0x0000004000000000ULL
386#define BIT39 0x0000008000000000ULL
387#define BIT40 0x0000010000000000ULL
388#define BIT41 0x0000020000000000ULL
389#define BIT42 0x0000040000000000ULL
390#define BIT43 0x0000080000000000ULL
391#define BIT44 0x0000100000000000ULL
392#define BIT45 0x0000200000000000ULL
393#define BIT46 0x0000400000000000ULL
394#define BIT47 0x0000800000000000ULL
395#define BIT48 0x0001000000000000ULL
396#define BIT49 0x0002000000000000ULL
397#define BIT50 0x0004000000000000ULL
398#define BIT51 0x0008000000000000ULL
399#define BIT52 0x0010000000000000ULL
400#define BIT53 0x0020000000000000ULL
401#define BIT54 0x0040000000000000ULL
402#define BIT55 0x0080000000000000ULL
403#define BIT56 0x0100000000000000ULL
404#define BIT57 0x0200000000000000ULL
405#define BIT58 0x0400000000000000ULL
406#define BIT59 0x0800000000000000ULL
407#define BIT60 0x1000000000000000ULL
408#define BIT61 0x2000000000000000ULL
409#define BIT62 0x4000000000000000ULL
410#define BIT63 0x8000000000000000ULL
411
412#define SIZE_1KB 0x00000400
413#define SIZE_2KB 0x00000800
414#define SIZE_4KB 0x00001000
415#define SIZE_8KB 0x00002000
416#define SIZE_16KB 0x00004000
417#define SIZE_32KB 0x00008000
418#define SIZE_64KB 0x00010000
419#define SIZE_128KB 0x00020000
420#define SIZE_256KB 0x00040000
421#define SIZE_512KB 0x00080000
422#define SIZE_1MB 0x00100000
423#define SIZE_2MB 0x00200000
424#define SIZE_4MB 0x00400000
425#define SIZE_8MB 0x00800000
426#define SIZE_16MB 0x01000000
427#define SIZE_32MB 0x02000000
428#define SIZE_64MB 0x04000000
429#define SIZE_128MB 0x08000000
430#define SIZE_256MB 0x10000000
431#define SIZE_512MB 0x20000000
432#define SIZE_1GB 0x40000000
433#define SIZE_2GB 0x80000000
434#define SIZE_4GB 0x0000000100000000ULL
435#define SIZE_8GB 0x0000000200000000ULL
436#define SIZE_16GB 0x0000000400000000ULL
437#define SIZE_32GB 0x0000000800000000ULL
438#define SIZE_64GB 0x0000001000000000ULL
439#define SIZE_128GB 0x0000002000000000ULL
440#define SIZE_256GB 0x0000004000000000ULL
441#define SIZE_512GB 0x0000008000000000ULL
442#define SIZE_1TB 0x0000010000000000ULL
443#define SIZE_2TB 0x0000020000000000ULL
444#define SIZE_4TB 0x0000040000000000ULL
445#define SIZE_8TB 0x0000080000000000ULL
446#define SIZE_16TB 0x0000100000000000ULL
447#define SIZE_32TB 0x0000200000000000ULL
448#define SIZE_64TB 0x0000400000000000ULL
449#define SIZE_128TB 0x0000800000000000ULL
450#define SIZE_256TB 0x0001000000000000ULL
451#define SIZE_512TB 0x0002000000000000ULL
452#define SIZE_1PB 0x0004000000000000ULL
453#define SIZE_2PB 0x0008000000000000ULL
454#define SIZE_4PB 0x0010000000000000ULL
455#define SIZE_8PB 0x0020000000000000ULL
456#define SIZE_16PB 0x0040000000000000ULL
457#define SIZE_32PB 0x0080000000000000ULL
458#define SIZE_64PB 0x0100000000000000ULL
459#define SIZE_128PB 0x0200000000000000ULL
460#define SIZE_256PB 0x0400000000000000ULL
461#define SIZE_512PB 0x0800000000000000ULL
462#define SIZE_1EB 0x1000000000000000ULL
463#define SIZE_2EB 0x2000000000000000ULL
464#define SIZE_4EB 0x4000000000000000ULL
465#define SIZE_8EB 0x8000000000000000ULL
466
467#define BASE_1KB 0x00000400
468#define BASE_2KB 0x00000800
469#define BASE_4KB 0x00001000
470#define BASE_8KB 0x00002000
471#define BASE_16KB 0x00004000
472#define BASE_32KB 0x00008000
473#define BASE_64KB 0x00010000
474#define BASE_128KB 0x00020000
475#define BASE_256KB 0x00040000
476#define BASE_512KB 0x00080000
477#define BASE_1MB 0x00100000
478#define BASE_2MB 0x00200000
479#define BASE_4MB 0x00400000
480#define BASE_8MB 0x00800000
481#define BASE_16MB 0x01000000
482#define BASE_32MB 0x02000000
483#define BASE_64MB 0x04000000
484#define BASE_128MB 0x08000000
485#define BASE_256MB 0x10000000
486#define BASE_512MB 0x20000000
487#define BASE_1GB 0x40000000
488#define BASE_2GB 0x80000000
489#define BASE_4GB 0x0000000100000000ULL
490#define BASE_8GB 0x0000000200000000ULL
491#define BASE_16GB 0x0000000400000000ULL
492#define BASE_32GB 0x0000000800000000ULL
493#define BASE_64GB 0x0000001000000000ULL
494#define BASE_128GB 0x0000002000000000ULL
495#define BASE_256GB 0x0000004000000000ULL
496#define BASE_512GB 0x0000008000000000ULL
497#define BASE_1TB 0x0000010000000000ULL
498#define BASE_2TB 0x0000020000000000ULL
499#define BASE_4TB 0x0000040000000000ULL
500#define BASE_8TB 0x0000080000000000ULL
501#define BASE_16TB 0x0000100000000000ULL
502#define BASE_32TB 0x0000200000000000ULL
503#define BASE_64TB 0x0000400000000000ULL
504#define BASE_128TB 0x0000800000000000ULL
505#define BASE_256TB 0x0001000000000000ULL
506#define BASE_512TB 0x0002000000000000ULL
507#define BASE_1PB 0x0004000000000000ULL
508#define BASE_2PB 0x0008000000000000ULL
509#define BASE_4PB 0x0010000000000000ULL
510#define BASE_8PB 0x0020000000000000ULL
511#define BASE_16PB 0x0040000000000000ULL
512#define BASE_32PB 0x0080000000000000ULL
513#define BASE_64PB 0x0100000000000000ULL
514#define BASE_128PB 0x0200000000000000ULL
515#define BASE_256PB 0x0400000000000000ULL
516#define BASE_512PB 0x0800000000000000ULL
517#define BASE_1EB 0x1000000000000000ULL
518#define BASE_2EB 0x2000000000000000ULL
519#define BASE_4EB 0x4000000000000000ULL
520#define BASE_8EB 0x8000000000000000ULL
521
522//
523// Support for variable argument lists in freestanding edk2 modules.
524//
525// For modules that use the ISO C library interfaces for variable
526// argument lists, refer to "StdLib/Include/stdarg.h".
527//
528// VA_LIST - typedef for argument list.
529// VA_START (VA_LIST Marker, argument before the ...) - Init Marker for use.
530// VA_END (VA_LIST Marker) - Clear Marker
531// VA_ARG (VA_LIST Marker, var arg type) - Use Marker to get an argument from
532// the ... list. You must know the type and pass it in this macro. Type
533// must be compatible with the type of the actual next argument (as promoted
534// according to the default argument promotions.)
535// VA_COPY (VA_LIST Dest, VA_LIST Start) - Initialize Dest as a copy of Start.
536//
537// Example:
538//
539// UINTN
540// EFIAPI
541// ExampleVarArg (
542// IN UINTN NumberOfArgs,
543// ...
544// )
545// {
546// VA_LIST Marker;
547// UINTN Index;
548// UINTN Result;
549//
550// //
551// // Initialize the Marker
552// //
553// VA_START (Marker, NumberOfArgs);
554// for (Index = 0, Result = 0; Index < NumberOfArgs; Index++) {
555// //
556// // The ... list is a series of UINTN values, so sum them up.
557// //
558// Result += VA_ARG (Marker, UINTN);
559// }
560//
561// VA_END (Marker);
562// return Result;
563// }
564//
565// Notes:
566// - Functions that call VA_START() / VA_END() must have a variable
567// argument list and must be declared EFIAPI.
568// - Functions that call VA_COPY() / VA_END() must be declared EFIAPI.
569// - Functions that only use VA_LIST and VA_ARG() need not be EFIAPI.
570//
571
579#define _INT_SIZE_OF(n) ((sizeof (n) + sizeof (UINTN) - 1) &~(sizeof (UINTN) - 1))
580
581#if defined (_M_ARM) || defined (_M_ARM64)
582//
583// MSFT ARM variable argument list support.
584//
585
586typedef char *VA_LIST;
587
588#define VA_START(Marker, Parameter) __va_start (&Marker, &Parameter, _INT_SIZE_OF (Parameter), __alignof(Parameter), &Parameter)
589#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE) + ((-(INTN)Marker) & (sizeof(TYPE) - 1))) - _INT_SIZE_OF (TYPE)))
590#define VA_END(Marker) (Marker = (VA_LIST) 0)
591#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
592
593#elif defined (__GNUC__) || defined (__clang__)
594
595 #if defined (MDE_CPU_X64) && !defined (NO_MSABI_VA_FUNCS)
596//
597// X64 only. Use MS ABI version of GCC built-in macros for variable argument lists.
598//
602
607typedef __builtin_ms_va_list VA_LIST;
608
609#define VA_START(Marker, Parameter) __builtin_ms_va_start (Marker, Parameter)
610
611#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
612
613#define VA_END(Marker) __builtin_ms_va_end (Marker)
614
615#define VA_COPY(Dest, Start) __builtin_ms_va_copy (Dest, Start)
616
617 #else
618//
619// Use GCC built-in macros for variable argument lists.
620//
621
626typedef __builtin_va_list VA_LIST;
627
628#define VA_START(Marker, Parameter) __builtin_va_start (Marker, Parameter)
629
630#define VA_ARG(Marker, TYPE) ((sizeof (TYPE) < sizeof (UINTN)) ? (TYPE)(__builtin_va_arg (Marker, UINTN)) : (TYPE)(__builtin_va_arg (Marker, TYPE)))
631
632#define VA_END(Marker) __builtin_va_end (Marker)
633
634#define VA_COPY(Dest, Start) __builtin_va_copy (Dest, Start)
635
636 #endif
637
638#else
643typedef CHAR8 *VA_LIST;
644
661#define VA_START(Marker, Parameter) (Marker = (VA_LIST) ((UINTN) & (Parameter) + _INT_SIZE_OF (Parameter)))
662
679#define VA_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _INT_SIZE_OF (TYPE)) - _INT_SIZE_OF (TYPE)))
680
691#define VA_END(Marker) (Marker = (VA_LIST) 0)
692
704#define VA_COPY(Dest, Start) ((void)((Dest) = (Start)))
705
706#endif
707
712
720#define _BASE_INT_SIZE_OF(TYPE) ((sizeof (TYPE) + sizeof (UINTN) - 1) / sizeof (UINTN))
721
738#define BASE_ARG(Marker, TYPE) (*(TYPE *) ((Marker += _BASE_INT_SIZE_OF (TYPE)) - _BASE_INT_SIZE_OF (TYPE)))
739
753#if (defined (__GNUC__) && __GNUC__ >= 4) || defined (__clang__)
754#define OFFSET_OF(TYPE, Field) ((UINTN) __builtin_offsetof(TYPE, Field))
755#endif
756
757#ifndef OFFSET_OF
758#define OFFSET_OF(TYPE, Field) ((UINTN) &(((TYPE *)0)->Field))
759#endif
760
768#if defined (__cplusplus)
769//
770// Standard C++ operator.
771//
772#define ALIGNOF(TYPE) alignof (TYPE)
773#elif defined (__GNUC__) || defined (__clang__) || (defined (_MSC_VER) && _MSC_VER >= 1900)
774//
775// All supported versions of GCC and Clang, as well as MSVC 2015 and later,
776// support the standard operator _Alignof.
777//
778#define ALIGNOF(TYPE) _Alignof (TYPE)
779#elif defined (_MSC_EXTENSIONS)
780//
781// Earlier versions of MSVC, at least MSVC 2008 and later, support the vendor
782// extension __alignof.
783//
784#define ALIGNOF(TYPE) __alignof (TYPE)
785#else
786//
787// For compilers that do not support inbuilt alignof operators, use OFFSET_OF.
788// CHAR8 is known to have both a size and an alignment requirement of 1 Byte.
789// As such, A must be located exactly at the offset equal to its alignment
790// requirement.
791//
792#define ALIGNOF(TYPE) OFFSET_OF (struct { CHAR8 C; TYPE A; }, A)
793#endif
794
803#ifdef MDE_CPU_EBC
804#define STATIC_ASSERT(Expression, Message)
805#elif defined (_MSC_EXTENSIONS) || defined (__cplusplus)
806#define STATIC_ASSERT static_assert
807#else
808#define STATIC_ASSERT _Static_assert
809#endif
810
811//
812// Verify that ProcessorBind.h produced UEFI Data Types that are compliant with
813// Section 2.3.1 of the UEFI 2.3 Specification.
814//
815
816STATIC_ASSERT (sizeof (BOOLEAN) == 1, "sizeof (BOOLEAN) does not meet UEFI Specification Data Type requirements");
817STATIC_ASSERT (sizeof (INT8) == 1, "sizeof (INT8) does not meet UEFI Specification Data Type requirements");
818STATIC_ASSERT (sizeof (UINT8) == 1, "sizeof (UINT8) does not meet UEFI Specification Data Type requirements");
819STATIC_ASSERT (sizeof (INT16) == 2, "sizeof (INT16) does not meet UEFI Specification Data Type requirements");
820STATIC_ASSERT (sizeof (UINT16) == 2, "sizeof (UINT16) does not meet UEFI Specification Data Type requirements");
821STATIC_ASSERT (sizeof (INT32) == 4, "sizeof (INT32) does not meet UEFI Specification Data Type requirements");
822STATIC_ASSERT (sizeof (UINT32) == 4, "sizeof (UINT32) does not meet UEFI Specification Data Type requirements");
823STATIC_ASSERT (sizeof (INT64) == 8, "sizeof (INT64) does not meet UEFI Specification Data Type requirements");
824STATIC_ASSERT (sizeof (UINT64) == 8, "sizeof (UINT64) does not meet UEFI Specification Data Type requirements");
825STATIC_ASSERT (sizeof (CHAR8) == 1, "sizeof (CHAR8) does not meet UEFI Specification Data Type requirements");
826STATIC_ASSERT (sizeof (CHAR16) == 2, "sizeof (CHAR16) does not meet UEFI Specification Data Type requirements");
827STATIC_ASSERT (sizeof (L'A') == 2, "sizeof (L'A') does not meet UEFI Specification Data Type requirements");
828STATIC_ASSERT (sizeof (L"A") == 4, "sizeof (L\"A\") does not meet UEFI Specification Data Type requirements");
829
830STATIC_ASSERT (ALIGNOF (BOOLEAN) == sizeof (BOOLEAN), "Alignment of BOOLEAN does not meet UEFI Specification Data Type requirements");
831STATIC_ASSERT (ALIGNOF (INT8) == sizeof (INT8), "Alignment of INT8 does not meet UEFI Specification Data Type requirements");
832STATIC_ASSERT (ALIGNOF (UINT8) == sizeof (UINT8), "Alignment of INT16 does not meet UEFI Specification Data Type requirements");
833STATIC_ASSERT (ALIGNOF (INT16) == sizeof (INT16), "Alignment of INT16 does not meet UEFI Specification Data Type requirements");
834STATIC_ASSERT (ALIGNOF (UINT16) == sizeof (UINT16), "Alignment of UINT16 does not meet UEFI Specification Data Type requirements");
835STATIC_ASSERT (ALIGNOF (INT32) == sizeof (INT32), "Alignment of INT32 does not meet UEFI Specification Data Type requirements");
836STATIC_ASSERT (ALIGNOF (UINT32) == sizeof (UINT32), "Alignment of UINT32 does not meet UEFI Specification Data Type requirements");
837STATIC_ASSERT (ALIGNOF (INT64) == sizeof (INT64), "Alignment of INT64 does not meet UEFI Specification Data Type requirements");
838STATIC_ASSERT (ALIGNOF (UINT64) == sizeof (UINT64), "Alignment of UINT64 does not meet UEFI Specification Data Type requirements");
839STATIC_ASSERT (ALIGNOF (CHAR8) == sizeof (CHAR8), "Alignment of CHAR8 does not meet UEFI Specification Data Type requirements");
840STATIC_ASSERT (ALIGNOF (CHAR16) == sizeof (CHAR16), "Alignment of CHAR16 does not meet UEFI Specification Data Type requirements");
841STATIC_ASSERT (ALIGNOF (INTN) == sizeof (INTN), "Alignment of INTN does not meet UEFI Specification Data Type requirements");
842STATIC_ASSERT (ALIGNOF (UINTN) == sizeof (UINTN), "Alignment of UINTN does not meet UEFI Specification Data Type requirements");
843STATIC_ASSERT (ALIGNOF (VOID *) == sizeof (VOID *), "Alignment of VOID * does not meet UEFI Specification Data Type requirements");
844
845//
846// The following three enum types are used to verify that the compiler
847// configuration for enum types is compliant with Section 2.3.1 of the
848// UEFI 2.3.1 Errata C Specification. These enum types and enum values
849// are not intended to be used. A prefix of '__' is used avoid
850// conflicts with other types.
851//
852typedef enum {
853 __VerifyUint8EnumValue = 0xff
854} __VERIFY_UINT8_ENUM_SIZE;
855
856typedef enum {
857 __VerifyUint16EnumValue = 0xffff
858} __VERIFY_UINT16_ENUM_SIZE;
859
860typedef enum {
861 __VerifyInt32EnumValue = 0x7fffffff
862} __VERIFY_INT32_ENUM_SIZE;
863
864STATIC_ASSERT (sizeof (__VERIFY_UINT8_ENUM_SIZE) == 4, "Size of enum does not meet UEFI Specification Data Type requirements");
865STATIC_ASSERT (sizeof (__VERIFY_UINT16_ENUM_SIZE) == 4, "Size of enum does not meet UEFI Specification Data Type requirements");
866STATIC_ASSERT (sizeof (__VERIFY_INT32_ENUM_SIZE) == 4, "Size of enum does not meet UEFI Specification Data Type requirements");
867
868STATIC_ASSERT (ALIGNOF (__VERIFY_UINT8_ENUM_SIZE) == sizeof (__VERIFY_UINT8_ENUM_SIZE), "Alignment of enum does not meet UEFI Specification Data Type requirements");
869STATIC_ASSERT (ALIGNOF (__VERIFY_UINT16_ENUM_SIZE) == sizeof (__VERIFY_UINT16_ENUM_SIZE), "Alignment of enum does not meet UEFI Specification Data Type requirements");
870STATIC_ASSERT (ALIGNOF (__VERIFY_INT32_ENUM_SIZE) == sizeof (__VERIFY_INT32_ENUM_SIZE), "Alignment of enum does not meet UEFI Specification Data Type requirements");
871
891#define BASE_CR(Record, TYPE, Field) ((TYPE *) ((CHAR8 *) (Record) - OFFSET_OF (TYPE, Field)))
892
901#define IS_POW2(Value) ((Value) != 0U && ((Value) & ((Value) - 1U)) == 0U)
902
912#define IS_ALIGNED(Value, Alignment) (((Value) & ((Alignment) - 1U)) == 0U)
913
923#define ADDRESS_IS_ALIGNED(Address, Alignment) IS_ALIGNED ((UINTN) (Address), Alignment)
924
934#define ALIGN_VALUE_ADDEND(Value, Alignment) (((Alignment) - (Value)) & ((Alignment) - 1U))
935
948#define ALIGN_VALUE(Value, Alignment) ((Value) + ALIGN_VALUE_ADDEND (Value, Alignment))
949
963#define ALIGN_POINTER(Pointer, Alignment) ((VOID *) (ALIGN_VALUE ((UINTN)(Pointer), (Alignment))))
964
977#define ALIGN_VARIABLE(Value) ALIGN_VALUE ((Value), sizeof (UINTN))
978
992#define MAX(a, b) \
993 (((a) > (b)) ? (a) : (b))
994
1007#define MIN(a, b) \
1008 (((a) < (b)) ? (a) : (b))
1009
1020#define ABS(a) \
1021 (((a) < 0) ? (-(a)) : (a))
1022
1023//
1024// Status codes common to all execution phases
1025//
1026typedef UINTN RETURN_STATUS;
1027
1037#define ENCODE_ERROR(StatusCode) ((RETURN_STATUS)(MAX_BIT | (StatusCode)))
1038
1048#define ENCODE_WARNING(StatusCode) ((RETURN_STATUS)(StatusCode))
1049
1061#define RETURN_ERROR(StatusCode) (((RETURN_STATUS)(StatusCode)) >= MAX_BIT)
1062
1066#define RETURN_SUCCESS (RETURN_STATUS)(0)
1067
1071#define RETURN_LOAD_ERROR ENCODE_ERROR (1)
1072
1076#define RETURN_INVALID_PARAMETER ENCODE_ERROR (2)
1077
1081#define RETURN_UNSUPPORTED ENCODE_ERROR (3)
1082
1086#define RETURN_BAD_BUFFER_SIZE ENCODE_ERROR (4)
1087
1093#define RETURN_BUFFER_TOO_SMALL ENCODE_ERROR (5)
1094
1098#define RETURN_NOT_READY ENCODE_ERROR (6)
1099
1104#define RETURN_DEVICE_ERROR ENCODE_ERROR (7)
1105
1109#define RETURN_WRITE_PROTECTED ENCODE_ERROR (8)
1110
1114#define RETURN_OUT_OF_RESOURCES ENCODE_ERROR (9)
1115
1120#define RETURN_VOLUME_CORRUPTED ENCODE_ERROR (10)
1121
1125#define RETURN_VOLUME_FULL ENCODE_ERROR (11)
1126
1131#define RETURN_NO_MEDIA ENCODE_ERROR (12)
1132
1137#define RETURN_MEDIA_CHANGED ENCODE_ERROR (13)
1138
1142#define RETURN_NOT_FOUND ENCODE_ERROR (14)
1143
1147#define RETURN_ACCESS_DENIED ENCODE_ERROR (15)
1148
1152#define RETURN_NO_RESPONSE ENCODE_ERROR (16)
1153
1157#define RETURN_NO_MAPPING ENCODE_ERROR (17)
1158
1162#define RETURN_TIMEOUT ENCODE_ERROR (18)
1163
1167#define RETURN_NOT_STARTED ENCODE_ERROR (19)
1168
1172#define RETURN_ALREADY_STARTED ENCODE_ERROR (20)
1173
1177#define RETURN_ABORTED ENCODE_ERROR (21)
1178
1182#define RETURN_ICMP_ERROR ENCODE_ERROR (22)
1183
1187#define RETURN_TFTP_ERROR ENCODE_ERROR (23)
1188
1192#define RETURN_PROTOCOL_ERROR ENCODE_ERROR (24)
1193
1198#define RETURN_INCOMPATIBLE_VERSION ENCODE_ERROR (25)
1199
1203#define RETURN_SECURITY_VIOLATION ENCODE_ERROR (26)
1204
1208#define RETURN_CRC_ERROR ENCODE_ERROR (27)
1209
1213#define RETURN_END_OF_MEDIA ENCODE_ERROR (28)
1214
1218#define RETURN_END_OF_FILE ENCODE_ERROR (31)
1219
1223#define RETURN_INVALID_LANGUAGE ENCODE_ERROR (32)
1224
1230#define RETURN_COMPROMISED_DATA ENCODE_ERROR (33)
1231
1235#define RETURN_IP_ADDRESS_CONFLICT ENCODE_ERROR (34)
1236
1240#define RETURN_HTTP_ERROR ENCODE_ERROR (35)
1241
1246#define RETURN_WARN_UNKNOWN_GLYPH ENCODE_WARNING (1)
1247
1251#define RETURN_WARN_DELETE_FAILURE ENCODE_WARNING (2)
1252
1257#define RETURN_WARN_WRITE_FAILURE ENCODE_WARNING (3)
1258
1263#define RETURN_WARN_BUFFER_TOO_SMALL ENCODE_WARNING (4)
1264
1269#define RETURN_WARN_STALE_DATA ENCODE_WARNING (5)
1270
1274#define RETURN_WARN_FILE_SYSTEM ENCODE_WARNING (6)
1275
1279#define RETURN_WARN_RESET_REQUIRED ENCODE_WARNING (7)
1280
1293#define SIGNATURE_16(A, B) ((A) | (B << 8))
1294
1310#define SIGNATURE_32(A, B, C, D) (SIGNATURE_16 (A, B) | (SIGNATURE_16 (C, D) << 16))
1311
1331#define SIGNATURE_64(A, B, C, D, E, F, G, H) \
1332 (SIGNATURE_32 (A, B, C, D) | ((UINT64) (SIGNATURE_32 (E, F, G, H)) << 32))
1333
1334#if defined (_MSC_EXTENSIONS) && !defined (__INTEL_COMPILER) && !defined (MDE_CPU_EBC)
1335void *
1336_ReturnAddress (
1337 void
1338 );
1339
1340 #pragma intrinsic(_ReturnAddress)
1341
1354#define RETURN_ADDRESS(L) ((L == 0) ? _ReturnAddress() : (VOID *) 0)
1355#elif defined (__GNUC__) || defined (__clang__)
1356
1368#define RETURN_ADDRESS(L) __builtin_return_address (L)
1369#else
1370
1379#define RETURN_ADDRESS(L) ((VOID *) 0)
1380#endif
1381
1393#define ARRAY_SIZE(Array) (sizeof (Array) / sizeof ((Array)[0]))
1394
1395#endif
UINT64 UINTN
INT64 INTN
#define VOID
Definition: Base.h:269
#define STATIC_ASSERT
Definition: Base.h:808
CHAR8 * VA_LIST
Definition: Base.h:643
UINTN * BASE_LIST
Definition: Base.h:711
#define ALIGNOF(TYPE)
Definition: Base.h:792
Definition: Base.h:213