dsound: Compute mix buffer's size more accurately.
[wine] / include / winnt.h
1 /*
2  * Win32 definitions for Windows NT
3  *
4  * Copyright 1996 Alexandre Julliard
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20
21 #ifndef _WINNT_
22 #define _WINNT_
23
24 #include <basetsd.h>
25 #include <guiddef.h>
26
27 #ifndef RC_INVOKED
28 #include <ctype.h>
29 #include <stddef.h>
30 #include <string.h>
31 #endif
32
33
34 #ifdef __cplusplus
35 extern "C" {
36 #endif
37
38 #ifdef _NTSYSTEM_
39 #define NTSYSAPI
40 #else
41 #define NTSYSAPI DECLSPEC_IMPORT
42 #endif
43
44 #define NTAPI __stdcall
45
46 #ifndef MIDL_PASS
47 # if defined(_MSC_VER)
48 #  define DECLSPEC_IMPORT __declspec(dllimport)
49 # elif defined(__MINGW32__) || defined(__CYGWIN__)
50 #  define DECLSPEC_IMPORT __attribute__((dllimport))
51 # else
52 #  define DECLSPEC_IMPORT DECLSPEC_HIDDEN
53 # endif
54 #else
55 # define DECLSPEC_IMPORT
56 #endif
57
58 #ifndef DECLSPEC_NORETURN
59 # if defined(_MSC_VER) && (_MSC_VER >= 1200) && !defined(MIDL_PASS)
60 #  define DECLSPEC_NORETURN __declspec(noreturn)
61 # elif defined(__GNUC__)
62 #  define DECLSPEC_NORETURN __attribute__((noreturn))
63 # else
64 #  define DECLSPEC_NORETURN
65 # endif
66 #endif
67
68 #ifndef DECLSPEC_ALIGN
69 # if defined(_MSC_VER) && (_MSC_VER >= 1300) && !defined(MIDL_PASS)
70 #  define DECLSPEC_ALIGN(x) __declspec(align(x))
71 # elif defined(__GNUC__)
72 #  define DECLSPEC_ALIGN(x) __attribute__((aligned(x)))
73 # else
74 #  define DECLSPEC_ALIGN(x)
75 # endif
76 #endif
77
78 #ifndef DECLSPEC_CACHEALIGN
79 # define DECLSPEC_CACHEALIGN DECLSPEC_ALIGN(128)
80 #endif
81
82 #ifndef DECLSPEC_UUID
83 # if defined(_MSC_VER) && (_MSC_VER >= 1100) && defined (__cplusplus)
84 #  define DECLSPEC_UUID(x) __declspec(uuid(x))
85 # else
86 #  define DECLSPEC_UUID(x)
87 # endif
88 #endif
89
90 #ifndef DECLSPEC_NOVTABLE
91 # if defined(_MSC_VER) && (_MSC_VER >= 1100) && defined(__cplusplus)
92 #  define DECLSPEC_NOVTABLE __declspec(novtable)
93 # else
94 #  define DECLSPEC_NOVTABLE
95 # endif
96 #endif
97
98 #ifndef DECLSPEC_SELECTANY
99 #if defined(_MSC_VER) && (_MSC_VER >= 1100)
100 #define DECLSPEC_SELECTANY __declspec(selectany)
101 #else
102 #define DECLSPEC_SELECTANY
103 #endif
104 #endif
105
106 #ifndef NOP_FUNCTION
107 # if defined(_MSC_VER) && (_MSC_VER >= 1210)
108 #  define NOP_FUNCTION __noop
109 # else
110 #  define NOP_FUNCTION (void)0
111 # endif
112 #endif
113
114 #ifndef DECLSPEC_ADDRSAFE
115 # if defined(_MSC_VER) && (_MSC_VER >= 1200) && (defined(_M_ALPHA) || defined(_M_AXP64))
116 #  define DECLSPEC_ADDRSAFE __declspec(address_safe)
117 # else
118 #  define DECLSPEC_ADDRSAFE
119 # endif
120 #endif
121
122 #ifndef FORCEINLINE
123 # if defined(_MSC_VER) && (_MSC_VER >= 1200)
124 #  define FORCEINLINE __forceinline
125 # elif defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 2)))
126 #  define FORCEINLINE inline __attribute__((always_inline))
127 # else
128 #  define FORCEINLINE inline
129 # endif
130 #endif
131
132 #ifndef DECLSPEC_DEPRECATED
133 # if defined(_MSC_VER) && (_MSC_VER >= 1300) && !defined(MIDL_PASS)
134 #  define DECLSPEC_DEPRECATED __declspec(deprecated)
135 #  define DEPRECATE_SUPPORTED
136 # elif defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 2)))
137 #  define DECLSPEC_DEPRECATED __attribute__((deprecated))
138 #  define DEPRECATE_SUPPORTED
139 # else
140 #  define DECLSPEC_DEPRECATED
141 #  undef  DEPRECATE_SUPPORTED
142 # endif
143 #endif
144
145 /* a couple of useful Wine extensions */
146
147 #ifdef _MSC_VER
148 # define DECLSPEC_EXPORT __declspec(dllexport)
149 #elif defined(__MINGW32__)
150 # define DECLSPEC_EXPORT __attribute__((dllexport))
151 #elif defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)))
152 # define DECLSPEC_EXPORT __attribute__((visibility ("default")))
153 #else
154 # define DECLSPEC_EXPORT
155 #endif
156
157 #if defined(__MSC_VER) || defined(__MINGW32__) || defined(__CYGWIN__)
158 # define DECLSPEC_HIDDEN
159 #elif defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)))
160 # define DECLSPEC_HIDDEN __attribute__((visibility ("hidden")))
161 #else
162 # define DECLSPEC_HIDDEN
163 #endif
164
165 #if defined(__GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 3)))
166 #define __WINE_ALLOC_SIZE(x) __attribute__((__alloc_size__(x)))
167 #else
168 #define __WINE_ALLOC_SIZE(x)
169 #endif
170
171 /* Anonymous union/struct handling */
172
173 #ifndef NONAMELESSSTRUCT
174 # ifdef __GNUC__
175    /* Anonymous struct support starts with gcc 2.96 or gcc/g++ 3.x */
176 #  if (__GNUC__ < 2) || ((__GNUC__ == 2) && (defined(__cplusplus) || (__GNUC_MINOR__ < 96)))
177 #   define NONAMELESSSTRUCT
178 #  endif
179 # elif defined(__SUNPRO_C) || defined(__SUNPRO_CC)
180 #  define NONAMELESSSTRUCT
181 # endif
182 #endif  /* NONAMELESSSTRUCT */
183
184 #ifndef NONAMELESSUNION
185 # ifdef __GNUC__
186    /* Anonymous unions support starts with gcc 2.96/g++ 2.95 */
187 #  if (__GNUC__ < 2) || ((__GNUC__ == 2) && ((__GNUC_MINOR__ < 95) || ((__GNUC_MINOR__ == 95) && !defined(__cplusplus))))
188 #   define NONAMELESSUNION
189 #  endif
190 # elif defined(__SUNPRO_C) || defined(__SUNPRO_CC)
191 #  define NONAMELESSUNION
192 # endif
193 #endif  /* NONAMELESSUNION */
194
195 #undef DUMMYSTRUCTNAME
196 #undef DUMMYSTRUCTNAME1
197 #undef DUMMYSTRUCTNAME2
198 #undef DUMMYSTRUCTNAME3
199 #undef DUMMYSTRUCTNAME4
200 #undef DUMMYSTRUCTNAME5
201 #ifndef NONAMELESSSTRUCT
202 #define DUMMYSTRUCTNAME
203 #define DUMMYSTRUCTNAME1
204 #define DUMMYSTRUCTNAME2
205 #define DUMMYSTRUCTNAME3
206 #define DUMMYSTRUCTNAME4
207 #define DUMMYSTRUCTNAME5
208 #else /* !defined(NONAMELESSSTRUCT) */
209 #define DUMMYSTRUCTNAME   s
210 #define DUMMYSTRUCTNAME1  s1
211 #define DUMMYSTRUCTNAME2  s2
212 #define DUMMYSTRUCTNAME3  s3
213 #define DUMMYSTRUCTNAME4  s4
214 #define DUMMYSTRUCTNAME5  s5
215 #endif /* !defined(NONAMELESSSTRUCT) */
216
217 #undef DUMMYUNIONNAME
218 #undef DUMMYUNIONNAME1
219 #undef DUMMYUNIONNAME2
220 #undef DUMMYUNIONNAME3
221 #undef DUMMYUNIONNAME4
222 #undef DUMMYUNIONNAME5
223 #undef DUMMYUNIONNAME6
224 #undef DUMMYUNIONNAME7
225 #undef DUMMYUNIONNAME8
226 #ifndef NONAMELESSUNION
227 #define DUMMYUNIONNAME
228 #define DUMMYUNIONNAME1
229 #define DUMMYUNIONNAME2
230 #define DUMMYUNIONNAME3
231 #define DUMMYUNIONNAME4
232 #define DUMMYUNIONNAME5
233 #define DUMMYUNIONNAME6
234 #define DUMMYUNIONNAME7
235 #define DUMMYUNIONNAME8
236 #else /* !defined(NONAMELESSUNION) */
237 #define DUMMYUNIONNAME   u
238 #define DUMMYUNIONNAME1  u1
239 #define DUMMYUNIONNAME2  u2
240 #define DUMMYUNIONNAME3  u3
241 #define DUMMYUNIONNAME4  u4
242 #define DUMMYUNIONNAME5  u5
243 #define DUMMYUNIONNAME6  u6
244 #define DUMMYUNIONNAME7  u7
245 #define DUMMYUNIONNAME8  u8
246 #endif /* !defined(NONAMELESSUNION) */
247
248 #undef __C89_NAMELESS
249 #undef __C89_NAMELESSSTRUCTNAME
250 #undef __C89_NAMELESSSTRUCTNAME1
251 #undef __C89_NAMELESSSTRUCTNAME2
252 #undef __C89_NAMELESSSTRUCTNAME3
253 #undef __C89_NAMELESSSTRUCTNAME4
254 #undef __C89_NAMELESSSTRUCTNAME5
255 #undef __C89_NAMELESSUNIONNAME
256 #undef __C89_NAMELESSUNIONNAME1
257 #undef __C89_NAMELESSUNIONNAME2
258 #undef __C89_NAMELESSUNIONNAME3
259 #undef __C89_NAMELESSUNIONNAME4
260 #undef __C89_NAMELESSUNIONNAME5
261 #undef __C89_NAMELESSUNIONNAME6
262 #undef __C89_NAMELESSUNIONNAME7
263 #undef __C89_NAMELESSUNIONNAME8
264
265 #if !defined(__WINESRC__) && !defined(WINE_NO_NAMELESS_EXTENSION)
266 # ifdef __GNUC__
267    /* Anonymous structs support starts with gcc 2.96/g++ 2.95 */
268 #  if (__GNUC__ > 2) || ((__GNUC__ == 2) && ((__GNUC_MINOR__ > 95) || ((__GNUC_MINOR__ == 95) && defined(__cplusplus))))
269 #   define __C89_NAMELESS __extension__
270 #  endif
271 # elif defined(_MSC_VER)
272 #  define __C89_NAMELESS
273 # endif
274 #endif
275
276 #ifdef __C89_NAMELESS
277 #  define __C89_NAMELESSSTRUCTNAME
278 #  define __C89_NAMELESSSTRUCTNAME1
279 #  define __C89_NAMELESSSTRUCTNAME2
280 #  define __C89_NAMELESSSTRUCTNAME3
281 #  define __C89_NAMELESSSTRUCTNAME4
282 #  define __C89_NAMELESSSTRUCTNAME5
283 #  define __C89_NAMELESSUNIONNAME
284 #  define __C89_NAMELESSUNIONNAME1
285 #  define __C89_NAMELESSUNIONNAME2
286 #  define __C89_NAMELESSUNIONNAME3
287 #  define __C89_NAMELESSUNIONNAME4
288 #  define __C89_NAMELESSUNIONNAME5
289 #  define __C89_NAMELESSUNIONNAME6
290 #  define __C89_NAMELESSUNIONNAME7
291 #  define __C89_NAMELESSUNIONNAME8
292 #else
293 #  define __C89_NAMELESS
294 #  define __C89_NAMELESSSTRUCTNAME DUMMYSTRUCTNAME
295 #  define __C89_NAMELESSSTRUCTNAME1 DUMMYSTRUCTNAME1
296 #  define __C89_NAMELESSSTRUCTNAME2 DUMMYSTRUCTNAME2
297 #  define __C89_NAMELESSSTRUCTNAME3 DUMMYSTRUCTNAME3
298 #  define __C89_NAMELESSSTRUCTNAME4 DUMMYSTRUCTNAME4
299 #  define __C89_NAMELESSSTRUCTNAME5 DUMMYSTRUCTNAME5
300 #  define __C89_NAMELESSUNIONNAME DUMMYUNIONNAME
301 #  define __C89_NAMELESSUNIONNAME1 DUMMYUNIONNAME1
302 #  define __C89_NAMELESSUNIONNAME2 DUMMYUNIONNAME2
303 #  define __C89_NAMELESSUNIONNAME3 DUMMYUNIONNAME3
304 #  define __C89_NAMELESSUNIONNAME4 DUMMYUNIONNAME4
305 #  define __C89_NAMELESSUNIONNAME5 DUMMYUNIONNAME5
306 #  define __C89_NAMELESSUNIONNAME6 DUMMYUNIONNAME6
307 #  define __C89_NAMELESSUNIONNAME7 DUMMYUNIONNAME7
308 #  define __C89_NAMELESSUNIONNAME8 DUMMYUNIONNAME8
309 #endif
310
311 /* C99 restrict support */
312
313 #if defined(ENABLE_RESTRICTED) && !defined(MIDL_PASS) && !defined(RC_INVOKED)
314 # if defined(_MSC_VER) && defined(_M_MRX000)
315 #  define RESTRICTED_POINTER __restrict
316 # elif defined(__GNUC__) && ((__GNUC__ > 2) || ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 95)))
317 #  define RESTRICTED_POINTER __restrict
318 # else
319 #  define RESTRICTED_POINTER
320 # endif
321 #else
322 # define RESTRICTED_POINTER
323 #endif
324
325 /* C99 unaligned support */
326
327 #ifndef UNALIGNED
328 #if defined(_MSC_VER) && (defined(_M_MRX000) || defined(_M_ALPHA) || defined(_M_PPC) || defined(_M_IA64) || defined(_M_AMD64))
329 # define UNALIGNED __unaligned
330 # ifdef _WIN64
331 #  define UNALIGNED64 __unaligned
332 # else
333 #  define UNALIGNED64
334 # endif
335 #else
336 # define UNALIGNED
337 # define UNALIGNED64
338 #endif
339 #endif
340
341 /* Alignment macros */
342
343 #if defined(_WIN64) || (defined(_MSC_VER) && defined(_M_ALPHA)) || defined(__alpha__)
344 #define MAX_NATURAL_ALIGNMENT sizeof(ULONGLONG)
345 #define MEMORY_ALLOCATION_ALIGNMENT 16
346 #else
347 #define MAX_NATURAL_ALIGNMENT sizeof(DWORD)
348 #define MEMORY_ALLOCATION_ALIGNMENT 8
349 #endif
350
351 #if defined(_MSC_VER) && (_MSC_VER >= 1300) && defined(__cplusplus)
352 # define TYPE_ALIGNMENT(t) __alignof(t)
353 #elif defined(__GNUC__)
354 # define TYPE_ALIGNMENT(t) __alignof__(t)
355 #else
356 # define TYPE_ALIGNMENT(t) FIELD_OFFSET(struct { char x; t test; }, test)
357 #endif
358
359 #ifdef _WIN64
360 # define PROBE_ALIGNMENT(_s) \
361     (TYPE_ALIGNMENT(_s) > TYPE_ALIGNMENT(DWORD) ? \
362     TYPE_ALIGNMENT(_s) : TYPE_ALIGNMENT(DWORD))
363 # define PROBE_ALIGNMENT32(_s) TYPE_ALIGNMENT(DWORD)
364 #else
365 # define PROBE_ALIGNMENT(_s) TYPE_ALIGNMENT(DWORD)
366 #endif
367
368 /* Compile time assertion */
369
370 #if defined(_MSC_VER)
371 # define C_ASSERT(e) typedef char __C_ASSERT__[(e)?1:-1]
372 #else
373 # define C_ASSERT(e) extern void __C_ASSERT__(int [(e)?1:-1])
374 #endif
375
376 /* Eliminate Microsoft C/C++ compiler warning 4715 */
377 #if defined(_MSC_VER) && (_MSC_VER > 1200)
378 # define DEFAULT_UNREACHABLE default: __assume(0)
379 #else
380 # define DEFAULT_UNREACHABLE
381 #endif
382
383 /* Error Masks */
384 #define APPLICATION_ERROR_MASK       0x20000000
385 #define ERROR_SEVERITY_SUCCESS       0x00000000
386 #define ERROR_SEVERITY_INFORMATIONAL 0x40000000
387 #define ERROR_SEVERITY_WARNING       0x80000000
388 #define ERROR_SEVERITY_ERROR         0xC0000000
389
390 #ifdef __cplusplus
391 #define DEFINE_ENUM_FLAG_OPERATORS(ENUMTYPE) \
392 extern "C++" { \
393     inline ENUMTYPE operator | (ENUMTYPE a, ENUMTYPE b) { return ENUMTYPE(((int)a)|((int)b)); } \
394     inline ENUMTYPE operator |= (ENUMTYPE &a, ENUMTYPE b) { return (ENUMTYPE &)(((int &)a) |= ((int)b)); } \
395     inline ENUMTYPE operator & (ENUMTYPE a, ENUMTYPE b) { return ENUMTYPE(((int)a)&((int)b)); } \
396     inline ENUMTYPE operator &= (ENUMTYPE &a, ENUMTYPE b) { return (ENUMTYPE &)(((int &)a) &= ((int)b)); } \
397     inline ENUMTYPE operator ~ (ENUMTYPE a) { return (ENUMTYPE)(~((int)a)); } \
398     inline ENUMTYPE operator ^ (ENUMTYPE a, ENUMTYPE b) { return ENUMTYPE(((int)a)^((int)b)); } \
399     inline ENUMTYPE operator ^= (ENUMTYPE &a, ENUMTYPE b) { return (ENUMTYPE &)(((int &)a) ^= ((int)b)); } \
400 }
401 #else
402 #define DEFINE_ENUM_FLAG_OPERATORS(ENUMTYPE) /* */
403 #endif
404
405 /* Microsoft's macros for declaring functions */
406
407 #ifdef __cplusplus
408 # define EXTERN_C    extern "C"
409 #else
410 # define EXTERN_C    extern
411 #endif
412
413 #define STDMETHODCALLTYPE       __stdcall
414 #define STDMETHODVCALLTYPE      __cdecl
415 #define STDAPICALLTYPE          __stdcall
416 #define STDAPIVCALLTYPE         __cdecl
417
418 #define STDAPI                  EXTERN_C HRESULT STDAPICALLTYPE
419 #define STDAPI_(type)           EXTERN_C type STDAPICALLTYPE
420 #define STDMETHODIMP            HRESULT STDMETHODCALLTYPE
421 #define STDMETHODIMP_(type)     type STDMETHODCALLTYPE
422 #define STDAPIV                 EXTERN_C HRESULT STDAPIVCALLTYPE
423 #define STDAPIV_(type)          EXTERN_C type STDAPIVCALLTYPE
424 #define STDMETHODIMPV           HRESULT STDMETHODVCALLTYPE
425 #define STDMETHODIMPV_(type)    type STDMETHODVCALLTYPE
426
427 /* Define the basic types */
428 #ifndef VOID
429 #define VOID void
430 #endif
431 typedef VOID           *PVOID;
432 typedef VOID           *PVOID64;
433 typedef BYTE            BOOLEAN,    *PBOOLEAN;
434 typedef char            CHAR,       *PCHAR;
435 typedef short           SHORT,      *PSHORT;
436 #ifdef _MSC_VER
437 typedef long            LONG,       *PLONG;
438 #else
439 typedef int             LONG,       *PLONG;
440 #endif
441
442 /* Some systems might have wchar_t, but we really need 16 bit characters */
443 #ifdef WINE_UNICODE_NATIVE
444 typedef wchar_t         WCHAR,      *PWCHAR;
445 #else
446 typedef unsigned short  WCHAR,      *PWCHAR;
447 #endif
448
449 /* 'Extended/Wide' numerical types */
450 #ifndef _ULONGLONG_
451 # define _ULONGLONG_
452 # ifdef _MSC_VER
453 typedef signed __int64   LONGLONG,  *PLONGLONG;
454 typedef unsigned __int64 ULONGLONG, *PULONGLONG;
455 # else
456 typedef signed __int64   DECLSPEC_ALIGN(8) LONGLONG,   *PLONGLONG;
457 typedef unsigned __int64 DECLSPEC_ALIGN(8) ULONGLONG,  *PULONGLONG;
458 # endif
459 #endif
460
461 #ifndef _DWORDLONG_
462 # define _DWORDLONG_
463 # ifdef _MSC_VER
464 typedef ULONGLONG DWORDLONG, *PDWORDLONG;
465 # else
466 typedef ULONGLONG   DECLSPEC_ALIGN(8) DWORDLONG,   *PDWORDLONG;
467 # endif
468 #endif
469
470 /* ANSI string types */
471 typedef CHAR           *PCH,        *LPCH;
472 typedef const CHAR     *PCCH,       *LPCCH;
473 typedef CHAR           *PSTR,       *LPSTR,     *NPSTR;
474 typedef const CHAR     *PCSTR,      *LPCSTR;
475 typedef CHAR           *PZZSTR;
476 typedef const CHAR     *PCZZSTR;
477
478 /* Unicode string types */
479 typedef WCHAR          *PWCH,       *LPWCH;
480 typedef const WCHAR    *PCWCH,      *LPCWCH;
481 typedef WCHAR          *PWSTR,      *LPWSTR,    *NWPSTR;
482 typedef const WCHAR    *PCWSTR,     *LPCWSTR;
483 typedef WCHAR          *PZZWSTR;
484 typedef const WCHAR    *PCZZWSTR;
485
486 /* Neutral character and string types */
487 /* These are only defined for Winelib, i.e. _not_ defined for
488  * the emulator. The reason is they depend on the UNICODE
489  * macro which only exists in the user's code.
490  */
491 #ifndef WINE_NO_UNICODE_MACROS
492 # ifdef UNICODE
493 # ifndef _TCHAR_DEFINED
494 typedef WCHAR           TCHAR,      *PTCHAR;
495 # define _TCHAR_DEFINED
496 #endif
497 typedef LPWSTR          PTSTR,       LPTSTR;
498 typedef LPCWSTR         PCTSTR,      LPCTSTR;
499 typedef PZZSTR          PZZTSTR;
500 typedef PCZZSTR         PCZZTSTR;
501 # else  /* UNICODE */
502 # ifndef _TCHAR_DEFINED
503 typedef CHAR            TCHAR,      *PTCHAR;
504 # define _TCHAR_DEFINED
505 # endif
506 typedef LPSTR           PTSTR,       LPTSTR;
507 typedef LPCSTR          PCTSTR,      LPCTSTR;
508 typedef PZZWSTR         PZZTSTR;
509 typedef PCZZWSTR        PCZZTSTR;
510 # endif /* UNICODE */
511 #endif   /* WINE_NO_UNICODE_MACROS */
512
513 /* Misc common WIN32 types */
514 typedef char            CCHAR;
515 typedef DWORD           LCID,       *PLCID;
516 typedef WORD            LANGID;
517 typedef DWORD           EXECUTION_STATE;
518 #ifndef _HRESULT_DEFINED
519 #define _HRESULT_DEFINED
520 typedef LONG            HRESULT;
521 #endif
522
523 /* Handle type */
524
525 typedef void *HANDLE;
526 typedef HANDLE *PHANDLE, *LPHANDLE;
527
528 #ifdef STRICT
529 #define DECLARE_HANDLE(a) typedef struct a##__ { int unused; } *a
530 #else /*STRICT*/
531 #define DECLARE_HANDLE(a) typedef HANDLE a
532 #endif /*STRICT*/
533
534 typedef BYTE  FCHAR;
535 typedef WORD  FSHORT;
536 typedef DWORD FLONG;
537
538 /* Macro to deal with LP64 <=> LLP64 differences in numeric constants with 'l' modifier */
539 #ifndef __MSABI_LONG
540 # if defined(_MSC_VER) || defined(__MINGW32__) || defined(__CYGWIN__)
541 #  define __MSABI_LONG(x)         x ## l
542 # else
543 #  define __MSABI_LONG(x)         x
544 # endif
545 #endif
546
547 /* Defines */
548
549 #ifndef WIN32_NO_STATUS
550
551 #define STATUS_WAIT_0                    ((DWORD) 0x00000000)
552 #define STATUS_ABANDONED_WAIT_0          ((DWORD) 0x00000080)
553 #define STATUS_USER_APC                  ((DWORD) 0x000000C0)
554 #define STATUS_TIMEOUT                   ((DWORD) 0x00000102)
555 #define STATUS_PENDING                   ((DWORD) 0x00000103)
556 #define STATUS_SEGMENT_NOTIFICATION      ((DWORD) 0x40000005)
557 #define STATUS_GUARD_PAGE_VIOLATION      ((DWORD) 0x80000001)
558 #define STATUS_DATATYPE_MISALIGNMENT     ((DWORD) 0x80000002)
559 #define STATUS_BREAKPOINT                ((DWORD) 0x80000003)
560 #define STATUS_SINGLE_STEP               ((DWORD) 0x80000004)
561 #define STATUS_ACCESS_VIOLATION          ((DWORD) 0xC0000005)
562 #define STATUS_IN_PAGE_ERROR             ((DWORD) 0xC0000006)
563 #define STATUS_INVALID_HANDLE            ((DWORD) 0xC0000008)
564 #define STATUS_NO_MEMORY                 ((DWORD) 0xC0000017)
565 #define STATUS_ILLEGAL_INSTRUCTION       ((DWORD) 0xC000001D)
566 #define STATUS_NONCONTINUABLE_EXCEPTION  ((DWORD) 0xC0000025)
567 #define STATUS_INVALID_DISPOSITION       ((DWORD) 0xC0000026)
568 #define STATUS_ARRAY_BOUNDS_EXCEEDED     ((DWORD) 0xC000008C)
569 #define STATUS_FLOAT_DENORMAL_OPERAND    ((DWORD) 0xC000008D)
570 #define STATUS_FLOAT_DIVIDE_BY_ZERO      ((DWORD) 0xC000008E)
571 #define STATUS_FLOAT_INEXACT_RESULT      ((DWORD) 0xC000008F)
572 #define STATUS_FLOAT_INVALID_OPERATION   ((DWORD) 0xC0000090)
573 #define STATUS_FLOAT_OVERFLOW            ((DWORD) 0xC0000091)
574 #define STATUS_FLOAT_STACK_CHECK         ((DWORD) 0xC0000092)
575 #define STATUS_FLOAT_UNDERFLOW           ((DWORD) 0xC0000093)
576 #define STATUS_INTEGER_DIVIDE_BY_ZERO    ((DWORD) 0xC0000094)
577 #define STATUS_INTEGER_OVERFLOW          ((DWORD) 0xC0000095)
578 #define STATUS_PRIVILEGED_INSTRUCTION    ((DWORD) 0xC0000096)
579 #define STATUS_STACK_OVERFLOW            ((DWORD) 0xC00000FD)
580 #define STATUS_CONTROL_C_EXIT            ((DWORD) 0xC000013A)
581 #define STATUS_FLOAT_MULTIPLE_FAULTS     ((DWORD) 0xC00002B4)
582 #define STATUS_FLOAT_MULTIPLE_TRAPS      ((DWORD) 0xC00002B5)
583 #define STATUS_REG_NAT_CONSUMPTION       ((DWORD) 0xC00002C9)
584 #define STATUS_SXS_EARLY_DEACTIVATION    ((DWORD) 0xC015000F)
585 #define STATUS_SXS_INVALID_DEACTIVATION  ((DWORD) 0xC0150010)
586
587 /* status values for ContinueDebugEvent */
588 #define DBG_EXCEPTION_HANDLED       ((DWORD) 0x00010001)
589 #define DBG_CONTINUE                ((DWORD) 0x00010002)
590 #define DBG_TERMINATE_THREAD        ((DWORD) 0x40010003)
591 #define DBG_TERMINATE_PROCESS       ((DWORD) 0x40010004)
592 #define DBG_CONTROL_C               ((DWORD) 0x40010005)
593 #define DBG_CONTROL_BREAK           ((DWORD) 0x40010008)
594 #define DBG_COMMAND_EXCEPTION       ((DWORD) 0x40010009)
595 #define DBG_EXCEPTION_NOT_HANDLED   ((DWORD) 0x80010001)
596
597 #endif /* WIN32_NO_STATUS */
598
599 /* Argument 1 passed to the DllEntryProc. */
600 #define DLL_PROCESS_DETACH      0       /* detach process (unload library) */
601 #define DLL_PROCESS_ATTACH      1       /* attach process (load library) */
602 #define DLL_THREAD_ATTACH       2       /* attach new thread */
603 #define DLL_THREAD_DETACH       3       /* detach thread */
604 #ifdef __WINESRC__
605 #define DLL_WINE_PREATTACH      8       /* called before process attach for Wine builtins */
606 #endif
607
608 /* u.x.wProcessorArchitecture (NT) */
609 #define PROCESSOR_ARCHITECTURE_INTEL    0
610 #define PROCESSOR_ARCHITECTURE_MIPS     1
611 #define PROCESSOR_ARCHITECTURE_ALPHA    2
612 #define PROCESSOR_ARCHITECTURE_PPC      3
613 #define PROCESSOR_ARCHITECTURE_SHX      4
614 #define PROCESSOR_ARCHITECTURE_ARM      5
615 #define PROCESSOR_ARCHITECTURE_IA64     6
616 #define PROCESSOR_ARCHITECTURE_ALPHA64  7
617 #define PROCESSOR_ARCHITECTURE_MSIL     8
618 #define PROCESSOR_ARCHITECTURE_AMD64    9
619 #define PROCESSOR_ARCHITECTURE_IA32_ON_WIN64    10
620 #define PROCESSOR_ARCHITECTURE_UNKNOWN  0xFFFF
621
622 /* Wine extension */
623 #define PROCESSOR_ARCHITECTURE_SPARC    20
624
625 /* dwProcessorType */
626 #define PROCESSOR_INTEL_386      386
627 #define PROCESSOR_INTEL_486      486
628 #define PROCESSOR_INTEL_PENTIUM  586
629 #define PROCESSOR_INTEL_860      860
630 #define PROCESSOR_INTEL_IA64     2200
631 #define PROCESSOR_AMD_X8664      8664
632 #define PROCESSOR_MIPS_R2000     2000
633 #define PROCESSOR_MIPS_R3000     3000
634 #define PROCESSOR_MIPS_R4000     4000
635 #define PROCESSOR_ALPHA_21064    21064
636 #define PROCESSOR_PPC_601        601
637 #define PROCESSOR_PPC_603        603
638 #define PROCESSOR_PPC_604        604
639 #define PROCESSOR_PPC_620        620
640 #define PROCESSOR_HITACHI_SH3    10003
641 #define PROCESSOR_HITACHI_SH3E   10004
642 #define PROCESSOR_HITACHI_SH4    10005
643 #define PROCESSOR_MOTOROLA_821   821
644 #define PROCESSOR_SHx_SH3        103
645 #define PROCESSOR_SHx_SH4        104
646 #define PROCESSOR_STRONGARM      2577
647 #define PROCESSOR_ARM720         1824    /* 0x720 */
648 #define PROCESSOR_ARM820         2080    /* 0x820 */
649 #define PROCESSOR_ARM920         2336    /* 0x920 */
650 #define PROCESSOR_ARM_7TDMI      70001
651 #define PROCESSOR_OPTIL          18767
652
653 #ifdef _WIN64
654 #define MAXIMUM_PROCESSORS       64
655 #else
656 #define MAXIMUM_PROCESSORS       32
657 #endif
658
659 typedef struct _MEMORY_BASIC_INFORMATION
660 {
661     LPVOID   BaseAddress;
662     LPVOID   AllocationBase;
663     DWORD    AllocationProtect;
664     SIZE_T   RegionSize;
665     DWORD    State;
666     DWORD    Protect;
667     DWORD    Type;
668 } MEMORY_BASIC_INFORMATION, *PMEMORY_BASIC_INFORMATION;
669
670 #define PAGE_NOACCESS           0x01
671 #define PAGE_READONLY           0x02
672 #define PAGE_READWRITE          0x04
673 #define PAGE_WRITECOPY          0x08
674 #define PAGE_EXECUTE            0x10
675 #define PAGE_EXECUTE_READ       0x20
676 #define PAGE_EXECUTE_READWRITE  0x40
677 #define PAGE_EXECUTE_WRITECOPY  0x80
678 #define PAGE_GUARD              0x100
679 #define PAGE_NOCACHE            0x200
680 #define PAGE_WRITECOMBINE       0x400
681
682 #define MEM_COMMIT              0x00001000
683 #define MEM_RESERVE             0x00002000
684 #define MEM_DECOMMIT            0x00004000
685 #define MEM_RELEASE             0x00008000
686 #define MEM_FREE                0x00010000
687 #define MEM_PRIVATE             0x00020000
688 #define MEM_MAPPED              0x00040000
689 #define MEM_RESET               0x00080000
690 #define MEM_TOP_DOWN            0x00100000
691 #define MEM_WRITE_WATCH         0x00200000
692 #define MEM_PHYSICAL            0x00400000
693 #define MEM_LARGE_PAGES         0x20000000
694 #define MEM_4MB_PAGES           0x80000000
695
696 #define SEC_FILE                0x00800000
697 #define SEC_IMAGE               0x01000000
698 #define SEC_RESERVE             0x04000000
699 #define SEC_COMMIT              0x08000000
700 #define SEC_NOCACHE             0x10000000
701 #define SEC_LARGE_PAGES         0x80000000
702 #define MEM_IMAGE               SEC_IMAGE
703
704 #define WRITE_WATCH_FLAG_RESET  0x00000001
705
706
707 #define MINCHAR       0x80
708 #define MAXCHAR       0x7f
709 #define MINSHORT      0x8000
710 #define MAXSHORT      0x7fff
711 #define MINLONG       0x80000000
712 #define MAXLONG       0x7fffffff
713 #define MAXBYTE       0xff
714 #define MAXWORD       0xffff
715 #define MAXDWORD      0xffffffff
716
717 #define UNICODE_STRING_MAX_CHARS 32767
718
719 #define FIELD_OFFSET(type, field) \
720   ((LONG)(INT_PTR)&(((type *)0)->field))
721
722 #define CONTAINING_RECORD(address, type, field) \
723   ((type *)((PCHAR)(address) - (PCHAR)(&((type *)0)->field)))
724
725 /* Types */
726
727 typedef struct _LIST_ENTRY {
728   struct _LIST_ENTRY *Flink;
729   struct _LIST_ENTRY *Blink;
730 } LIST_ENTRY, *PLIST_ENTRY, * RESTRICTED_POINTER PRLIST_ENTRY;
731
732 typedef struct _SINGLE_LIST_ENTRY {
733   struct _SINGLE_LIST_ENTRY *Next;
734 } SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
735
736 #ifdef _WIN64
737
738 typedef struct DECLSPEC_ALIGN(16) _SLIST_ENTRY *PSLIST_ENTRY;
739 typedef struct DECLSPEC_ALIGN(16) _SLIST_ENTRY {
740     PSLIST_ENTRY Next;
741 } SLIST_ENTRY;
742
743 typedef union DECLSPEC_ALIGN(16) _SLIST_HEADER {
744     struct {
745         ULONGLONG Alignment;
746         ULONGLONG Region;
747     } DUMMYSTRUCTNAME;
748     struct {
749         ULONGLONG Depth:16;
750         ULONGLONG Sequence:9;
751         ULONGLONG NextEntry:39;
752         ULONGLONG HeaderType:1;
753         ULONGLONG Init:1;
754         ULONGLONG Reserved:59;
755         ULONGLONG Region:3;
756     } Header8;
757     struct {
758         ULONGLONG Depth:16;
759         ULONGLONG Sequence:48;
760         ULONGLONG HeaderType:1;
761         ULONGLONG Init:1;
762         ULONGLONG Reserved:2;
763         ULONGLONG NextEntry:60;
764     } Header16;
765 } SLIST_HEADER, *PSLIST_HEADER;
766
767 #else
768
769 #undef SLIST_ENTRY /* for Mac OS */
770 #define SLIST_ENTRY SINGLE_LIST_ENTRY
771 #define _SLIST_ENTRY _SINGLE_LIST_ENTRY
772 #define PSLIST_ENTRY PSINGLE_LIST_ENTRY
773
774 typedef union _SLIST_HEADER {
775     ULONGLONG Alignment;
776     struct {
777         SLIST_ENTRY Next;
778         WORD Depth;
779         WORD Sequence;
780     } DUMMYSTRUCTNAME;
781 } SLIST_HEADER, *PSLIST_HEADER;
782
783 #endif
784
785 NTSYSAPI PSLIST_ENTRY WINAPI RtlFirstEntrySList(const SLIST_HEADER*);
786 NTSYSAPI VOID         WINAPI RtlInitializeSListHead(PSLIST_HEADER);
787 NTSYSAPI PSLIST_ENTRY WINAPI RtlInterlockedFlushSList(PSLIST_HEADER);
788 NTSYSAPI PSLIST_ENTRY WINAPI RtlInterlockedPopEntrySList(PSLIST_HEADER);
789 NTSYSAPI PSLIST_ENTRY WINAPI RtlInterlockedPushEntrySList(PSLIST_HEADER, PSLIST_ENTRY);
790 NTSYSAPI WORD         WINAPI RtlQueryDepthSList(PSLIST_HEADER);
791
792
793 /* Heap flags */
794
795 #define HEAP_NO_SERIALIZE               0x00000001
796 #define HEAP_GROWABLE                   0x00000002
797 #define HEAP_GENERATE_EXCEPTIONS        0x00000004
798 #define HEAP_ZERO_MEMORY                0x00000008
799 #define HEAP_REALLOC_IN_PLACE_ONLY      0x00000010
800 #define HEAP_TAIL_CHECKING_ENABLED      0x00000020
801 #define HEAP_FREE_CHECKING_ENABLED      0x00000040
802 #define HEAP_DISABLE_COALESCE_ON_FREE   0x00000080
803 #define HEAP_CREATE_ALIGN_16            0x00010000
804 #define HEAP_CREATE_ENABLE_TRACING      0x00020000
805 #define HEAP_CREATE_ENABLE_EXECUTE      0x00040000
806
807 /* This flag allows it to create heaps shared by all processes under win95,
808    FIXME: correct name */
809 #define HEAP_SHARED                     0x04000000
810
811 typedef enum _HEAP_INFORMATION_CLASS {
812     HeapCompatibilityInformation,
813 } HEAP_INFORMATION_CLASS;
814
815 /* Processor feature flags.  */
816 #define PF_FLOATING_POINT_PRECISION_ERRATA      0
817 #define PF_FLOATING_POINT_EMULATED              1
818 #define PF_COMPARE_EXCHANGE_DOUBLE              2
819 #define PF_MMX_INSTRUCTIONS_AVAILABLE           3
820 #define PF_PPC_MOVEMEM_64BIT_OK                 4
821 #define PF_ALPHA_BYTE_INSTRUCTIONS              5
822 #define PF_XMMI_INSTRUCTIONS_AVAILABLE          6
823 #define PF_3DNOW_INSTRUCTIONS_AVAILABLE         7
824 #define PF_RDTSC_INSTRUCTION_AVAILABLE          8
825 #define PF_PAE_ENABLED                          9
826 #define PF_XMMI64_INSTRUCTIONS_AVAILABLE        10
827 #define PF_SSE_DAZ_MODE_AVAILABLE               11
828 #define PF_NX_ENABLED                           12
829 #define PF_SSE3_INSTRUCTIONS_AVAILABLE          13
830 #define PF_COMPARE_EXCHANGE128                  14
831 #define PF_COMPARE64_EXCHANGE128                15
832 #define PF_CHANNELS_ENABLED                     16
833 #define PF_XSAVE_ENABLED                        17
834 #define PF_ARM_VFP_32_REGISTERS_AVAILABLE       18
835 #define PF_ARM_NEON_INSTRUCTIONS_AVAILABLE      19
836 #define PF_SECOND_LEVEL_ADDRESS_TRANSLATION     20
837 #define PF_VIRT_FIRMWARE_ENABLED                21
838 #define PF_RDWRFSGSBASE_AVAILABLE               22
839
840
841 /* Execution state flags */
842 #define ES_SYSTEM_REQUIRED    0x00000001
843 #define ES_DISPLAY_REQUIRED   0x00000002
844 #define ES_USER_PRESENT       0x00000004
845 #define ES_CONTINUOUS         0x80000000
846
847 /* The Win32 register context */
848
849 /* i386 context definitions */
850 #ifdef __i386__
851
852 #define SIZE_OF_80387_REGISTERS      80
853
854 typedef struct _FLOATING_SAVE_AREA
855 {
856     DWORD   ControlWord;
857     DWORD   StatusWord;
858     DWORD   TagWord;
859     DWORD   ErrorOffset;
860     DWORD   ErrorSelector;
861     DWORD   DataOffset;
862     DWORD   DataSelector;
863     BYTE    RegisterArea[SIZE_OF_80387_REGISTERS];
864     DWORD   Cr0NpxState;
865 } FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
866
867 #define MAXIMUM_SUPPORTED_EXTENSION     512
868
869 typedef struct _CONTEXT
870 {
871     DWORD   ContextFlags;
872
873     /* These are selected by CONTEXT_DEBUG_REGISTERS */
874     DWORD   Dr0;
875     DWORD   Dr1;
876     DWORD   Dr2;
877     DWORD   Dr3;
878     DWORD   Dr6;
879     DWORD   Dr7;
880
881     /* These are selected by CONTEXT_FLOATING_POINT */
882     FLOATING_SAVE_AREA FloatSave;
883
884     /* These are selected by CONTEXT_SEGMENTS */
885     DWORD   SegGs;
886     DWORD   SegFs;
887     DWORD   SegEs;
888     DWORD   SegDs;
889
890     /* These are selected by CONTEXT_INTEGER */
891     DWORD   Edi;
892     DWORD   Esi;
893     DWORD   Ebx;
894     DWORD   Edx;
895     DWORD   Ecx;
896     DWORD   Eax;
897
898     /* These are selected by CONTEXT_CONTROL */
899     DWORD   Ebp;
900     DWORD   Eip;
901     DWORD   SegCs;
902     DWORD   EFlags;
903     DWORD   Esp;
904     DWORD   SegSs;
905
906     BYTE    ExtendedRegisters[MAXIMUM_SUPPORTED_EXTENSION];
907 } CONTEXT;
908
909 #define CONTEXT_X86       0x00010000
910 #define CONTEXT_i386      CONTEXT_X86
911 #define CONTEXT_i486      CONTEXT_X86
912
913 #define CONTEXT_CONTROL   (CONTEXT_i386 | 0x0001) /* SS:SP, CS:IP, FLAGS, BP */
914 #define CONTEXT_INTEGER   (CONTEXT_i386 | 0x0002) /* AX, BX, CX, DX, SI, DI */
915 #define CONTEXT_SEGMENTS  (CONTEXT_i386 | 0x0004) /* DS, ES, FS, GS */
916 #define CONTEXT_FLOATING_POINT  (CONTEXT_i386 | 0x0008) /* 387 state */
917 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_i386 | 0x0010) /* DB 0-3,6,7 */
918 #define CONTEXT_EXTENDED_REGISTERS (CONTEXT_i386 | 0x0020)
919 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS)
920 #define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | \
921         CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS | CONTEXT_EXTENDED_REGISTERS)
922
923 #define EXCEPTION_READ_FAULT    0
924 #define EXCEPTION_WRITE_FAULT   1
925 #define EXCEPTION_EXECUTE_FAULT 8
926
927 #endif  /* __i386__ */
928
929 typedef struct _LDT_ENTRY {
930     WORD        LimitLow;
931     WORD        BaseLow;
932     union {
933         struct {
934             BYTE    BaseMid;
935             BYTE    Flags1;
936             BYTE    Flags2;
937             BYTE    BaseHi;
938         } Bytes;
939         struct {
940             unsigned    BaseMid: 8;
941             unsigned    Type : 5;
942             unsigned    Dpl : 2;
943             unsigned    Pres : 1;
944             unsigned    LimitHi : 4;
945             unsigned    Sys : 1;
946             unsigned    Reserved_0 : 1;
947             unsigned    Default_Big : 1;
948             unsigned    Granularity : 1;
949             unsigned    BaseHi : 8;
950         } Bits;
951     } HighWord;
952 } LDT_ENTRY, *PLDT_ENTRY;
953
954 /* x86-64 context definitions */
955 #if defined(__x86_64__)
956
957 #define CONTEXT_AMD64   0x00100000
958
959 #define CONTEXT_CONTROL   (CONTEXT_AMD64 | 0x0001)
960 #define CONTEXT_INTEGER   (CONTEXT_AMD64 | 0x0002)
961 #define CONTEXT_SEGMENTS  (CONTEXT_AMD64 | 0x0004)
962 #define CONTEXT_FLOATING_POINT  (CONTEXT_AMD64 | 0x0008)
963 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_AMD64 | 0x0010)
964 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
965 #define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS)
966
967 #define EXCEPTION_READ_FAULT    0
968 #define EXCEPTION_WRITE_FAULT   1
969 #define EXCEPTION_EXECUTE_FAULT 8
970
971 typedef struct DECLSPEC_ALIGN(16) _M128A {
972     ULONGLONG Low;
973     LONGLONG High;
974 } M128A, *PM128A;
975
976 typedef struct _XMM_SAVE_AREA32 {
977     WORD ControlWord;        /* 000 */
978     WORD StatusWord;         /* 002 */
979     BYTE TagWord;            /* 004 */
980     BYTE Reserved1;          /* 005 */
981     WORD ErrorOpcode;        /* 006 */
982     DWORD ErrorOffset;       /* 008 */
983     WORD ErrorSelector;      /* 00c */
984     WORD Reserved2;          /* 00e */
985     DWORD DataOffset;        /* 010 */
986     WORD DataSelector;       /* 014 */
987     WORD Reserved3;          /* 016 */
988     DWORD MxCsr;             /* 018 */
989     DWORD MxCsr_Mask;        /* 01c */
990     M128A FloatRegisters[8]; /* 020 */
991     M128A XmmRegisters[16];  /* 0a0 */
992     BYTE Reserved4[96];      /* 1a0 */
993 } XMM_SAVE_AREA32, *PXMM_SAVE_AREA32;
994
995 typedef struct DECLSPEC_ALIGN(16) _CONTEXT {
996     DWORD64 P1Home;          /* 000 */
997     DWORD64 P2Home;          /* 008 */
998     DWORD64 P3Home;          /* 010 */
999     DWORD64 P4Home;          /* 018 */
1000     DWORD64 P5Home;          /* 020 */
1001     DWORD64 P6Home;          /* 028 */
1002
1003     /* Control flags */
1004     DWORD ContextFlags;      /* 030 */
1005     DWORD MxCsr;             /* 034 */
1006
1007     /* Segment */
1008     WORD SegCs;              /* 038 */
1009     WORD SegDs;              /* 03a */
1010     WORD SegEs;              /* 03c */
1011     WORD SegFs;              /* 03e */
1012     WORD SegGs;              /* 040 */
1013     WORD SegSs;              /* 042 */
1014     DWORD EFlags;            /* 044 */
1015
1016     /* Debug */
1017     DWORD64 Dr0;             /* 048 */
1018     DWORD64 Dr1;             /* 050 */
1019     DWORD64 Dr2;             /* 058 */
1020     DWORD64 Dr3;             /* 060 */
1021     DWORD64 Dr6;             /* 068 */
1022     DWORD64 Dr7;             /* 070 */
1023
1024     /* Integer */
1025     DWORD64 Rax;             /* 078 */
1026     DWORD64 Rcx;             /* 080 */
1027     DWORD64 Rdx;             /* 088 */
1028     DWORD64 Rbx;             /* 090 */
1029     DWORD64 Rsp;             /* 098 */
1030     DWORD64 Rbp;             /* 0a0 */
1031     DWORD64 Rsi;             /* 0a8 */
1032     DWORD64 Rdi;             /* 0b0 */
1033     DWORD64 R8;              /* 0b8 */
1034     DWORD64 R9;              /* 0c0 */
1035     DWORD64 R10;             /* 0c8 */
1036     DWORD64 R11;             /* 0d0 */
1037     DWORD64 R12;             /* 0d8 */
1038     DWORD64 R13;             /* 0e0 */
1039     DWORD64 R14;             /* 0e8 */
1040     DWORD64 R15;             /* 0f0 */
1041
1042     /* Counter */
1043     DWORD64 Rip;             /* 0f8 */
1044
1045     /* Floating point */
1046     union {
1047         XMM_SAVE_AREA32 FltSave;  /* 100 */
1048         struct {
1049             M128A Header[2];      /* 100 */
1050             M128A Legacy[8];      /* 120 */
1051             M128A Xmm0;           /* 1a0 */
1052             M128A Xmm1;           /* 1b0 */
1053             M128A Xmm2;           /* 1c0 */
1054             M128A Xmm3;           /* 1d0 */
1055             M128A Xmm4;           /* 1e0 */
1056             M128A Xmm5;           /* 1f0 */
1057             M128A Xmm6;           /* 200 */
1058             M128A Xmm7;           /* 210 */
1059             M128A Xmm8;           /* 220 */
1060             M128A Xmm9;           /* 230 */
1061             M128A Xmm10;          /* 240 */
1062             M128A Xmm11;          /* 250 */
1063             M128A Xmm12;          /* 260 */
1064             M128A Xmm13;          /* 270 */
1065             M128A Xmm14;          /* 280 */
1066             M128A Xmm15;          /* 290 */
1067         } DUMMYSTRUCTNAME;
1068     } DUMMYUNIONNAME;
1069
1070     /* Vector */
1071     M128A VectorRegister[26];     /* 300 */
1072     DWORD64 VectorControl;        /* 4a0 */
1073
1074     /* Debug control */
1075     DWORD64 DebugControl;         /* 4a8 */
1076     DWORD64 LastBranchToRip;      /* 4b0 */
1077     DWORD64 LastBranchFromRip;    /* 4b8 */
1078     DWORD64 LastExceptionToRip;   /* 4c0 */
1079     DWORD64 LastExceptionFromRip; /* 4c8 */
1080 } CONTEXT;
1081
1082 typedef struct _RUNTIME_FUNCTION
1083 {
1084     DWORD BeginAddress;
1085     DWORD EndAddress;
1086     DWORD UnwindData;
1087 } RUNTIME_FUNCTION, *PRUNTIME_FUNCTION;
1088
1089 #define UNWIND_HISTORY_TABLE_SIZE 12
1090
1091 typedef struct _UNWIND_HISTORY_TABLE_ENTRY
1092 {
1093     ULONG64 ImageBase;
1094     PRUNTIME_FUNCTION FunctionEntry;
1095 } UNWIND_HISTORY_TABLE_ENTRY, *PUNWIND_HISTORY_TABLE_ENTRY;
1096
1097 #define UNWIND_HISTORY_TABLE_NONE 0
1098 #define UNWIND_HISTORY_TABLE_GLOBAL 1
1099 #define UNWIND_HISTORY_TABLE_LOCAL 2
1100
1101 typedef struct _UNWIND_HISTORY_TABLE
1102 {
1103     ULONG Count;
1104     UCHAR Search;
1105     ULONG64 LowAddress;
1106     ULONG64 HighAddress;
1107     UNWIND_HISTORY_TABLE_ENTRY Entry[UNWIND_HISTORY_TABLE_SIZE];
1108 } UNWIND_HISTORY_TABLE, *PUNWIND_HISTORY_TABLE;
1109
1110 typedef struct _KNONVOLATILE_CONTEXT_POINTERS
1111 {
1112     union
1113     {
1114         PM128A FloatingContext[16];
1115         struct
1116         {
1117             PM128A Xmm0;
1118             PM128A Xmm1;
1119             PM128A Xmm2;
1120             PM128A Xmm3;
1121             PM128A Xmm4;
1122             PM128A Xmm5;
1123             PM128A Xmm6;
1124             PM128A Xmm7;
1125             PM128A Xmm8;
1126             PM128A Xmm9;
1127             PM128A Xmm10;
1128             PM128A Xmm11;
1129             PM128A Xmm12;
1130             PM128A Xmm13;
1131             PM128A Xmm14;
1132             PM128A Xmm15;
1133         } DUMMYSTRUCTNAME1;
1134     } DUMMYUNIONNAME1;
1135
1136     union
1137     {
1138         PULONG64 IntegerContext[16];
1139         struct
1140         {
1141             PULONG64 Rax;
1142             PULONG64 Rcx;
1143             PULONG64 Rdx;
1144             PULONG64 Rbx;
1145             PULONG64 Rsp;
1146             PULONG64 Rbp;
1147             PULONG64 Rsi;
1148             PULONG64 Rdi;
1149             PULONG64 R8;
1150             PULONG64 R9;
1151             PULONG64 R10;
1152             PULONG64 R11;
1153             PULONG64 R12;
1154             PULONG64 R13;
1155             PULONG64 R14;
1156             PULONG64 R15;
1157         } DUMMYSTRUCTNAME2;
1158     } DUMMYUNIONNAME2;
1159 } KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS;
1160
1161 BOOLEAN CDECL            RtlAddFunctionTable(RUNTIME_FUNCTION*,DWORD,DWORD64);
1162 BOOLEAN CDECL            RtlDeleteFunctionTable(RUNTIME_FUNCTION*);
1163 PRUNTIME_FUNCTION WINAPI RtlLookupFunctionEntry(DWORD64,DWORD64*,UNWIND_HISTORY_TABLE*);
1164 PVOID WINAPI             RtlVirtualUnwind(ULONG,ULONG64,ULONG64,RUNTIME_FUNCTION*,CONTEXT*,PVOID*,ULONG64*,KNONVOLATILE_CONTEXT_POINTERS*);
1165
1166 #define UNW_FLAG_NHANDLER  0
1167 #define UNW_FLAG_EHANDLER  1
1168 #define UNW_FLAG_UHANDLER  2
1169 #define UNW_FLAG_CHAININFO 4
1170
1171 #endif /* __x86_64__ */
1172
1173 /* IA64 context definitions */
1174 #ifdef __ia64__
1175
1176 #define CONTEXT_IA64                  0x00080000
1177 #define CONTEXT_CONTROL               (CONTEXT_IA64 | 0x00000001)
1178 #define CONTEXT_LOWER_FLOATING_POINT  (CONTEXT_IA64 | 0x00000002)
1179 #define CONTEXT_HIGHER_FLOATING_POINT (CONTEXT_IA64 | 0x00000004)
1180 #define CONTEXT_INTEGER               (CONTEXT_IA64 | 0x00000008)
1181 #define CONTEXT_DEBUG                 (CONTEXT_IA64 | 0x00000010)
1182 #define CONTEXT_IA32_CONTROL          (CONTEXT_IA64 | 0x00000020)
1183 #define CONTEXT_FLOATING_POINT        (CONTEXT_LOWER_FLOATING_POINT | CONTEXT_HIGHER_FLOATING_POINT)
1184 #define CONTEXT_FULL                  (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER | CONTEXT_IA32_CONTROL)
1185 #define CONTEXT_ALL                   (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER | CONTEXT_DEBUG | CONTEXT_IA32_CONTROL)
1186
1187 #define CONTEXT_EXCEPTION_ACTIVE      0x8000000
1188 #define CONTEXT_SERVICE_ACTIVE        0x10000000
1189 #define CONTEXT_EXCEPTION_REQUEST     0x40000000
1190 #define CONTEXT_EXCEPTION_REPORTING   0x80000000
1191
1192 typedef struct _CONTEXT
1193 {
1194     DWORD ContextFlags;
1195     DWORD Fill1[3];
1196     ULONGLONG DbI0;
1197     ULONGLONG DbI1;
1198     ULONGLONG DbI2;
1199     ULONGLONG DbI3;
1200     ULONGLONG DbI4;
1201     ULONGLONG DbI5;
1202     ULONGLONG DbI6;
1203     ULONGLONG DbI7;
1204     ULONGLONG DbD0;
1205     ULONGLONG DbD1;
1206     ULONGLONG DbD2;
1207     ULONGLONG DbD3;
1208     ULONGLONG DbD4;
1209     ULONGLONG DbD5;
1210     ULONGLONG DbD6;
1211     ULONGLONG DbD7;
1212     FLOAT128 FltS0;
1213     FLOAT128 FltS1;
1214     FLOAT128 FltS2;
1215     FLOAT128 FltS3;
1216     FLOAT128 FltT0;
1217     FLOAT128 FltT1;
1218     FLOAT128 FltT2;
1219     FLOAT128 FltT3;
1220     FLOAT128 FltT4;
1221     FLOAT128 FltT5;
1222     FLOAT128 FltT6;
1223     FLOAT128 FltT7;
1224     FLOAT128 FltT8;
1225     FLOAT128 FltT9;
1226     FLOAT128 FltS4;
1227     FLOAT128 FltS5;
1228     FLOAT128 FltS6;
1229     FLOAT128 FltS7;
1230     FLOAT128 FltS8;
1231     FLOAT128 FltS9;
1232     FLOAT128 FltS10;
1233     FLOAT128 FltS11;
1234     FLOAT128 FltS12;
1235     FLOAT128 FltS13;
1236     FLOAT128 FltS14;
1237     FLOAT128 FltS15;
1238     FLOAT128 FltS16;
1239     FLOAT128 FltS17;
1240     FLOAT128 FltS18;
1241     FLOAT128 FltS19;
1242     FLOAT128 FltF32;
1243     FLOAT128 FltF33;
1244     FLOAT128 FltF34;
1245     FLOAT128 FltF35;
1246     FLOAT128 FltF36;
1247     FLOAT128 FltF37;
1248     FLOAT128 FltF38;
1249     FLOAT128 FltF39;
1250     FLOAT128 FltF40;
1251     FLOAT128 FltF41;
1252     FLOAT128 FltF42;
1253     FLOAT128 FltF43;
1254     FLOAT128 FltF44;
1255     FLOAT128 FltF45;
1256     FLOAT128 FltF46;
1257     FLOAT128 FltF47;
1258     FLOAT128 FltF48;
1259     FLOAT128 FltF49;
1260     FLOAT128 FltF50;
1261     FLOAT128 FltF51;
1262     FLOAT128 FltF52;
1263     FLOAT128 FltF53;
1264     FLOAT128 FltF54;
1265     FLOAT128 FltF55;
1266     FLOAT128 FltF56;
1267     FLOAT128 FltF57;
1268     FLOAT128 FltF58;
1269     FLOAT128 FltF59;
1270     FLOAT128 FltF60;
1271     FLOAT128 FltF61;
1272     FLOAT128 FltF62;
1273     FLOAT128 FltF63;
1274     FLOAT128 FltF64;
1275     FLOAT128 FltF65;
1276     FLOAT128 FltF66;
1277     FLOAT128 FltF67;
1278     FLOAT128 FltF68;
1279     FLOAT128 FltF69;
1280     FLOAT128 FltF70;
1281     FLOAT128 FltF71;
1282     FLOAT128 FltF72;
1283     FLOAT128 FltF73;
1284     FLOAT128 FltF74;
1285     FLOAT128 FltF75;
1286     FLOAT128 FltF76;
1287     FLOAT128 FltF77;
1288     FLOAT128 FltF78;
1289     FLOAT128 FltF79;
1290     FLOAT128 FltF80;
1291     FLOAT128 FltF81;
1292     FLOAT128 FltF82;
1293     FLOAT128 FltF83;
1294     FLOAT128 FltF84;
1295     FLOAT128 FltF85;
1296     FLOAT128 FltF86;
1297     FLOAT128 FltF87;
1298     FLOAT128 FltF88;
1299     FLOAT128 FltF89;
1300     FLOAT128 FltF90;
1301     FLOAT128 FltF91;
1302     FLOAT128 FltF92;
1303     FLOAT128 FltF93;
1304     FLOAT128 FltF94;
1305     FLOAT128 FltF95;
1306     FLOAT128 FltF96;
1307     FLOAT128 FltF97;
1308     FLOAT128 FltF98;
1309     FLOAT128 FltF99;
1310     FLOAT128 FltF100;
1311     FLOAT128 FltF101;
1312     FLOAT128 FltF102;
1313     FLOAT128 FltF103;
1314     FLOAT128 FltF104;
1315     FLOAT128 FltF105;
1316     FLOAT128 FltF106;
1317     FLOAT128 FltF107;
1318     FLOAT128 FltF108;
1319     FLOAT128 FltF109;
1320     FLOAT128 FltF110;
1321     FLOAT128 FltF111;
1322     FLOAT128 FltF112;
1323     FLOAT128 FltF113;
1324     FLOAT128 FltF114;
1325     FLOAT128 FltF115;
1326     FLOAT128 FltF116;
1327     FLOAT128 FltF117;
1328     FLOAT128 FltF118;
1329     FLOAT128 FltF119;
1330     FLOAT128 FltF120;
1331     FLOAT128 FltF121;
1332     FLOAT128 FltF122;
1333     FLOAT128 FltF123;
1334     FLOAT128 FltF124;
1335     FLOAT128 FltF125;
1336     FLOAT128 FltF126;
1337     FLOAT128 FltF127;
1338     ULONGLONG StFPSR;
1339     ULONGLONG IntGp;
1340     ULONGLONG IntT0;
1341     ULONGLONG IntT1;
1342     ULONGLONG IntS0;
1343     ULONGLONG IntS1;
1344     ULONGLONG IntS2;
1345     ULONGLONG IntS3;
1346     ULONGLONG IntV0;
1347     ULONGLONG IntT2;
1348     ULONGLONG IntT3;
1349     ULONGLONG IntT4;
1350     ULONGLONG IntSp;
1351     ULONGLONG IntTeb;
1352     ULONGLONG IntT5;
1353     ULONGLONG IntT6;
1354     ULONGLONG IntT7;
1355     ULONGLONG IntT8;
1356     ULONGLONG IntT9;
1357     ULONGLONG IntT10;
1358     ULONGLONG IntT11;
1359     ULONGLONG IntT12;
1360     ULONGLONG IntT13;
1361     ULONGLONG IntT14;
1362     ULONGLONG IntT15;
1363     ULONGLONG IntT16;
1364     ULONGLONG IntT17;
1365     ULONGLONG IntT18;
1366     ULONGLONG IntT19;
1367     ULONGLONG IntT20;
1368     ULONGLONG IntT21;
1369     ULONGLONG IntT22;
1370     ULONGLONG IntNats;
1371     ULONGLONG Preds;
1372     ULONGLONG BrRp;
1373     ULONGLONG BrS0;
1374     ULONGLONG BrS1;
1375     ULONGLONG BrS2;
1376     ULONGLONG BrS3;
1377     ULONGLONG BrS4;
1378     ULONGLONG BrT0;
1379     ULONGLONG BrT1;
1380     ULONGLONG ApUNAT;
1381     ULONGLONG ApLC;
1382     ULONGLONG ApEC;
1383     ULONGLONG ApCCV;
1384     ULONGLONG ApDCR;
1385     ULONGLONG RsPFS;
1386     ULONGLONG RsBSP;
1387     ULONGLONG RsBSPSTORE;
1388     ULONGLONG RsRSC;
1389     ULONGLONG RsRNAT;
1390     ULONGLONG StIPSR;
1391     ULONGLONG StIIP;
1392     ULONGLONG StIFS;
1393     ULONGLONG StFCR;
1394     ULONGLONG Eflag;
1395     ULONGLONG SegCSD;
1396     ULONGLONG SegSSD;
1397     ULONGLONG Cflag;
1398     ULONGLONG StFSR;
1399     ULONGLONG StFIR;
1400     ULONGLONG StFDR;
1401     ULONGLONG UNUSEDPACK;
1402 } CONTEXT, *PCONTEXT;
1403
1404 typedef struct _RUNTIME_FUNCTION
1405 {
1406     ULONG BeginAddress;
1407     ULONG EndAddress;
1408     ULONG UnwindInfoAddress;
1409 } RUNTIME_FUNCTION, *PRUNTIME_FUNCTION;
1410
1411 typedef struct _FRAME_POINTERS {
1412   ULONGLONG MemoryStackFp;
1413   ULONGLONG BackingStoreFp;
1414 } FRAME_POINTERS, *PFRAME_POINTERS;
1415
1416 #define UNWIND_HISTORY_TABLE_SIZE 12
1417
1418 typedef struct _UNWIND_HISTORY_TABLE_ENTRY {
1419   ULONG64 ImageBase;
1420   ULONG64 Gp;
1421   PRUNTIME_FUNCTION FunctionEntry;
1422 } UNWIND_HISTORY_TABLE_ENTRY, *PUNWIND_HISTORY_TABLE_ENTRY;
1423
1424 typedef struct _UNWIND_HISTORY_TABLE {
1425   ULONG Count;
1426   UCHAR Search;
1427   ULONG64 LowAddress;
1428   ULONG64 HighAddress;
1429   UNWIND_HISTORY_TABLE_ENTRY Entry[UNWIND_HISTORY_TABLE_SIZE];
1430 } UNWIND_HISTORY_TABLE, *PUNWIND_HISTORY_TABLE;
1431
1432 typedef struct _KNONVOLATILE_CONTEXT_POINTERS
1433 {
1434     PFLOAT128  FltS0;
1435     PFLOAT128  FltS1;
1436     PFLOAT128  FltS2;
1437     PFLOAT128  FltS3;
1438     PFLOAT128  HighFloatingContext[10];
1439     PFLOAT128  FltS4;
1440     PFLOAT128  FltS5;
1441     PFLOAT128  FltS6;
1442     PFLOAT128  FltS7;
1443     PFLOAT128  FltS8;
1444     PFLOAT128  FltS9;
1445     PFLOAT128  FltS10;
1446     PFLOAT128  FltS11;
1447     PFLOAT128  FltS12;
1448     PFLOAT128  FltS13;
1449     PFLOAT128  FltS14;
1450     PFLOAT128  FltS15;
1451     PFLOAT128  FltS16;
1452     PFLOAT128  FltS17;
1453     PFLOAT128  FltS18;
1454     PFLOAT128  FltS19;
1455     PULONGLONG IntS0;
1456     PULONGLONG IntS1;
1457     PULONGLONG IntS2;
1458     PULONGLONG IntS3;
1459     PULONGLONG IntSp;
1460     PULONGLONG IntS0Nat;
1461     PULONGLONG IntS1Nat;
1462     PULONGLONG IntS2Nat;
1463     PULONGLONG IntS3Nat;
1464     PULONGLONG IntSpNat;
1465     PULONGLONG Preds;
1466     PULONGLONG BrRp;
1467     PULONGLONG BrS0;
1468     PULONGLONG BrS1;
1469     PULONGLONG BrS2;
1470     PULONGLONG BrS3;
1471     PULONGLONG BrS4;
1472     PULONGLONG ApUNAT;
1473     PULONGLONG ApLC;
1474     PULONGLONG ApEC;
1475     PULONGLONG RsPFS;
1476     PULONGLONG StFSR;
1477     PULONGLONG StFIR;
1478     PULONGLONG StFDR;
1479     PULONGLONG Cflag;
1480 } KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS;
1481
1482 ULONGLONG WINAPI RtlVirtualUnwind(ULONGLONG,ULONGLONG,RUNTIME_FUNCTION*,CONTEXT*,BOOLEAN*,FRAME_POINTERS*,KNONVOLATILE_CONTEXT_POINTERS*);
1483
1484 #endif /* __ia64__ */
1485
1486 /* Alpha context definitions */
1487 #if defined(_ALPHA_) || defined(__ALPHA__) || defined(__alpha__)
1488
1489 #define CONTEXT_ALPHA   0x00020000
1490
1491 #define CONTEXT_CONTROL         (CONTEXT_ALPHA | 0x00000001)
1492 #define CONTEXT_FLOATING_POINT  (CONTEXT_ALPHA | 0x00000002)
1493 #define CONTEXT_INTEGER         (CONTEXT_ALPHA | 0x00000004)
1494 #define CONTEXT_FULL  (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1495
1496 #define EXCEPTION_READ_FAULT    0
1497 #define EXCEPTION_WRITE_FAULT   1
1498 #define EXCEPTION_EXECUTE_FAULT 8
1499
1500 typedef struct _CONTEXT
1501 {
1502     /* selected by CONTEXT_FLOATING_POINT */
1503     ULONGLONG FltF0;
1504     ULONGLONG FltF1;
1505     ULONGLONG FltF2;
1506     ULONGLONG FltF3;
1507     ULONGLONG FltF4;
1508     ULONGLONG FltF5;
1509     ULONGLONG FltF6;
1510     ULONGLONG FltF7;
1511     ULONGLONG FltF8;
1512     ULONGLONG FltF9;
1513     ULONGLONG FltF10;
1514     ULONGLONG FltF11;
1515     ULONGLONG FltF12;
1516     ULONGLONG FltF13;
1517     ULONGLONG FltF14;
1518     ULONGLONG FltF15;
1519     ULONGLONG FltF16;
1520     ULONGLONG FltF17;
1521     ULONGLONG FltF18;
1522     ULONGLONG FltF19;
1523     ULONGLONG FltF20;
1524     ULONGLONG FltF21;
1525     ULONGLONG FltF22;
1526     ULONGLONG FltF23;
1527     ULONGLONG FltF24;
1528     ULONGLONG FltF25;
1529     ULONGLONG FltF26;
1530     ULONGLONG FltF27;
1531     ULONGLONG FltF28;
1532     ULONGLONG FltF29;
1533     ULONGLONG FltF30;
1534     ULONGLONG FltF31;
1535
1536     /* selected by CONTEXT_INTEGER */
1537     ULONGLONG IntV0;
1538     ULONGLONG IntT0;
1539     ULONGLONG IntT1;
1540     ULONGLONG IntT2;
1541     ULONGLONG IntT3;
1542     ULONGLONG IntT4;
1543     ULONGLONG IntT5;
1544     ULONGLONG IntT6;
1545     ULONGLONG IntT7;
1546     ULONGLONG IntS0;
1547     ULONGLONG IntS1;
1548     ULONGLONG IntS2;
1549     ULONGLONG IntS3;
1550     ULONGLONG IntS4;
1551     ULONGLONG IntS5;
1552     ULONGLONG IntFp;
1553     ULONGLONG IntA0;
1554     ULONGLONG IntA1;
1555     ULONGLONG IntA2;
1556     ULONGLONG IntA3;
1557     ULONGLONG IntA4;
1558     ULONGLONG IntA5;
1559     ULONGLONG IntT8;
1560     ULONGLONG IntT9;
1561     ULONGLONG IntT10;
1562     ULONGLONG IntT11;
1563     ULONGLONG IntRa;
1564     ULONGLONG IntT12;
1565     ULONGLONG IntAt;
1566     ULONGLONG IntGp;
1567     ULONGLONG IntSp;
1568     ULONGLONG IntZero;
1569
1570     /* selected by CONTEXT_FLOATING_POINT */
1571     ULONGLONG Fpcr;
1572     ULONGLONG SoftFpcr;
1573
1574     /* selected by CONTEXT_CONTROL */
1575     ULONGLONG Fir;
1576     DWORD Psr;
1577     DWORD ContextFlags;
1578     DWORD Fill[4];
1579 } CONTEXT;
1580
1581 #define _QUAD_PSR_OFFSET   HighSoftFpcr
1582 #define _QUAD_FLAGS_OFFSET HighFir
1583
1584 #endif  /* _ALPHA_ */
1585
1586 #ifdef __arm__
1587
1588 /* The following flags control the contents of the CONTEXT structure. */
1589
1590 #define CONTEXT_ARM    0x0200000
1591 #define CONTEXT_CONTROL         (CONTEXT_ARM | 0x00000001)
1592 #define CONTEXT_INTEGER         (CONTEXT_ARM | 0x00000002)
1593 #define CONTEXT_FLOATING_POINT  (CONTEXT_ARM | 0x00000004)
1594 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_ARM | 0x00000008)
1595
1596 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1597
1598 #define EXCEPTION_READ_FAULT    0
1599 #define EXCEPTION_WRITE_FAULT   1
1600 #define EXCEPTION_EXECUTE_FAULT 8
1601
1602 typedef struct _CONTEXT {
1603         /* The flags values within this flag control the contents of
1604            a CONTEXT record.
1605
1606            If the context record is used as an input parameter, then
1607            for each portion of the context record controlled by a flag
1608            whose value is set, it is assumed that that portion of the
1609            context record contains valid context. If the context record
1610            is being used to modify a thread's context, then only that
1611            portion of the threads context will be modified.
1612
1613            If the context record is used as an IN OUT parameter to capture
1614            the context of a thread, then only those portions of the thread's
1615            context corresponding to set flags will be returned.
1616
1617            The context record is never used as an OUT only parameter. */
1618
1619         ULONG ContextFlags;
1620
1621         /* This section is specified/returned if the ContextFlags word contains
1622            the flag CONTEXT_INTEGER. */
1623         ULONG R0;
1624         ULONG R1;
1625         ULONG R2;
1626         ULONG R3;
1627         ULONG R4;
1628         ULONG R5;
1629         ULONG R6;
1630         ULONG R7;
1631         ULONG R8;
1632         ULONG R9;
1633         ULONG R10;
1634         ULONG Fp;
1635         ULONG Ip;
1636
1637         /* These are selected by CONTEXT_CONTROL */
1638         ULONG Sp;
1639         ULONG Lr;
1640         ULONG Pc;
1641         ULONG Cpsr;
1642 } CONTEXT;
1643
1644 #endif /* __arm__ */
1645
1646
1647 /* Mips context definitions */
1648 #if defined(_MIPS_) || defined(__MIPS__) || defined(__mips__)
1649
1650 #define CONTEXT_R4000   0x00010000
1651
1652 #define CONTEXT_CONTROL         (CONTEXT_R4000 | 0x00000001)
1653 #define CONTEXT_FLOATING_POINT  (CONTEXT_R4000 | 0x00000002)
1654 #define CONTEXT_INTEGER         (CONTEXT_R4000 | 0x00000004)
1655
1656 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1657
1658 #define EXCEPTION_READ_FAULT    0
1659 #define EXCEPTION_WRITE_FAULT   1
1660 #define EXCEPTION_EXECUTE_FAULT 8
1661
1662 typedef struct _CONTEXT
1663 {
1664     DWORD Argument[4];
1665     /* These are selected by CONTEXT_FLOATING_POINT */
1666     DWORD FltF0;
1667     DWORD FltF1;
1668     DWORD FltF2;
1669     DWORD FltF3;
1670     DWORD FltF4;
1671     DWORD FltF5;
1672     DWORD FltF6;
1673     DWORD FltF7;
1674     DWORD FltF8;
1675     DWORD FltF9;
1676     DWORD FltF10;
1677     DWORD FltF11;
1678     DWORD FltF12;
1679     DWORD FltF13;
1680     DWORD FltF14;
1681     DWORD FltF15;
1682     DWORD FltF16;
1683     DWORD FltF17;
1684     DWORD FltF18;
1685     DWORD FltF19;
1686     DWORD FltF20;
1687     DWORD FltF21;
1688     DWORD FltF22;
1689     DWORD FltF23;
1690     DWORD FltF24;
1691     DWORD FltF25;
1692     DWORD FltF26;
1693     DWORD FltF27;
1694     DWORD FltF28;
1695     DWORD FltF29;
1696     DWORD FltF30;
1697     DWORD FltF31;
1698
1699     /* These are selected by CONTEXT_INTEGER */
1700     DWORD IntZero;
1701     DWORD IntAt;
1702     DWORD IntV0;
1703     DWORD IntV1;
1704     DWORD IntA0;
1705     DWORD IntA1;
1706     DWORD IntA2;
1707     DWORD IntA3;
1708     DWORD IntT0;
1709     DWORD IntT1;
1710     DWORD IntT2;
1711     DWORD IntT3;
1712     DWORD IntT4;
1713     DWORD IntT5;
1714     DWORD IntT6;
1715     DWORD IntT7;
1716     DWORD IntS0;
1717     DWORD IntS1;
1718     DWORD IntS2;
1719     DWORD IntS3;
1720     DWORD IntS4;
1721     DWORD IntS5;
1722     DWORD IntS6;
1723     DWORD IntS7;
1724     DWORD IntT8;
1725     DWORD IntT9;
1726     DWORD IntK0;
1727     DWORD IntK1;
1728     DWORD IntGp;
1729     DWORD IntSp;
1730     DWORD IntS8;
1731     DWORD IntRa;
1732     DWORD IntLo;
1733     DWORD IntHi;
1734
1735     /* These are selected by CONTEXT_FLOATING_POINT */
1736     DWORD Fsr;
1737
1738     /* These are selected by CONTEXT_CONTROL */
1739     DWORD Fir;
1740     DWORD Psr;
1741
1742     DWORD ContextFlags;
1743     DWORD Fill[2];
1744 } CONTEXT;
1745
1746 #endif  /* _MIPS_ */
1747
1748 /* PowerPC context definitions */
1749 #ifdef __powerpc__
1750
1751 #define CONTEXT_CONTROL         0x0001
1752 #define CONTEXT_FLOATING_POINT  0x0002
1753 #define CONTEXT_INTEGER         0x0004
1754 #define CONTEXT_DEBUG_REGISTERS 0x0008
1755 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1756
1757 #define EXCEPTION_READ_FAULT    0
1758 #define EXCEPTION_WRITE_FAULT   1
1759 #define EXCEPTION_EXECUTE_FAULT 8
1760
1761 typedef struct
1762 {
1763     /* These are selected by CONTEXT_FLOATING_POINT */
1764     double Fpr0;
1765     double Fpr1;
1766     double Fpr2;
1767     double Fpr3;
1768     double Fpr4;
1769     double Fpr5;
1770     double Fpr6;
1771     double Fpr7;
1772     double Fpr8;
1773     double Fpr9;
1774     double Fpr10;
1775     double Fpr11;
1776     double Fpr12;
1777     double Fpr13;
1778     double Fpr14;
1779     double Fpr15;
1780     double Fpr16;
1781     double Fpr17;
1782     double Fpr18;
1783     double Fpr19;
1784     double Fpr20;
1785     double Fpr21;
1786     double Fpr22;
1787     double Fpr23;
1788     double Fpr24;
1789     double Fpr25;
1790     double Fpr26;
1791     double Fpr27;
1792     double Fpr28;
1793     double Fpr29;
1794     double Fpr30;
1795     double Fpr31;
1796     double Fpscr;
1797
1798     /* These are selected by CONTEXT_INTEGER */
1799     DWORD Gpr0;
1800     DWORD Gpr1;
1801     DWORD Gpr2;
1802     DWORD Gpr3;
1803     DWORD Gpr4;
1804     DWORD Gpr5;
1805     DWORD Gpr6;
1806     DWORD Gpr7;
1807     DWORD Gpr8;
1808     DWORD Gpr9;
1809     DWORD Gpr10;
1810     DWORD Gpr11;
1811     DWORD Gpr12;
1812     DWORD Gpr13;
1813     DWORD Gpr14;
1814     DWORD Gpr15;
1815     DWORD Gpr16;
1816     DWORD Gpr17;
1817     DWORD Gpr18;
1818     DWORD Gpr19;
1819     DWORD Gpr20;
1820     DWORD Gpr21;
1821     DWORD Gpr22;
1822     DWORD Gpr23;
1823     DWORD Gpr24;
1824     DWORD Gpr25;
1825     DWORD Gpr26;
1826     DWORD Gpr27;
1827     DWORD Gpr28;
1828     DWORD Gpr29;
1829     DWORD Gpr30;
1830     DWORD Gpr31;
1831
1832     DWORD Cr;
1833     DWORD Xer;
1834
1835     /* These are selected by CONTEXT_CONTROL */
1836     DWORD Msr;
1837     DWORD Iar; /* Instruction Address Register , aka PC ... */
1838     DWORD Lr;
1839     DWORD Ctr;
1840
1841     DWORD ContextFlags;
1842     
1843     DWORD Dar;   /* Fault registers for coredump */
1844     DWORD Dsisr; 
1845     DWORD Trap;  /* number of powerpc exception taken */
1846
1847     /* These are selected by CONTEXT_DEBUG_REGISTERS */
1848     DWORD Dr0;
1849     DWORD Dr1;
1850     DWORD Dr2;
1851     DWORD Dr3;
1852     DWORD Dr4;
1853     DWORD Dr5;
1854     DWORD Dr6;
1855     DWORD Dr7;
1856 } CONTEXT;
1857
1858 typedef struct _STACK_FRAME_HEADER
1859 {
1860     DWORD BackChain;
1861     DWORD GlueSaved1;
1862     DWORD GlueSaved2;
1863     DWORD Reserved1;
1864     DWORD Spare1;
1865     DWORD Spare2;
1866
1867     DWORD Parameter0;
1868     DWORD Parameter1;
1869     DWORD Parameter2;
1870     DWORD Parameter3;
1871     DWORD Parameter4;
1872     DWORD Parameter5;
1873     DWORD Parameter6;
1874     DWORD Parameter7;
1875 } STACK_FRAME_HEADER,*PSTACK_FRAME_HEADER;
1876
1877 #endif  /* __powerpc__ */
1878
1879 #ifdef __sparc__
1880
1881 /*
1882  * FIXME:
1883  *
1884  * There is no official CONTEXT structure defined for the SPARC
1885  * architecture, so I just made one up.
1886  *
1887  * This structure is valid only for 32-bit SPARC architectures,
1888  * not for 64-bit SPARC.
1889  *
1890  * Note that this structure contains only the 'top-level' registers;
1891  * the rest of the register window chain is not visible.
1892  *
1893  * The layout follows the Solaris 'prgregset_t' structure.
1894  *
1895  */
1896
1897 #define CONTEXT_SPARC            0x10000000
1898
1899 #define CONTEXT_CONTROL         (CONTEXT_SPARC | 0x00000001)
1900 #define CONTEXT_FLOATING_POINT  (CONTEXT_SPARC | 0x00000002)
1901 #define CONTEXT_INTEGER         (CONTEXT_SPARC | 0x00000004)
1902
1903 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1904
1905 #define EXCEPTION_READ_FAULT    0
1906 #define EXCEPTION_WRITE_FAULT   1
1907 #define EXCEPTION_EXECUTE_FAULT 8
1908
1909 typedef struct _CONTEXT
1910 {
1911     DWORD ContextFlags;
1912
1913     /* These are selected by CONTEXT_INTEGER */
1914     DWORD g0;
1915     DWORD g1;
1916     DWORD g2;
1917     DWORD g3;
1918     DWORD g4;
1919     DWORD g5;
1920     DWORD g6;
1921     DWORD g7;
1922     DWORD o0;
1923     DWORD o1;
1924     DWORD o2;
1925     DWORD o3;
1926     DWORD o4;
1927     DWORD o5;
1928     DWORD o6;
1929     DWORD o7;
1930     DWORD l0;
1931     DWORD l1;
1932     DWORD l2;
1933     DWORD l3;
1934     DWORD l4;
1935     DWORD l5;
1936     DWORD l6;
1937     DWORD l7;
1938     DWORD i0;
1939     DWORD i1;
1940     DWORD i2;
1941     DWORD i3;
1942     DWORD i4;
1943     DWORD i5;
1944     DWORD i6;
1945     DWORD i7;
1946
1947     /* These are selected by CONTEXT_CONTROL */
1948     DWORD psr;
1949     DWORD pc;
1950     DWORD npc;
1951     DWORD y;
1952     DWORD wim;
1953     DWORD tbr;
1954
1955     /* FIXME: floating point registers missing */
1956
1957 } CONTEXT;
1958
1959 #endif  /* __sparc__ */
1960
1961 #if !defined(CONTEXT_FULL) && !defined(RC_INVOKED)
1962 #error You need to define a CONTEXT for your CPU
1963 #endif
1964
1965 typedef CONTEXT *PCONTEXT;
1966
1967 NTSYSAPI void WINAPI RtlCaptureContext(CONTEXT*);
1968
1969 /*
1970  * Product types
1971  */
1972 #define PRODUCT_UNLICENSED                              0xABCDABCD
1973 #define PRODUCT_BUSINESS                                0x00000006
1974 #define PRODUCT_BUSINESS_N                              0x00000010
1975 #define PRODUCT_CLUSTER_SERVER                          0x00000012
1976 #define PRODUCT_DATACENTER_SERVER                       0x00000008
1977 #define PRODUCT_DATACENTER_SERVER_CORE                  0x0000000C
1978 #define PRODUCT_DATACENTER_SERVER_CORE_V                0x00000027
1979 #define PRODUCT_SERVER_V                                0x00000025
1980 #define PRODUCT_ENTERPRISE                              0x00000004
1981 #define PRODUCT_ENTERPRISE_N                            0x0000001B
1982 #define PRODUCT_ENTERPRISE_SERVER                       0x0000000A
1983 #define PRODUCT_ENTERPRISE_SERVER_CORE                  0x0000000E
1984 #define PRODUCT_ENTERPRISE_SERVER_CORE_V                0x00000029
1985 #define PRODUCT_ENTERPRISE_SERVER_IA64                  0x0000000F
1986 #define PRODUCT_ENTERPRISE_SERVER_V                     0x00000026
1987 #define PRODUCT_HOME_BASIC                              0x00000002
1988 #define PRODUCT_HOME_BASIC_N                            0x00000005
1989 #define PRODUCT_HOME_PREMIUM                            0x00000003
1990 #define PRODUCT_HOME_PREMIUM_N                          0x0000001A
1991 #define PRODUCT_HYPERV                                  0x0000002A
1992 #define PRODUCT_MEDIUMBUSINESS_SERVER_MANAGEMENT        0x0000001E
1993 #define PRODUCT_MEDIUMBUSINESS_SERVER_MESSAGING         0x00000020
1994 #define PRODUCT_MEDIUMBUSINESS_SERVER_SECURITY          0x0000001F
1995 #define PRODUCT_SERVER_FOR_SMALLBUSINESS                0x00000018
1996 #define PRODUCT_SERVER_FOR_SMALLBUSINESS_V              0x00000023
1997 #define PRODUCT_SMALLBUSINESS_SERVER                    0x00000009
1998 #define PRODUCT_STANDARD_SERVER                         0x00000007
1999 #define PRODUCT_STANDARD_SERVER_CORE                    0x0000000D
2000 #define PRODUCT_STANDARD_SERVER_CORE_V                  0x00000028
2001 #define PRODUCT_STANDARD_SERVER_V                       0x00000024
2002 #define PRODUCT_STARTER                                 0x0000000B
2003 #define PRODUCT_STORAGE_ENTERPRISE_SERVER               0x00000017
2004 #define PRODUCT_STORAGE_EXPRESS_SERVER                  0x00000014
2005 #define PRODUCT_STORAGE_STANDARD_SERVER                 0x00000015
2006 #define PRODUCT_STORAGE_WORKGROUP_SERVER                0x00000016
2007 #define PRODUCT_UNDEFINED                               0x00000000
2008 #define PRODUCT_ULTIMATE                                0x00000001
2009 #define PRODUCT_ULTIMATE_N                              0x0000001C
2010 #define PRODUCT_WEB_SERVER                              0x00000011
2011 #define PRODUCT_WEB_SERVER_CORE                         0x0000001D
2012
2013
2014 /*
2015  * Language IDs
2016  */
2017
2018 #define MAKELCID(l, s)          (MAKELONG(l, s))
2019
2020 #define MAKELANGID(p, s)        ((((WORD)(s))<<10) | (WORD)(p))
2021 #define PRIMARYLANGID(l)        ((WORD)(l) & 0x3ff)
2022 #define SUBLANGID(l)            ((WORD)(l) >> 10)
2023
2024 #define LANGIDFROMLCID(lcid)    ((WORD)(lcid))
2025 #define SORTIDFROMLCID(lcid)    ((WORD)((((DWORD)(lcid)) >> 16) & 0x0f))
2026
2027 #define LANG_SYSTEM_DEFAULT     (MAKELANGID(LANG_NEUTRAL, SUBLANG_SYS_DEFAULT))
2028 #define LANG_USER_DEFAULT       (MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT))
2029 #define LOCALE_SYSTEM_DEFAULT   (MAKELCID(LANG_SYSTEM_DEFAULT, SORT_DEFAULT))
2030 #define LOCALE_USER_DEFAULT     (MAKELCID(LANG_USER_DEFAULT, SORT_DEFAULT))
2031 #define LOCALE_NEUTRAL          (MAKELCID(MAKELANGID(LANG_NEUTRAL,SUBLANG_NEUTRAL),SORT_DEFAULT))
2032 #define LOCALE_INVARIANT        (MAKELCID(MAKELANGID(LANG_INVARIANT,SUBLANG_NEUTRAL),SORT_DEFAULT))
2033 #define LOCALE_CUSTOM_DEFAULT      (MAKELCID(MAKELANGID(LANG_NEUTRAL,SUBLANG_CUSTOM_DEFAULT),SORT_DEFAULT))
2034 #define LOCALE_CUSTOM_UNSPECIFIED  (MAKELCID(MAKELANGID(LANG_NEUTRAL,SUBLANG_CUSTOM_UNSPECIFIED),SORT_DEFAULT))
2035 #define LOCALE_CUSTOM_UI_DEFAULT   (MAKELCID(MAKELANGID(LANG_NEUTRAL,SUBLANG_UI_CUSTOM_DEFAULT),SORT_DEFAULT))
2036 #define LOCALE_NAME_MAX_LENGTH     85
2037
2038
2039 #define UNREFERENCED_PARAMETER(u)       (void)(u)
2040 #define DBG_UNREFERENCED_PARAMETER(u)   (void)(u)
2041 #define DBG_UNREFERENCED_LOCAL_VARIABLE(u) (void)(u)
2042
2043 #include <winnt.rh>
2044
2045
2046 /*
2047  * Definitions for IsTextUnicode()
2048  */
2049
2050 #define IS_TEXT_UNICODE_ASCII16            0x0001
2051 #define IS_TEXT_UNICODE_STATISTICS         0x0002
2052 #define IS_TEXT_UNICODE_CONTROLS           0x0004
2053 #define IS_TEXT_UNICODE_SIGNATURE          0x0008
2054 #define IS_TEXT_UNICODE_UNICODE_MASK       0x000F
2055 #define IS_TEXT_UNICODE_REVERSE_ASCII16    0x0010
2056 #define IS_TEXT_UNICODE_REVERSE_STATISTICS 0x0020
2057 #define IS_TEXT_UNICODE_REVERSE_CONTROLS   0x0040
2058 #define IS_TEXT_UNICODE_REVERSE_SIGNATURE  0x0080
2059 #define IS_TEXT_UNICODE_REVERSE_MASK       0x00F0
2060 #define IS_TEXT_UNICODE_ILLEGAL_CHARS      0x0100
2061 #define IS_TEXT_UNICODE_ODD_LENGTH         0x0200
2062 #define IS_TEXT_UNICODE_DBCS_LEADBYTE      0x0400
2063 #define IS_TEXT_UNICODE_NOT_UNICODE_MASK   0x0F00
2064 #define IS_TEXT_UNICODE_NULL_BYTES         0x1000
2065 #define IS_TEXT_UNICODE_NOT_ASCII_MASK     0xF000
2066
2067 #define MAXIMUM_WAIT_OBJECTS 64
2068 #define MAXIMUM_SUSPEND_COUNT 127
2069
2070 #define WT_EXECUTEDEFAULT              0x00
2071 #define WT_EXECUTEINIOTHREAD           0x01
2072 #define WT_EXECUTEINUITHREAD           0x02
2073 #define WT_EXECUTEINWAITTHREAD         0x04
2074 #define WT_EXECUTEONLYONCE             0x08
2075 #define WT_EXECUTELONGFUNCTION         0x10
2076 #define WT_EXECUTEINTIMERTHREAD        0x20
2077 #define WT_EXECUTEINPERSISTENTIOTHREAD 0x40
2078 #define WT_EXECUTEINPERSISTENTTHREAD   0x80
2079 #define WT_EXECUTEINLONGTHREAD         0x10
2080 #define WT_EXECUTEDELETEWAIT           0x08
2081 #define WT_TRANSFER_IMPERSONATION      0x0100
2082
2083
2084 #define EXCEPTION_CONTINUABLE        0
2085 #define EXCEPTION_NONCONTINUABLE     0x01
2086
2087 /*
2088  * The exception record used by Win32 to give additional information
2089  * about exception to exception handlers.
2090  */
2091
2092 #define EXCEPTION_MAXIMUM_PARAMETERS 15
2093
2094 typedef struct _EXCEPTION_RECORD
2095 {
2096     DWORD    ExceptionCode;
2097     DWORD    ExceptionFlags;
2098     struct  _EXCEPTION_RECORD *ExceptionRecord;
2099
2100     PVOID    ExceptionAddress;
2101     DWORD    NumberParameters;
2102     ULONG_PTR ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
2103 } EXCEPTION_RECORD, *PEXCEPTION_RECORD;
2104
2105 /*
2106  * The exception pointers structure passed to exception filters
2107  * in except() and the UnhandledExceptionFilter().
2108  */
2109
2110 typedef struct _EXCEPTION_POINTERS
2111 {
2112   PEXCEPTION_RECORD  ExceptionRecord;
2113   PCONTEXT           ContextRecord;
2114 } EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
2115
2116
2117 /*
2118  * The exception frame, used for registering exception handlers
2119  * Win32 cares only about this, but compilers generally emit
2120  * larger exception frames for their own use.
2121  */
2122
2123 struct _EXCEPTION_REGISTRATION_RECORD;
2124
2125 typedef DWORD (*PEXCEPTION_HANDLER)(PEXCEPTION_RECORD,struct _EXCEPTION_REGISTRATION_RECORD*,
2126                                     PCONTEXT,struct _EXCEPTION_REGISTRATION_RECORD **);
2127
2128 typedef struct _EXCEPTION_REGISTRATION_RECORD
2129 {
2130   struct _EXCEPTION_REGISTRATION_RECORD *Prev;
2131   PEXCEPTION_HANDLER       Handler;
2132 } EXCEPTION_REGISTRATION_RECORD;
2133
2134 /*
2135  * function pointer to an exception filter
2136  */
2137
2138 typedef LONG (CALLBACK *PVECTORED_EXCEPTION_HANDLER)(PEXCEPTION_POINTERS ExceptionInfo);
2139
2140 typedef struct _NT_TIB
2141 {
2142         struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList;
2143         PVOID StackBase;
2144         PVOID StackLimit;
2145         PVOID SubSystemTib;
2146         union {
2147           PVOID FiberData;
2148           DWORD Version;
2149         } DUMMYUNIONNAME;
2150         PVOID ArbitraryUserPointer;
2151         struct _NT_TIB *Self;
2152 } NT_TIB, *PNT_TIB;
2153
2154 struct _TEB;
2155
2156 #if defined(__i386__) && defined(__GNUC__) && ((__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 2)))
2157 static FORCEINLINE struct _TEB * WINAPI NtCurrentTeb(void)
2158 {
2159     struct _TEB *teb;
2160     __asm__(".byte 0x64\n\tmovl (0x18),%0" : "=r" (teb));
2161     return teb;
2162 }
2163 #elif defined(__i386__) && defined(_MSC_VER)
2164 static FORCEINLINE struct _TEB * WINAPI NtCurrentTeb(void)
2165 {
2166   struct _TEB *teb;
2167   __asm mov eax, fs:[0x18];
2168   __asm mov teb, eax;
2169   return teb;
2170 }
2171 #elif defined(__x86_64__) && defined(__GNUC__)
2172 static FORCEINLINE struct _TEB * WINAPI NtCurrentTeb(void)
2173 {
2174     struct _TEB *teb;
2175     __asm__(".byte 0x65\n\tmovq (0x30),%0" : "=r" (teb));
2176     return teb;
2177 }
2178 #elif defined(__x86_64__) && defined (_MSC_VER)
2179 static FORCEINLINE struct _TEB * WINAPI NtCurrentTeb(void)
2180 {
2181   struct _TEB *teb;
2182   __asm mov rax, gs:[0x30];
2183   __asm mov teb, rax;
2184   return teb;
2185 }
2186 #else
2187 extern struct _TEB * WINAPI NtCurrentTeb(void);
2188 #endif
2189
2190 #ifdef NONAMELESSUNION
2191 #define GetCurrentFiber()  (((NT_TIB *)NtCurrentTeb())->u.FiberData)
2192 #else
2193 #define GetCurrentFiber()  (((NT_TIB *)NtCurrentTeb())->FiberData)
2194 #endif
2195 #define GetFiberData()     (*(void **)GetCurrentFiber())
2196
2197 #define TLS_MINIMUM_AVAILABLE 64
2198
2199 /*
2200  * File formats definitions
2201  */
2202
2203 #include <pshpack2.h>
2204 typedef struct _IMAGE_DOS_HEADER {
2205     WORD  e_magic;      /* 00: MZ Header signature */
2206     WORD  e_cblp;       /* 02: Bytes on last page of file */
2207     WORD  e_cp;         /* 04: Pages in file */
2208     WORD  e_crlc;       /* 06: Relocations */
2209     WORD  e_cparhdr;    /* 08: Size of header in paragraphs */
2210     WORD  e_minalloc;   /* 0a: Minimum extra paragraphs needed */
2211     WORD  e_maxalloc;   /* 0c: Maximum extra paragraphs needed */
2212     WORD  e_ss;         /* 0e: Initial (relative) SS value */
2213     WORD  e_sp;         /* 10: Initial SP value */
2214     WORD  e_csum;       /* 12: Checksum */
2215     WORD  e_ip;         /* 14: Initial IP value */
2216     WORD  e_cs;         /* 16: Initial (relative) CS value */
2217     WORD  e_lfarlc;     /* 18: File address of relocation table */
2218     WORD  e_ovno;       /* 1a: Overlay number */
2219     WORD  e_res[4];     /* 1c: Reserved words */
2220     WORD  e_oemid;      /* 24: OEM identifier (for e_oeminfo) */
2221     WORD  e_oeminfo;    /* 26: OEM information; e_oemid specific */
2222     WORD  e_res2[10];   /* 28: Reserved words */
2223     DWORD e_lfanew;     /* 3c: Offset to extended header */
2224 } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
2225 #include <poppack.h>
2226
2227 #define IMAGE_DOS_SIGNATURE    0x5A4D     /* MZ   */
2228 #define IMAGE_OS2_SIGNATURE    0x454E     /* NE   */
2229 #define IMAGE_OS2_SIGNATURE_LE 0x454C     /* LE   */
2230 #define IMAGE_OS2_SIGNATURE_LX 0x584C     /* LX */
2231 #define IMAGE_VXD_SIGNATURE    0x454C     /* LE   */
2232 #define IMAGE_NT_SIGNATURE     0x00004550 /* PE00 */
2233
2234 /*
2235  * This is the Windows executable (NE) header.
2236  * the name IMAGE_OS2_HEADER is misleading, but in the SDK this way.
2237  */
2238 #include <pshpack2.h>
2239 typedef struct
2240 {
2241     WORD  ne_magic;             /* 00 NE signature 'NE' */
2242     BYTE  ne_ver;               /* 02 Linker version number */
2243     BYTE  ne_rev;               /* 03 Linker revision number */
2244     WORD  ne_enttab;            /* 04 Offset to entry table relative to NE */
2245     WORD  ne_cbenttab;          /* 06 Length of entry table in bytes */
2246     LONG  ne_crc;               /* 08 Checksum */
2247     WORD  ne_flags;             /* 0c Flags about segments in this file */
2248     WORD  ne_autodata;          /* 0e Automatic data segment number */
2249     WORD  ne_heap;              /* 10 Initial size of local heap */
2250     WORD  ne_stack;             /* 12 Initial size of stack */
2251     DWORD ne_csip;              /* 14 Initial CS:IP */
2252     DWORD ne_sssp;              /* 18 Initial SS:SP */
2253     WORD  ne_cseg;              /* 1c # of entries in segment table */
2254     WORD  ne_cmod;              /* 1e # of entries in module reference tab. */
2255     WORD  ne_cbnrestab;         /* 20 Length of nonresident-name table     */
2256     WORD  ne_segtab;            /* 22 Offset to segment table */
2257     WORD  ne_rsrctab;           /* 24 Offset to resource table */
2258     WORD  ne_restab;            /* 26 Offset to resident-name table */
2259     WORD  ne_modtab;            /* 28 Offset to module reference table */
2260     WORD  ne_imptab;            /* 2a Offset to imported name table */
2261     DWORD ne_nrestab;           /* 2c Offset to nonresident-name table */
2262     WORD  ne_cmovent;           /* 30 # of movable entry points */
2263     WORD  ne_align;             /* 32 Logical sector alignment shift count */
2264     WORD  ne_cres;              /* 34 # of resource segments */
2265     BYTE  ne_exetyp;            /* 36 Flags indicating target OS */
2266     BYTE  ne_flagsothers;       /* 37 Additional information flags */
2267     WORD  ne_pretthunks;        /* 38 Offset to return thunks */
2268     WORD  ne_psegrefbytes;      /* 3a Offset to segment ref. bytes */
2269     WORD  ne_swaparea;          /* 3c Reserved by Microsoft */
2270     WORD  ne_expver;            /* 3e Expected Windows version number */
2271 } IMAGE_OS2_HEADER, *PIMAGE_OS2_HEADER;
2272 #include <poppack.h>
2273
2274 #include <pshpack2.h>
2275 typedef struct _IMAGE_VXD_HEADER {
2276   WORD  e32_magic;
2277   BYTE  e32_border;
2278   BYTE  e32_worder;
2279   DWORD e32_level;
2280   WORD  e32_cpu;
2281   WORD  e32_os;
2282   DWORD e32_ver;
2283   DWORD e32_mflags;
2284   DWORD e32_mpages;
2285   DWORD e32_startobj;
2286   DWORD e32_eip;
2287   DWORD e32_stackobj;
2288   DWORD e32_esp;
2289   DWORD e32_pagesize;
2290   DWORD e32_lastpagesize;
2291   DWORD e32_fixupsize;
2292   DWORD e32_fixupsum;
2293   DWORD e32_ldrsize;
2294   DWORD e32_ldrsum;
2295   DWORD e32_objtab;
2296   DWORD e32_objcnt;
2297   DWORD e32_objmap;
2298   DWORD e32_itermap;
2299   DWORD e32_rsrctab;
2300   DWORD e32_rsrccnt;
2301   DWORD e32_restab;
2302   DWORD e32_enttab;
2303   DWORD e32_dirtab;
2304   DWORD e32_dircnt;
2305   DWORD e32_fpagetab;
2306   DWORD e32_frectab;
2307   DWORD e32_impmod;
2308   DWORD e32_impmodcnt;
2309   DWORD e32_impproc;
2310   DWORD e32_pagesum;
2311   DWORD e32_datapage;
2312   DWORD e32_preload;
2313   DWORD e32_nrestab;
2314   DWORD e32_cbnrestab;
2315   DWORD e32_nressum;
2316   DWORD e32_autodata;
2317   DWORD e32_debuginfo;
2318   DWORD e32_debuglen;
2319   DWORD e32_instpreload;
2320   DWORD e32_instdemand;
2321   DWORD e32_heapsize;
2322   BYTE  e32_res3[12];
2323   DWORD e32_winresoff;
2324   DWORD e32_winreslen;
2325   WORD  e32_devid;
2326   WORD  e32_ddkver;
2327 } IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
2328 #include <poppack.h>
2329
2330 /* These defines describe the meanings of the bits in the Characteristics
2331    field */
2332
2333 #define IMAGE_FILE_RELOCS_STRIPPED      0x0001 /* No relocation info */
2334 #define IMAGE_FILE_EXECUTABLE_IMAGE     0x0002
2335 #define IMAGE_FILE_LINE_NUMS_STRIPPED   0x0004
2336 #define IMAGE_FILE_LOCAL_SYMS_STRIPPED  0x0008
2337 #define IMAGE_FILE_AGGRESIVE_WS_TRIM    0x0010
2338 #define IMAGE_FILE_LARGE_ADDRESS_AWARE  0x0020
2339 #define IMAGE_FILE_16BIT_MACHINE        0x0040
2340 #define IMAGE_FILE_BYTES_REVERSED_LO    0x0080
2341 #define IMAGE_FILE_32BIT_MACHINE        0x0100
2342 #define IMAGE_FILE_DEBUG_STRIPPED       0x0200
2343 #define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP      0x0400
2344 #define IMAGE_FILE_NET_RUN_FROM_SWAP    0x0800
2345 #define IMAGE_FILE_SYSTEM               0x1000
2346 #define IMAGE_FILE_DLL                  0x2000
2347 #define IMAGE_FILE_UP_SYSTEM_ONLY       0x4000
2348 #define IMAGE_FILE_BYTES_REVERSED_HI    0x8000
2349
2350 /* These are the settings of the Machine field. */
2351 #define IMAGE_FILE_MACHINE_UNKNOWN      0
2352 #define IMAGE_FILE_MACHINE_I860         0x014d
2353 #define IMAGE_FILE_MACHINE_I386         0x014c
2354 #define IMAGE_FILE_MACHINE_R3000        0x0162
2355 #define IMAGE_FILE_MACHINE_R4000        0x0166
2356 #define IMAGE_FILE_MACHINE_R10000       0x0168
2357 #define IMAGE_FILE_MACHINE_WCEMIPSV2    0x0169
2358 #define IMAGE_FILE_MACHINE_ALPHA        0x0184
2359 #define IMAGE_FILE_MACHINE_SH3          0x01a2
2360 #define IMAGE_FILE_MACHINE_SH3DSP       0x01a3
2361 #define IMAGE_FILE_MACHINE_SH3E         0x01a4
2362 #define IMAGE_FILE_MACHINE_SH4          0x01a6
2363 #define IMAGE_FILE_MACHINE_SH5          0x01a8
2364 #define IMAGE_FILE_MACHINE_ARM          0x01c0
2365 #define IMAGE_FILE_MACHINE_THUMB        0x01c2
2366 #define IMAGE_FILE_MACHINE_ARMV7        0x01c4
2367 #define IMAGE_FILE_MACHINE_AM33         0x01d3
2368 #define IMAGE_FILE_MACHINE_POWERPC      0x01f0
2369 #define IMAGE_FILE_MACHINE_POWERPCFP    0x01f1
2370 #define IMAGE_FILE_MACHINE_IA64         0x0200
2371 #define IMAGE_FILE_MACHINE_MIPS16       0x0266
2372 #define IMAGE_FILE_MACHINE_ALPHA64      0x0284
2373 #define IMAGE_FILE_MACHINE_MIPSFPU      0x0366
2374 #define IMAGE_FILE_MACHINE_MIPSFPU16    0x0466
2375 #define IMAGE_FILE_MACHINE_AXP64        IMAGE_FILE_MACHINE_ALPHA64
2376 #define IMAGE_FILE_MACHINE_TRICORE      0x0520
2377 #define IMAGE_FILE_MACHINE_CEF          0x0cef
2378 #define IMAGE_FILE_MACHINE_EBC          0x0ebc
2379 #define IMAGE_FILE_MACHINE_AMD64        0x8664
2380 #define IMAGE_FILE_MACHINE_M32R         0x9041
2381 #define IMAGE_FILE_MACHINE_CEE          0xc0ee
2382
2383 /* Wine extension */
2384 #define IMAGE_FILE_MACHINE_SPARC        0x2000
2385
2386 #define IMAGE_SIZEOF_FILE_HEADER                20
2387 #define IMAGE_SIZEOF_ROM_OPTIONAL_HEADER        56
2388 #define IMAGE_SIZEOF_STD_OPTIONAL_HEADER        28
2389 #define IMAGE_SIZEOF_NT_OPTIONAL32_HEADER       224
2390 #define IMAGE_SIZEOF_NT_OPTIONAL64_HEADER       240
2391 #define IMAGE_SIZEOF_SHORT_NAME                 8
2392 #define IMAGE_SIZEOF_SECTION_HEADER             40
2393 #define IMAGE_SIZEOF_SYMBOL                     18
2394 #define IMAGE_SIZEOF_AUX_SYMBOL                 18
2395 #define IMAGE_SIZEOF_RELOCATION                 10
2396 #define IMAGE_SIZEOF_BASE_RELOCATION            8
2397 #define IMAGE_SIZEOF_LINENUMBER                 6
2398 #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR         60
2399
2400 /* Possible Magic values */
2401 #define IMAGE_NT_OPTIONAL_HDR32_MAGIC      0x10b
2402 #define IMAGE_NT_OPTIONAL_HDR64_MAGIC      0x20b
2403 #define IMAGE_ROM_OPTIONAL_HDR_MAGIC       0x107
2404
2405 #ifdef _WIN64
2406 #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER IMAGE_SIZEOF_NT_OPTIONAL64_HEADER
2407 #define IMAGE_NT_OPTIONAL_HDR_MAGIC     IMAGE_NT_OPTIONAL_HDR64_MAGIC
2408 #else
2409 #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER IMAGE_SIZEOF_NT_OPTIONAL32_HEADER
2410 #define IMAGE_NT_OPTIONAL_HDR_MAGIC     IMAGE_NT_OPTIONAL_HDR32_MAGIC
2411 #endif
2412
2413 /* These are indexes into the DataDirectory array */
2414 #define IMAGE_FILE_EXPORT_DIRECTORY             0
2415 #define IMAGE_FILE_IMPORT_DIRECTORY             1
2416 #define IMAGE_FILE_RESOURCE_DIRECTORY           2
2417 #define IMAGE_FILE_EXCEPTION_DIRECTORY          3
2418 #define IMAGE_FILE_SECURITY_DIRECTORY           4
2419 #define IMAGE_FILE_BASE_RELOCATION_TABLE        5
2420 #define IMAGE_FILE_DEBUG_DIRECTORY              6
2421 #define IMAGE_FILE_DESCRIPTION_STRING           7
2422 #define IMAGE_FILE_MACHINE_VALUE                8  /* Mips */
2423 #define IMAGE_FILE_THREAD_LOCAL_STORAGE         9
2424 #define IMAGE_FILE_CALLBACK_DIRECTORY           10
2425
2426 /* Directory Entries, indices into the DataDirectory array */
2427
2428 #define IMAGE_DIRECTORY_ENTRY_EXPORT            0
2429 #define IMAGE_DIRECTORY_ENTRY_IMPORT            1
2430 #define IMAGE_DIRECTORY_ENTRY_RESOURCE          2
2431 #define IMAGE_DIRECTORY_ENTRY_EXCEPTION         3
2432 #define IMAGE_DIRECTORY_ENTRY_SECURITY          4
2433 #define IMAGE_DIRECTORY_ENTRY_BASERELOC         5
2434 #define IMAGE_DIRECTORY_ENTRY_DEBUG             6
2435 #define IMAGE_DIRECTORY_ENTRY_COPYRIGHT         7
2436 #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR         8   /* (MIPS GP) */
2437 #define IMAGE_DIRECTORY_ENTRY_TLS               9
2438 #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG       10
2439 #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT      11
2440 #define IMAGE_DIRECTORY_ENTRY_IAT               12  /* Import Address Table */
2441 #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT      13
2442 #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR    14
2443
2444 /* Subsystem Values */
2445
2446 #define IMAGE_SUBSYSTEM_UNKNOWN                 0
2447 #define IMAGE_SUBSYSTEM_NATIVE                  1
2448 #define IMAGE_SUBSYSTEM_WINDOWS_GUI             2       /* Windows GUI subsystem */
2449 #define IMAGE_SUBSYSTEM_WINDOWS_CUI             3       /* Windows character subsystem */
2450 #define IMAGE_SUBSYSTEM_OS2_CUI                 5
2451 #define IMAGE_SUBSYSTEM_POSIX_CUI               7
2452 #define IMAGE_SUBSYSTEM_NATIVE_WINDOWS          8       /* native Win9x driver */
2453 #define IMAGE_SUBSYSTEM_WINDOWS_CE_GUI          9       /* Windows CE subsystem */
2454 #define IMAGE_SUBSYSTEM_EFI_APPLICATION         10
2455 #define IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER 11
2456 #define IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER      12
2457 #define IMAGE_SUBSYSTEM_EFI_ROM                 13
2458 #define IMAGE_SUBSYSTEM_XBOX                    14
2459 #define IMAGE_SUBSYSTEM_WINDOWS_BOOT_APPLICATION        16
2460
2461 /* DLL Characteristics */
2462 #define IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE          0x0040
2463 #define IMAGE_DLLCHARACTERISTICS_FORCE_INTEGRITY       0x0080
2464 #define IMAGE_DLLCHARACTERISTICS_NX_COMPAT             0x0100
2465 #define IMAGE_DLLCHARACTERISTICS_NO_ISOLATION          0x0200
2466 #define IMAGE_DLLCHARACTERISTICS_NO_SEH                0x0400
2467 #define IMAGE_DLLCHARACTERISTICS_NO_BIND               0x0800
2468 #define IMAGE_DLLCHARACTERISTICS_WDM_DRIVER            0x2000
2469 #define IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE 0x8000
2470
2471 typedef struct _IMAGE_FILE_HEADER {
2472   WORD  Machine;
2473   WORD  NumberOfSections;
2474   DWORD TimeDateStamp;
2475   DWORD PointerToSymbolTable;
2476   DWORD NumberOfSymbols;
2477   WORD  SizeOfOptionalHeader;
2478   WORD  Characteristics;
2479 } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
2480
2481 typedef struct _IMAGE_DATA_DIRECTORY {
2482   DWORD VirtualAddress;
2483   DWORD Size;
2484 } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
2485
2486 #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
2487
2488 typedef struct _IMAGE_OPTIONAL_HEADER64 {
2489   WORD  Magic; /* 0x20b */
2490   BYTE MajorLinkerVersion;
2491   BYTE MinorLinkerVersion;
2492   DWORD SizeOfCode;
2493   DWORD SizeOfInitializedData;
2494   DWORD SizeOfUninitializedData;
2495   DWORD AddressOfEntryPoint;
2496   DWORD BaseOfCode;
2497   ULONGLONG ImageBase;
2498   DWORD SectionAlignment;
2499   DWORD FileAlignment;
2500   WORD MajorOperatingSystemVersion;
2501   WORD MinorOperatingSystemVersion;
2502   WORD MajorImageVersion;
2503   WORD MinorImageVersion;
2504   WORD MajorSubsystemVersion;
2505   WORD MinorSubsystemVersion;
2506   DWORD Win32VersionValue;
2507   DWORD SizeOfImage;
2508   DWORD SizeOfHeaders;
2509   DWORD CheckSum;
2510   WORD Subsystem;
2511   WORD DllCharacteristics;
2512   ULONGLONG SizeOfStackReserve;
2513   ULONGLONG SizeOfStackCommit;
2514   ULONGLONG SizeOfHeapReserve;
2515   ULONGLONG SizeOfHeapCommit;
2516   DWORD LoaderFlags;
2517   DWORD NumberOfRvaAndSizes;
2518   IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
2519 } IMAGE_OPTIONAL_HEADER64, *PIMAGE_OPTIONAL_HEADER64;
2520
2521 typedef struct _IMAGE_NT_HEADERS64 {
2522   DWORD Signature;
2523   IMAGE_FILE_HEADER FileHeader;
2524   IMAGE_OPTIONAL_HEADER64 OptionalHeader;
2525 } IMAGE_NT_HEADERS64, *PIMAGE_NT_HEADERS64;
2526
2527 typedef struct _IMAGE_OPTIONAL_HEADER {
2528
2529   /* Standard fields */
2530
2531   WORD  Magic; /* 0x10b or 0x107 */     /* 0x00 */
2532   BYTE  MajorLinkerVersion;
2533   BYTE  MinorLinkerVersion;
2534   DWORD SizeOfCode;
2535   DWORD SizeOfInitializedData;
2536   DWORD SizeOfUninitializedData;
2537   DWORD AddressOfEntryPoint;            /* 0x10 */
2538   DWORD BaseOfCode;
2539   DWORD BaseOfData;
2540
2541   /* NT additional fields */
2542
2543   DWORD ImageBase;
2544   DWORD SectionAlignment;               /* 0x20 */
2545   DWORD FileAlignment;
2546   WORD  MajorOperatingSystemVersion;
2547   WORD  MinorOperatingSystemVersion;
2548   WORD  MajorImageVersion;
2549   WORD  MinorImageVersion;
2550   WORD  MajorSubsystemVersion;          /* 0x30 */
2551   WORD  MinorSubsystemVersion;
2552   DWORD Win32VersionValue;
2553   DWORD SizeOfImage;
2554   DWORD SizeOfHeaders;
2555   DWORD CheckSum;                       /* 0x40 */
2556   WORD  Subsystem;
2557   WORD  DllCharacteristics;
2558   DWORD SizeOfStackReserve;
2559   DWORD SizeOfStackCommit;
2560   DWORD SizeOfHeapReserve;              /* 0x50 */
2561   DWORD SizeOfHeapCommit;
2562   DWORD LoaderFlags;
2563   DWORD NumberOfRvaAndSizes;
2564   IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES]; /* 0x60 */
2565   /* 0xE0 */
2566 } IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
2567
2568 typedef struct _IMAGE_NT_HEADERS {
2569   DWORD Signature; /* "PE"\0\0 */       /* 0x00 */
2570   IMAGE_FILE_HEADER FileHeader;         /* 0x04 */
2571   IMAGE_OPTIONAL_HEADER32 OptionalHeader;       /* 0x18 */
2572 } IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;
2573
2574 #ifdef _WIN64
2575 typedef IMAGE_NT_HEADERS64  IMAGE_NT_HEADERS;
2576 typedef PIMAGE_NT_HEADERS64 PIMAGE_NT_HEADERS;
2577 typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
2578 typedef PIMAGE_OPTIONAL_HEADER64 PIMAGE_OPTIONAL_HEADER;
2579 #else
2580 typedef IMAGE_NT_HEADERS32  IMAGE_NT_HEADERS;
2581 typedef PIMAGE_NT_HEADERS32 PIMAGE_NT_HEADERS;
2582 typedef IMAGE_OPTIONAL_HEADER32 IMAGE_OPTIONAL_HEADER;
2583 typedef PIMAGE_OPTIONAL_HEADER32 PIMAGE_OPTIONAL_HEADER;
2584 #endif
2585
2586 #define IMAGE_SIZEOF_SHORT_NAME 8
2587
2588 typedef struct _IMAGE_SECTION_HEADER {
2589   BYTE  Name[IMAGE_SIZEOF_SHORT_NAME];
2590   union {
2591     DWORD PhysicalAddress;
2592     DWORD VirtualSize;
2593   } Misc;
2594   DWORD VirtualAddress;
2595   DWORD SizeOfRawData;
2596   DWORD PointerToRawData;
2597   DWORD PointerToRelocations;
2598   DWORD PointerToLinenumbers;
2599   WORD  NumberOfRelocations;
2600   WORD  NumberOfLinenumbers;
2601   DWORD Characteristics;
2602 } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
2603
2604 #define IMAGE_SIZEOF_SECTION_HEADER 40
2605
2606 #define IMAGE_FIRST_SECTION(ntheader) \
2607   ((PIMAGE_SECTION_HEADER)(ULONG_PTR)((const BYTE *)&((const IMAGE_NT_HEADERS *)(ntheader))->OptionalHeader + \
2608                            ((const IMAGE_NT_HEADERS *)(ntheader))->FileHeader.SizeOfOptionalHeader))
2609
2610 /* These defines are for the Characteristics bitfield. */
2611 /* #define IMAGE_SCN_TYPE_REG                   0x00000000 - Reserved */
2612 /* #define IMAGE_SCN_TYPE_DSECT                 0x00000001 - Reserved */
2613 /* #define IMAGE_SCN_TYPE_NOLOAD                0x00000002 - Reserved */
2614 /* #define IMAGE_SCN_TYPE_GROUP                 0x00000004 - Reserved */
2615 #define IMAGE_SCN_TYPE_NO_PAD                   0x00000008 /* Reserved */
2616 /* #define IMAGE_SCN_TYPE_COPY                  0x00000010 - Reserved */
2617
2618 #define IMAGE_SCN_CNT_CODE                      0x00000020
2619 #define IMAGE_SCN_CNT_INITIALIZED_DATA          0x00000040
2620 #define IMAGE_SCN_CNT_UNINITIALIZED_DATA        0x00000080
2621
2622 #define IMAGE_SCN_LNK_OTHER                     0x00000100
2623 #define IMAGE_SCN_LNK_INFO                      0x00000200
2624 /* #define      IMAGE_SCN_TYPE_OVER             0x00000400 - Reserved */
2625 #define IMAGE_SCN_LNK_REMOVE                    0x00000800
2626 #define IMAGE_SCN_LNK_COMDAT                    0x00001000
2627
2628 /*                                              0x00002000 - Reserved */
2629 /* #define IMAGE_SCN_MEM_PROTECTED              0x00004000 - Obsolete */
2630 #define IMAGE_SCN_MEM_FARDATA                   0x00008000
2631
2632 /* #define IMAGE_SCN_MEM_SYSHEAP                0x00010000 - Obsolete */
2633 #define IMAGE_SCN_MEM_PURGEABLE                 0x00020000
2634 #define IMAGE_SCN_MEM_16BIT                     0x00020000
2635 #define IMAGE_SCN_MEM_LOCKED                    0x00040000
2636 #define IMAGE_SCN_MEM_PRELOAD                   0x00080000
2637
2638 #define IMAGE_SCN_ALIGN_1BYTES                  0x00100000
2639 #define IMAGE_SCN_ALIGN_2BYTES                  0x00200000
2640 #define IMAGE_SCN_ALIGN_4BYTES                  0x00300000
2641 #define IMAGE_SCN_ALIGN_8BYTES                  0x00400000
2642 #define IMAGE_SCN_ALIGN_16BYTES                 0x00500000  /* Default */
2643 #define IMAGE_SCN_ALIGN_32BYTES                 0x00600000
2644 #define IMAGE_SCN_ALIGN_64BYTES                 0x00700000
2645 #define IMAGE_SCN_ALIGN_128BYTES                0x00800000
2646 #define IMAGE_SCN_ALIGN_256BYTES                0x00900000
2647 #define IMAGE_SCN_ALIGN_512BYTES                0x00A00000
2648 #define IMAGE_SCN_ALIGN_1024BYTES               0x00B00000
2649 #define IMAGE_SCN_ALIGN_2048BYTES               0x00C00000
2650 #define IMAGE_SCN_ALIGN_4096BYTES               0x00D00000
2651 #define IMAGE_SCN_ALIGN_8192BYTES               0x00E00000
2652 /*                                              0x00F00000 - Unused */
2653 #define IMAGE_SCN_ALIGN_MASK                    0x00F00000
2654
2655 #define IMAGE_SCN_LNK_NRELOC_OVFL               0x01000000
2656
2657
2658 #define IMAGE_SCN_MEM_DISCARDABLE               0x02000000
2659 #define IMAGE_SCN_MEM_NOT_CACHED                0x04000000
2660 #define IMAGE_SCN_MEM_NOT_PAGED                 0x08000000
2661 #define IMAGE_SCN_MEM_SHARED                    0x10000000
2662 #define IMAGE_SCN_MEM_EXECUTE                   0x20000000
2663 #define IMAGE_SCN_MEM_READ                      0x40000000
2664 #define IMAGE_SCN_MEM_WRITE                     0x80000000
2665
2666 #include <pshpack2.h>
2667
2668 typedef struct _IMAGE_SYMBOL {
2669     union {
2670         BYTE    ShortName[8];
2671         struct {
2672             DWORD   Short;
2673             DWORD   Long;
2674         } Name;
2675         DWORD   LongName[2];
2676     } N;
2677     DWORD   Value;
2678     SHORT   SectionNumber;
2679     WORD    Type;
2680     BYTE    StorageClass;
2681     BYTE    NumberOfAuxSymbols;
2682 } IMAGE_SYMBOL;
2683 typedef IMAGE_SYMBOL *PIMAGE_SYMBOL;
2684
2685 #define IMAGE_SIZEOF_SYMBOL 18
2686
2687 typedef struct _IMAGE_LINENUMBER {
2688     union {
2689         DWORD   SymbolTableIndex;
2690         DWORD   VirtualAddress;
2691     } Type;
2692     WORD    Linenumber;
2693 } IMAGE_LINENUMBER;
2694 typedef IMAGE_LINENUMBER *PIMAGE_LINENUMBER;
2695
2696 #define IMAGE_SIZEOF_LINENUMBER  6
2697
2698 typedef union _IMAGE_AUX_SYMBOL {
2699     struct {
2700         DWORD    TagIndex;
2701         union {
2702             struct {
2703                 WORD    Linenumber;
2704                 WORD    Size;
2705             } LnSz;
2706            DWORD    TotalSize;
2707         } Misc;
2708         union {
2709             struct {
2710                 DWORD    PointerToLinenumber;
2711                 DWORD    PointerToNextFunction;
2712             } Function;
2713             struct {
2714                 WORD     Dimension[4];
2715             } Array;
2716         } FcnAry;
2717         WORD    TvIndex;
2718     } Sym;
2719     struct {
2720         BYTE    Name[IMAGE_SIZEOF_SYMBOL];
2721     } File;
2722     struct {
2723         DWORD   Length;
2724         WORD    NumberOfRelocations;
2725         WORD    NumberOfLinenumbers;
2726         DWORD   CheckSum;
2727         SHORT   Number;
2728         BYTE    Selection;
2729     } Section;
2730 } IMAGE_AUX_SYMBOL;
2731 typedef IMAGE_AUX_SYMBOL *PIMAGE_AUX_SYMBOL;
2732
2733 #define IMAGE_SIZEOF_AUX_SYMBOL 18
2734
2735 #include <poppack.h>
2736
2737 #define IMAGE_SYM_UNDEFINED           (SHORT)0
2738 #define IMAGE_SYM_ABSOLUTE            (SHORT)-1
2739 #define IMAGE_SYM_DEBUG               (SHORT)-2
2740
2741 #define IMAGE_SYM_TYPE_NULL                 0x0000
2742 #define IMAGE_SYM_TYPE_VOID                 0x0001
2743 #define IMAGE_SYM_TYPE_CHAR                 0x0002
2744 #define IMAGE_SYM_TYPE_SHORT                0x0003
2745 #define IMAGE_SYM_TYPE_INT                  0x0004
2746 #define IMAGE_SYM_TYPE_LONG                 0x0005
2747 #define IMAGE_SYM_TYPE_FLOAT                0x0006
2748 #define IMAGE_SYM_TYPE_DOUBLE               0x0007
2749 #define IMAGE_SYM_TYPE_STRUCT               0x0008
2750 #define IMAGE_SYM_TYPE_UNION                0x0009
2751 #define IMAGE_SYM_TYPE_ENUM                 0x000A
2752 #define IMAGE_SYM_TYPE_MOE                  0x000B
2753 #define IMAGE_SYM_TYPE_BYTE                 0x000C
2754 #define IMAGE_SYM_TYPE_WORD                 0x000D
2755 #define IMAGE_SYM_TYPE_UINT                 0x000E
2756 #define IMAGE_SYM_TYPE_DWORD                0x000F
2757 #define IMAGE_SYM_TYPE_PCODE                0x8000
2758
2759 #define IMAGE_SYM_DTYPE_NULL                0
2760 #define IMAGE_SYM_DTYPE_POINTER             1
2761 #define IMAGE_SYM_DTYPE_FUNCTION            2
2762 #define IMAGE_SYM_DTYPE_ARRAY               3
2763
2764 #define IMAGE_SYM_CLASS_END_OF_FUNCTION     (BYTE )-1
2765 #define IMAGE_SYM_CLASS_NULL                0x0000
2766 #define IMAGE_SYM_CLASS_AUTOMATIC           0x0001
2767 #define IMAGE_SYM_CLASS_EXTERNAL            0x0002
2768 #define IMAGE_SYM_CLASS_STATIC              0x0003
2769 #define IMAGE_SYM_CLASS_REGISTER            0x0004
2770 #define IMAGE_SYM_CLASS_EXTERNAL_DEF        0x0005
2771 #define IMAGE_SYM_CLASS_LABEL               0x0006
2772 #define IMAGE_SYM_CLASS_UNDEFINED_LABEL     0x0007
2773 #define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT    0x0008
2774 #define IMAGE_SYM_CLASS_ARGUMENT            0x0009
2775 #define IMAGE_SYM_CLASS_STRUCT_TAG          0x000A
2776 #define IMAGE_SYM_CLASS_MEMBER_OF_UNION     0x000B
2777 #define IMAGE_SYM_CLASS_UNION_TAG           0x000C
2778 #define IMAGE_SYM_CLASS_TYPE_DEFINITION     0x000D
2779 #define IMAGE_SYM_CLASS_UNDEFINED_STATIC    0x000E
2780 #define IMAGE_SYM_CLASS_ENUM_TAG            0x000F
2781 #define IMAGE_SYM_CLASS_MEMBER_OF_ENUM      0x0010
2782 #define IMAGE_SYM_CLASS_REGISTER_PARAM      0x0011
2783 #define IMAGE_SYM_CLASS_BIT_FIELD           0x0012
2784
2785 #define IMAGE_SYM_CLASS_FAR_EXTERNAL        0x0044
2786 #define IMAGE_SYM_CLASS_BLOCK               0x0064
2787 #define IMAGE_SYM_CLASS_FUNCTION            0x0065
2788 #define IMAGE_SYM_CLASS_END_OF_STRUCT       0x0066
2789 #define IMAGE_SYM_CLASS_FILE                0x0067
2790 #define IMAGE_SYM_CLASS_SECTION             0x0068
2791 #define IMAGE_SYM_CLASS_WEAK_EXTERNAL       0x0069
2792
2793 #define N_BTMASK                            0x000F
2794 #define N_TMASK                             0x0030
2795 #define N_TMASK1                            0x00C0
2796 #define N_TMASK2                            0x00F0
2797 #define N_BTSHFT                            4
2798 #define N_TSHIFT                            2
2799
2800 #define BTYPE(x) ((x) & N_BTMASK)
2801
2802 #ifndef ISPTR
2803 #define ISPTR(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_POINTER << N_BTSHFT))
2804 #endif
2805
2806 #ifndef ISFCN
2807 #define ISFCN(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_FUNCTION << N_BTSHFT))
2808 #endif
2809
2810 #ifndef ISARY
2811 #define ISARY(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_ARRAY << N_BTSHFT))
2812 #endif
2813
2814 #ifndef ISTAG
2815 #define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG || (x)==IMAGE_SYM_CLASS_UNION_TAG || (x)==IMAGE_SYM_CLASS_ENUM_TAG)
2816 #endif
2817
2818 #ifndef INCREF
2819 #define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
2820 #endif
2821 #ifndef DECREF
2822 #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
2823 #endif
2824
2825 #define IMAGE_COMDAT_SELECT_NODUPLICATES    1
2826 #define IMAGE_COMDAT_SELECT_ANY             2
2827 #define IMAGE_COMDAT_SELECT_SAME_SIZE       3
2828 #define IMAGE_COMDAT_SELECT_EXACT_MATCH     4
2829 #define IMAGE_COMDAT_SELECT_ASSOCIATIVE     5
2830 #define IMAGE_COMDAT_SELECT_LARGEST         6
2831 #define IMAGE_COMDAT_SELECT_NEWEST          7
2832
2833 #define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY  1
2834 #define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY    2
2835 #define IMAGE_WEAK_EXTERN_SEARCH_ALIAS      3
2836
2837 /* Export module directory */
2838
2839 typedef struct _IMAGE_EXPORT_DIRECTORY {
2840         DWORD   Characteristics;
2841         DWORD   TimeDateStamp;
2842         WORD    MajorVersion;
2843         WORD    MinorVersion;
2844         DWORD   Name;
2845         DWORD   Base;
2846         DWORD   NumberOfFunctions;
2847         DWORD   NumberOfNames;
2848         DWORD   AddressOfFunctions;
2849         DWORD   AddressOfNames;
2850         DWORD   AddressOfNameOrdinals;
2851 } IMAGE_EXPORT_DIRECTORY,*PIMAGE_EXPORT_DIRECTORY;
2852
2853 /* Import name entry */
2854 typedef struct _IMAGE_IMPORT_BY_NAME {
2855         WORD    Hint;
2856         BYTE    Name[1];
2857 } IMAGE_IMPORT_BY_NAME,*PIMAGE_IMPORT_BY_NAME;
2858
2859 #include <pshpack8.h>
2860 /* Import thunk */
2861 typedef struct _IMAGE_THUNK_DATA64 {
2862         union {
2863                 ULONGLONG ForwarderString;
2864                 ULONGLONG Function;
2865                 ULONGLONG Ordinal;
2866                 ULONGLONG AddressOfData;
2867         } u1;
2868 } IMAGE_THUNK_DATA64,*PIMAGE_THUNK_DATA64;
2869 #include <poppack.h>
2870
2871 typedef struct _IMAGE_THUNK_DATA32 {
2872         union {
2873                 DWORD ForwarderString;
2874                 DWORD Function;
2875                 DWORD Ordinal;
2876                 DWORD AddressOfData;
2877         } u1;
2878 } IMAGE_THUNK_DATA32,*PIMAGE_THUNK_DATA32;
2879
2880 /* Import module directory */
2881
2882 typedef struct _IMAGE_IMPORT_DESCRIPTOR {
2883         union {
2884                 DWORD   Characteristics; /* 0 for terminating null import descriptor  */
2885                 DWORD   OriginalFirstThunk;     /* RVA to original unbound IAT */
2886         } DUMMYUNIONNAME;
2887         DWORD   TimeDateStamp;  /* 0 if not bound,
2888                                  * -1 if bound, and real date\time stamp
2889                                  *    in IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT
2890                                  * (new BIND)
2891                                  * otherwise date/time stamp of DLL bound to
2892                                  * (Old BIND)
2893                                  */
2894         DWORD   ForwarderChain; /* -1 if no forwarders */
2895         DWORD   Name;
2896         /* RVA to IAT (if bound this IAT has actual addresses) */
2897         DWORD   FirstThunk;
2898 } IMAGE_IMPORT_DESCRIPTOR,*PIMAGE_IMPORT_DESCRIPTOR;
2899
2900 #define IMAGE_ORDINAL_FLAG64             (((ULONGLONG)0x80000000 << 32) | 0x00000000)
2901 #define IMAGE_ORDINAL_FLAG32             0x80000000
2902 #define IMAGE_SNAP_BY_ORDINAL64(ordinal) (((ordinal) & IMAGE_ORDINAL_FLAG64) != 0)
2903 #define IMAGE_SNAP_BY_ORDINAL32(ordinal) (((ordinal) & IMAGE_ORDINAL_FLAG32) != 0)
2904 #define IMAGE_ORDINAL64(ordinal)         ((ordinal) & 0xffff)
2905 #define IMAGE_ORDINAL32(ordinal)         ((ordinal) & 0xffff)
2906
2907 #ifdef _WIN64
2908 #define IMAGE_ORDINAL_FLAG              IMAGE_ORDINAL_FLAG64
2909 #define IMAGE_SNAP_BY_ORDINAL(Ordinal)  IMAGE_SNAP_BY_ORDINAL64(Ordinal)
2910 #define IMAGE_ORDINAL(Ordinal)          IMAGE_ORDINAL64(Ordinal)
2911 typedef IMAGE_THUNK_DATA64              IMAGE_THUNK_DATA;
2912 typedef PIMAGE_THUNK_DATA64             PIMAGE_THUNK_DATA;
2913 #else
2914 #define IMAGE_ORDINAL_FLAG              IMAGE_ORDINAL_FLAG32
2915 #define IMAGE_SNAP_BY_ORDINAL(Ordinal)  IMAGE_SNAP_BY_ORDINAL32(Ordinal)
2916 #define IMAGE_ORDINAL(Ordinal)          IMAGE_ORDINAL32(Ordinal)
2917 typedef IMAGE_THUNK_DATA32              IMAGE_THUNK_DATA;
2918 typedef PIMAGE_THUNK_DATA32             PIMAGE_THUNK_DATA;
2919 #endif
2920
2921 typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR
2922 {
2923     DWORD   TimeDateStamp;
2924     WORD    OffsetModuleName;
2925     WORD    NumberOfModuleForwarderRefs;
2926 /* Array of zero or more IMAGE_BOUND_FORWARDER_REF follows */
2927 } IMAGE_BOUND_IMPORT_DESCRIPTOR,  *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
2928
2929 typedef struct _IMAGE_BOUND_FORWARDER_REF
2930 {
2931     DWORD   TimeDateStamp;
2932     WORD    OffsetModuleName;
2933     WORD    Reserved;
2934 } IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
2935
2936 typedef struct _IMAGE_BASE_RELOCATION
2937 {
2938         DWORD   VirtualAddress;
2939         DWORD   SizeOfBlock;
2940         /* WORD TypeOffset[1]; */
2941 } IMAGE_BASE_RELOCATION,*PIMAGE_BASE_RELOCATION;
2942
2943 #include <pshpack2.h>
2944
2945 typedef struct _IMAGE_RELOCATION
2946 {
2947     union {
2948         DWORD   VirtualAddress;
2949         DWORD   RelocCount;
2950     } DUMMYUNIONNAME;
2951     DWORD   SymbolTableIndex;
2952     WORD    Type;
2953 } IMAGE_RELOCATION, *PIMAGE_RELOCATION;
2954
2955 #include <poppack.h>
2956
2957 #define IMAGE_SIZEOF_RELOCATION 10
2958
2959 /* generic relocation types */
2960 #define IMAGE_REL_BASED_ABSOLUTE                0
2961 #define IMAGE_REL_BASED_HIGH                    1
2962 #define IMAGE_REL_BASED_LOW                     2
2963 #define IMAGE_REL_BASED_HIGHLOW                 3
2964 #define IMAGE_REL_BASED_HIGHADJ                 4
2965 #define IMAGE_REL_BASED_MIPS_JMPADDR            5
2966 #define IMAGE_REL_BASED_ARM_MOV32A              5 /* yes, 5 too */
2967 #define IMAGE_REL_BASED_SECTION                 6
2968 #define IMAGE_REL_BASED_REL                     7
2969 #define IMAGE_REL_BASED_ARM_MOV32T              7 /* yes, 7 too */
2970 #define IMAGE_REL_BASED_MIPS_JMPADDR16          9
2971 #define IMAGE_REL_BASED_IA64_IMM64              9 /* yes, 9 too */
2972 #define IMAGE_REL_BASED_DIR64                   10
2973 #define IMAGE_REL_BASED_HIGH3ADJ                11
2974
2975 /* I386 relocation types */
2976 #define IMAGE_REL_I386_ABSOLUTE                 0
2977 #define IMAGE_REL_I386_DIR16                    1
2978 #define IMAGE_REL_I386_REL16                    2
2979 #define IMAGE_REL_I386_DIR32                    6
2980 #define IMAGE_REL_I386_DIR32NB                  7
2981 #define IMAGE_REL_I386_SEG12                    9
2982 #define IMAGE_REL_I386_SECTION                  10
2983 #define IMAGE_REL_I386_SECREL                   11
2984 #define IMAGE_REL_I386_TOKEN                    12
2985 #define IMAGE_REL_I386_SECREL7                  13
2986 #define IMAGE_REL_I386_REL32                    20
2987
2988 /* MIPS relocation types */
2989 #define IMAGE_REL_MIPS_ABSOLUTE         0x0000
2990 #define IMAGE_REL_MIPS_REFHALF          0x0001
2991 #define IMAGE_REL_MIPS_REFWORD          0x0002
2992 #define IMAGE_REL_MIPS_JMPADDR          0x0003
2993 #define IMAGE_REL_MIPS_REFHI            0x0004
2994 #define IMAGE_REL_MIPS_REFLO            0x0005
2995 #define IMAGE_REL_MIPS_GPREL            0x0006
2996 #define IMAGE_REL_MIPS_LITERAL          0x0007
2997 #define IMAGE_REL_MIPS_SECTION          0x000A
2998 #define IMAGE_REL_MIPS_SECREL           0x000B
2999 #define IMAGE_REL_MIPS_SECRELLO         0x000C
3000 #define IMAGE_REL_MIPS_SECRELHI         0x000D
3001 #define IMAGE_REL_MIPS_TOKEN            0x000E
3002 #define IMAGE_REL_MIPS_JMPADDR16        0x0010
3003 #define IMAGE_REL_MIPS_REFWORDNB        0x0022
3004 #define IMAGE_REL_MIPS_PAIR             0x0025
3005
3006 /* ALPHA relocation types */
3007 #define IMAGE_REL_ALPHA_ABSOLUTE        0x0000
3008 #define IMAGE_REL_ALPHA_REFLONG         0x0001
3009 #define IMAGE_REL_ALPHA_REFQUAD         0x0002
3010 #define IMAGE_REL_ALPHA_GPREL           0x0003
3011 #define IMAGE_REL_ALPHA_LITERAL         0x0004
3012 #define IMAGE_REL_ALPHA_LITUSE          0x0005
3013 #define IMAGE_REL_ALPHA_GPDISP          0x0006
3014 #define IMAGE_REL_ALPHA_BRADDR          0x0007
3015 #define IMAGE_REL_ALPHA_HINT            0x0008
3016 #define IMAGE_REL_ALPHA_INLINE_REFLONG  0x0009
3017 #define IMAGE_REL_ALPHA_REFHI           0x000A
3018 #define IMAGE_REL_ALPHA_REFLO           0x000B
3019 #define IMAGE_REL_ALPHA_PAIR            0x000C
3020 #define IMAGE_REL_ALPHA_MATCH           0x000D
3021 #define IMAGE_REL_ALPHA_SECTION         0x000E
3022 #define IMAGE_REL_ALPHA_SECREL          0x000F
3023 #define IMAGE_REL_ALPHA_REFLONGNB       0x0010
3024 #define IMAGE_REL_ALPHA_SECRELLO        0x0011
3025 #define IMAGE_REL_ALPHA_SECRELHI        0x0012
3026 #define IMAGE_REL_ALPHA_REFQ3           0x0013
3027 #define IMAGE_REL_ALPHA_REFQ2           0x0014
3028 #define IMAGE_REL_ALPHA_REFQ1           0x0015
3029 #define IMAGE_REL_ALPHA_GPRELLO         0x0016
3030 #define IMAGE_REL_ALPHA_GPRELHI         0x0017
3031
3032 /* PowerPC relocation types */
3033 #define IMAGE_REL_PPC_ABSOLUTE          0x0000
3034 #define IMAGE_REL_PPC_ADDR64            0x0001
3035 #define IMAGE_REL_PPC_ADDR            0x0002
3036 #define IMAGE_REL_PPC_ADDR24            0x0003
3037 #define IMAGE_REL_PPC_ADDR16            0x0004
3038 #define IMAGE_REL_PPC_ADDR14            0x0005
3039 #define IMAGE_REL_PPC_REL24             0x0006
3040 #define IMAGE_REL_PPC_REL14             0x0007
3041 #define IMAGE_REL_PPC_TOCREL16          0x0008
3042 #define IMAGE_REL_PPC_TOCREL14          0x0009
3043 #define IMAGE_REL_PPC_ADDR32NB          0x000A
3044 #define IMAGE_REL_PPC_SECREL            0x000B
3045 #define IMAGE_REL_PPC_SECTION           0x000C
3046 #define IMAGE_REL_PPC_IFGLUE            0x000D
3047 #define IMAGE_REL_PPC_IMGLUE            0x000E
3048 #define IMAGE_REL_PPC_SECREL16          0x000F
3049 #define IMAGE_REL_PPC_REFHI             0x0010
3050 #define IMAGE_REL_PPC_REFLO             0x0011
3051 #define IMAGE_REL_PPC_PAIR              0x0012
3052 #define IMAGE_REL_PPC_SECRELLO          0x0013
3053 #define IMAGE_REL_PPC_SECRELHI          0x0014
3054 #define IMAGE_REL_PPC_GPREL             0x0015
3055 #define IMAGE_REL_PPC_TOKEN             0x0016
3056 #define IMAGE_REL_PPC_TYPEMASK          0x00FF
3057 /* modifier bits */
3058 #define IMAGE_REL_PPC_NEG               0x0100
3059 #define IMAGE_REL_PPC_BRTAKEN           0x0200
3060 #define IMAGE_REL_PPC_BRNTAKEN          0x0400
3061 #define IMAGE_REL_PPC_TOCDEFN           0x0800
3062
3063 /* SH3 relocation types */
3064 #define IMAGE_REL_SH3_ABSOLUTE          0x0000
3065 #define IMAGE_REL_SH3_DIRECT16          0x0001
3066 #define IMAGE_REL_SH3_DIRECT          0x0002
3067 #define IMAGE_REL_SH3_DIRECT8           0x0003
3068 #define IMAGE_REL_SH3_DIRECT8_WORD      0x0004
3069 #define IMAGE_REL_SH3_DIRECT8_LONG      0x0005
3070 #define IMAGE_REL_SH3_DIRECT4           0x0006
3071 #define IMAGE_REL_SH3_DIRECT4_WORD      0x0007
3072 #define IMAGE_REL_SH3_DIRECT4_LONG      0x0008
3073 #define IMAGE_REL_SH3_PCREL8_WORD       0x0009
3074 #define IMAGE_REL_SH3_PCREL8_LONG       0x000A
3075 #define IMAGE_REL_SH3_PCREL12_WORD      0x000B
3076 #define IMAGE_REL_SH3_STARTOF_SECTION   0x000C
3077 #define IMAGE_REL_SH3_SIZEOF_SECTION    0x000D
3078 #define IMAGE_REL_SH3_SECTION           0x000E
3079 #define IMAGE_REL_SH3_SECREL            0x000F
3080 #define IMAGE_REL_SH3_DIRECT32_NB       0x0010
3081 #define IMAGE_REL_SH3_GPREL4_LONG       0x0011
3082 #define IMAGE_REL_SH3_TOKEN             0x0012
3083
3084 /* ARM relocation types */
3085 #define IMAGE_REL_ARM_ABSOLUTE          0x0000
3086 #define IMAGE_REL_ARM_ADDR              0x0001
3087 #define IMAGE_REL_ARM_ADDR32NB          0x0002
3088 #define IMAGE_REL_ARM_BRANCH24          0x0003
3089 #define IMAGE_REL_ARM_BRANCH11          0x0004
3090 #define IMAGE_REL_ARM_TOKEN             0x0005
3091 #define IMAGE_REL_ARM_GPREL12           0x0006
3092 #define IMAGE_REL_ARM_GPREL7            0x0007
3093 #define IMAGE_REL_ARM_BLX24             0x0008
3094 #define IMAGE_REL_ARM_BLX11             0x0009
3095 #define IMAGE_REL_ARM_SECTION           0x000E
3096 #define IMAGE_REL_ARM_SECREL            0x000F
3097 #define IMAGE_REL_ARM_MOV32A            0x0010
3098 #define IMAGE_REL_ARM_MOV32T            0x0011
3099 #define IMAGE_REL_ARM_BRANCH20T 0x0012
3100 #define IMAGE_REL_ARM_BRANCH24T 0x0014
3101 #define IMAGE_REL_ARM_BLX23T            0x0015
3102
3103 /* IA64 relocation types */
3104 #define IMAGE_REL_IA64_ABSOLUTE         0x0000
3105 #define IMAGE_REL_IA64_IMM14            0x0001
3106 #define IMAGE_REL_IA64_IMM22            0x0002
3107 #define IMAGE_REL_IA64_IMM64            0x0003
3108 #define IMAGE_REL_IA64_DIR              0x0004
3109 #define IMAGE_REL_IA64_DIR64            0x0005
3110 #define IMAGE_REL_IA64_PCREL21B         0x0006
3111 #define IMAGE_REL_IA64_PCREL21M         0x0007
3112 #define IMAGE_REL_IA64_PCREL21F         0x0008
3113 #define IMAGE_REL_IA64_GPREL22          0x0009
3114 #define IMAGE_REL_IA64_LTOFF22          0x000A
3115 #define IMAGE_REL_IA64_SECTION          0x000B
3116 #define IMAGE_REL_IA64_SECREL22         0x000C
3117 #define IMAGE_REL_IA64_SECREL64I        0x000D
3118 #define IMAGE_REL_IA64_SECREL           0x000E
3119 #define IMAGE_REL_IA64_LTOFF64          0x000F
3120 #define IMAGE_REL_IA64_DIR32NB          0x0010
3121 #define IMAGE_REL_IA64_SREL14           0x0011
3122 #define IMAGE_REL_IA64_SREL22           0x0012
3123 #define IMAGE_REL_IA64_SREL32           0x0013
3124 #define IMAGE_REL_IA64_UREL32           0x0014
3125 #define IMAGE_REL_IA64_PCREL60X 0x0015
3126 #define IMAGE_REL_IA64_PCREL60B 0x0016
3127 #define IMAGE_REL_IA64_PCREL60F 0x0017
3128 #define IMAGE_REL_IA64_PCREL60I 0x0018
3129 #define IMAGE_REL_IA64_PCREL60M 0x0019
3130 #define IMAGE_REL_IA64_IMMGPREL64       0x001A
3131 #define IMAGE_REL_IA64_TOKEN            0x001B
3132 #define IMAGE_REL_IA64_GPREL32          0x001C
3133 #define IMAGE_REL_IA64_ADDEND           0x001F
3134
3135 /* AMD64 relocation types */
3136 #define IMAGE_REL_AMD64_ABSOLUTE        0x0000
3137 #define IMAGE_REL_AMD64_ADDR64          0x0001
3138 #define IMAGE_REL_AMD64_ADDR32          0x0002
3139 #define IMAGE_REL_AMD64_ADDR32NB        0x0003
3140 #define IMAGE_REL_AMD64_REL32           0x0004
3141 #define IMAGE_REL_AMD64_REL32_1         0x0005
3142 #define IMAGE_REL_AMD64_REL32_2         0x0006
3143 #define IMAGE_REL_AMD64_REL32_3         0x0007
3144 #define IMAGE_REL_AMD64_REL32_4         0x0008
3145 #define IMAGE_REL_AMD64_REL32_5         0x0009
3146 #define IMAGE_REL_AMD64_SECTION         0x000A
3147 #define IMAGE_REL_AMD64_SECREL          0x000B
3148 #define IMAGE_REL_AMD64_SECREL7         0x000C
3149 #define IMAGE_REL_AMD64_TOKEN           0x000D
3150 #define IMAGE_REL_AMD64_SREL32          0x000E
3151 #define IMAGE_REL_AMD64_PAIR            0x000F
3152 #define IMAGE_REL_AMD64_SSPAN32         0x0010
3153
3154 /* archive format */
3155
3156 #define IMAGE_ARCHIVE_START_SIZE             8
3157 #define IMAGE_ARCHIVE_START                  "!<arch>\n"
3158 #define IMAGE_ARCHIVE_END                    "`\n"
3159 #define IMAGE_ARCHIVE_PAD                    "\n"
3160 #define IMAGE_ARCHIVE_LINKER_MEMBER          "/               "
3161 #define IMAGE_ARCHIVE_LONGNAMES_MEMBER       "//              "
3162
3163 typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER
3164 {
3165     BYTE     Name[16];
3166     BYTE     Date[12];
3167     BYTE     UserID[6];
3168     BYTE     GroupID[6];
3169     BYTE     Mode[8];
3170     BYTE     Size[10];
3171     BYTE     EndHeader[2];
3172 } IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
3173
3174 #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
3175
3176 typedef struct _IMPORT_OBJECT_HEADER
3177 {
3178     WORD     Sig1;
3179     WORD     Sig2;
3180     WORD     Version;
3181     WORD     Machine;
3182     DWORD    TimeDateStamp;
3183     DWORD    SizeOfData;
3184     union
3185     {
3186         WORD Ordinal;
3187         WORD Hint;
3188     } DUMMYUNIONNAME;
3189     WORD     Type : 2;
3190     WORD     NameType : 3;
3191     WORD     Reserved : 11;
3192 } IMPORT_OBJECT_HEADER;
3193
3194 #define IMPORT_OBJECT_HDR_SIG2  0xffff
3195
3196 typedef enum IMPORT_OBJECT_TYPE
3197 {
3198     IMPORT_OBJECT_CODE = 0,
3199     IMPORT_OBJECT_DATA = 1,
3200     IMPORT_OBJECT_CONST = 2
3201 } IMPORT_OBJECT_TYPE;
3202
3203 typedef enum IMPORT_OBJECT_NAME_TYPE
3204 {
3205     IMPORT_OBJECT_ORDINAL = 0,
3206     IMPORT_OBJECT_NAME = 1,
3207     IMPORT_OBJECT_NAME_NO_PREFIX = 2,
3208     IMPORT_OBJECT_NAME_UNDECORATE = 3
3209 } IMPORT_OBJECT_NAME_TYPE;
3210
3211 typedef struct _ANON_OBJECT_HEADER
3212 {
3213     WORD     Sig1;
3214     WORD     Sig2;
3215     WORD     Version;
3216     WORD     Machine;
3217     DWORD    TimeDateStamp;
3218     CLSID    ClassID;
3219     DWORD    SizeOfData;
3220 } ANON_OBJECT_HEADER;
3221
3222 /*
3223  * Resource directory stuff
3224  */
3225 typedef struct _IMAGE_RESOURCE_DIRECTORY {
3226         DWORD   Characteristics;
3227         DWORD   TimeDateStamp;
3228         WORD    MajorVersion;
3229         WORD    MinorVersion;
3230         WORD    NumberOfNamedEntries;
3231         WORD    NumberOfIdEntries;
3232         /*  IMAGE_RESOURCE_DIRECTORY_ENTRY DirectoryEntries[]; */
3233 } IMAGE_RESOURCE_DIRECTORY,*PIMAGE_RESOURCE_DIRECTORY;
3234
3235 #define IMAGE_RESOURCE_NAME_IS_STRING           0x80000000
3236 #define IMAGE_RESOURCE_DATA_IS_DIRECTORY        0x80000000
3237
3238 typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
3239         union {
3240                 struct {
3241 #ifdef BITFIELDS_BIGENDIAN
3242                         unsigned NameIsString:1;
3243                         unsigned NameOffset:31;
3244 #else
3245                         unsigned NameOffset:31;
3246                         unsigned NameIsString:1;
3247 #endif
3248                 } DUMMYSTRUCTNAME1;
3249                 DWORD   Name;
3250                 struct {
3251 #ifdef WORDS_BIGENDIAN
3252                         WORD    __pad;
3253                         WORD    Id;
3254 #else
3255                         WORD    Id;
3256                         WORD    __pad;
3257 #endif
3258                 } DUMMYSTRUCTNAME2;
3259         } DUMMYUNIONNAME1;
3260         union {
3261                 DWORD   OffsetToData;
3262                 struct {
3263 #ifdef BITFIELDS_BIGENDIAN
3264                         unsigned DataIsDirectory:1;
3265                         unsigned OffsetToDirectory:31;
3266 #else
3267                         unsigned OffsetToDirectory:31;
3268                         unsigned DataIsDirectory:1;
3269 #endif
3270                 } DUMMYSTRUCTNAME3;
3271         } DUMMYUNIONNAME2;
3272 } IMAGE_RESOURCE_DIRECTORY_ENTRY,*PIMAGE_RESOURCE_DIRECTORY_ENTRY;
3273
3274
3275 typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
3276         WORD    Length;
3277         CHAR    NameString[ 1 ];
3278 } IMAGE_RESOURCE_DIRECTORY_STRING,*PIMAGE_RESOURCE_DIRECTORY_STRING;
3279
3280 typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
3281         WORD    Length;
3282         WCHAR   NameString[ 1 ];
3283 } IMAGE_RESOURCE_DIR_STRING_U,*PIMAGE_RESOURCE_DIR_STRING_U;
3284
3285 typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
3286         DWORD   OffsetToData;
3287         DWORD   Size;
3288         DWORD   CodePage;
3289         DWORD   Reserved;
3290 } IMAGE_RESOURCE_DATA_ENTRY,*PIMAGE_RESOURCE_DATA_ENTRY;
3291
3292
3293 typedef VOID (CALLBACK *PIMAGE_TLS_CALLBACK)(
3294         LPVOID DllHandle,DWORD Reason,LPVOID Reserved
3295 );
3296
3297 typedef struct _IMAGE_TLS_DIRECTORY64 {
3298     ULONGLONG   StartAddressOfRawData;
3299     ULONGLONG   EndAddressOfRawData;
3300     ULONGLONG   AddressOfIndex;
3301     ULONGLONG   AddressOfCallBacks;
3302     DWORD       SizeOfZeroFill;
3303     DWORD       Characteristics;
3304 } IMAGE_TLS_DIRECTORY64, *PIMAGE_TLS_DIRECTORY64;
3305
3306 typedef struct _IMAGE_TLS_DIRECTORY32 {
3307     DWORD   StartAddressOfRawData;
3308     DWORD   EndAddressOfRawData;
3309     DWORD   AddressOfIndex;
3310     DWORD   AddressOfCallBacks;
3311     DWORD   SizeOfZeroFill;
3312     DWORD   Characteristics;
3313 } IMAGE_TLS_DIRECTORY32, *PIMAGE_TLS_DIRECTORY32;
3314
3315 #ifdef _WIN64
3316 typedef IMAGE_TLS_DIRECTORY64           IMAGE_TLS_DIRECTORY;
3317 typedef PIMAGE_TLS_DIRECTORY64          PIMAGE_TLS_DIRECTORY;
3318 #else
3319 typedef IMAGE_TLS_DIRECTORY32           IMAGE_TLS_DIRECTORY;
3320 typedef PIMAGE_TLS_DIRECTORY32          PIMAGE_TLS_DIRECTORY;
3321 #endif
3322
3323 typedef struct _IMAGE_DEBUG_DIRECTORY {
3324   DWORD Characteristics;
3325   DWORD TimeDateStamp;
3326   WORD  MajorVersion;
3327   WORD  MinorVersion;
3328   DWORD Type;
3329   DWORD SizeOfData;
3330   DWORD AddressOfRawData;
3331   DWORD PointerToRawData;
3332 } IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
3333
3334 #define IMAGE_DEBUG_TYPE_UNKNOWN        0
3335 #define IMAGE_DEBUG_TYPE_COFF           1
3336 #define IMAGE_DEBUG_TYPE_CODEVIEW       2
3337 #define IMAGE_DEBUG_TYPE_FPO            3
3338 #define IMAGE_DEBUG_TYPE_MISC           4
3339 #define IMAGE_DEBUG_TYPE_EXCEPTION      5
3340 #define IMAGE_DEBUG_TYPE_FIXUP          6
3341 #define IMAGE_DEBUG_TYPE_OMAP_TO_SRC    7
3342 #define IMAGE_DEBUG_TYPE_OMAP_FROM_SRC  8
3343 #define IMAGE_DEBUG_TYPE_BORLAND        9
3344 #define IMAGE_DEBUG_TYPE_RESERVED10    10
3345
3346 typedef enum ReplacesCorHdrNumericDefines
3347 {
3348     COMIMAGE_FLAGS_ILONLY           = 0x00000001,
3349     COMIMAGE_FLAGS_32BITREQUIRED    = 0x00000002,
3350     COMIMAGE_FLAGS_IL_LIBRARY       = 0x00000004,
3351     COMIMAGE_FLAGS_STRONGNAMESIGNED = 0x00000008,
3352     COMIMAGE_FLAGS_TRACKDEBUGDATA   = 0x00010000,
3353
3354     COR_VERSION_MAJOR_V2       = 2,
3355     COR_VERSION_MAJOR          = COR_VERSION_MAJOR_V2,
3356     COR_VERSION_MINOR          = 0,
3357     COR_DELETED_NAME_LENGTH    = 8,
3358     COR_VTABLEGAP_NAME_LENGTH  = 8,
3359
3360     NATIVE_TYPE_MAX_CB = 1,
3361     COR_ILMETHOD_SECT_SMALL_MAX_DATASIZE = 0xff,
3362
3363     IMAGE_COR_MIH_METHODRVA  = 0x01,
3364     IMAGE_COR_MIH_EHRVA      = 0x02,
3365     IMAGE_COR_MIH_BASICBLOCK = 0x08,
3366
3367     COR_VTABLE_32BIT             = 0x01,
3368     COR_VTABLE_64BIT             = 0x02,
3369     COR_VTABLE_FROM_UNMANAGED    = 0x04,
3370     COR_VTABLE_CALL_MOST_DERIVED = 0x10,
3371
3372     IMAGE_COR_EATJ_THUNK_SIZE = 32,
3373
3374     MAX_CLASS_NAME   = 1024,
3375     MAX_PACKAGE_NAME = 1024,
3376 } ReplacesCorHdrNumericDefines;
3377
3378 typedef struct IMAGE_COR20_HEADER
3379 {
3380     DWORD cb;
3381     WORD  MajorRuntimeVersion;
3382     WORD  MinorRuntimeVersion;
3383
3384     IMAGE_DATA_DIRECTORY MetaData;
3385     DWORD Flags;
3386     DWORD EntryPointToken;
3387
3388     IMAGE_DATA_DIRECTORY Resources;
3389     IMAGE_DATA_DIRECTORY StrongNameSignature;
3390     IMAGE_DATA_DIRECTORY CodeManagerTable;
3391     IMAGE_DATA_DIRECTORY VTableFixups;
3392     IMAGE_DATA_DIRECTORY ExportAddressTableJumps;
3393     IMAGE_DATA_DIRECTORY ManagedNativeHeader;
3394
3395 } IMAGE_COR20_HEADER, *PIMAGE_COR20_HEADER;
3396
3397 typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
3398   DWORD NumberOfSymbols;
3399   DWORD LvaToFirstSymbol;
3400   DWORD NumberOfLinenumbers;
3401   DWORD LvaToFirstLinenumber;
3402   DWORD RvaToFirstByteOfCode;
3403   DWORD RvaToLastByteOfCode;
3404   DWORD RvaToFirstByteOfData;
3405   DWORD RvaToLastByteOfData;
3406 } IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
3407
3408 #define FRAME_FPO       0
3409 #define FRAME_TRAP      1
3410 #define FRAME_TSS       2
3411 #define FRAME_NONFPO    3
3412
3413 typedef struct _FPO_DATA {
3414   DWORD ulOffStart;
3415   DWORD cbProcSize;
3416   DWORD cdwLocals;
3417   WORD  cdwParams;
3418   WORD  cbProlog : 8;
3419   WORD  cbRegs   : 3;
3420   WORD  fHasSEH  : 1;
3421   WORD  fUseBP   : 1;
3422   WORD  reserved : 1;
3423   WORD  cbFrame  : 2;
3424 } FPO_DATA, *PFPO_DATA;
3425
3426 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY {
3427   DWORD Size;
3428   DWORD TimeDateStamp;
3429   WORD  MajorVersion;
3430   WORD  MinorVersion;
3431   DWORD GlobalFlagsClear;
3432   DWORD GlobalFlagsSet;
3433   DWORD CriticalSectionDefaultTimeout;
3434   DWORD DeCommitFreeBlockThreshold;
3435   DWORD DeCommitTotalFreeThreshold;
3436   PVOID LockPrefixTable;
3437   DWORD MaximumAllocationSize;
3438   DWORD VirtualMemoryThreshold;
3439   DWORD ProcessHeapFlags;
3440   DWORD ProcessAffinityMask;
3441   WORD  CSDVersion;
3442   WORD  Reserved1;
3443   PVOID EditList;
3444   DWORD SecurityCookie;
3445   DWORD SEHandlerTable;
3446   DWORD SEHandlerCount;
3447 } IMAGE_LOAD_CONFIG_DIRECTORY, *PIMAGE_LOAD_CONFIG_DIRECTORY;
3448
3449 typedef struct _IMAGE_FUNCTION_ENTRY {
3450   DWORD StartingAddress;
3451   DWORD EndingAddress;
3452   DWORD EndOfPrologue;
3453 } IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
3454
3455 #define IMAGE_DEBUG_MISC_EXENAME    1
3456
3457 typedef struct _IMAGE_DEBUG_MISC {
3458     DWORD       DataType;
3459     DWORD       Length;
3460     BYTE        Unicode;
3461     BYTE        Reserved[ 3 ];
3462     BYTE        Data[ 1 ];
3463 } IMAGE_DEBUG_MISC, *PIMAGE_DEBUG_MISC;
3464
3465 /* This is the structure that appears at the very start of a .DBG file. */
3466
3467 typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
3468         WORD    Signature;
3469         WORD    Flags;
3470         WORD    Machine;
3471         WORD    Characteristics;
3472         DWORD   TimeDateStamp;
3473         DWORD   CheckSum;
3474         DWORD   ImageBase;
3475         DWORD   SizeOfImage;
3476         DWORD   NumberOfSections;
3477         DWORD   ExportedNamesSize;
3478         DWORD   DebugDirectorySize;
3479         DWORD   SectionAlignment;
3480         DWORD   Reserved[ 2 ];
3481 } IMAGE_SEPARATE_DEBUG_HEADER,*PIMAGE_SEPARATE_DEBUG_HEADER;
3482
3483 #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
3484
3485
3486 typedef struct tagMESSAGE_RESOURCE_ENTRY {
3487         WORD    Length;
3488         WORD    Flags;
3489         BYTE    Text[1];
3490 } MESSAGE_RESOURCE_ENTRY,*PMESSAGE_RESOURCE_ENTRY;
3491 #define MESSAGE_RESOURCE_UNICODE        0x0001
3492
3493 typedef struct tagMESSAGE_RESOURCE_BLOCK {
3494         DWORD   LowId;
3495         DWORD   HighId;
3496         DWORD   OffsetToEntries;
3497 } MESSAGE_RESOURCE_BLOCK,*PMESSAGE_RESOURCE_BLOCK;
3498
3499 typedef struct tagMESSAGE_RESOURCE_DATA {
3500         DWORD                   NumberOfBlocks;
3501         MESSAGE_RESOURCE_BLOCK  Blocks[ 1 ];
3502 } MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA;
3503
3504 /*
3505  * Here follows typedefs for security and tokens.
3506  */
3507
3508 /*
3509  * First a constant for the following typedefs.
3510  */
3511
3512 #define ANYSIZE_ARRAY   1
3513
3514 /* FIXME:  Orphan.  What does it point to? */
3515 typedef PVOID PACCESS_TOKEN;
3516 typedef PVOID PSECURITY_DESCRIPTOR;
3517 typedef PVOID PSID;
3518
3519 typedef enum _TOKEN_ELEVATION_TYPE {
3520   TokenElevationTypeDefault = 1,
3521   TokenElevationTypeFull,
3522   TokenElevationTypeLimited
3523 } TOKEN_ELEVATION_TYPE, *PTOKEN_ELEVATION_TYPE;
3524
3525 /*
3526  * TOKEN_INFORMATION_CLASS
3527  */
3528
3529 typedef enum _TOKEN_INFORMATION_CLASS {
3530   TokenUser = 1,
3531   TokenGroups,
3532   TokenPrivileges,
3533   TokenOwner,
3534   TokenPrimaryGroup,
3535   TokenDefaultDacl,
3536   TokenSource,
3537   TokenType,
3538   TokenImpersonationLevel,
3539   TokenStatistics,
3540   TokenRestrictedSids,
3541   TokenSessionId,
3542   TokenGroupsAndPrivileges,
3543   TokenSessionReference,
3544   TokenSandBoxInert,
3545   TokenAuditPolicy,
3546   TokenOrigin,
3547   TokenElevationType,
3548   TokenLinkedToken,
3549   TokenElevation,
3550   TokenHasRestrictions,
3551   TokenAccessInformation,
3552   TokenVirtualizationAllowed,
3553   TokenVirtualizationEnabled,
3554   TokenIntegrityLevel,
3555   TokenUIAccess,
3556   TokenMandatoryPolicy,
3557   TokenLogonSid,
3558   MaxTokenInfoClass
3559 } TOKEN_INFORMATION_CLASS;
3560
3561 #define TOKEN_TOKEN_ADJUST_DEFAULT   0x0080
3562 #define TOKEN_ADJUST_GROUPS          0x0040
3563 #define TOKEN_ADJUST_PRIVILEGES      0x0020
3564 #define TOKEN_ADJUST_SESSIONID       0x0100
3565 #define TOKEN_ASSIGN_PRIMARY         0x0001
3566 #define TOKEN_DUPLICATE              0x0002
3567 #define TOKEN_EXECUTE                STANDARD_RIGHTS_EXECUTE
3568 #define TOKEN_IMPERSONATE            0x0004
3569 #define TOKEN_QUERY                  0x0008
3570 #define TOKEN_QUERY_SOURCE           0x0010
3571 #define TOKEN_ADJUST_DEFAULT         0x0080
3572 #define TOKEN_READ                   (STANDARD_RIGHTS_READ|TOKEN_QUERY)
3573 #define TOKEN_WRITE                  (STANDARD_RIGHTS_WRITE     | \
3574                                         TOKEN_ADJUST_PRIVILEGES | \
3575                                         TOKEN_ADJUST_GROUPS | \
3576                                         TOKEN_ADJUST_DEFAULT )
3577 #define TOKEN_ALL_ACCESS             (STANDARD_RIGHTS_REQUIRED | \
3578                                         TOKEN_ASSIGN_PRIMARY | \
3579                                         TOKEN_DUPLICATE | \
3580                                         TOKEN_IMPERSONATE | \
3581                                         TOKEN_QUERY | \
3582                                         TOKEN_QUERY_SOURCE | \
3583                                         TOKEN_ADJUST_PRIVILEGES | \
3584                                         TOKEN_ADJUST_GROUPS | \
3585                                         TOKEN_ADJUST_SESSIONID | \
3586                                         TOKEN_ADJUST_DEFAULT )
3587
3588 #ifndef _SECURITY_DEFINED
3589 #define _SECURITY_DEFINED
3590
3591
3592 typedef DWORD ACCESS_MASK, *PACCESS_MASK;
3593
3594 typedef struct _GENERIC_MAPPING {
3595     ACCESS_MASK GenericRead;
3596     ACCESS_MASK GenericWrite;
3597     ACCESS_MASK GenericExecute;
3598     ACCESS_MASK GenericAll;
3599 } GENERIC_MAPPING, *PGENERIC_MAPPING;
3600
3601 #ifndef SID_IDENTIFIER_AUTHORITY_DEFINED
3602 #define SID_IDENTIFIER_AUTHORITY_DEFINED
3603 typedef struct {
3604     BYTE Value[6];
3605 } SID_IDENTIFIER_AUTHORITY, *PSID_IDENTIFIER_AUTHORITY;
3606 #endif /* !defined(SID_IDENTIFIER_AUTHORITY_DEFINED) */
3607
3608 #ifndef SID_DEFINED
3609 #define SID_DEFINED
3610 typedef struct _SID {
3611     BYTE Revision;
3612     BYTE SubAuthorityCount;
3613     SID_IDENTIFIER_AUTHORITY IdentifierAuthority;
3614     DWORD SubAuthority[1];
3615 } SID,*PISID;
3616 #endif /* !defined(SID_DEFINED) */
3617
3618 #define SID_REVISION                    (1)     /* Current revision */
3619 #define SID_MAX_SUB_AUTHORITIES         (15)    /* current max subauths */
3620 #define SID_RECOMMENDED_SUB_AUTHORITIES (1)     /* recommended subauths */
3621
3622 #define SECURITY_MAX_SID_SIZE (sizeof(SID) - sizeof(DWORD) + (SID_MAX_SUB_AUTHORITIES * sizeof(DWORD)))
3623
3624 /*
3625  * ACL
3626  */
3627
3628 #define ACL_REVISION1 1
3629 #define ACL_REVISION2 2
3630 #define ACL_REVISION3 3
3631 #define ACL_REVISION4 4
3632
3633 #define MIN_ACL_REVISION ACL_REVISION2
3634 #define MAX_ACL_REVISION ACL_REVISION4
3635
3636 #define ACL_REVISION 2
3637
3638 typedef struct _ACL {
3639     BYTE AclRevision;
3640     BYTE Sbz1;
3641     WORD AclSize;
3642     WORD AceCount;
3643     WORD Sbz2;
3644 } ACL, *PACL;
3645
3646 typedef enum _ACL_INFORMATION_CLASS
3647 {
3648   AclRevisionInformation = 1, 
3649   AclSizeInformation
3650 } ACL_INFORMATION_CLASS;
3651
3652 typedef struct _ACL_REVISION_INFORMATION
3653 {
3654     DWORD AclRevision;
3655 } ACL_REVISION_INFORMATION, *PACL_REVISION_INFORMATION;
3656
3657 typedef struct _ACL_SIZE_INFORMATION
3658 {
3659     DWORD AceCount;
3660     DWORD AclBytesInUse;
3661     DWORD AclBytesFree;
3662 } ACL_SIZE_INFORMATION, *PACL_SIZE_INFORMATION;
3663
3664 /* SECURITY_DESCRIPTOR */
3665 #define SECURITY_DESCRIPTOR_REVISION    1
3666 #define SECURITY_DESCRIPTOR_REVISION1   1
3667
3668
3669 /*
3670  * Privilege Names
3671  */
3672 #define SE_CREATE_TOKEN_NAME            TEXT("SeCreateTokenPrivilege")
3673 #define SE_ASSIGNPRIMARYTOKEN_NAME      TEXT("SeAssignPrimaryTokenPrivilege")
3674 #define SE_LOCK_MEMORY_NAME             TEXT("SeLockMemoryPrivilege")
3675 #define SE_INCREASE_QUOTA_NAME          TEXT("SeIncreaseQuotaPrivilege")
3676 #define SE_UNSOLICITED_INPUT_NAME       TEXT("SeUnsolicitedInputPrivilege")
3677 #define SE_MACHINE_ACCOUNT_NAME         TEXT("SeMachineAccountPrivilege")
3678 #define SE_TCB_NAME                     TEXT("SeTcbPrivilege")
3679 #define SE_SECURITY_NAME                TEXT("SeSecurityPrivilege")
3680 #define SE_TAKE_OWNERSHIP_NAME          TEXT("SeTakeOwnershipPrivilege")
3681 #define SE_LOAD_DRIVER_NAME             TEXT("SeLoadDriverPrivilege")
3682 #define SE_SYSTEM_PROFILE_NAME          TEXT("SeSystemProfilePrivilege")
3683 #define SE_SYSTEMTIME_NAME              TEXT("SeSystemtimePrivilege")
3684 #define SE_PROF_SINGLE_PROCESS_NAME     TEXT("SeProfileSingleProcessPrivilege")
3685 #define SE_INC_BASE_PRIORITY_NAME       TEXT("SeIncreaseBasePriorityPrivilege")
3686 #define SE_CREATE_PAGEFILE_NAME         TEXT("SeCreatePagefilePrivilege")
3687 #define SE_CREATE_PERMANENT_NAME        TEXT("SeCreatePermanentPrivilege")
3688 #define SE_BACKUP_NAME                  TEXT("SeBackupPrivilege")
3689 #define SE_RESTORE_NAME                 TEXT("SeRestorePrivilege")
3690 #define SE_SHUTDOWN_NAME                TEXT("SeShutdownPrivilege")
3691 #define SE_DEBUG_NAME                   TEXT("SeDebugPrivilege")
3692 #define SE_AUDIT_NAME                   TEXT("SeAuditPrivilege")
3693 #define SE_SYSTEM_ENVIRONMENT_NAME      TEXT("SeSystemEnvironmentPrivilege")
3694 #define SE_CHANGE_NOTIFY_NAME           TEXT("SeChangeNotifyPrivilege")
3695 #define SE_REMOTE_SHUTDOWN_NAME         TEXT("SeRemoteShutdownPrivilege")
3696 #define SE_UNDOCK_NAME                  TEXT("SeUndockPrivilege")
3697 #define SE_ENABLE_DELEGATION_NAME       TEXT("SeEnableDelegationPrivilege")
3698 #define SE_MANAGE_VOLUME_NAME           TEXT("SeManageVolumePrivilege")
3699 #define SE_IMPERSONATE_NAME             TEXT("SeImpersonatePrivilege")
3700 #define SE_CREATE_GLOBAL_NAME           TEXT("SeCreateGlobalPrivilege")
3701
3702 #define SE_GROUP_MANDATORY              0x00000001
3703 #define SE_GROUP_ENABLED_BY_DEFAULT     0x00000002
3704 #define SE_GROUP_ENABLED                0x00000004
3705 #define SE_GROUP_OWNER                  0x00000008
3706 #define SE_GROUP_USE_FOR_DENY_ONLY      0x00000010
3707 #define SE_GROUP_LOGON_ID               0xC0000000
3708 #define SE_GROUP_RESOURCE               0x20000000
3709
3710 #define SE_PRIVILEGE_ENABLED_BY_DEFAULT 0x00000001
3711 #define SE_PRIVILEGE_ENABLED            0x00000002
3712 #define SE_PRIVILEGE_REMOVED            0x00000004
3713 #define SE_PRIVILEGE_USED_FOR_ACCESS    0x80000000
3714
3715 #define PRIVILEGE_SET_ALL_NECESSARY     1
3716
3717 #define SE_OWNER_DEFAULTED              0x00000001
3718 #define SE_GROUP_DEFAULTED              0x00000002
3719 #define SE_DACL_PRESENT                 0x00000004
3720 #define SE_DACL_DEFAULTED               0x00000008
3721 #define SE_SACL_PRESENT                 0x00000010
3722 #define SE_SACL_DEFAULTED               0x00000020
3723 #define SE_DACL_AUTO_INHERIT_REQ        0x00000100
3724 #define SE_SACL_AUTO_INHERIT_REQ        0x00000200
3725 #define SE_DACL_AUTO_INHERITED          0x00000400
3726 #define SE_SACL_AUTO_INHERITED          0x00000800
3727 #define SE_DACL_PROTECTED               0x00001000
3728 #define SE_SACL_PROTECTED               0x00002000
3729 #define SE_RM_CONTROL_VALID             0x00004000
3730 #define SE_SELF_RELATIVE                0x00008000
3731
3732 typedef DWORD SECURITY_INFORMATION, *PSECURITY_INFORMATION;
3733 typedef WORD SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL;
3734
3735 /* The security descriptor structure */
3736 typedef struct {
3737     BYTE Revision;
3738     BYTE Sbz1;
3739     SECURITY_DESCRIPTOR_CONTROL Control;
3740     DWORD Owner;
3741     DWORD Group;
3742     DWORD Sacl;
3743     DWORD Dacl;
3744 } SECURITY_DESCRIPTOR_RELATIVE, *PISECURITY_DESCRIPTOR_RELATIVE;
3745
3746 typedef struct {
3747     BYTE Revision;
3748     BYTE Sbz1;
3749     SECURITY_DESCRIPTOR_CONTROL Control;
3750     PSID Owner;
3751     PSID Group;
3752     PACL Sacl;
3753     PACL Dacl;
3754 } SECURITY_DESCRIPTOR, *PISECURITY_DESCRIPTOR;
3755
3756 #define SECURITY_DESCRIPTOR_MIN_LENGTH   (sizeof(SECURITY_DESCRIPTOR))
3757
3758 #endif /* _SECURITY_DEFINED */
3759
3760 /*
3761  * SID_AND_ATTRIBUTES
3762  */
3763
3764 typedef struct _SID_AND_ATTRIBUTES {
3765   PSID  Sid;
3766   DWORD Attributes;
3767 } SID_AND_ATTRIBUTES, *PSID_AND_ATTRIBUTES;
3768
3769 /* security entities */
3770 #define SECURITY_NULL_RID                       __MSABI_LONG(0x00000000)
3771 #define SECURITY_WORLD_RID                      __MSABI_LONG(0x00000000)
3772 #define SECURITY_LOCAL_RID                      __MSABI_LONG(0X00000000)
3773
3774 #define SECURITY_NULL_SID_AUTHORITY             {0,0,0,0,0,0}
3775
3776 /* S-1-1 */
3777 #define SECURITY_WORLD_SID_AUTHORITY            {0,0,0,0,0,1}
3778
3779 /* S-1-2 */
3780 #define SECURITY_LOCAL_SID_AUTHORITY            {0,0,0,0,0,2}
3781
3782 /* S-1-3 */
3783 #define SECURITY_CREATOR_SID_AUTHORITY          {0,0,0,0,0,3}
3784 #define SECURITY_CREATOR_OWNER_RID              __MSABI_LONG(0x00000000)
3785 #define SECURITY_CREATOR_GROUP_RID              __MSABI_LONG(0x00000001)
3786 #define SECURITY_CREATOR_OWNER_SERVER_RID       __MSABI_LONG(0x00000002)
3787 #define SECURITY_CREATOR_GROUP_SERVER_RID       __MSABI_LONG(0x00000003)
3788
3789 /* S-1-4 */
3790 #define SECURITY_NON_UNIQUE_AUTHORITY           {0,0,0,0,0,4}
3791
3792 /* S-1-5 */
3793 #define SECURITY_NT_AUTHORITY                   {0,0,0,0,0,5}
3794 #define SECURITY_DIALUP_RID                     __MSABI_LONG(0x00000001)
3795 #define SECURITY_NETWORK_RID                    __MSABI_LONG(0x00000002)
3796 #define SECURITY_BATCH_RID                      __MSABI_LONG(0x00000003)
3797 #define SECURITY_INTERACTIVE_RID                __MSABI_LONG(0x00000004)
3798 #define SECURITY_LOGON_IDS_RID                  __MSABI_LONG(0x00000005)
3799 #define SECURITY_SERVICE_RID                    __MSABI_LONG(0x00000006)
3800 #define SECURITY_ANONYMOUS_LOGON_RID            __MSABI_LONG(0x00000007)
3801 #define SECURITY_PROXY_RID                      __MSABI_LONG(0x00000008)
3802 #define SECURITY_ENTERPRISE_CONTROLLERS_RID     __MSABI_LONG(0x00000009)
3803 #define SECURITY_SERVER_LOGON_RID               SECURITY_ENTERPRISE_CONTROLLERS_RID
3804 #define SECURITY_PRINCIPAL_SELF_RID             __MSABI_LONG(0x0000000A)
3805 #define SECURITY_AUTHENTICATED_USER_RID         __MSABI_LONG(0x0000000B)
3806 #define SECURITY_RESTRICTED_CODE_RID            __MSABI_LONG(0x0000000C)
3807 #define SECURITY_TERMINAL_SERVER_RID            __MSABI_LONG(0x0000000D)
3808 #define SECURITY_REMOTE_LOGON_RID               __MSABI_LONG(0x0000000E)
3809 #define SECURITY_THIS_ORGANIZATION_RID          __MSABI_LONG(0x0000000F)
3810 #define SECURITY_LOCAL_SYSTEM_RID               __MSABI_LONG(0x00000012)
3811 #define SECURITY_LOCAL_SERVICE_RID              __MSABI_LONG(0x00000013)
3812 #define SECURITY_NETWORK_SERVICE_RID            __MSABI_LONG(0x00000014)
3813 #define SECURITY_NT_NON_UNIQUE                  __MSABI_LONG(0x00000015)
3814 #define SECURITY_BUILTIN_DOMAIN_RID             __MSABI_LONG(0x00000020)
3815
3816 #define SECURITY_PACKAGE_BASE_RID               __MSABI_LONG(0x00000040)
3817 #define SECURITY_PACKAGE_NTLM_RID               __MSABI_LONG(0x0000000A)
3818 #define SECURITY_PACKAGE_SCHANNEL_RID           __MSABI_LONG(0x0000000E)
3819 #define SECURITY_PACKAGE_DIGEST_RID             __MSABI_LONG(0x00000015)
3820 #define SECURITY_MAX_ALWAYS_FILTERED            __MSABI_LONG(0x000003E7)
3821 #define SECURITY_MIN_NEVER_FILTERED             __MSABI_LONG(0x000003E8)
3822 #define SECURITY_OTHER_ORGANIZATION_RID         __MSABI_LONG(0x000003E8)
3823
3824 #define FOREST_USER_RID_MAX                     __MSABI_LONG(0x000001F3)
3825 #define DOMAIN_USER_RID_ADMIN                   __MSABI_LONG(0x000001F4)
3826 #define DOMAIN_USER_RID_GUEST                   __MSABI_LONG(0x000001F5)
3827 #define DOMAIN_USER_RID_KRBTGT                  __MSABI_LONG(0x000001F6)
3828 #define DOMAIN_USER_RID_MAX                     __MSABI_LONG(0x000003E7)
3829
3830 #define DOMAIN_GROUP_RID_ADMINS                 __MSABI_LONG(0x00000200)
3831 #define DOMAIN_GROUP_RID_USERS                  __MSABI_LONG(0x00000201)
3832 #define DOMAIN_GROUP_RID_GUESTS                 __MSABI_LONG(0x00000202)
3833 #define DOMAIN_GROUP_RID_COMPUTERS              __MSABI_LONG(0x00000203)
3834 #define DOMAIN_GROUP_RID_CONTROLLERS            __MSABI_LONG(0x00000204)
3835 #define DOMAIN_GROUP_RID_CERT_ADMINS            __MSABI_LONG(0x00000205)
3836 #define DOMAIN_GROUP_RID_SCHEMA_ADMINS          __MSABI_LONG(0x00000206)
3837 #define DOMAIN_GROUP_RID_ENTERPRISE_ADMINS      __MSABI_LONG(0x00000207)
3838 #define DOMAIN_GROUP_RID_POLICY_ADMINS          __MSABI_LONG(0x00000208)
3839
3840 #define SECURITY_MANDATORY_LABEL_AUTHORITY {0,0,0,0,0,16}
3841 #define SECURITY_MANDATORY_UNTRUSTED_RID        __MSABI_LONG(0x00000000)
3842 #define SECURITY_MANDATORY_LOW_RID              __MSABI_LONG(0x00001000)
3843 #define SECURITY_MANDATORY_MEDIUM_RID           __MSABI_LONG(0x00002000)
3844 #define SECURITY_MANDATORY_HIGH_RID             __MSABI_LONG(0x00003000)
3845 #define SECURITY_MANDATORY_SYSTEM_RID           __MSABI_LONG(0x00004000)
3846 #define SECURITY_MANDATORY_PROTECTED_PROCESS_RID __MSABI_LONG(0x00005000)
3847
3848 #define DOMAIN_ALIAS_RID_ADMINS                 __MSABI_LONG(0x00000220)
3849 #define DOMAIN_ALIAS_RID_USERS                  __MSABI_LONG(0x00000221)
3850 #define DOMAIN_ALIAS_RID_GUESTS                 __MSABI_LONG(0x00000222)
3851 #define DOMAIN_ALIAS_RID_POWER_USERS            __MSABI_LONG(0x00000223)
3852
3853 #define DOMAIN_ALIAS_RID_ACCOUNT_OPS            __MSABI_LONG(0x00000224)
3854 #define DOMAIN_ALIAS_RID_SYSTEM_OPS             __MSABI_LONG(0x00000225)
3855 #define DOMAIN_ALIAS_RID_PRINT_OPS              __MSABI_LONG(0x00000226)
3856 #define DOMAIN_ALIAS_RID_BACKUP_OPS             __MSABI_LONG(0x00000227)
3857
3858 #define DOMAIN_ALIAS_RID_REPLICATOR             __MSABI_LONG(0x00000228)
3859 #define DOMAIN_ALIAS_RID_RAS_SERVERS            __MSABI_LONG(0x00000229)
3860 #define DOMAIN_ALIAS_RID_PREW2KCOMPACCESS       __MSABI_LONG(0x0000022A)
3861 #define DOMAIN_ALIAS_RID_REMOTE_DESKTOP_USERS   __MSABI_LONG(0x0000022B)
3862 #define DOMAIN_ALIAS_RID_NETWORK_CONFIGURATION_OPS __MSABI_LONG(0x0000022C)
3863 #define DOMAIN_ALIAS_RID_INCOMING_FOREST_TRUST_BUILDERS __MSABI_LONG(0x0000022D)
3864
3865 #define DOMAIN_ALIAS_RID_MONITORING_USERS       __MSABI_LONG(0x0000022E)
3866 #define DOMAIN_ALIAS_RID_LOGGING_USERS          __MSABI_LONG(0x0000022F)
3867 #define DOMAIN_ALIAS_RID_AUTHORIZATIONACCESS    __MSABI_LONG(0x00000230)
3868 #define DOMAIN_ALIAS_RID_TS_LICENSE_SERVERS     __MSABI_LONG(0x00000231)
3869 #define DOMAIN_ALIAS_RID_DCOM_USERS             __MSABI_LONG(0x00000232)
3870
3871 #define SECURITY_SERVER_LOGON_RID               SECURITY_ENTERPRISE_CONTROLLERS_RID
3872
3873 #define SECURITY_PACKAGE_RID_COUNT              __MSABI_LONG(2)
3874 #define SECURITY_LOGON_IDS_RID_COUNT            __MSABI_LONG(3)
3875
3876 typedef enum {
3877     WinNullSid                                  = 0,
3878     WinWorldSid                                 = 1,
3879     WinLocalSid                                 = 2,
3880     WinCreatorOwnerSid                          = 3,
3881     WinCreatorGroupSid                          = 4,
3882     WinCreatorOwnerServerSid                    = 5,
3883     WinCreatorGroupServerSid                    = 6,
3884     WinNtAuthoritySid                           = 7,
3885     WinDialupSid                                = 8,
3886     WinNetworkSid                               = 9,
3887     WinBatchSid                                 = 10,
3888     WinInteractiveSid                           = 11,
3889     WinServiceSid                               = 12,
3890     WinAnonymousSid                             = 13,
3891     WinProxySid                                 = 14,
3892     WinEnterpriseControllersSid                 = 15,
3893     WinSelfSid                                  = 16,
3894     WinAuthenticatedUserSid                     = 17,
3895     WinRestrictedCodeSid                        = 18,
3896     WinTerminalServerSid                        = 19,
3897     WinRemoteLogonIdSid                         = 20,
3898     WinLogonIdsSid                              = 21,
3899     WinLocalSystemSid                           = 22,
3900     WinLocalServiceSid                          = 23,
3901     WinNetworkServiceSid                        = 24,
3902     WinBuiltinDomainSid                         = 25,
3903     WinBuiltinAdministratorsSid                 = 26,
3904     WinBuiltinUsersSid                          = 27,
3905     WinBuiltinGuestsSid                         = 28,
3906     WinBuiltinPowerUsersSid                     = 29,
3907     WinBuiltinAccountOperatorsSid               = 30,
3908     WinBuiltinSystemOperatorsSid                = 31,
3909     WinBuiltinPrintOperatorsSid                 = 32,
3910     WinBuiltinBackupOperatorsSid                = 33,
3911     WinBuiltinReplicatorSid                     = 34,
3912     WinBuiltinPreWindows2000CompatibleAccessSid = 35,
3913     WinBuiltinRemoteDesktopUsersSid             = 36,
3914     WinBuiltinNetworkConfigurationOperatorsSid  = 37,
3915     WinAccountAdministratorSid                  = 38,
3916     WinAccountGuestSid                          = 39,
3917     WinAccountKrbtgtSid                         = 40,
3918     WinAccountDomainAdminsSid                   = 41,
3919     WinAccountDomainUsersSid                    = 42,
3920     WinAccountDomainGuestsSid                   = 43,
3921     WinAccountComputersSid                      = 44,
3922     WinAccountControllersSid                    = 45,
3923     WinAccountCertAdminsSid                     = 46,
3924     WinAccountSchemaAdminsSid                   = 47,
3925     WinAccountEnterpriseAdminsSid               = 48,
3926     WinAccountPolicyAdminsSid                   = 49,
3927     WinAccountRasAndIasServersSid               = 50,
3928     WinNTLMAuthenticationSid                    = 51,
3929     WinDigestAuthenticationSid                  = 52,
3930     WinSChannelAuthenticationSid                = 53,
3931     WinThisOrganizationSid                      = 54,
3932     WinOtherOrganizationSid                     = 55,
3933     WinBuiltinIncomingForestTrustBuildersSid    = 56,
3934     WinBuiltinPerfMonitoringUsersSid            = 57,
3935     WinBuiltinPerfLoggingUsersSid               = 58,
3936     WinBuiltinAuthorizationAccessSid            = 59,
3937     WinBuiltinTerminalServerLicenseServersSid   = 60,
3938     WinBuiltinDCOMUsersSid                      = 61,
3939     WinBuiltinIUsersSid                         = 62,
3940     WinIUserSid                                 = 63,
3941     WinBuiltinCryptoOperatorsSid                = 64,
3942     WinUntrustedLabelSid                        = 65,
3943     WinLowLabelSid                              = 66,
3944     WinMediumLabelSid                           = 67,
3945     WinHighLabelSid                             = 68,
3946     WinSystemLabelSid                           = 69,
3947     WinWriteRestrictedCodeSid                   = 70,
3948     WinCreatorOwnerRightsSid                    = 71,
3949     WinCacheablePrincipalsGroupSid              = 72,
3950     WinNonCacheablePrincipalsGroupSid           = 73,
3951     WinEnterpriseReadonlyControllersSid         = 74,
3952     WinAccountReadonlyControllersSid            = 75,
3953     WinBuiltinEventLogReadersGroup              = 76,
3954     WinNewEnterpriseReadonlyControllersSid      = 77,
3955     WinBuiltinCertSvcDComAccessGroup            = 78,
3956     WinMediumPlusLabelSid                       = 79,
3957     WinLocalLogonSid                            = 80,
3958     WinConsoleLogonSid                          = 81,
3959     WinThisOrganizationCertificateSid           = 82,
3960 } WELL_KNOWN_SID_TYPE;
3961
3962 /*
3963  * TOKEN_USER
3964  */
3965
3966 typedef struct _TOKEN_USER {
3967     SID_AND_ATTRIBUTES User;
3968 } TOKEN_USER, *PTOKEN_USER;
3969
3970 /*
3971  * TOKEN_GROUPS
3972  */
3973
3974 typedef struct _TOKEN_GROUPS {
3975     DWORD GroupCount;
3976     SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY];
3977 } TOKEN_GROUPS, *PTOKEN_GROUPS;
3978
3979 /*
3980  * LUID_AND_ATTRIBUTES
3981  */
3982
3983 typedef union _LARGE_INTEGER {
3984     struct {
3985 #ifdef WORDS_BIGENDIAN
3986         LONG     HighPart;
3987         DWORD    LowPart;
3988 #else
3989         DWORD    LowPart;
3990         LONG     HighPart;
3991 #endif
3992     } u;
3993 #ifndef NONAMELESSSTRUCT
3994     struct {
3995 #ifdef WORDS_BIGENDIAN
3996         LONG     HighPart;
3997         DWORD    LowPart;
3998 #else
3999         DWORD    LowPart;
4000         LONG     HighPart;
4001 #endif
4002     };
4003 #endif
4004     LONGLONG QuadPart;
4005 } LARGE_INTEGER, *PLARGE_INTEGER;
4006
4007 typedef union _ULARGE_INTEGER {
4008     struct {
4009 #ifdef WORDS_BIGENDIAN
4010         DWORD    HighPart;
4011         DWORD    LowPart;
4012 #else
4013         DWORD    LowPart;
4014         DWORD    HighPart;
4015 #endif
4016     } u;
4017 #ifndef NONAMELESSSTRUCT
4018     struct {
4019 #ifdef WORDS_BIGENDIAN
4020         DWORD    HighPart;
4021         DWORD    LowPart;
4022 #else
4023         DWORD    LowPart;
4024         DWORD    HighPart;
4025 #endif
4026     };
4027 #endif
4028     ULONGLONG QuadPart;
4029 } ULARGE_INTEGER, *PULARGE_INTEGER;
4030
4031 /*
4032  * Locally Unique Identifier
4033  */
4034
4035 typedef struct _LUID {
4036     DWORD LowPart;
4037     LONG HighPart;
4038 } LUID, *PLUID;
4039
4040 #include <pshpack4.h>
4041 typedef struct _LUID_AND_ATTRIBUTES {
4042   LUID   Luid;
4043   DWORD  Attributes;
4044 } LUID_AND_ATTRIBUTES, *PLUID_AND_ATTRIBUTES;
4045 #include <poppack.h>
4046
4047 /*
4048  * PRIVILEGE_SET
4049  */
4050
4051 typedef struct _PRIVILEGE_SET {
4052     DWORD PrivilegeCount;
4053     DWORD Control;
4054     LUID_AND_ATTRIBUTES Privilege[ANYSIZE_ARRAY];
4055 } PRIVILEGE_SET, *PPRIVILEGE_SET;
4056
4057 /*
4058  * TOKEN_PRIVILEGES
4059  */
4060
4061 typedef struct _TOKEN_PRIVILEGES {
4062   DWORD PrivilegeCount;
4063   LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
4064 } TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES;
4065
4066 /*
4067  * TOKEN_OWNER
4068  */
4069
4070 typedef struct _TOKEN_OWNER {
4071   PSID Owner;
4072 } TOKEN_OWNER, *PTOKEN_OWNER;
4073
4074 /*
4075  * TOKEN_PRIMARY_GROUP
4076  */
4077
4078 typedef struct _TOKEN_PRIMARY_GROUP {
4079   PSID PrimaryGroup;
4080 } TOKEN_PRIMARY_GROUP, *PTOKEN_PRIMARY_GROUP;
4081
4082
4083 /*
4084  * TOKEN_DEFAULT_DACL
4085  */
4086
4087 typedef struct _TOKEN_DEFAULT_DACL {
4088   PACL DefaultDacl;
4089 } TOKEN_DEFAULT_DACL, *PTOKEN_DEFAULT_DACL;
4090
4091 /*
4092  * TOKEN_SOURCE
4093  */
4094
4095 #define TOKEN_SOURCE_LENGTH 8
4096
4097 typedef struct _TOKEN_SOURCE {
4098   char SourceName[TOKEN_SOURCE_LENGTH];
4099   LUID SourceIdentifier;
4100 } TOKEN_SOURCE, *PTOKEN_SOURCE;
4101
4102 /*
4103  * TOKEN_TYPE
4104  */
4105
4106 typedef enum tagTOKEN_TYPE {
4107   TokenPrimary = 1,
4108   TokenImpersonation
4109 } TOKEN_TYPE;
4110
4111 /*
4112  * SECURITY_IMPERSONATION_LEVEL
4113  */
4114
4115 typedef enum _SECURITY_IMPERSONATION_LEVEL {
4116   SecurityAnonymous,
4117   SecurityIdentification,
4118   SecurityImpersonation,
4119   SecurityDelegation
4120 } SECURITY_IMPERSONATION_LEVEL, *PSECURITY_IMPERSONATION_LEVEL;
4121
4122 #define SECURITY_DYNAMIC_TRACKING   (TRUE)
4123 #define SECURITY_STATIC_TRACKING    (FALSE)
4124
4125 typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,
4126         * PSECURITY_CONTEXT_TRACKING_MODE;
4127 /*
4128  *      Quality of Service
4129  */
4130
4131 typedef struct _SECURITY_QUALITY_OF_SERVICE {
4132   DWORD                         Length;
4133   SECURITY_IMPERSONATION_LEVEL  ImpersonationLevel;
4134   SECURITY_CONTEXT_TRACKING_MODE ContextTrackingMode;
4135   BOOLEAN                       EffectiveOnly;
4136 } SECURITY_QUALITY_OF_SERVICE, *PSECURITY_QUALITY_OF_SERVICE;
4137
4138 /*
4139  * TOKEN_STATISTICS
4140  */
4141
4142 #include <pshpack4.h>
4143 typedef struct _TOKEN_STATISTICS {
4144   LUID  TokenId;
4145   LUID  AuthenticationId;
4146   LARGE_INTEGER ExpirationTime;
4147   TOKEN_TYPE    TokenType;
4148   SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
4149   DWORD DynamicCharged;
4150   DWORD DynamicAvailable;
4151   DWORD GroupCount;
4152   DWORD PrivilegeCount;
4153   LUID  ModifiedId;
4154 } TOKEN_STATISTICS;
4155 #include <poppack.h>
4156
4157 typedef struct _TOKEN_GROUPS_AND_PRIVILEGES {
4158   DWORD                 SidCount;
4159   DWORD                 SidLength;
4160   PSID_AND_ATTRIBUTES   Sids;
4161   DWORD                 RestrictedSidCount;
4162   DWORD                 RestrictedSidLength;
4163   PSID_AND_ATTRIBUTES   RestrictedSids;
4164   DWORD                 PrivilegeCount;
4165   DWORD                 PrivilegeLength;
4166   PLUID_AND_ATTRIBUTES  Privileges;
4167   LUID                  AuthenticationId;
4168 } TOKEN_GROUPS_AND_PRIVILEGES, * PTOKEN_GROUPS_AND_PRIVILEGES;
4169
4170 typedef struct _TOKEN_ORIGIN {
4171   LUID  OriginatingLogonSession;
4172 } TOKEN_ORIGIN, * PTOKEN_ORIGIN;
4173
4174 typedef struct _TOKEN_LINKED_TOKEN {
4175   HANDLE LinkedToken;
4176 } TOKEN_LINKED_TOKEN, * PTOKEN_LINKED_TOKEN;
4177
4178 typedef struct _TOKEN_ELEVATION {
4179   DWORD TokenIsElevated;
4180 } TOKEN_ELEVATION, * PTOKEN_ELEVATION;
4181
4182
4183 /*
4184  *      ACLs of NT
4185  */
4186
4187 /* ACEs, directly starting after an ACL */
4188 typedef struct _ACE_HEADER {
4189         BYTE    AceType;
4190         BYTE    AceFlags;
4191         WORD    AceSize;
4192 } ACE_HEADER,*PACE_HEADER;
4193
4194 /* AceType */
4195 #define ACCESS_ALLOWED_ACE_TYPE         0
4196 #define ACCESS_DENIED_ACE_TYPE          1
4197 #define SYSTEM_AUDIT_ACE_TYPE           2
4198 #define SYSTEM_ALARM_ACE_TYPE           3
4199
4200 /* inherit AceFlags */
4201 #define OBJECT_INHERIT_ACE              0x01
4202 #define CONTAINER_INHERIT_ACE           0x02
4203 #define NO_PROPAGATE_INHERIT_ACE        0x04
4204 #define INHERIT_ONLY_ACE                0x08
4205 #define INHERITED_ACE                   0x10
4206 #define VALID_INHERIT_FLAGS             0x1F
4207
4208 /* AceFlags mask for what events we (should) audit */
4209 #define SUCCESSFUL_ACCESS_ACE_FLAG      0x40
4210 #define FAILED_ACCESS_ACE_FLAG          0x80
4211
4212 /* different ACEs depending on AceType
4213  * SidStart marks the begin of a SID
4214  * so the thing finally looks like this:
4215  * 0: ACE_HEADER
4216  * 4: ACCESS_MASK
4217  * 8... : SID
4218  */
4219 typedef struct _ACCESS_ALLOWED_ACE {
4220         ACE_HEADER      Header;
4221         DWORD           Mask;
4222         DWORD           SidStart;
4223 } ACCESS_ALLOWED_ACE,*PACCESS_ALLOWED_ACE;
4224
4225 typedef struct _ACCESS_DENIED_ACE {
4226         ACE_HEADER      Header;
4227         DWORD           Mask;
4228         DWORD           SidStart;
4229 } ACCESS_DENIED_ACE,*PACCESS_DENIED_ACE;
4230
4231 typedef struct _SYSTEM_AUDIT_ACE {
4232         ACE_HEADER      Header;
4233         DWORD           Mask;
4234         DWORD           SidStart;
4235 } SYSTEM_AUDIT_ACE,*PSYSTEM_AUDIT_ACE;
4236
4237 typedef struct _SYSTEM_ALARM_ACE {
4238         ACE_HEADER      Header;
4239         DWORD           Mask;
4240         DWORD           SidStart;
4241 } SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
4242
4243 typedef enum tagSID_NAME_USE {
4244         SidTypeUser = 1,
4245         SidTypeGroup,
4246         SidTypeDomain,
4247         SidTypeAlias,
4248         SidTypeWellKnownGroup,
4249         SidTypeDeletedAccount,
4250         SidTypeInvalid,
4251         SidTypeUnknown
4252 } SID_NAME_USE,*PSID_NAME_USE;
4253
4254 #define ACE_OBJECT_TYPE_PRESENT 0x1
4255 #define ACE_INHERITED_OBJECT_TYPE_PRESENT   0x2
4256
4257 /* Access rights */
4258
4259 /* DELETE may be already defined via /usr/include/arpa/nameser_compat.h */
4260 #undef  DELETE
4261 #define DELETE                     0x00010000
4262 #define READ_CONTROL               0x00020000
4263 #define WRITE_DAC                  0x00040000
4264 #define WRITE_OWNER                0x00080000
4265 #define SYNCHRONIZE                0x00100000
4266 #define STANDARD_RIGHTS_REQUIRED   0x000f0000
4267
4268 #define STANDARD_RIGHTS_READ       READ_CONTROL
4269 #define STANDARD_RIGHTS_WRITE      READ_CONTROL
4270 #define STANDARD_RIGHTS_EXECUTE    READ_CONTROL
4271
4272 #define STANDARD_RIGHTS_ALL        0x001f0000
4273
4274 #define SPECIFIC_RIGHTS_ALL        0x0000ffff
4275
4276 #define GENERIC_READ               0x80000000
4277 #define GENERIC_WRITE              0x40000000
4278 #define GENERIC_EXECUTE            0x20000000
4279 #define GENERIC_ALL                0x10000000
4280
4281 #define MAXIMUM_ALLOWED            0x02000000
4282 #define ACCESS_SYSTEM_SECURITY     0x01000000
4283
4284 #define EVENT_QUERY_STATE          0x0001
4285 #define EVENT_MODIFY_STATE         0x0002
4286 #define EVENT_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4287
4288 #define SEMAPHORE_MODIFY_STATE     0x0002
4289 #define SEMAPHORE_ALL_ACCESS       (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4290
4291 #define MUTANT_QUERY_STATE         0x0001
4292 #define MUTANT_ALL_ACCESS          (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|MUTANT_QUERY_STATE)
4293
4294 #define JOB_OBJECT_ASSIGN_PROCESS           0x0001
4295 #define JOB_OBJECT_SET_ATTRIBUTES           0x0002
4296 #define JOB_OBJECT_QUERY                    0x0004
4297 #define JOB_OBJECT_TERMINATE                0x0008
4298 #define JOB_OBJECT_SET_SECURITY_ATTRIBUTES  0x0010
4299 #define JOB_OBJECT_ALL_ACCESS               (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1f)
4300
4301 #define TIMER_QUERY_STATE          0x0001
4302 #define TIMER_MODIFY_STATE         0x0002
4303 #define TIMER_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4304
4305 #define PROCESS_TERMINATE          0x0001
4306 #define PROCESS_CREATE_THREAD      0x0002
4307 #define PROCESS_VM_OPERATION       0x0008
4308 #define PROCESS_VM_READ            0x0010
4309 #define PROCESS_VM_WRITE           0x0020
4310 #define PROCESS_DUP_HANDLE         0x0040
4311 #define PROCESS_CREATE_PROCESS     0x0080
4312 #define PROCESS_SET_QUOTA          0x0100
4313 #define PROCESS_SET_INFORMATION    0x0200
4314 #define PROCESS_QUERY_INFORMATION  0x0400
4315 #define PROCESS_SUSPEND_RESUME     0x0800
4316 #define PROCESS_QUERY_LIMITED_INFORMATION 0x1000
4317 #define PROCESS_ALL_ACCESS         (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xfff)
4318
4319 #define THREAD_TERMINATE           0x0001
4320 #define THREAD_SUSPEND_RESUME      0x0002
4321 #define THREAD_GET_CONTEXT         0x0008
4322 #define THREAD_SET_CONTEXT         0x0010
4323 #define THREAD_SET_INFORMATION     0x0020
4324 #define THREAD_QUERY_INFORMATION   0x0040
4325 #define THREAD_SET_THREAD_TOKEN    0x0080
4326 #define THREAD_IMPERSONATE         0x0100
4327 #define THREAD_DIRECT_IMPERSONATION 0x0200
4328 #define THREAD_ALL_ACCESS          (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3ff)
4329
4330 #define THREAD_BASE_PRIORITY_LOWRT  15
4331 #define THREAD_BASE_PRIORITY_MAX    2
4332 #define THREAD_BASE_PRIORITY_MIN   -2
4333 #define THREAD_BASE_PRIORITY_IDLE  -15
4334
4335 typedef struct _QUOTA_LIMITS {
4336     SIZE_T PagedPoolLimit;
4337     SIZE_T NonPagedPoolLimit;
4338     SIZE_T MinimumWorkingSetSize;
4339     SIZE_T MaximumWorkingSetSize;
4340     SIZE_T PagefileLimit;
4341     LARGE_INTEGER TimeLimit;
4342 } QUOTA_LIMITS, *PQUOTA_LIMITS;
4343
4344 #define QUOTA_LIMITS_HARDWS_MIN_ENABLE  0x00000001
4345 #define QUOTA_LIMITS_HARDWS_MIN_DISABLE 0x00000002
4346 #define QUOTA_LIMITS_HARDWS_MAX_ENABLE  0x00000004
4347 #define QUOTA_LIMITS_HARDWS_MAX_DISABLE 0x00000008
4348
4349 typedef struct _QUOTA_LIMITS_EX {
4350     SIZE_T PagedPoolLimit;
4351     SIZE_T NonPagedPoolLimit;
4352     SIZE_T MinimumWorkingSetSize;
4353     SIZE_T MaximumWorkingSetSize;
4354     SIZE_T PagefileLimit;
4355     LARGE_INTEGER TimeLimit;
4356     SIZE_T Reserved1;
4357     SIZE_T Reserved2;
4358     SIZE_T Reserved3;
4359     SIZE_T Reserved4;
4360     DWORD Flags;
4361     DWORD Reserved5;
4362 } QUOTA_LIMITS_EX, *PQUOTA_LIMITS_EX;
4363
4364 #define SECTION_QUERY              0x0001
4365 #define SECTION_MAP_WRITE          0x0002
4366 #define SECTION_MAP_READ           0x0004
4367 #define SECTION_MAP_EXECUTE        0x0008
4368 #define SECTION_EXTEND_SIZE        0x0010
4369 #define SECTION_MAP_EXECUTE_EXPLICIT 0x0020
4370 #define SECTION_ALL_ACCESS         (STANDARD_RIGHTS_REQUIRED|0x01f)
4371
4372 #define FILE_READ_DATA            0x0001    /* file & pipe */
4373 #define FILE_LIST_DIRECTORY       0x0001    /* directory */
4374 #define FILE_WRITE_DATA           0x0002    /* file & pipe */
4375 #define FILE_ADD_FILE             0x0002    /* directory */
4376 #define FILE_APPEND_DATA          0x0004    /* file */
4377 #define FILE_ADD_SUBDIRECTORY     0x0004    /* directory */
4378 #define FILE_CREATE_PIPE_INSTANCE 0x0004    /* named pipe */
4379 #define FILE_READ_EA              0x0008    /* file & directory */
4380 #define FILE_READ_PROPERTIES      FILE_READ_EA
4381 #define FILE_WRITE_EA             0x0010    /* file & directory */
4382 #define FILE_WRITE_PROPERTIES     FILE_WRITE_EA
4383 #define FILE_EXECUTE              0x0020    /* file */
4384 #define FILE_TRAVERSE             0x0020    /* directory */
4385 #define FILE_DELETE_CHILD         0x0040    /* directory */
4386 #define FILE_READ_ATTRIBUTES      0x0080    /* all */
4387 #define FILE_WRITE_ATTRIBUTES     0x0100    /* all */
4388 #define FILE_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1ff)
4389
4390 #define FILE_GENERIC_READ         (STANDARD_RIGHTS_READ | FILE_READ_DATA | \
4391                                    FILE_READ_ATTRIBUTES | FILE_READ_EA | \
4392                                    SYNCHRONIZE)
4393 #define FILE_GENERIC_WRITE        (STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA | \
4394                                    FILE_WRITE_ATTRIBUTES | FILE_WRITE_EA | \
4395                                    FILE_APPEND_DATA | SYNCHRONIZE)
4396 #define FILE_GENERIC_EXECUTE      (STANDARD_RIGHTS_EXECUTE | FILE_EXECUTE | \
4397                                    FILE_READ_ATTRIBUTES | SYNCHRONIZE)
4398
4399 #define DUPLICATE_CLOSE_SOURCE     0x00000001
4400 #define DUPLICATE_SAME_ACCESS      0x00000002
4401
4402 /* File attribute flags */
4403 #define FILE_SHARE_READ                    0x00000001
4404 #define FILE_SHARE_WRITE                   0x00000002
4405 #define FILE_SHARE_DELETE                  0x00000004
4406
4407 #define FILE_ATTRIBUTE_READONLY            0x00000001
4408 #define FILE_ATTRIBUTE_HIDDEN              0x00000002
4409 #define FILE_ATTRIBUTE_SYSTEM              0x00000004
4410 #define FILE_ATTRIBUTE_DIRECTORY           0x00000010
4411 #define FILE_ATTRIBUTE_ARCHIVE             0x00000020
4412 #define FILE_ATTRIBUTE_DEVICE              0x00000040
4413 #define FILE_ATTRIBUTE_NORMAL              0x00000080
4414 #define FILE_ATTRIBUTE_TEMPORARY           0x00000100
4415 #define FILE_ATTRIBUTE_SPARSE_FILE         0x00000200
4416 #define FILE_ATTRIBUTE_REPARSE_POINT       0x00000400
4417 #define FILE_ATTRIBUTE_COMPRESSED          0x00000800
4418 #define FILE_ATTRIBUTE_OFFLINE             0x00001000
4419 #define FILE_ATTRIBUTE_NOT_CONTENT_INDEXED 0x00002000
4420 #define FILE_ATTRIBUTE_ENCRYPTED           0x00004000
4421
4422 /* File notification flags */
4423 #define FILE_NOTIFY_CHANGE_FILE_NAME    0x00000001
4424 #define FILE_NOTIFY_CHANGE_DIR_NAME     0x00000002
4425 #define FILE_NOTIFY_CHANGE_ATTRIBUTES   0x00000004
4426 #define FILE_NOTIFY_CHANGE_SIZE         0x00000008
4427 #define FILE_NOTIFY_CHANGE_LAST_WRITE   0x00000010
4428 #define FILE_NOTIFY_CHANGE_LAST_ACCESS  0x00000020
4429 #define FILE_NOTIFY_CHANGE_CREATION     0x00000040
4430 #define FILE_NOTIFY_CHANGE_EA           0x00000080
4431 #define FILE_NOTIFY_CHANGE_SECURITY     0x00000100
4432 #define FILE_NOTIFY_CHANGE_STREAM_NAME  0x00000200
4433 #define FILE_NOTIFY_CHANGE_STREAM_SIZE  0x00000400
4434 #define FILE_NOTIFY_CHANGE_STREAM_WRITE 0x00000800
4435
4436 #define FILE_ACTION_ADDED               0x00000001
4437 #define FILE_ACTION_REMOVED             0x00000002
4438 #define FILE_ACTION_MODIFIED            0x00000003
4439 #define FILE_ACTION_RENAMED_OLD_NAME    0x00000004
4440 #define FILE_ACTION_RENAMED_NEW_NAME    0x00000005
4441 #define FILE_ACTION_ADDED_STREAM        0x00000006
4442 #define FILE_ACTION_REMOVED_STREAM      0x00000007
4443 #define FILE_ACTION_MODIFIED_STREAM     0x00000008
4444
4445 #define FILE_CASE_SENSITIVE_SEARCH      0x00000001
4446 #define FILE_CASE_PRESERVED_NAMES       0x00000002
4447 #define FILE_UNICODE_ON_DISK            0x00000004
4448 #define FILE_PERSISTENT_ACLS            0x00000008
4449 #define FILE_FILE_COMPRESSION           0x00000010
4450 #define FILE_VOLUME_QUOTAS              0x00000020
4451 #define FILE_SUPPORTS_SPARSE_FILES      0x00000040
4452 #define FILE_SUPPORTS_REPARSE_POINTS    0x00000080
4453 #define FILE_VOLUME_IS_COMPRESSED       0x00008000
4454 #define FILE_SUPPORTS_OBJECT_IDS        0x00010000
4455 #define FILE_SUPPORTS_ENCRYPTION        0x00020000
4456 #define FILE_NAMED_STREAMS              0x00040000
4457 #define FILE_READ_ONLY_VOLUME           0x00080000
4458
4459 /* File alignments (NT) */
4460 #define FILE_BYTE_ALIGNMENT             0x00000000
4461 #define FILE_WORD_ALIGNMENT             0x00000001
4462 #define FILE_LONG_ALIGNMENT             0x00000003
4463 #define FILE_QUAD_ALIGNMENT             0x00000007
4464 #define FILE_OCTA_ALIGNMENT             0x0000000f
4465 #define FILE_32_BYTE_ALIGNMENT          0x0000001f
4466 #define FILE_64_BYTE_ALIGNMENT          0x0000003f
4467 #define FILE_128_BYTE_ALIGNMENT         0x0000007f
4468 #define FILE_256_BYTE_ALIGNMENT         0x000000ff
4469 #define FILE_512_BYTE_ALIGNMENT         0x000001ff
4470
4471 #define MAILSLOT_NO_MESSAGE             ((DWORD)-1)
4472 #define MAILSLOT_WAIT_FOREVER           ((DWORD)-1)
4473
4474 #define REG_NONE                0       /* no type */
4475 #define REG_SZ                  1       /* string type (ASCII) */
4476 #define REG_EXPAND_SZ           2       /* string, includes %ENVVAR% (expanded by caller) (ASCII) */
4477 #define REG_BINARY              3       /* binary format, callerspecific */
4478 /* YES, REG_DWORD == REG_DWORD_LITTLE_ENDIAN */
4479 #define REG_DWORD               4       /* DWORD in little endian format */
4480 #define REG_DWORD_LITTLE_ENDIAN 4       /* DWORD in little endian format */
4481 #define REG_DWORD_BIG_ENDIAN    5       /* DWORD in big endian format  */
4482 #define REG_LINK                6       /* symbolic link (UNICODE) */
4483 #define REG_MULTI_SZ            7       /* multiple strings, delimited by \0, terminated by \0\0 (ASCII) */
4484 #define REG_RESOURCE_LIST       8       /* resource list? huh? */
4485 #define REG_FULL_RESOURCE_DESCRIPTOR    9       /* full resource descriptor? huh? */
4486 #define REG_RESOURCE_REQUIREMENTS_LIST  10
4487 #define REG_QWORD               11      /* QWORD in little endian format */
4488 #define REG_QWORD_LITTLE_ENDIAN 11      /* QWORD in little endian format */
4489
4490 /* ----------------------------- begin power management --------------------- */
4491
4492 typedef enum _LATENCY_TIME {
4493         LT_DONT_CARE,
4494         LT_LOWEST_LATENCY
4495 } LATENCY_TIME, *PLATENCY_TIME;
4496
4497 #define DISCHARGE_POLICY_CRITICAL       0
4498 #define DISCHARGE_POLICY_LOW            1
4499 #define NUM_DISCHARGE_POLICIES          4
4500
4501 #define PO_THROTTLE_NONE                0
4502 #define PO_THROTTLE_CONSTANT            1
4503 #define PO_THROTTLE_DEGRADE             2
4504 #define PO_THROTTLE_ADAPTIVE            3
4505
4506 typedef enum _POWER_ACTION {
4507         PowerActionNone = 0,
4508         PowerActionReserved,
4509         PowerActionSleep,
4510         PowerActionHibernate,
4511         PowerActionShutdown,
4512         PowerActionShutdownReset,
4513         PowerActionShutdownOff,
4514         PowerActionWarmEject
4515 } POWER_ACTION,
4516 *PPOWER_ACTION;
4517
4518 typedef enum _SYSTEM_POWER_STATE {
4519         PowerSystemUnspecified = 0,
4520         PowerSystemWorking = 1,
4521         PowerSystemSleeping1 = 2,
4522         PowerSystemSleeping2 = 3,
4523         PowerSystemSleeping3 = 4,
4524         PowerSystemHibernate = 5,
4525         PowerSystemShutdown = 6,
4526         PowerSystemMaximum = 7
4527 } SYSTEM_POWER_STATE,
4528 *PSYSTEM_POWER_STATE;
4529
4530 typedef enum _DEVICE_POWER_STATE {
4531     PowerDeviceUnspecified,
4532     PowerDeviceD0,
4533     PowerDeviceD1,
4534     PowerDeviceD2,
4535     PowerDeviceD3,
4536     PowerDeviceMaximum
4537 } DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;
4538
4539 typedef enum _POWER_INFORMATION_LEVEL {
4540         SystemPowerPolicyAc,
4541         SystemPowerPolicyDc,
4542         VerifySystemPolicyAc,
4543         VerifySystemPolicyDc,
4544         SystemPowerCapabilities,
4545         SystemBatteryState,
4546         SystemPowerStateHandler,
4547         ProcessorStateHandler,
4548         SystemPowerPolicyCurrent,
4549         AdministratorPowerPolicy,
4550         SystemReserveHiberFile,
4551         ProcessorInformation,
4552         SystemPowerInformation,
4553         ProcessorStateHandler2,
4554         LastWakeTime,
4555         LastSleepTime,
4556         SystemExecutionState,
4557         SystemPowerStateNotifyHandler,
4558         ProcessorPowerPolicyAc,
4559         ProcessorPowerPolicyDc,
4560         VerifyProcessorPowerPolicyAc,
4561         VerifyProcessorPowerPolicyDc,
4562         ProcessorPowerPolicyCurrent
4563 } POWER_INFORMATION_LEVEL;
4564
4565 typedef struct _ADMINISTRATOR_POWER_POLICY {
4566         SYSTEM_POWER_STATE MinSleep;
4567         SYSTEM_POWER_STATE MaxSleep;
4568         ULONG MinVideoTimeout;
4569         ULONG MaxVideoTimeout;
4570         ULONG MinSpindownTimeout;
4571         ULONG MaxSpindownTimeout;
4572 } ADMINISTRATOR_POWER_POLICY, *PADMINISTRATOR_POWER_POLICY;
4573
4574 typedef struct {
4575         ULONG Granularity;
4576         ULONG Capacity;
4577 } BATTERY_REPORTING_SCALE,
4578 *PBATTERY_REPORTING_SCALE;
4579
4580 typedef struct {
4581         POWER_ACTION Action;
4582         ULONG Flags;
4583         ULONG EventCode;
4584 } POWER_ACTION_POLICY,
4585 *PPOWER_ACTION_POLICY;
4586
4587 typedef struct _PROCESSOR_POWER_INFORMATION {
4588         ULONG Number;
4589         ULONG MaxMhz;
4590         ULONG CurrentMhz;
4591         ULONG MhzLimit;
4592         ULONG MaxIdleState;
4593         ULONG CurrentIdleState;
4594 } PROCESSOR_POWER_INFORMATION,
4595 *PPROCESSOR_POWER_INFORMATION;
4596
4597 typedef struct _PROCESSOR_POWER_POLICY_INFO {
4598         ULONG TimeCheck;
4599         ULONG DemoteLimit;
4600         ULONG PromoteLimit;
4601         UCHAR DemotePercent;
4602         UCHAR PromotePercent;
4603         UCHAR Spare[2];
4604         ULONG AllowDemotion:1;
4605         ULONG AllowPromotion:1;
4606         ULONG Reserved:30;
4607 } PROCESSOR_POWER_POLICY_INFO,
4608 *PPROCESSOR_POWER_POLICY_INFO;
4609
4610 typedef struct _PROCESSOR_POWER_POLICY {
4611         DWORD Revision;
4612         BYTE DynamicThrottle;
4613         BYTE Spare[3];
4614         DWORD DisableCStates:1;
4615         DWORD Reserved:31;
4616         DWORD PolicyCount;
4617         PROCESSOR_POWER_POLICY_INFO Policy[3];
4618 } PROCESSOR_POWER_POLICY,
4619 *PPROCESSOR_POWER_POLICY;
4620
4621 typedef struct {
4622         BOOLEAN AcOnLine;
4623         BOOLEAN BatteryPresent;
4624         BOOLEAN Charging;
4625         BOOLEAN Discharging;
4626         BOOLEAN Spare1[4];
4627         ULONG MaxCapacity;
4628         ULONG RemainingCapacity;
4629         ULONG Rate;
4630         ULONG EstimatedTime;
4631         ULONG DefaultAlert1;
4632         ULONG DefaultAlert2;
4633 } SYSTEM_BATTERY_STATE,
4634 *PSYSTEM_BATTERY_STATE;
4635
4636 typedef struct {
4637         BOOLEAN PowerButtonPresent;
4638         BOOLEAN SleepButtonPresent;
4639         BOOLEAN LidPresent;
4640         BOOLEAN SystemS1;
4641         BOOLEAN SystemS2;
4642         BOOLEAN SystemS3;
4643         BOOLEAN SystemS4;
4644         BOOLEAN SystemS5;
4645         BOOLEAN HiberFilePresent;
4646         BOOLEAN FullWake;
4647         BOOLEAN VideoDimPresent;
4648         BOOLEAN ApmPresent;
4649         BOOLEAN UpsPresent;
4650         BOOLEAN ThermalControl;
4651         BOOLEAN ProcessorThrottle;
4652         UCHAR ProcessorMinThrottle;
4653         UCHAR ProcessorMaxThrottle;
4654         UCHAR spare2[4];
4655         BOOLEAN DiskSpinDown;
4656         UCHAR spare3[8];
4657         BOOLEAN SystemBatteriesPresent;
4658         BOOLEAN BatteriesAreShortTerm;
4659         BATTERY_REPORTING_SCALE BatteryScale[3];
4660         SYSTEM_POWER_STATE AcOnLineWake;
4661         SYSTEM_POWER_STATE SoftLidWake;
4662         SYSTEM_POWER_STATE RtcWake;
4663         SYSTEM_POWER_STATE MinDeviceWakeState;
4664         SYSTEM_POWER_STATE DefaultLowLatencyWake;
4665 } SYSTEM_POWER_CAPABILITIES,
4666 *PSYSTEM_POWER_CAPABILITIES;
4667
4668 typedef struct _SYSTEM_POWER_INFORMATION {
4669         ULONG MaxIdlenessAllowed;
4670         ULONG Idleness;
4671         ULONG TimeRemaining;
4672         UCHAR CoolingMode;
4673 } SYSTEM_POWER_INFORMATION,
4674 *PSYSTEM_POWER_INFORMATION;
4675
4676 typedef struct _SYSTEM_POWER_LEVEL {
4677         BOOLEAN Enable;
4678         UCHAR Spare[3];
4679         ULONG BatteryLevel;
4680         POWER_ACTION_POLICY PowerPolicy;
4681         SYSTEM_POWER_STATE MinSystemState;
4682 } SYSTEM_POWER_LEVEL,
4683 *PSYSTEM_POWER_LEVEL;
4684
4685 typedef struct _SYSTEM_POWER_POLICY {
4686         ULONG Revision;
4687         POWER_ACTION_POLICY PowerButton;
4688         POWER_ACTION_POLICY SleepButton;
4689         POWER_ACTION_POLICY LidClose;
4690         SYSTEM_POWER_STATE LidOpenWake;
4691         ULONG Reserved;
4692         POWER_ACTION_POLICY Idle;
4693         ULONG IdleTimeout;
4694         UCHAR IdleSensitivity;
4695         UCHAR DynamicThrottle;
4696         UCHAR Spare2[2];
4697         SYSTEM_POWER_STATE MinSleep;
4698         SYSTEM_POWER_STATE MaxSleep;
4699         SYSTEM_POWER_STATE ReducedLatencySleep;
4700         ULONG WinLogonFlags;
4701         ULONG Spare3;
4702         ULONG DozeS4Timeout;
4703         ULONG BroadcastCapacityResolution;
4704         SYSTEM_POWER_LEVEL DischargePolicy[NUM_DISCHARGE_POLICIES];
4705         ULONG VideoTimeout;
4706         BOOLEAN VideoDimDisplay;
4707         ULONG VideoReserved[3];
4708         ULONG SpindownTimeout;
4709         BOOLEAN OptimizeForPower;
4710         UCHAR FanThrottleTolerance;
4711         UCHAR ForcedThrottle;
4712         UCHAR MinThrottle;
4713         POWER_ACTION_POLICY OverThrottled;
4714 } SYSTEM_POWER_POLICY,
4715 *PSYSTEM_POWER_POLICY;
4716
4717 typedef union _FILE_SEGMENT_ELEMENT {
4718         PVOID64 Buffer;
4719         ULONGLONG Alignment;
4720 } FILE_SEGMENT_ELEMENT, *PFILE_SEGMENT_ELEMENT;
4721
4722 typedef struct _FILE_NOTIFY_INFORMATION {
4723         DWORD NextEntryOffset;
4724         DWORD Action;
4725         DWORD FileNameLength;
4726         WCHAR FileName[1];
4727 } FILE_NOTIFY_INFORMATION, *PFILE_NOTIFY_INFORMATION;
4728
4729 /* ----------------------------- begin tape storage --------------------- */
4730
4731 #define TAPE_FIXED_PARTITIONS     0
4732 #define TAPE_SELECT_PARTITIONS    1
4733 #define TAPE_INITIATOR_PARTITIONS 2
4734 #define TAPE_ERASE_SHORT 0
4735 #define TAPE_ERASE_LONG  1
4736 #define TAPE_LOAD    0
4737 #define TAPE_UNLOAD  1
4738 #define TAPE_TENSION 2
4739 #define TAPE_LOCK    3
4740 #define TAPE_UNLOCK  4
4741 #define TAPE_FORMAT  5
4742 #define TAPE_SETMARKS  0
4743 #define TAPE_FILEMARKS 1
4744 #define TAPE_SHORT_FILEMARKS 2
4745 #define TAPE_LONG_FILEMARKS  3
4746 #define TAPE_REWIND                0
4747 #define TAPE_ABSOLUTE_BLOCK        1
4748 #define TAPE_LOGICAL_BLOCK         2
4749 #define TAPE_PSEUDO_LOGICAL_BLOCK  3
4750 #define TAPE_SPACE_END_OF_DATA     4
4751 #define TAPE_SPACE_RELATIVE_BLOCKS 5
4752 #define TAPE_SPACE_FILEMARKS       6
4753 #define TAPE_SPACE_SEQUENTIAL_FMKS 7
4754 #define TAPE_SPACE_SETMARKS        8
4755 #define TAPE_SPACE_SEQUENTIAL_SMKS 9
4756
4757 typedef struct _TAPE_CREATE_PARTITION {
4758     DWORD Method;
4759     DWORD Count;
4760     DWORD Size;
4761 } TAPE_CREATE_PARTITION, *PTAPE_CREATE_PARTITION;
4762
4763 typedef struct _TAPE_ERASE {
4764     DWORD Type;
4765     BOOLEAN Immediate;
4766 } TAPE_ERASE, *PTAPE_ERASE;
4767
4768 typedef struct _TAPE_PREPARE {
4769     DWORD Operation;
4770     BOOLEAN Immediate;
4771 } TAPE_PREPARE, *PTAPE_PREPARE;
4772
4773 typedef struct _TAPE_SET_DRIVE_PARAMETERS {
4774     BOOLEAN ECC;
4775     BOOLEAN Compression;
4776     BOOLEAN DataPadding;
4777     BOOLEAN ReportSetmarks;
4778     ULONG EOTWarningZoneSize;
4779 } TAPE_SET_DRIVE_PARAMETERS, *PTAPE_SET_DRIVE_PARAMETERS;
4780
4781 typedef struct _TAPE_SET_MEDIA_PARAMETERS {
4782     ULONG BlockSize;
4783 } TAPE_SET_MEDIA_PARAMETERS, *PTAPE_SET_MEDIA_PARAMETERS;
4784
4785 typedef struct _TAPE_WRITE_MARKS {
4786     DWORD Type;
4787     DWORD Count;
4788     BOOLEAN Immediate;
4789 } TAPE_WRITE_MARKS, *PTAPE_WRITE_MARKS;
4790
4791 typedef struct _TAPE_GET_POSITION {
4792     ULONG Type;
4793     ULONG Partition;
4794     ULONG OffsetLow;
4795     ULONG OffsetHigh;
4796 } TAPE_GET_POSITION, *PTAPE_GET_POSITION;
4797
4798 typedef struct _TAPE_SET_POSITION {
4799     ULONG Method;
4800     ULONG Partition;
4801     LARGE_INTEGER Offset;
4802     BOOLEAN Immediate;
4803 } TAPE_SET_POSITION, *PTAPE_SET_POSITION;
4804
4805 typedef struct _TAPE_GET_DRIVE_PARAMETERS {
4806     BOOLEAN ECC;
4807     BOOLEAN Compression;
4808     BOOLEAN DataPadding;
4809     BOOLEAN ReportSetmarks;
4810     DWORD DefaultBlockSize;
4811     DWORD MaximumBlockSize;
4812     DWORD MinimumBlockSize;
4813     DWORD MaximumPartitionCount;
4814     DWORD FeaturesLow;
4815     DWORD FeaturesHigh;
4816     DWORD EOTWarningZoneSize;
4817 } TAPE_GET_DRIVE_PARAMETERS, *PTAPE_GET_DRIVE_PARAMETERS;
4818
4819 typedef struct _TAPE_GET_MEDIA_PARAMETERS {
4820     LARGE_INTEGER Capacity;
4821     LARGE_INTEGER Remaining;
4822     DWORD BlockSize;
4823     DWORD PartitionCount;
4824     BOOLEAN WriteProtected;
4825 } TAPE_GET_MEDIA_PARAMETERS, *PTAPE_GET_MEDIA_PARAMETERS;
4826
4827 /* ----------------------------- begin registry ----------------------------- */
4828
4829 /* Registry security values */
4830 #define OWNER_SECURITY_INFORMATION      0x00000001
4831 #define GROUP_SECURITY_INFORMATION      0x00000002
4832 #define DACL_SECURITY_INFORMATION       0x00000004
4833 #define SACL_SECURITY_INFORMATION       0x00000008
4834
4835 #define REG_OPTION_RESERVED             0x00000000
4836 #define REG_OPTION_NON_VOLATILE         0x00000000
4837 #define REG_OPTION_VOLATILE             0x00000001
4838 #define REG_OPTION_CREATE_LINK          0x00000002
4839 #define REG_OPTION_BACKUP_RESTORE       0x00000004 /* FIXME */
4840 #define REG_OPTION_OPEN_LINK            0x00000008
4841 #define REG_LEGAL_OPTION               (REG_OPTION_RESERVED|  \
4842                                         REG_OPTION_NON_VOLATILE|  \
4843                                         REG_OPTION_VOLATILE|  \
4844                                         REG_OPTION_CREATE_LINK|  \
4845                                         REG_OPTION_BACKUP_RESTORE|  \
4846                                         REG_OPTION_OPEN_LINK)
4847
4848
4849 #define REG_CREATED_NEW_KEY     0x00000001
4850 #define REG_OPENED_EXISTING_KEY 0x00000002
4851
4852 /* For RegNotifyChangeKeyValue */
4853 #define REG_NOTIFY_CHANGE_NAME       0x01
4854 #define REG_NOTIFY_CHANGE_ATTRIBUTES 0x02
4855 #define REG_NOTIFY_CHANGE_LAST_SET   0x04
4856 #define REG_NOTIFY_CHANGE_SECURITY   0x08
4857
4858 #define KEY_QUERY_VALUE         0x00000001
4859 #define KEY_SET_VALUE           0x00000002
4860 #define KEY_CREATE_SUB_KEY      0x00000004
4861 #define KEY_ENUMERATE_SUB_KEYS  0x00000008
4862 #define KEY_NOTIFY              0x00000010
4863 #define KEY_CREATE_LINK         0x00000020
4864 #define KEY_WOW64_64KEY         0x00000100
4865 #define KEY_WOW64_32KEY         0x00000200
4866 #define KEY_WOW64_RES           0x00000300
4867
4868 /* for RegKeyRestore flags */
4869 #define REG_WHOLE_HIVE_VOLATILE 0x00000001
4870 #define REG_REFRESH_HIVE        0x00000002
4871 #define REG_NO_LAZY_FLUSH       0x00000004
4872 #define REG_FORCE_RESTORE       0x00000008
4873
4874 #define KEY_READ              ((STANDARD_RIGHTS_READ|  \
4875                                 KEY_QUERY_VALUE|  \
4876                                 KEY_ENUMERATE_SUB_KEYS|  \
4877                                 KEY_NOTIFY)  \
4878                                 & (~SYNCHRONIZE)  \
4879                               )
4880 #define KEY_WRITE             ((STANDARD_RIGHTS_WRITE|  \
4881                                 KEY_SET_VALUE|  \
4882                                 KEY_CREATE_SUB_KEY)  \
4883                                 & (~SYNCHRONIZE)  \
4884                               )
4885 #define KEY_EXECUTE           ((KEY_READ) & (~SYNCHRONIZE))
4886 #define KEY_ALL_ACCESS        ((STANDARD_RIGHTS_ALL|  \
4887                                 KEY_QUERY_VALUE|  \
4888                                 KEY_SET_VALUE|  \
4889                                 KEY_CREATE_SUB_KEY|  \
4890                                 KEY_ENUMERATE_SUB_KEYS|  \
4891                                 KEY_NOTIFY|  \
4892                                 KEY_CREATE_LINK)  \
4893                                 & (~SYNCHRONIZE)  \
4894                               )
4895 /* ------------------------------ end registry ------------------------------ */
4896
4897
4898 #define EVENTLOG_SUCCESS                0x0000
4899 #define EVENTLOG_ERROR_TYPE             0x0001
4900 #define EVENTLOG_WARNING_TYPE           0x0002
4901 #define EVENTLOG_INFORMATION_TYPE       0x0004
4902 #define EVENTLOG_AUDIT_SUCCESS          0x0008
4903 #define EVENTLOG_AUDIT_FAILURE          0x0010
4904
4905 #define EVENTLOG_SEQUENTIAL_READ        0x0001
4906 #define EVENTLOG_SEEK_READ              0x0002
4907 #define EVENTLOG_FORWARDS_READ          0x0004
4908 #define EVENTLOG_BACKWARDS_READ         0x0008
4909
4910 typedef struct _EVENTLOGRECORD {
4911     DWORD  Length;
4912     DWORD  Reserved;
4913     DWORD  RecordNumber;
4914     DWORD  TimeGenerated;
4915     DWORD  TimeWritten;
4916     DWORD  EventID;
4917     WORD   EventType;
4918     WORD   NumStrings;
4919     WORD   EventCategory;
4920     WORD   ReservedFlags;
4921     DWORD  ClosingRecordNumber;
4922     DWORD  StringOffset;
4923     DWORD  UserSidLength;
4924     DWORD  UserSidOffset;
4925     DWORD  DataLength;
4926     DWORD  DataOffset;
4927 } EVENTLOGRECORD, *PEVENTLOGRECORD;
4928
4929 #define SERVICE_BOOT_START   0x00000000
4930 #define SERVICE_SYSTEM_START 0x00000001
4931 #define SERVICE_AUTO_START   0x00000002
4932 #define SERVICE_DEMAND_START 0x00000003
4933 #define SERVICE_DISABLED     0x00000004
4934
4935 #define SERVICE_ERROR_IGNORE   0x00000000
4936 #define SERVICE_ERROR_NORMAL   0x00000001
4937 #define SERVICE_ERROR_SEVERE   0x00000002
4938 #define SERVICE_ERROR_CRITICAL 0x00000003
4939
4940 /* Service types */
4941 #define SERVICE_KERNEL_DRIVER      0x00000001
4942 #define SERVICE_FILE_SYSTEM_DRIVER 0x00000002
4943 #define SERVICE_ADAPTER            0x00000004
4944 #define SERVICE_RECOGNIZER_DRIVER  0x00000008
4945
4946 #define SERVICE_DRIVER ( SERVICE_KERNEL_DRIVER | SERVICE_FILE_SYSTEM_DRIVER | \
4947                          SERVICE_RECOGNIZER_DRIVER )
4948
4949 #define SERVICE_WIN32_OWN_PROCESS   0x00000010
4950 #define SERVICE_WIN32_SHARE_PROCESS 0x00000020
4951 #define SERVICE_WIN32  (SERVICE_WIN32_OWN_PROCESS | SERVICE_WIN32_SHARE_PROCESS)
4952
4953 #define SERVICE_INTERACTIVE_PROCESS 0x00000100
4954
4955 #define SERVICE_TYPE_ALL ( SERVICE_WIN32 | SERVICE_ADAPTER | \
4956                            SERVICE_DRIVER | SERVICE_INTERACTIVE_PROCESS )
4957
4958
4959 typedef enum _CM_SERVICE_NODE_TYPE
4960 {
4961   DriverType               = SERVICE_KERNEL_DRIVER,
4962   FileSystemType           = SERVICE_FILE_SYSTEM_DRIVER,
4963   Win32ServiceOwnProcess   = SERVICE_WIN32_OWN_PROCESS,
4964   Win32ServiceShareProcess = SERVICE_WIN32_SHARE_PROCESS,
4965   AdapterType              = SERVICE_ADAPTER,
4966   RecognizerType           = SERVICE_RECOGNIZER_DRIVER
4967 } SERVICE_NODE_TYPE;
4968
4969 typedef enum _CM_SERVICE_LOAD_TYPE
4970 {
4971   BootLoad    = SERVICE_BOOT_START,
4972   SystemLoad  = SERVICE_SYSTEM_START,
4973   AutoLoad    = SERVICE_AUTO_START,
4974   DemandLoad  = SERVICE_DEMAND_START,
4975   DisableLoad = SERVICE_DISABLED
4976 } SERVICE_LOAD_TYPE;
4977
4978 typedef enum _CM_ERROR_CONTROL_TYPE
4979 {
4980   IgnoreError   = SERVICE_ERROR_IGNORE,
4981   NormalError   = SERVICE_ERROR_NORMAL,
4982   SevereError   = SERVICE_ERROR_SEVERE,
4983   CriticalError = SERVICE_ERROR_CRITICAL
4984 } SERVICE_ERROR_TYPE;
4985
4986
4987
4988 #define RtlEqualMemory(Destination, Source, Length) (!memcmp((Destination),(Source),(Length)))
4989 #define RtlMoveMemory(Destination, Source, Length) memmove((Destination),(Source),(Length))
4990 #define RtlCopyMemory(Destination, Source, Length) memcpy((Destination),(Source),(Length))
4991 #define RtlFillMemory(Destination, Length, Fill) memset((Destination),(Fill),(Length))
4992 #define RtlZeroMemory(Destination, Length) memset((Destination),0,(Length))
4993
4994 #include <guiddef.h>
4995
4996 typedef struct _OBJECT_TYPE_LIST {
4997     WORD   Level;
4998     WORD   Sbz;
4999     GUID *ObjectType;
5000 } OBJECT_TYPE_LIST, *POBJECT_TYPE_LIST;
5001
5002 typedef struct _RTL_CRITICAL_SECTION_DEBUG
5003 {
5004   WORD   Type;
5005   WORD   CreatorBackTraceIndex;
5006   struct _RTL_CRITICAL_SECTION *CriticalSection;
5007   LIST_ENTRY ProcessLocksList;
5008   DWORD EntryCount;
5009   DWORD ContentionCount;
5010 #ifdef __WINESRC__  /* in Wine we store the name here */
5011   DWORD_PTR Spare[8/sizeof(DWORD_PTR)];
5012 #else
5013   DWORD Spare[ 2 ];
5014 #endif
5015 } RTL_CRITICAL_SECTION_DEBUG, *PRTL_CRITICAL_SECTION_DEBUG, RTL_RESOURCE_DEBUG, *PRTL_RESOURCE_DEBUG;
5016
5017 typedef struct _RTL_CRITICAL_SECTION {
5018     PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
5019     LONG LockCount;
5020     LONG RecursionCount;
5021     HANDLE OwningThread;
5022     HANDLE LockSemaphore;
5023     ULONG_PTR SpinCount;
5024 }  RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;
5025
5026 #define RTL_CRITICAL_SECTION_FLAG_NO_DEBUG_INFO 0x1000000
5027 #define RTL_CRITICAL_SECTION_FLAG_DYNAMIC_SPIN  0x2000000
5028 #define RTL_CRITICAL_SECTION_FLAG_STATIC_INIT   0x4000000
5029 #define RTL_CRITICAL_SECTION_ALL_FLAG_BITS      0xFF000000
5030 #define RTL_CRITICAL_SECTION_FLAG_RESERVED      (RTL_CRITICAL_SECTION_ALL_FLAG_BITS & ~0x7000000)
5031
5032 typedef struct _RTL_SRWLOCK {
5033     PVOID Ptr;
5034 } RTL_SRWLOCK, *PRTL_SRWLOCK;
5035
5036 #define RTL_SRWLOCK_INIT {0}
5037
5038 typedef VOID (NTAPI * WAITORTIMERCALLBACKFUNC) (PVOID, BOOLEAN );
5039 typedef VOID (NTAPI * PFLS_CALLBACK_FUNCTION) ( PVOID );
5040
5041 #include <pshpack8.h>
5042 typedef struct _IO_COUNTERS {
5043     ULONGLONG DECLSPEC_ALIGN(8) ReadOperationCount;
5044     ULONGLONG DECLSPEC_ALIGN(8) WriteOperationCount;
5045     ULONGLONG DECLSPEC_ALIGN(8) OtherOperationCount;
5046     ULONGLONG DECLSPEC_ALIGN(8) ReadTransferCount;
5047     ULONGLONG DECLSPEC_ALIGN(8) WriteTransferCount;
5048     ULONGLONG DECLSPEC_ALIGN(8) OtherTransferCount;
5049 } IO_COUNTERS, *PIO_COUNTERS;
5050 #include <poppack.h>
5051
5052 typedef struct {
5053         DWORD dwOSVersionInfoSize;
5054         DWORD dwMajorVersion;
5055         DWORD dwMinorVersion;
5056         DWORD dwBuildNumber;
5057         DWORD dwPlatformId;
5058         CHAR szCSDVersion[128];
5059 } OSVERSIONINFOA, *POSVERSIONINFOA, *LPOSVERSIONINFOA;
5060
5061 typedef struct {
5062         DWORD dwOSVersionInfoSize;
5063         DWORD dwMajorVersion;
5064         DWORD dwMinorVersion;
5065         DWORD dwBuildNumber;
5066         DWORD dwPlatformId;
5067         WCHAR szCSDVersion[128];
5068 } OSVERSIONINFOW, *POSVERSIONINFOW, *LPOSVERSIONINFOW, RTL_OSVERSIONINFOW, *PRTL_OSVERSIONINFOW;
5069
5070 DECL_WINELIB_TYPE_AW(OSVERSIONINFO)
5071 DECL_WINELIB_TYPE_AW(POSVERSIONINFO)
5072 DECL_WINELIB_TYPE_AW(LPOSVERSIONINFO)
5073
5074 typedef struct {
5075         DWORD dwOSVersionInfoSize;
5076         DWORD dwMajorVersion;
5077         DWORD dwMinorVersion;
5078         DWORD dwBuildNumber;
5079         DWORD dwPlatformId;
5080         CHAR szCSDVersion[128];
5081         WORD wServicePackMajor;
5082         WORD wServicePackMinor;
5083         WORD wSuiteMask;
5084         BYTE wProductType;
5085         BYTE wReserved;
5086 } OSVERSIONINFOEXA, *POSVERSIONINFOEXA, *LPOSVERSIONINFOEXA;
5087
5088 typedef struct {
5089         DWORD dwOSVersionInfoSize;
5090         DWORD dwMajorVersion;
5091         DWORD dwMinorVersion;
5092         DWORD dwBuildNumber;
5093         DWORD dwPlatformId;
5094         WCHAR szCSDVersion[128];
5095         WORD wServicePackMajor;
5096         WORD wServicePackMinor;
5097         WORD wSuiteMask;
5098         BYTE wProductType;
5099         BYTE wReserved;
5100 } OSVERSIONINFOEXW, *POSVERSIONINFOEXW, *LPOSVERSIONINFOEXW, RTL_OSVERSIONINFOEXW, *PRTL_OSVERSIONINFOEXW;
5101
5102 DECL_WINELIB_TYPE_AW(OSVERSIONINFOEX)
5103 DECL_WINELIB_TYPE_AW(POSVERSIONINFOEX)
5104 DECL_WINELIB_TYPE_AW(LPOSVERSIONINFOEX)
5105
5106 NTSYSAPI ULONGLONG WINAPI VerSetConditionMask(ULONGLONG,DWORD,BYTE);
5107
5108 #define VER_SET_CONDITION(_m_,_t_,_c_) ((_m_)=VerSetConditionMask((_m_),(_t_),(_c_)))
5109
5110 #define VER_PLATFORM_WIN32s                     0
5111 #define VER_PLATFORM_WIN32_WINDOWS              1
5112 #define VER_PLATFORM_WIN32_NT                   2
5113
5114 #define VER_MINORVERSION                        0x00000001
5115 #define VER_MAJORVERSION                        0x00000002
5116 #define VER_BUILDNUMBER                         0x00000004
5117 #define VER_PLATFORMID                          0x00000008
5118 #define VER_SERVICEPACKMINOR                    0x00000010
5119 #define VER_SERVICEPACKMAJOR                    0x00000020
5120 #define VER_SUITENAME                           0x00000040
5121 #define VER_PRODUCT_TYPE                        0x00000080
5122
5123 #define VER_NT_WORKSTATION                      1
5124 #define VER_NT_DOMAIN_CONTROLLER                2
5125 #define VER_NT_SERVER                           3
5126
5127 #define VER_SUITE_SMALLBUSINESS                 0x00000001
5128 #define VER_SUITE_ENTERPRISE                    0x00000002
5129 #define VER_SUITE_BACKOFFICE                    0x00000004
5130 #define VER_SUITE_COMMUNICATIONS                0x00000008
5131 #define VER_SUITE_TERMINAL                      0x00000010
5132 #define VER_SUITE_SMALLBUSINESS_RESTRICTED      0x00000020
5133 #define VER_SUITE_EMBEDDEDNT                    0x00000040
5134 #define VER_SUITE_DATACENTER                    0x00000080
5135 #define VER_SUITE_SINGLEUSERTS                  0x00000100
5136 #define VER_SUITE_PERSONAL                      0x00000200
5137 #define VER_SUITE_BLADE                         0x00000400
5138 #define VER_SUITE_EMBEDDED_RESTRICTED           0x00000800
5139 #define VER_SUITE_SECURITY_APPLIANCE            0x00001000
5140 #define VER_SUITE_STORAGE_SERVER                0x00002000
5141 #define VER_SUITE_COMPUTE_SERVER                0x00004000
5142 #define VER_SUITE_WH_SERVER                     0x00008000
5143
5144 #define VER_EQUAL                               1
5145 #define VER_GREATER                             2
5146 #define VER_GREATER_EQUAL                       3
5147 #define VER_LESS                                4
5148 #define VER_LESS_EQUAL                          5
5149 #define VER_AND                                 6
5150 #define VER_OR                                  7
5151
5152 typedef struct _ACTIVATION_CONTEXT_DETAILED_INFORMATION {
5153     DWORD dwFlags;
5154     DWORD ulFormatVersion;
5155     DWORD ulAssemblyCount;
5156     DWORD ulRootManifestPathType;
5157     DWORD ulRootManifestPathChars;
5158     DWORD ulRootConfigurationPathType;
5159     DWORD ulRootConfigurationPathChars;
5160     DWORD ulAppDirPathType;
5161     DWORD ulAppDirPathChars;
5162     PCWSTR lpRootManifestPath;
5163     PCWSTR lpRootConfigurationPath;
5164     PCWSTR lpAppDirPath;
5165 } ACTIVATION_CONTEXT_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_DETAILED_INFORMATION;
5166
5167 typedef struct _ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION {
5168     DWORD ulFlags;
5169     DWORD ulEncodedAssemblyIdentityLength;
5170     DWORD ulManifestPathType;
5171     DWORD ulManifestPathLength;
5172     LARGE_INTEGER liManifestLastWriteTime;
5173     DWORD ulPolicyPathType;
5174     DWORD ulPolicyPathLength;
5175     LARGE_INTEGER liPolicyLastWriteTime;
5176     DWORD ulMetadataSatelliteRosterIndex;
5177     DWORD ulManifestVersionMajor;
5178     DWORD ulManifestVersionMinor;
5179     DWORD ulPolicyVersionMajor;
5180     DWORD ulPolicyVersionMinor;
5181     DWORD ulAssemblyDirectoryNameLength;
5182     PCWSTR lpAssemblyEncodedAssemblyIdentity;
5183     PCWSTR lpAssemblyManifestPath;
5184     PCWSTR lpAssemblyPolicyPath;
5185     PCWSTR lpAssemblyDirectoryName;
5186     DWORD  ulFileCount;
5187 } ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION;
5188
5189 typedef struct _ACTIVATION_CONTEXT_QUERY_INDEX {
5190     DWORD ulAssemblyIndex;
5191     DWORD ulFileIndexInAssembly;
5192 } ACTIVATION_CONTEXT_QUERY_INDEX, *PACTIVATION_CONTEXT_QUERY_INDEX;
5193
5194 typedef const struct _ACTIVATION_CONTEXT_QUERY_INDEX *PCACTIVATION_CONTEXT_QUERY_INDEX;
5195
5196 typedef struct _ASSEMBLY_FILE_DETAILED_INFORMATION {
5197     DWORD ulFlags;
5198     DWORD ulFilenameLength;
5199     DWORD ulPathLength;
5200     PCWSTR lpFileName;
5201     PCWSTR lpFilePath;
5202 } ASSEMBLY_FILE_DETAILED_INFORMATION, *PASSEMBLY_FILE_DETAILED_INFORMATION;
5203
5204 typedef const ASSEMBLY_FILE_DETAILED_INFORMATION *PCASSEMBLY_FILE_DETAILED_INFORMATION;
5205
5206 typedef enum _ACTIVATION_CONTEXT_INFO_CLASS {
5207     ActivationContextBasicInformation                       = 1,
5208     ActivationContextDetailedInformation                    = 2,
5209     AssemblyDetailedInformationInActivationContext          = 3,
5210     FileInformationInAssemblyOfAssemblyInActivationContext  = 4,
5211     MaxActivationContextInfoClass,
5212
5213     AssemblyDetailedInformationInActivationContxt          = 3,
5214     FileInformationInAssemblyOfAssemblyInActivationContxt  = 4
5215 } ACTIVATION_CONTEXT_INFO_CLASS;
5216
5217 #define ACTIVATION_CONTEXT_PATH_TYPE_NONE         1
5218 #define ACTIVATION_CONTEXT_PATH_TYPE_WIN32_FILE   2
5219 #define ACTIVATION_CONTEXT_PATH_TYPE_URL          3
5220 #define ACTIVATION_CONTEXT_PATH_TYPE_ASSEMBLYREF  4
5221
5222 #define ACTIVATION_CONTEXT_SECTION_ASSEMBLY_INFORMATION          1
5223 #define ACTIVATION_CONTEXT_SECTION_DLL_REDIRECTION               2
5224 #define ACTIVATION_CONTEXT_SECTION_WINDOW_CLASS_REDIRECTION      3
5225 #define ACTIVATION_CONTEXT_SECTION_COM_SERVER_REDIRECTION        4
5226 #define ACTIVATION_CONTEXT_SECTION_COM_INTERFACE_REDIRECTION     5
5227 #define ACTIVATION_CONTEXT_SECTION_COM_TYPE_LIBRARY_REDIRECTION  6
5228 #define ACTIVATION_CONTEXT_SECTION_COM_PROGID_REDIRECTION        7
5229 #define ACTIVATION_CONTEXT_SECTION_GLOBAL_OBJECT_RENAME_TABLE    8
5230 #define ACTIVATION_CONTEXT_SECTION_CLR_SURROGATES                9
5231
5232 typedef enum _JOBOBJECTINFOCLASS
5233 {
5234     JobObjectBasicAccountingInformation = 1,
5235     JobObjectBasicLimitInformation,
5236     JobObjectBasicProcessIdList,
5237     JobObjectBasicUIRestrictions,
5238     JobObjectSecurityLimitInformation,
5239     JobObjectEndOfJobTimeInformation,
5240     JobObjectAssociateCompletionPortInformation,
5241     JobObjectBasicAndIoAccountingInformation,
5242     JobObjectExtendedLimitInformation,
5243     JobObjectJobSetInformation,
5244     MaxJobObjectInfoClass
5245 } JOBOBJECTINFOCLASS;
5246
5247 typedef enum _LOGICAL_PROCESSOR_RELATIONSHIP
5248 {
5249     RelationProcessorCore    = 0,
5250     RelationNumaNode         = 1,
5251     RelationCache            = 2,
5252     RelationProcessorPackage = 3,
5253     RelationGroup            = 4,
5254     RelationAll              = 0xffff
5255 } LOGICAL_PROCESSOR_RELATIONSHIP;
5256
5257 typedef enum _PROCESSOR_CACHE_TYPE
5258 {
5259     CacheUnified,
5260     CacheInstruction,
5261     CacheData,
5262     CacheTrace
5263 } PROCESSOR_CACHE_TYPE;
5264
5265 typedef struct _PROCESSOR_GROUP_INFO
5266 {
5267     BYTE MaximumProcessorCount;
5268     BYTE ActiveProcessorCount;
5269     BYTE Reserved[38];
5270     KAFFINITY ActiveProcessorMask;
5271 } PROCESSOR_GROUP_INFO, *PPROCESSOR_GROUP_INFO;
5272
5273 typedef struct _CACHE_DESCRIPTOR
5274 {
5275     BYTE Level;
5276     BYTE Associativity;
5277     WORD LineSize;
5278     DWORD Size;
5279     PROCESSOR_CACHE_TYPE Type;
5280 } CACHE_DESCRIPTOR, *PCACHE_DESCRIPTOR;
5281
5282 typedef struct _GROUP_AFFINITY
5283 {
5284     KAFFINITY Mask;
5285     WORD Group;
5286     WORD Reserved[3];
5287 } GROUP_AFFINITY, *PGROUP_AFFINITY;
5288
5289 typedef struct _PROCESSOR_RELATIONSHIP
5290 {
5291     BYTE Flags;
5292     BYTE Reserved[21];
5293     WORD GroupCount;
5294     GROUP_AFFINITY GroupMask[ANYSIZE_ARRAY];
5295 } PROCESSOR_RELATIONSHIP, *PPROCESSOR_RELATIONSHIP;
5296
5297
5298 typedef struct _NUMA_NODE_RELATIONSHIP
5299 {
5300     DWORD NodeNumber;
5301     BYTE Reserved[20];
5302     GROUP_AFFINITY GroupMask;
5303 } NUMA_NODE_RELATIONSHIP, *PNUMA_NODE_RELATIONSHIP;
5304
5305 typedef struct _CACHE_RELATIONSHIP
5306 {
5307     BYTE Level;
5308     BYTE Associativity;
5309     WORD LineSize;
5310     PROCESSOR_CACHE_TYPE Type;
5311     BYTE Reserved[20];
5312     GROUP_AFFINITY GroupMask;
5313 } CACHE_RELATIONSHIP, *PCACHE_RELATIONSHIP;
5314
5315 typedef struct _GROUP_RELATIONSHIP
5316 {
5317     WORD MaximumGroupCount;
5318     WORD ActiveGroupCount;
5319     BYTE Reserved[20];
5320     PROCESSOR_GROUP_INFO GroupInfo[ANYSIZE_ARRAY];
5321 } GROUP_RELATIONSHIP, *PGROUP_RELATIONSHIP;
5322
5323 typedef struct _SYSTEM_LOGICAL_PROCESSOR_INFORMATION
5324 {
5325     ULONG_PTR ProcessorMask;
5326     LOGICAL_PROCESSOR_RELATIONSHIP Relationship;
5327     union
5328     {
5329         struct
5330         {
5331             BYTE Flags;
5332         } ProcessorCore;
5333         struct
5334         {
5335             DWORD NodeNumber;
5336         } NumaNode;
5337         CACHE_DESCRIPTOR Cache;
5338         ULONGLONG Reserved[2];
5339     } DUMMYUNIONNAME;
5340 } SYSTEM_LOGICAL_PROCESSOR_INFORMATION, *PSYSTEM_LOGICAL_PROCESSOR_INFORMATION;
5341
5342 typedef struct _SYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX
5343 {
5344     LOGICAL_PROCESSOR_RELATIONSHIP Relationship;
5345     DWORD Size;
5346     union
5347     {
5348         PROCESSOR_RELATIONSHIP Processor;
5349         NUMA_NODE_RELATIONSHIP NumaNode;
5350         CACHE_RELATIONSHIP Cache;
5351         GROUP_RELATIONSHIP Group;
5352     } DUMMYUNIONNAME;
5353 } SYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX, *PSYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX;
5354
5355 NTSYSAPI BOOLEAN NTAPI RtlGetProductInfo(DWORD,DWORD,DWORD,DWORD,PDWORD);
5356
5357 #ifdef __cplusplus
5358 }
5359 #endif
5360
5361 #endif  /* _WINNT_ */