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