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