xref: /freebsd/stand/efi/include/amd64/efibind.h (revision 5ab1c5846ff41be24b1f6beb0317bf8258cd4409)
1 /* $FreeBSD$ */
2 /*++
3 
4 Copyright (c)  1999 - 2003 Intel Corporation. All rights reserved
5 This software and associated documentation (if any) is furnished
6 under a license and may only be used or copied in accordance
7 with the terms of the license. Except as permitted by such
8 license, no part of this software or documentation may be
9 reproduced, stored in a retrieval system, or transmitted in any
10 form or by any means without the express written consent of
11 Intel Corporation.
12 
13 Module Name:
14 
15     efefind.h
16 
17 Abstract:
18 
19     EFI to compile bindings
20 
21 
22 
23 
24 Revision History
25 
26 --*/
27 
28 #pragma pack()
29 
30 
31 #ifdef __FreeBSD__
32 #include <sys/stdint.h>
33 #else
34 //
35 // Basic int types of various widths
36 //
37 
38 #if (__STDC_VERSION__ < 199901L )
39 
40     // No ANSI C 1999/2000 stdint.h integer width declarations
41 
42     #ifdef _MSC_EXTENSIONS
43 
44         // Use Microsoft C compiler integer width declarations
45 
46         typedef unsigned __int64    uint64_t;
47         typedef __int64             int64_t;
48         typedef unsigned __int32    uint32_t;
49         typedef __int32             int32_t;
50         typedef unsigned short      uint16_t;
51         typedef short               int16_t;
52         typedef unsigned char       uint8_t;
53         typedef char                int8_t;
54     #else
55         #ifdef UNIX_LP64
56 
57             // Use LP64 programming model from C_FLAGS for integer width declarations
58 
59             typedef unsigned long       uint64_t;
60             typedef long                int64_t;
61             typedef unsigned int        uint32_t;
62             typedef int                 int32_t;
63             typedef unsigned short      uint16_t;
64             typedef short               int16_t;
65             typedef unsigned char       uint8_t;
66             typedef char                int8_t;
67         #else
68 
69             // Assume P64 programming model from C_FLAGS for integer width declarations
70 
71             typedef unsigned long long  uint64_t;
72             typedef long long           int64_t;
73             typedef unsigned int        uint32_t;
74             typedef int                 int32_t;
75             typedef unsigned short      uint16_t;
76             typedef short               int16_t;
77             typedef unsigned char       uint8_t;
78             typedef char                int8_t;
79         #endif
80     #endif
81 #endif
82 #endif	/* __FreeBSD__ */
83 
84 //
85 // Basic EFI types of various widths
86 //
87 
88 #ifndef ACPI_THREAD_ID		/* ACPI's definitions are fine */
89 #define ACPI_USE_SYSTEM_INTTYPES 1	/* Tell ACPI we've defined types */
90 
91 typedef uint64_t   UINT64;
92 typedef int64_t    INT64;
93 
94 #ifndef _BASETSD_H_
95     typedef uint32_t   UINT32;
96     typedef int32_t    INT32;
97 #endif
98 
99 typedef uint16_t   UINT16;
100 typedef int16_t    INT16;
101 typedef uint8_t    UINT8;
102 typedef int8_t     INT8;
103 
104 #endif
105 
106 #undef VOID
107 #define VOID    void
108 
109 
110 typedef int64_t    INTN;
111 typedef uint64_t   UINTN;
112 
113 #ifdef EFI_NT_EMULATOR
114     #define POST_CODE(_Data)
115 #else
116     #ifdef EFI_DEBUG
117 #define POST_CODE(_Data)    __asm mov eax,(_Data) __asm out 0x80,al
118     #else
119         #define POST_CODE(_Data)
120     #endif
121 #endif
122 
123 #define EFIERR(a)           (0x8000000000000000 | a)
124 #define EFI_ERROR_MASK      0x8000000000000000
125 #define EFIERR_OEM(a)       (0xc000000000000000 | a)
126 
127 
128 #define BAD_POINTER         0xFBFBFBFBFBFBFBFB
129 #define MAX_ADDRESS         0xFFFFFFFFFFFFFFFF
130 
131 #define BREAKPOINT()        __asm { int 3 }
132 
133 //
134 // Pointers must be aligned to these address to function
135 //
136 
137 #define MIN_ALIGNMENT_SIZE  4
138 
139 #define ALIGN_VARIABLE(Value ,Adjustment) \
140             (UINTN)Adjustment = 0; \
141             if((UINTN)Value % MIN_ALIGNMENT_SIZE) \
142                 (UINTN)Adjustment = MIN_ALIGNMENT_SIZE - ((UINTN)Value % MIN_ALIGNMENT_SIZE); \
143             Value = (UINTN)Value + (UINTN)Adjustment
144 
145 
146 //
147 // Define macros to build data structure signatures from characters.
148 //
149 
150 #define EFI_SIGNATURE_16(A,B)             ((A) | (B<<8))
151 #define EFI_SIGNATURE_32(A,B,C,D)         (EFI_SIGNATURE_16(A,B)     | (EFI_SIGNATURE_16(C,D)     << 16))
152 #define EFI_SIGNATURE_64(A,B,C,D,E,F,G,H) (EFI_SIGNATURE_32(A,B,C,D) | ((UINT64)(EFI_SIGNATURE_32(E,F,G,H)) << 32))
153 
154 //
155 // EFIAPI - prototype calling convention for EFI function pointers
156 // BOOTSERVICE - prototype for implementation of a boot service interface
157 // RUNTIMESERVICE - prototype for implementation of a runtime service interface
158 // RUNTIMEFUNCTION - prototype for implementation of a runtime function that is not a service
159 // RUNTIME_CODE - pragma macro for declaring runtime code
160 //
161 
162 #ifdef	__amd64__
163 #define	EFIAPI	__attribute__((ms_abi))
164 #endif
165 
166 #ifndef EFIAPI                  // Forces EFI calling conventions reguardless of compiler options
167     #ifdef _MSC_EXTENSIONS
168         #define EFIAPI __cdecl  // Force C calling convention for Microsoft C compiler
169     #else
170         #define EFIAPI          // Substitute expresion to force C calling convention
171     #endif
172 #endif
173 
174 #define BOOTSERVICE
175 //#define RUNTIMESERVICE(proto,a)    alloc_text("rtcode",a); proto a
176 //#define RUNTIMEFUNCTION(proto,a)   alloc_text("rtcode",a); proto a
177 #define RUNTIMESERVICE
178 #define RUNTIMEFUNCTION
179 
180 
181 #define RUNTIME_CODE(a)         alloc_text("rtcode", a)
182 #define BEGIN_RUNTIME_DATA()    data_seg("rtdata")
183 #define END_RUNTIME_DATA()      data_seg("")
184 
185 #define VOLATILE    volatile
186 
187 #define MEMORY_FENCE()
188 
189 #ifdef EFI_NO_INTERFACE_DECL
190   #define EFI_FORWARD_DECLARATION(x)
191   #define EFI_INTERFACE_DECL(x)
192 #else
193   #define EFI_FORWARD_DECLARATION(x) typedef struct _##x x
194   #define EFI_INTERFACE_DECL(x) typedef struct x
195 #endif
196 
197 #ifdef EFI_NT_EMULATOR
198 
199 //
200 // To help ensure proper coding of integrated drivers, they are
201 // compiled as DLLs.  In NT they require a dll init entry pointer.
202 // The macro puts a stub entry point into the DLL so it will load.
203 //
204 
205 #define EFI_DRIVER_ENTRY_POINT(InitFunction)            \
206     EFI_STATUS                                          \
207     InitFunction (                                      \
208       EFI_HANDLE  ImageHandle,                          \
209       EFI_SYSTEM_TABLE  *SystemTable                    \
210       );                                                \
211                                                         \
212     UINTN                                               \
213     __stdcall                                           \
214     _DllMainCRTStartup (                                \
215         UINTN    Inst,                                  \
216         UINTN    reason_for_call,                       \
217         VOID    *rserved                                \
218         )                                               \
219     {                                                   \
220         return 1;                                       \
221     }                                                   \
222                                                         \
223     int                                                 \
224     __declspec( dllexport )                             \
225     __cdecl                                             \
226     InitializeDriver (                                  \
227         void *ImageHandle,                              \
228         void *SystemTable                               \
229         )                                               \
230     {                                                   \
231         return InitFunction(ImageHandle, SystemTable);  \
232     }
233 
234 
235     #define LOAD_INTERNAL_DRIVER(_if, type, name, entry)      \
236         (_if)->LoadInternal(type, name, NULL)
237 
238 #else // EFI_NT_EMULATOR
239 
240 //
241 // When building similar to FW, link everything together as
242 // one big module.
243 //
244 
245     #define EFI_DRIVER_ENTRY_POINT(InitFunction)
246 
247     #define LOAD_INTERNAL_DRIVER(_if, type, name, entry)    \
248             (_if)->LoadInternal(type, name, entry)
249 
250 #endif // EFI_FW_NT
251 
252 #ifdef __FreeBSD__
253 #define INTERFACE_DECL(x) struct x
254 #else
255 //
256 // Some compilers don't support the forward reference construct:
257 //  typedef struct XXXXX
258 //
259 // The following macro provide a workaround for such cases.
260 //
261 #ifdef NO_INTERFACE_DECL
262 #define INTERFACE_DECL(x)
263 #else
264 #define INTERFACE_DECL(x) typedef struct x
265 #endif
266 #endif	/* __FreeBSD__ */
267 
268 #ifdef _MSC_EXTENSIONS
269 #pragma warning ( disable : 4731 )  // Suppress warnings about modification of EBP
270 #endif
271 
272