* Sync up to trunk head (r65481).
[reactos.git] / include / psdk / winnt.h
1 /*
2 * winnt.h
3 *
4 * Windows NT native definitions for user mode
5 *
6 * This file is part of the ReactOS PSDK package.
7 *
8 * This file is auto-generated from ReactOS XDK.
9 *
10 * THIS SOFTWARE IS NOT COPYRIGHTED
11 *
12 * This source code is offered for use in the public domain. You may
13 * use, modify or distribute it freely.
14 *
15 * This code is distributed in the hope that it will be useful but
16 * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
17 * DISCLAIMED. This includes but is not limited to warranties of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
19 *
20 */
21
22 #pragma once
23 #define _WINNT_
24
25 /* We require WDK / VS 2008 or newer */
26 #if defined(_MSC_VER) && (_MSC_VER < 1500)
27 #error Compiler too old!
28 #endif
29
30 /* HACK for wine code */
31 #if !defined(__ROS_LONG64__)
32 #ifdef __WINESRC__
33 #define __ROS_LONG64__
34 #endif
35 #endif
36
37 #include <ctype.h>
38 //#include <winapifamily.h>
39 #include <msvctarget.h>
40 #include <specstrings.h>
41 #include <kernelspecs.h>
42
43 #include <excpt.h>
44 #include <basetsd.h>
45 #include <guiddef.h>
46 #include <intrin.h>
47
48 #undef __need_wchar_t
49 #include <winerror.h>
50 #include <stddef.h>
51 #include <sdkddkver.h>
52 #ifndef RC_INVOKED
53 #include <string.h>
54 #endif
55
56 /* Silence some MSVC warnings */
57 #ifdef _MSC_VER
58 #pragma warning(push)
59 #pragma warning(disable:4201)
60 #pragma warning(disable:4214)
61 #endif
62
63 #ifdef __cplusplus
64 extern "C" {
65 #endif
66
67 /* Defines the "size" of an any-size array */
68 #ifndef ANYSIZE_ARRAY
69 #define ANYSIZE_ARRAY 1
70 #endif
71
72 /* Helper macro to enable gcc's extension. */
73 #ifndef __GNU_EXTENSION
74 #ifdef __GNUC__
75 #define __GNU_EXTENSION __extension__
76 #else
77 #define __GNU_EXTENSION
78 #endif
79 #endif /* __GNU_EXTENSION */
80
81 #ifndef DUMMYUNIONNAME
82 #if defined(NONAMELESSUNION)// || !defined(_MSC_EXTENSIONS)
83 #define _ANONYMOUS_UNION
84 #define _UNION_NAME(x) x
85 #define DUMMYUNIONNAME u
86 #define DUMMYUNIONNAME1 u1
87 #define DUMMYUNIONNAME2 u2
88 #define DUMMYUNIONNAME3 u3
89 #define DUMMYUNIONNAME4 u4
90 #define DUMMYUNIONNAME5 u5
91 #define DUMMYUNIONNAME6 u6
92 #define DUMMYUNIONNAME7 u7
93 #define DUMMYUNIONNAME8 u8
94 #define DUMMYUNIONNAME9 u9
95 #else
96 #define _ANONYMOUS_UNION __GNU_EXTENSION
97 #define _UNION_NAME(x)
98 #define DUMMYUNIONNAME
99 #define DUMMYUNIONNAME1
100 #define DUMMYUNIONNAME2
101 #define DUMMYUNIONNAME3
102 #define DUMMYUNIONNAME4
103 #define DUMMYUNIONNAME5
104 #define DUMMYUNIONNAME6
105 #define DUMMYUNIONNAME7
106 #define DUMMYUNIONNAME8
107 #define DUMMYUNIONNAME9
108 #endif /* NONAMELESSUNION */
109 #endif /* !DUMMYUNIONNAME */
110
111 #ifndef DUMMYSTRUCTNAME
112 #if defined(NONAMELESSUNION)// || !defined(_MSC_EXTENSIONS)
113 #define _ANONYMOUS_STRUCT
114 #define _STRUCT_NAME(x) x
115 #define DUMMYSTRUCTNAME s
116 #define DUMMYSTRUCTNAME1 s1
117 #define DUMMYSTRUCTNAME2 s2
118 #define DUMMYSTRUCTNAME3 s3
119 #define DUMMYSTRUCTNAME4 s4
120 #define DUMMYSTRUCTNAME5 s5
121 #else
122 #define _ANONYMOUS_STRUCT __GNU_EXTENSION
123 #define _STRUCT_NAME(x)
124 #define DUMMYSTRUCTNAME
125 #define DUMMYSTRUCTNAME1
126 #define DUMMYSTRUCTNAME2
127 #define DUMMYSTRUCTNAME3
128 #define DUMMYSTRUCTNAME4
129 #define DUMMYSTRUCTNAME5
130 #endif /* NONAMELESSUNION */
131 #endif /* DUMMYSTRUCTNAME */
132
133 #if defined(STRICT_GS_ENABLED)
134 #pragma strict_gs_check(push, on)
135 #endif
136
137 #if defined(_M_MRX000) || defined(_M_ALPHA) || defined(_M_PPC) || defined(_M_IA64) || defined(_M_AMD64) || defined(_M_ARM)
138 #define ALIGNMENT_MACHINE
139 #define UNALIGNED __unaligned
140 #if defined(_WIN64)
141 #define UNALIGNED64 __unaligned
142 #else
143 #define UNALIGNED64
144 #endif
145 #else
146 #undef ALIGNMENT_MACHINE
147 #define UNALIGNED
148 #define UNALIGNED64
149 #endif
150
151 #if defined(_WIN64) || defined(_M_ALPHA)
152 #define MAX_NATURAL_ALIGNMENT sizeof(ULONGLONG)
153 #define MEMORY_ALLOCATION_ALIGNMENT 16
154 #else
155 #define MAX_NATURAL_ALIGNMENT sizeof(DWORD)
156 #define MEMORY_ALLOCATION_ALIGNMENT 8
157 #endif
158
159 /* C99 restrict support */
160 #if defined(ENABLE_RESTRICTED) && defined(_M_MRX000) && !defined(MIDL_PASS) && !defined(RC_INVOKED)
161 #define RESTRICTED_POINTER __restrict
162 #else
163 #define RESTRICTED_POINTER
164 #endif
165
166 /* Returns the base address of a structure from a structure member */
167 #ifndef CONTAINING_RECORD
168 #define CONTAINING_RECORD(address, type, field) \
169 ((type *)(((ULONG_PTR)address) - (ULONG_PTR)(&(((type *)0)->field))))
170 #endif
171
172 /* Returns the byte offset of the specified structure's member */
173 #ifndef __GNUC__
174 #define FIELD_OFFSET(Type, Field) ((LONG)(LONG_PTR)&(((Type*) 0)->Field))
175 #else
176 #define FIELD_OFFSET(Type, Field) ((LONG)__builtin_offsetof(Type, Field))
177 #endif /* __GNUC__ */
178
179 /* Returns the type's alignment */
180 #if defined(_MSC_VER)
181 #define TYPE_ALIGNMENT(t) __alignof(t)
182 #else
183 #define TYPE_ALIGNMENT(t) FIELD_OFFSET(struct { char x; t test; }, test)
184 #endif /* _MSC_VER */
185
186 #if defined(_AMD64_) || defined(_X86_)
187 #define PROBE_ALIGNMENT(_s) TYPE_ALIGNMENT(DWORD)
188 #elif defined(_IA64_) || defined(_ARM_)
189 #define PROBE_ALIGNMENT(_s) max((TYPE_ALIGNMENT(_s), TYPE_ALIGNMENT(DWORD))
190 #else
191 #error "unknown architecture"
192 #endif
193
194 #if defined(_WIN64)
195 #define PROBE_ALIGNMENT32(_s) TYPE_ALIGNMENT(DWORD)
196 #endif /* _WIN64 */
197
198 #ifdef __cplusplus
199 #define EXTERN_C extern "C"
200 #else
201 #define EXTERN_C extern
202 #endif /* __cplusplus */
203
204 #define NTAPI __stdcall
205
206 #ifndef STDMETHODCALLTYPE
207 #define STDMETHODCALLTYPE __stdcall
208 #define STDMETHODVCALLTYPE __cdecl
209 #define STDAPICALLTYPE __stdcall
210 #define STDAPIVCALLTYPE __cdecl
211 #define STDAPI EXTERN_C HRESULT STDAPICALLTYPE
212 #define STDAPI_(t) EXTERN_C t STDAPICALLTYPE
213 #define STDMETHODIMP HRESULT STDMETHODCALLTYPE
214 #define STDMETHODIMP_(t) t STDMETHODCALLTYPE
215 #define STDAPIV EXTERN_C HRESULT STDAPIVCALLTYPE
216 #define STDAPIV_(t) EXTERN_C t STDAPIVCALLTYPE
217 #define STDMETHODIMPV HRESULT STDMETHODVCALLTYPE
218 #define STDMETHODIMPV_(t) t STDMETHODVCALLTYPE
219 #endif /* !STDMETHODCALLTYPE */
220
221 #define STDOVERRIDEMETHODIMP __override STDMETHODIMP
222 #define STDOVERRIDEMETHODIMP_(t) __override STDMETHODIMP_(t)
223 #define IFACEMETHODIMP __override STDMETHODIMP
224 #define IFACEMETHODIMP_(t) __override STDMETHODIMP_(t)
225 #define STDOVERRIDEMETHODIMPV __override STDMETHODIMPV
226 #define STDOVERRIDEMETHODIMPV_(t) __override STDMETHODIMPV_(t)
227 #define IFACEMETHODIMPV __override STDMETHODIMPV
228 #define IFACEMETHODIMPV_(t) __override STDMETHODIMPV_(t)
229
230 /* Import and Export Specifiers */
231
232 /* Done the same way as in windef.h for now */
233 #define DECLSPEC_IMPORT __declspec(dllimport) // MIDL?
234 #define DECLSPEC_NORETURN __declspec(noreturn)
235
236 #ifndef DECLSPEC_ADDRSAFE
237 #if defined(_MSC_VER) && (defined(_M_ALPHA) || defined(_M_AXP64))
238 #define DECLSPEC_ADDRSAFE __declspec(address_safe)
239 #else
240 #define DECLSPEC_ADDRSAFE
241 #endif
242 #endif /* DECLSPEC_ADDRSAFE */
243
244 #ifndef DECLSPEC_NOTHROW
245 #if !defined(MIDL_PASS)
246 #define DECLSPEC_NOTHROW __declspec(nothrow)
247 #else
248 #define DECLSPEC_NOTHROW
249 #endif
250 #endif /* DECLSPEC_NOTHROW */
251
252 #ifndef NOP_FUNCTION
253 #if defined(_MSC_VER)
254 #define NOP_FUNCTION __noop
255 #else
256 #define NOP_FUNCTION (void)0
257 #endif
258 #endif /* NOP_FUNCTION */
259
260 #if !defined(_NTSYSTEM_)
261 #define NTSYSAPI DECLSPEC_IMPORT
262 #define NTSYSCALLAPI DECLSPEC_IMPORT
263 #else
264 #define NTSYSAPI
265 #if defined(_NTDLLBUILD_)
266 #define NTSYSCALLAPI
267 #else
268 #define NTSYSCALLAPI DECLSPEC_ADDRSAFE
269 #endif
270 #endif /* _NTSYSTEM_ */
271
272 /* Inlines */
273 #ifndef FORCEINLINE
274 #if defined(_MSC_VER)
275 #define FORCEINLINE __forceinline
276 #elif ( __MINGW_GNUC_PREREQ(4, 3) && __STDC_VERSION__ >= 199901L)
277 #define FORCEINLINE extern inline __attribute__((__always_inline__,__gnu_inline__))
278 #else
279 #define FORCEINLINE extern __inline__ __attribute__((__always_inline__))
280 #endif
281 #endif /* FORCEINLINE */
282
283 #ifndef DECLSPEC_NOINLINE
284 #if (_MSC_VER >= 1300)
285 #define DECLSPEC_NOINLINE __declspec(noinline)
286 #elif defined(__GNUC__)
287 #define DECLSPEC_NOINLINE __attribute__((noinline))
288 #else
289 #define DECLSPEC_NOINLINE
290 #endif
291 #endif /* DECLSPEC_NOINLINE */
292
293 #if !defined(_M_CEE_PURE)
294 #define NTAPI_INLINE NTAPI
295 #else
296 #define NTAPI_INLINE
297 #endif /* _M_CEE_PURE */
298
299 /* Use to specify structure alignment. Note: VS and GCC behave slightly
300 different. Therefore it is important to stick to the following rules:
301 - If you want a struct to be aligned, put DECLSPEC_ALIGN after "struct":
302 "typedef struct DECLSPEC_ALIGN(16) _FOO { ... } FOO, *PFOO;"
303 _alignof(PFOO) is sizeof(void*) here as usual.
304 - If you don't want the struct, but only the typedef to be aligned,
305 use an extra typedef.
306 struct _BAR { ... };
307 typedef DECLSPEC_ALIGN(16) struct _BAR BAR, *ALIGNEDPBAR;
308 _alignof(ALIGNEDPBAR) is 16 now! */
309 #ifndef DECLSPEC_ALIGN
310 #if defined(_MSC_VER) && !defined(MIDL_PASS)
311 #define DECLSPEC_ALIGN(x) __declspec(align(x))
312 #elif defined(__GNUC__)
313 #define DECLSPEC_ALIGN(x) __attribute__((aligned(x)))
314 #else
315 #define DECLSPEC_ALIGN(x)
316 #endif
317 #endif /* DECLSPEC_ALIGN */
318
319 #ifndef SYSTEM_CACHE_ALIGNMENT_SIZE
320 #if defined(_AMD64_) || defined(_X86_)
321 #define SYSTEM_CACHE_ALIGNMENT_SIZE 64
322 #else
323 #define SYSTEM_CACHE_ALIGNMENT_SIZE 128
324 #endif
325 #endif /* SYSTEM_CACHE_ALIGNMENT_SIZE */
326
327 #ifndef DECLSPEC_CACHEALIGN
328 #define DECLSPEC_CACHEALIGN DECLSPEC_ALIGN(SYSTEM_CACHE_ALIGNMENT_SIZE)
329 #endif /* DECLSPEC_CACHEALIGN */
330
331 #ifndef DECLSPEC_UUID
332 #if defined(_MSC_VER) && defined(__cplusplus)
333 #define DECLSPEC_UUID(x) __declspec(uuid(x))
334 #else
335 #define DECLSPEC_UUID(x)
336 #endif
337 #endif /* DECLSPEC_UUID */
338
339 #ifndef DECLSPEC_NOVTABLE
340 #if defined(_MSC_VER) && defined(__cplusplus)
341 #define DECLSPEC_NOVTABLE __declspec(novtable)
342 #else
343 #define DECLSPEC_NOVTABLE
344 #endif
345 #endif /* DECLSPEC_NOVTABLE */
346
347 #ifndef DECLSPEC_SELECTANY
348 #if defined(_MSC_VER) || defined(__GNUC__)
349 #define DECLSPEC_SELECTANY __declspec(selectany)
350 #else
351 #define DECLSPEC_SELECTANY
352 #endif
353 #endif /* DECLSPEC_SELECTANY */
354
355 #ifndef DECLSPEC_DEPRECATED
356 #if (defined(_MSC_VER) || defined(__GNUC__)) && !defined(MIDL_PASS)
357 #define DECLSPEC_DEPRECATED __declspec(deprecated)
358 #define DEPRECATE_SUPPORTED
359 #else
360 #define DECLSPEC_DEPRECATED
361 #undef DEPRECATE_SUPPORTED
362 #endif
363 #endif /* DECLSPEC_DEPRECATED */
364
365 #ifdef DEPRECATE_DDK_FUNCTIONS
366 #ifdef _NTDDK_
367 #define DECLSPEC_DEPRECATED_DDK DECLSPEC_DEPRECATED
368 #ifdef DEPRECATE_SUPPORTED
369 #define PRAGMA_DEPRECATED_DDK 1
370 #endif
371 #else
372 #define DECLSPEC_DEPRECATED_DDK
373 #define PRAGMA_DEPRECATED_DDK 1
374 #endif
375 #else
376 #define DECLSPEC_DEPRECATED_DDK
377 #define PRAGMA_DEPRECATED_DDK 0
378 #endif /* DEPRECATE_DDK_FUNCTIONS */
379
380 /* Use to silence unused variable warnings when it is intentional */
381 #define UNREFERENCED_PARAMETER(P) {(P)=(P);}
382 #define UNREFERENCED_LOCAL_VARIABLE(L) ((void)(L))
383 #define DBG_UNREFERENCED_PARAMETER(P) {(P)=(P);}
384 #define DBG_UNREFERENCED_LOCAL_VARIABLE(L) ((void)(L))
385
386 /* Void Pointers */
387 typedef void *PVOID;
388 typedef void * POINTER_64 PVOID64;
389
390 /* Handle Type */
391 typedef void *HANDLE, **PHANDLE;;
392 #ifdef STRICT
393 #define DECLARE_HANDLE(n) typedef struct n##__{int unused;} *n
394 #else
395 #define DECLARE_HANDLE(n) typedef HANDLE n
396 #endif
397
398 /* Upper-Case Versions of Some Standard C Types */
399 #ifndef VOID
400 #define VOID void
401 typedef char CHAR;
402 typedef short SHORT;
403
404 #if defined(__ROS_LONG64__) && !defined(_M_AMD64)
405 typedef int LONG;
406 #else
407 typedef long LONG;
408 #endif
409
410 #if !defined(MIDL_PASS)
411 typedef int INT;
412 #endif /* !MIDL_PASS */
413 #endif /* VOID */
414
415
416 /* Signed Types */
417 typedef SHORT *PSHORT;
418 typedef LONG *PLONG;
419
420 /* Flag types */
421 typedef unsigned char FCHAR;
422 typedef unsigned short FSHORT;
423 typedef unsigned long FLONG;
424
425 typedef unsigned char BOOLEAN, *PBOOLEAN;
426
427 #ifndef _HRESULT_DEFINED
428 #define _HRESULT_DEFINED
429 typedef _Return_type_success_(return >= 0) LONG HRESULT;
430 #endif /* _HRESULT_DEFINED */
431
432 /* 64-bit types */
433 #define _ULONGLONG_
434 __GNU_EXTENSION typedef __int64 LONGLONG, *PLONGLONG;
435 __GNU_EXTENSION typedef unsigned __int64 ULONGLONG, *PULONGLONG;
436 #define _DWORDLONG_
437 typedef ULONGLONG DWORDLONG, *PDWORDLONG;
438
439 /* Update Sequence Number */
440 typedef LONGLONG USN;
441
442 /* ANSI (Multi-byte Character) types */
443 typedef CHAR *PCHAR, *LPCH, *PCH, *PNZCH;
444 typedef CONST CHAR *LPCCH, *PCCH, *PCNZCH;
445 typedef _Null_terminated_ CHAR *NPSTR, *LPSTR, *PSTR;
446 typedef _Null_terminated_ PSTR *PZPSTR;
447 typedef _Null_terminated_ CONST PSTR *PCZPSTR;
448 typedef _Null_terminated_ CONST CHAR *LPCSTR, *PCSTR;
449 typedef _Null_terminated_ PCSTR *PZPCSTR;
450
451 typedef _NullNull_terminated_ CHAR *PZZSTR;
452 typedef _NullNull_terminated_ CONST CHAR *PCZZSTR;
453
454
455 /* UNICODE (Wide Character) types */
456 typedef wchar_t WCHAR;
457 typedef WCHAR *PWCHAR, *LPWCH, *PWCH;
458 typedef CONST WCHAR *LPCWCH, *PCWCH;
459 typedef _Null_terminated_ WCHAR *NWPSTR, *LPWSTR, *PWSTR;
460 typedef _Null_terminated_ PWSTR *PZPWSTR;
461 typedef _Null_terminated_ CONST PWSTR *PCZPWSTR;
462 typedef _Null_terminated_ WCHAR UNALIGNED *LPUWSTR, *PUWSTR;
463 typedef _Null_terminated_ CONST WCHAR *LPCWSTR, *PCWSTR;
464 typedef _Null_terminated_ PCWSTR *PZPCWSTR;
465 typedef _Null_terminated_ CONST WCHAR UNALIGNED *LPCUWSTR, *PCUWSTR;
466
467 typedef _NullNull_terminated_ WCHAR *PZZWSTR;
468 typedef _NullNull_terminated_ CONST WCHAR *PCZZWSTR;
469 typedef _NullNull_terminated_ WCHAR UNALIGNED *PUZZWSTR;
470 typedef _NullNull_terminated_ CONST WCHAR UNALIGNED *PCUZZWSTR;
471
472 typedef WCHAR *PNZWCH;
473 typedef CONST WCHAR *PCNZWCH;
474 typedef WCHAR UNALIGNED *PUNZWCH;
475 typedef CONST WCHAR UNALIGNED *PCUNZWCH;
476
477 #if (_WIN32_WINNT >= 0x0600) || (defined(__cplusplus) && defined(WINDOWS_ENABLE_CPLUSPLUS))
478 typedef CONST WCHAR *LPCWCHAR, *PCWCHAR;
479 typedef CONST WCHAR UNALIGNED *LPCUWCHAR, *PCUWCHAR;
480 typedef unsigned long UCSCHAR, *PUCSCHAR, *PUCSSTR;
481 typedef const UCSCHAR *PCUCSCHAR, *PCUCSSTR;
482 typedef UCSCHAR UNALIGNED *PUUCSCHAR, *PUUCSSTR;
483 typedef const UCSCHAR UNALIGNED *PCUUCSCHAR, *PCUUCSSTR;
484 #define UCSCHAR_INVALID_CHARACTER (0xffffffff)
485 #define MIN_UCSCHAR (0)
486 #define MAX_UCSCHAR (0x0010FFFF)
487 #endif /* _WIN32_WINNT >= 0x0600 */
488
489 #ifdef UNICODE
490
491 #ifndef _TCHAR_DEFINED
492 typedef WCHAR TCHAR, *PTCHAR;
493 typedef WCHAR TBYTE, *PTBYTE;
494 #define _TCHAR_DEFINED
495 #endif /* !_TCHAR_DEFINED */
496
497 typedef LPWCH LPTCH, PTCH;
498 typedef LPCWCH LPCTCH, PCTCH;
499 typedef LPWSTR PTSTR, LPTSTR;
500 typedef LPCWSTR PCTSTR, LPCTSTR;
501 typedef LPUWSTR PUTSTR, LPUTSTR;
502 typedef LPCUWSTR PCUTSTR, LPCUTSTR;
503 typedef LPWSTR LP;
504 typedef PZZWSTR PZZTSTR;
505 typedef PCZZWSTR PCZZTSTR;
506 typedef PUZZWSTR PUZZTSTR;
507 typedef PCUZZWSTR PCUZZTSTR;
508 typedef PZPWSTR PZPTSTR;
509 typedef PNZWCH PNZTCH;
510 typedef PCNZWCH PCNZTCH;
511 typedef PUNZWCH PUNZTCH;
512 typedef PCUNZWCH PCUNZTCH;
513 #define __TEXT(quote) L##quote
514
515 #else /* UNICODE */
516
517 #ifndef _TCHAR_DEFINED
518 typedef char TCHAR, *PTCHAR;
519 typedef unsigned char TBYTE, *PTBYTE;
520 #define _TCHAR_DEFINED
521 #endif /* !_TCHAR_DEFINED */
522 typedef LPCH LPTCH, PTCH;
523 typedef LPCCH LPCTCH, PCTCH;
524 typedef LPSTR PTSTR, LPTSTR, PUTSTR, LPUTSTR;
525 typedef LPCSTR PCTSTR, LPCTSTR, PCUTSTR, LPCUTSTR;
526 typedef PZZSTR PZZTSTR, PUZZTSTR;
527 typedef PCZZSTR PCZZTSTR, PCUZZTSTR;
528 typedef PZPSTR PZPTSTR;
529 typedef PNZCH PNZTCH, PUNZTCH;
530 typedef PCNZCH PCNZTCH, PCUNZTCH;
531 #define __TEXT(quote) quote
532
533 #endif /* UNICODE */
534
535 #define TEXT(quote) __TEXT(quote)
536
537 /* Cardinal Data Types */
538 typedef char CCHAR;
539
540 /* NLS basics (Locale and Language Ids) */
541 typedef DWORD LCID, *PLCID;
542 typedef WORD LANGID;
543
544 #ifndef __COMPARTMENT_ID_DEFINED__
545 #define __COMPARTMENT_ID_DEFINED__
546 typedef enum
547 {
548 UNSPECIFIED_COMPARTMENT_ID = 0,
549 DEFAULT_COMPARTMENT_ID
550 } COMPARTMENT_ID, *PCOMPARTMENT_ID;
551 #endif /* __COMPARTMENT_ID_DEFINED__ */
552
553 #ifndef __OBJECTID_DEFINED
554 #define __OBJECTID_DEFINED
555 typedef struct _OBJECTID {
556 GUID Lineage;
557 DWORD Uniquifier;
558 } OBJECTID;
559 #endif /* __OBJECTID_DEFINED */
560
561 #ifdef _MSC_VER
562 #pragma warning(push)
563 #pragma warning(disable:4201) // nameless struct / union
564 #endif
565
566 typedef struct
567 #if defined(_M_IA64)
568 DECLSPEC_ALIGN(16)
569 #endif
570 _FLOAT128 {
571 __int64 LowPart;
572 __int64 HighPart;
573 } FLOAT128;
574 typedef FLOAT128 *PFLOAT128;
575
576 /* Large Integer Unions */
577 #if defined(MIDL_PASS)
578 typedef struct _LARGE_INTEGER {
579 #else
580 typedef union _LARGE_INTEGER {
581 _ANONYMOUS_STRUCT struct
582 {
583 DWORD LowPart;
584 LONG HighPart;
585 } DUMMYSTRUCTNAME;
586 struct
587 {
588 DWORD LowPart;
589 LONG HighPart;
590 } u;
591 #endif /* MIDL_PASS */
592 LONGLONG QuadPart;
593 } LARGE_INTEGER, *PLARGE_INTEGER;
594
595 #if defined(MIDL_PASS)
596 typedef struct _ULARGE_INTEGER {
597 #else
598 typedef union _ULARGE_INTEGER {
599 _ANONYMOUS_STRUCT struct
600 {
601 DWORD LowPart;
602 DWORD HighPart;
603 } DUMMYSTRUCTNAME;
604 struct
605 {
606 DWORD LowPart;
607 DWORD HighPart;
608 } u;
609 #endif /* MIDL_PASS */
610 ULONGLONG QuadPart;
611 } ULARGE_INTEGER, *PULARGE_INTEGER;
612
613 #ifdef _MSC_VER
614 #pragma warning(pop) /* disable:4201 */
615 #endif
616
617 /* Locally Unique Identifier */
618 typedef struct _LUID
619 {
620 DWORD LowPart;
621 LONG HighPart;
622 } LUID, *PLUID;
623
624 #define APPLICATION_ERROR_MASK 0x20000000
625 #define ERROR_SEVERITY_SUCCESS 0x00000000
626 #define ERROR_SEVERITY_INFORMATIONAL 0x40000000
627 #define ERROR_SEVERITY_WARNING 0x80000000
628 #define ERROR_SEVERITY_ERROR 0xC0000000
629
630
631 #define ANSI_NULL ((CHAR)0)
632 #define UNICODE_NULL ((WCHAR)0)
633 #define UNICODE_STRING_MAX_BYTES ((USHORT) 65534)
634 #define UNICODE_STRING_MAX_CHARS (32767)
635
636 /* Doubly Linked Lists */
637 typedef struct _LIST_ENTRY {
638 struct _LIST_ENTRY *Flink;
639 struct _LIST_ENTRY *Blink;
640 } LIST_ENTRY, *PLIST_ENTRY, *RESTRICTED_POINTER PRLIST_ENTRY;
641
642 typedef struct LIST_ENTRY32 {
643 DWORD Flink;
644 DWORD Blink;
645 } LIST_ENTRY32, *PLIST_ENTRY32;
646
647 typedef struct LIST_ENTRY64 {
648 ULONGLONG Flink;
649 ULONGLONG Blink;
650 } LIST_ENTRY64, *PLIST_ENTRY64;
651
652 /* Singly Linked Lists */
653 typedef struct _SINGLE_LIST_ENTRY {
654 struct _SINGLE_LIST_ENTRY *Next;
655 } SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
656
657
658 typedef struct _PROCESSOR_NUMBER {
659 WORD Group;
660 BYTE Number;
661 BYTE Reserved;
662 } PROCESSOR_NUMBER, *PPROCESSOR_NUMBER;
663
664 #define ALL_PROCESSOR_GROUPS 0xffff
665
666 typedef
667 _IRQL_requires_same_
668 _Function_class_(EXCEPTION_ROUTINE)
669 EXCEPTION_DISPOSITION
670 NTAPI
671 EXCEPTION_ROUTINE(
672 _Inout_ struct _EXCEPTION_RECORD *ExceptionRecord,
673 _In_ PVOID EstablisherFrame,
674 _Inout_ struct _CONTEXT *ContextRecord,
675 _In_ PVOID DispatcherContext);
676
677 typedef EXCEPTION_ROUTINE *PEXCEPTION_ROUTINE;
678
679 typedef struct _GROUP_AFFINITY {
680 KAFFINITY Mask;
681 WORD Group;
682 WORD Reserved[3];
683 } GROUP_AFFINITY, *PGROUP_AFFINITY;
684
685 /* Helper Macros */
686
687 #define RTL_FIELD_TYPE(type, field) (((type*)0)->field)
688 #define RTL_BITS_OF(sizeOfArg) (sizeof(sizeOfArg) * 8)
689 #define RTL_BITS_OF_FIELD(type, field) (RTL_BITS_OF(RTL_FIELD_TYPE(type, field)))
690 #define RTL_FIELD_SIZE(type, field) (sizeof(((type *)0)->field))
691
692 #define RTL_SIZEOF_THROUGH_FIELD(type, field) \
693 (FIELD_OFFSET(type, field) + RTL_FIELD_SIZE(type, field))
694
695 #define RTL_CONTAINS_FIELD(Struct, Size, Field) \
696 ( (((PCHAR)(&(Struct)->Field)) + sizeof((Struct)->Field)) <= (((PCHAR)(Struct))+(Size)) )
697
698 #define RTL_NUMBER_OF_V1(A) (sizeof(A)/sizeof((A)[0]))
699
700 #ifdef __GNUC__
701 #define RTL_NUMBER_OF_V2(A) \
702 (({ int _check_array_type[__builtin_types_compatible_p(typeof(A), typeof(&A[0])) ? -1 : 1]; (void)_check_array_type; }), \
703 RTL_NUMBER_OF_V1(A))
704 #else
705 /// \todo implement security checks for cplusplus / MSVC
706 #define RTL_NUMBER_OF_V2(A) RTL_NUMBER_OF_V1(A)
707 #endif
708
709 #ifdef ENABLE_RTL_NUMBER_OF_V2
710 #define RTL_NUMBER_OF(A) RTL_NUMBER_OF_V2(A)
711 #else
712 #define RTL_NUMBER_OF(A) RTL_NUMBER_OF_V1(A)
713 #endif
714
715 #define ARRAYSIZE(A) RTL_NUMBER_OF_V2(A)
716 #define _ARRAYSIZE(A) RTL_NUMBER_OF_V1(A)
717
718 #define RTL_NUMBER_OF_FIELD(type, field) \
719 (RTL_NUMBER_OF(RTL_FIELD_TYPE(type, field)))
720
721 #define RTL_PADDING_BETWEEN_FIELDS(type, field1, field2) \
722 ((FIELD_OFFSET(type, field2) > FIELD_OFFSET(type, field1)) \
723 ? (FIELD_OFFSET(type, field2) - FIELD_OFFSET(type, field1) - RTL_FIELD_SIZE(type, field1)) \
724 : (FIELD_OFFSET(type, field1) - FIELD_OFFSET(type, field2) - RTL_FIELD_SIZE(type, field2)))
725
726 #if defined(__cplusplus)
727 #define RTL_CONST_CAST(type) const_cast<type>
728 #else
729 #define RTL_CONST_CAST(type) (type)
730 #endif
731
732 #ifdef __cplusplus
733 #define DEFINE_ENUM_FLAG_OPERATORS(_ENUMTYPE) \
734 extern "C++" { \
735 inline _ENUMTYPE operator|(_ENUMTYPE a, _ENUMTYPE b) { return _ENUMTYPE(((int)a) | ((int)b)); } \
736 inline _ENUMTYPE &operator|=(_ENUMTYPE &a, _ENUMTYPE b) { return (_ENUMTYPE &)(((int &)a) |= ((int)b)); } \
737 inline _ENUMTYPE operator&(_ENUMTYPE a, _ENUMTYPE b) { return _ENUMTYPE(((int)a) & ((int)b)); } \
738 inline _ENUMTYPE &operator&=(_ENUMTYPE &a, _ENUMTYPE b) { return (_ENUMTYPE &)(((int &)a) &= ((int)b)); } \
739 inline _ENUMTYPE operator~(_ENUMTYPE a) { return _ENUMTYPE(~((int)a)); } \
740 inline _ENUMTYPE operator^(_ENUMTYPE a, _ENUMTYPE b) { return _ENUMTYPE(((int)a) ^ ((int)b)); } \
741 inline _ENUMTYPE &operator^=(_ENUMTYPE &a, _ENUMTYPE b) { return (_ENUMTYPE &)(((int &)a) ^= ((int)b)); } \
742 }
743 #else
744 #define DEFINE_ENUM_FLAG_OPERATORS(_ENUMTYPE)
745 #endif
746
747 #define COMPILETIME_OR_2FLAGS(a,b) ((UINT)(a)|(UINT)(b))
748 #define COMPILETIME_OR_3FLAGS(a,b,c) ((UINT)(a)|(UINT)(b)|(UINT)(c))
749 #define COMPILETIME_OR_4FLAGS(a,b,c,d) ((UINT)(a)|(UINT)(b)|(UINT)(c)|(UINT)(d))
750 #define COMPILETIME_OR_5FLAGS(a,b,c,d,e) ((UINT)(a)|(UINT)(b)|(UINT)(c)|(UINT)(d)|(UINT)(e))
751
752 /* Type Limits */
753 #define MINCHAR 0x80
754 #define MAXCHAR 0x7f
755 #define MINSHORT 0x8000
756 #define MAXSHORT 0x7fff
757 #define MINLONG 0x80000000
758 #define MAXLONG 0x7fffffff
759 #define MAXBYTE 0xff
760 #define MAXWORD 0xffff
761 #define MAXDWORD 0xffffffff
762 #define MAXLONGLONG (0x7fffffffffffffffLL)
763
764 /* 32 to 64 bit multiplication. GCC is really bad at optimizing the native math */
765 #if defined(_M_IX86) && defined(__GNUC__) && \
766 !defined(MIDL_PASS)&& !defined(RC_INVOKED) && !defined(_M_CEE_PURE)
767 #define Int32x32To64(a,b) __emul(a,b)
768 #define UInt32x32To64(a,b) __emulu(a,b)
769 #else
770 #define Int32x32To64(a,b) (((__int64)(long)(a))*((__int64)(long)(b)))
771 #define UInt32x32To64(a,b) ((unsigned __int64)(unsigned int)(a)*(unsigned __int64)(unsigned int)(b))
772 #endif
773
774 #if defined(MIDL_PASS)|| defined(RC_INVOKED) || defined(_M_CEE_PURE)
775 /* Use native math */
776 #define Int64ShllMod32(a,b) ((unsigned __int64)(a)<<(b))
777 #define Int64ShraMod32(a,b) (((__int64)(a))>>(b))
778 #define Int64ShrlMod32(a,b) (((unsigned __int64)(a))>>(b))
779 #else
780 /* Use intrinsics */
781 #define Int64ShllMod32(a,b) __ll_lshift(a,b)
782 #define Int64ShraMod32(a,b) __ll_rshift(a,b)
783 #define Int64ShrlMod32(a,b) __ull_rshift(a,b)
784 #endif
785
786 #define RotateLeft32 _rotl
787 #define RotateLeft64 _rotl64
788 #define RotateRight32 _rotr
789 #define RotateRight64 _rotr64
790
791 #if defined(_M_AMD64)
792 #define RotateLeft8 _rotl8
793 #define RotateLeft16 _rotl16
794 #define RotateRight8 _rotr8
795 #define RotateRight16 _rotr16
796 #endif /* _M_AMD64 */
797
798 /* C_ASSERT Definition */
799 #define C_ASSERT(expr) extern char (*c_assert(void)) [(expr) ? 1 : -1]
800
801 /* Eliminate Microsoft C/C++ compiler warning 4715 */
802 #if defined(_MSC_VER)
803 #define DEFAULT_UNREACHABLE default: __assume(0)
804 #elif defined(__clang__) || (defined(__GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 5))))
805 #define DEFAULT_UNREACHABLE default: __builtin_unreachable()
806 #else
807 #define DEFAULT_UNREACHABLE default: break
808 #endif
809
810 #define VER_WORKSTATION_NT 0x40000000
811 #define VER_SERVER_NT 0x80000000
812 #define VER_SUITE_SMALLBUSINESS 0x00000001
813 #define VER_SUITE_ENTERPRISE 0x00000002
814 #define VER_SUITE_BACKOFFICE 0x00000004
815 #define VER_SUITE_COMMUNICATIONS 0x00000008
816 #define VER_SUITE_TERMINAL 0x00000010
817 #define VER_SUITE_SMALLBUSINESS_RESTRICTED 0x00000020
818 #define VER_SUITE_EMBEDDEDNT 0x00000040
819 #define VER_SUITE_DATACENTER 0x00000080
820 #define VER_SUITE_SINGLEUSERTS 0x00000100
821 #define VER_SUITE_PERSONAL 0x00000200
822 #define VER_SUITE_BLADE 0x00000400
823 #define VER_SUITE_EMBEDDED_RESTRICTED 0x00000800
824 #define VER_SUITE_SECURITY_APPLIANCE 0x00001000
825 #define VER_SUITE_STORAGE_SERVER 0x00002000
826 #define VER_SUITE_COMPUTE_SERVER 0x00004000
827 #define VER_SUITE_WH_SERVER 0x00008000
828
829 /* Product types */
830 #define PRODUCT_UNDEFINED 0x00000000
831 #define PRODUCT_ULTIMATE 0x00000001
832 #define PRODUCT_HOME_BASIC 0x00000002
833 #define PRODUCT_HOME_PREMIUM 0x00000003
834 #define PRODUCT_ENTERPRISE 0x00000004
835 #define PRODUCT_HOME_BASIC_N 0x00000005
836 #define PRODUCT_BUSINESS 0x00000006
837 #define PRODUCT_STANDARD_SERVER 0x00000007
838 #define PRODUCT_DATACENTER_SERVER 0x00000008
839 #define PRODUCT_SMALLBUSINESS_SERVER 0x00000009
840 #define PRODUCT_ENTERPRISE_SERVER 0x0000000A
841 #define PRODUCT_STARTER 0x0000000B
842 #define PRODUCT_DATACENTER_SERVER_CORE 0x0000000C
843 #define PRODUCT_STANDARD_SERVER_CORE 0x0000000D
844 #define PRODUCT_ENTERPRISE_SERVER_CORE 0x0000000E
845 #define PRODUCT_ENTERPRISE_SERVER_IA64 0x0000000F
846 #define PRODUCT_BUSINESS_N 0x00000010
847 #define PRODUCT_WEB_SERVER 0x00000011
848 #define PRODUCT_CLUSTER_SERVER 0x00000012
849 #define PRODUCT_HOME_SERVER 0x00000013
850 #define PRODUCT_STORAGE_EXPRESS_SERVER 0x00000014
851 #define PRODUCT_STORAGE_STANDARD_SERVER 0x00000015
852 #define PRODUCT_STORAGE_WORKGROUP_SERVER 0x00000016
853 #define PRODUCT_STORAGE_ENTERPRISE_SERVER 0x00000017
854 #define PRODUCT_SERVER_FOR_SMALLBUSINESS 0x00000018
855 #define PRODUCT_SMALLBUSINESS_SERVER_PREMIUM 0x00000019
856 #define PRODUCT_HOME_PREMIUM_N 0x0000001A
857 #define PRODUCT_ENTERPRISE_N 0x0000001B
858 #define PRODUCT_ULTIMATE_N 0x0000001C
859 #define PRODUCT_WEB_SERVER_CORE 0x0000001D
860 #define PRODUCT_MEDIUMBUSINESS_SERVER_MANAGEMENT 0x0000001E
861 #define PRODUCT_MEDIUMBUSINESS_SERVER_SECURITY 0x0000001F
862 #define PRODUCT_MEDIUMBUSINESS_SERVER_MESSAGING 0x00000020
863 #define PRODUCT_SERVER_FOUNDATION 0x00000021
864 #define PRODUCT_HOME_PREMIUM_SERVER 0x00000022
865 #define PRODUCT_SERVER_FOR_SMALLBUSINESS_V 0x00000023
866 #define PRODUCT_STANDARD_SERVER_V 0x00000024
867 #define PRODUCT_DATACENTER_SERVER_V 0x00000025
868 #define PRODUCT_ENTERPRISE_SERVER_V 0x00000026
869 #define PRODUCT_DATACENTER_SERVER_CORE_V 0x00000027
870 #define PRODUCT_STANDARD_SERVER_CORE_V 0x00000028
871 #define PRODUCT_ENTERPRISE_SERVER_CORE_V 0x00000029
872 #define PRODUCT_HYPERV 0x0000002A
873 #define PRODUCT_STORAGE_EXPRESS_SERVER_CORE 0x0000002B
874 #define PRODUCT_STORAGE_STANDARD_SERVER_CORE 0x0000002C
875 #define PRODUCT_STORAGE_WORKGROUP_SERVER_CORE 0x0000002D
876 #define PRODUCT_STORAGE_ENTERPRISE_SERVER_CORE 0x0000002E
877 #define PRODUCT_STARTER_N 0x0000002F
878 #define PRODUCT_PROFESSIONAL 0x00000030
879 #define PRODUCT_PROFESSIONAL_N 0x00000031
880 #define PRODUCT_SB_SOLUTION_SERVER 0x00000032
881 #define PRODUCT_SERVER_FOR_SB_SOLUTIONS 0x00000033
882 #define PRODUCT_STANDARD_SERVER_SOLUTIONS 0x00000034
883 #define PRODUCT_STANDARD_SERVER_SOLUTIONS_CORE 0x00000035
884 #define PRODUCT_SB_SOLUTION_SERVER_EM 0x00000036
885 #define PRODUCT_SERVER_FOR_SB_SOLUTIONS_EM 0x00000037
886 #define PRODUCT_SOLUTION_EMBEDDEDSERVER 0x00000038
887 #define PRODUCT_SOLUTION_EMBEDDEDSERVER_CORE 0x00000039
888 #define PRODUCT_ESSENTIALBUSINESS_SERVER_MGMT 0x0000003B
889 #define PRODUCT_ESSENTIALBUSINESS_SERVER_ADDL 0x0000003C
890 #define PRODUCT_ESSENTIALBUSINESS_SERVER_MGMTSVC 0x0000003D
891 #define PRODUCT_ESSENTIALBUSINESS_SERVER_ADDLSVC 0x0000003E
892 #define PRODUCT_SMALLBUSINESS_SERVER_PREMIUM_CORE 0x0000003F
893 #define PRODUCT_CLUSTER_SERVER_V 0x00000040
894 #define PRODUCT_EMBEDDED 0x00000041
895 #define PRODUCT_STARTER_E 0x00000042
896 #define PRODUCT_HOME_BASIC_E 0x00000043
897 #define PRODUCT_HOME_PREMIUM_E 0x00000044
898 #define PRODUCT_PROFESSIONAL_E 0x00000045
899 #define PRODUCT_ENTERPRISE_E 0x00000046
900 #define PRODUCT_ULTIMATE_E 0x00000047
901 #define PRODUCT_ENTERPRISE_EVALUATION 0x00000048
902 #define PRODUCT_MULTIPOINT_STANDARD_SERVER 0x0000004C
903 #define PRODUCT_MULTIPOINT_PREMIUM_SERVER 0x0000004D
904 #define PRODUCT_STANDARD_EVALUATION_SERVER 0x0000004F
905 #define PRODUCT_DATACENTER_EVALUATION_SERVER 0x00000050
906 #define PRODUCT_ENTERPRISE_N_EVALUATION 0x00000054
907 #define PRODUCT_EMBEDDED_AUTOMOTIVE 0x00000055
908 #define PRODUCT_EMBEDDED_INDUSTRY_A 0x00000056
909 #define PRODUCT_THINPC 0x00000057
910 #define PRODUCT_EMBEDDED_A 0x00000058
911 #define PRODUCT_EMBEDDED_INDUSTRY 0x00000059
912 #define PRODUCT_EMBEDDED_E 0x0000005A
913 #define PRODUCT_EMBEDDED_INDUSTRY_E 0x0000005B
914 #define PRODUCT_EMBEDDED_INDUSTRY_A_E 0x0000005C
915 #define PRODUCT_STORAGE_WORKGROUP_EVALUATION_SERVER 0x0000005F
916 #define PRODUCT_STORAGE_STANDARD_EVALUATION_SERVER 0x00000060
917 #define PRODUCT_CORE_ARM 0x00000061
918 #define PRODUCT_CORE_N 0x00000062
919 #define PRODUCT_CORE_COUNTRYSPECIFIC 0x00000063
920 #define PRODUCT_CORE_SINGLELANGUAGE 0x00000064
921 #define PRODUCT_CORE 0x00000065
922 #define PRODUCT_PROFESSIONAL_WMC 0x00000067
923 #define PRODUCT_UNLICENSED 0xABCDABCD
924
925 /* LangID and NLS */
926 #define MAKELANGID(p, s) ((((USHORT)(s)) << 10) | (USHORT)(p))
927 #define PRIMARYLANGID(lgid) ((USHORT)(lgid) & 0x3ff)
928 #define SUBLANGID(lgid) ((USHORT)(lgid) >> 10)
929 #define MAKELCID(lgid, srtid) ((DWORD)((((DWORD)((USHORT)(srtid))) << 16) | \
930 ((DWORD)((USHORT)(lgid)))))
931 #define MAKESORTLCID(lgid, srtid, ver) \
932 ((DWORD)((MAKELCID(lgid, srtid)) | \
933 (((DWORD)((USHORT)(ver))) << 20)))
934 #define LANGIDFROMLCID(lcid) ((USHORT)(lcid))
935 #define SORTIDFROMLCID(lcid) ((USHORT)((((DWORD)(lcid)) >> 16) & 0xf))
936 #define SORTVERSIONFROMLCID(lcid) ((USHORT)((((DWORD)(lcid)) >> 20) & 0xf))
937
938 #define NLS_VALID_LOCALE_MASK 0x000fffff
939 #define LOCALE_NAME_MAX_LENGTH 85
940
941 /* Primary language IDs. */
942 #define LANG_NEUTRAL 0x00
943 #define LANG_INVARIANT 0x7f
944 #define LANG_AFRIKAANS 0x36
945 #define LANG_ALBANIAN 0x1c
946 #define LANG_ALSATIAN 0x84
947 #define LANG_AMHARIC 0x5e
948 #define LANG_ARABIC 0x01
949 #define LANG_ARMENIAN 0x2b
950 #define LANG_ASSAMESE 0x4d
951 #define LANG_AZERI 0x2c
952 #define LANG_AZERBAIJANI 0x2c
953 #define LANG_BANGLA 0x45
954 #define LANG_BASHKIR 0x6d
955 #define LANG_BASQUE 0x2d
956 #define LANG_BELARUSIAN 0x23
957 #define LANG_BENGALI 0x45
958 #define LANG_BOSNIAN 0x1a
959 #define LANG_BOSNIAN_NEUTRAL 0x781a
960 #define LANG_BRETON 0x7e
961 #define LANG_BULGARIAN 0x02
962 #define LANG_CATALAN 0x03
963 #define LANG_CENTRAL_KURDISH 0x92
964 #define LANG_CHEROKEE 0x5c
965 #define LANG_CHINESE 0x04
966 #define LANG_CHINESE_SIMPLIFIED 0x04
967 #define LANG_CHINESE_TRADITIONAL 0x7c04
968 #define LANG_CORSICAN 0x83
969 #define LANG_CROATIAN 0x1a
970 #define LANG_CZECH 0x05
971 #define LANG_DANISH 0x06
972 #define LANG_DARI 0x8c
973 #define LANG_DIVEHI 0x65
974 #define LANG_DUTCH 0x13
975 #define LANG_ENGLISH 0x09
976 #define LANG_ESTONIAN 0x25
977 #define LANG_FAEROESE 0x38
978 #define LANG_FARSI 0x29
979 #define LANG_FILIPINO 0x64
980 #define LANG_FINNISH 0x0b
981 #define LANG_FRENCH 0x0c
982 #define LANG_FRISIAN 0x62
983 #define LANG_FULAH 0x67
984 #define LANG_GALICIAN 0x56
985 #define LANG_GEORGIAN 0x37
986 #define LANG_GERMAN 0x07
987 #define LANG_GREEK 0x08
988 #define LANG_GREENLANDIC 0x6f
989 #define LANG_GUJARATI 0x47
990 #define LANG_HAUSA 0x68
991 #define LANG_HAWAIIAN 0x75
992 #define LANG_HEBREW 0x0d
993 #define LANG_HINDI 0x39
994 #define LANG_HUNGARIAN 0x0e
995 #define LANG_ICELANDIC 0x0f
996 #define LANG_IGBO 0x70
997 #define LANG_INDONESIAN 0x21
998 #define LANG_INUKTITUT 0x5d
999 #define LANG_IRISH 0x3c
1000 #define LANG_ITALIAN 0x10
1001 #define LANG_JAPANESE 0x11
1002 #define LANG_KANNADA 0x4b
1003 #define LANG_KASHMIRI 0x60
1004 #define LANG_KAZAK 0x3f
1005 #define LANG_KHMER 0x53
1006 #define LANG_KICHE 0x86
1007 #define LANG_KINYARWANDA 0x87
1008 #define LANG_KONKANI 0x57
1009 #define LANG_KOREAN 0x12
1010 #define LANG_KYRGYZ 0x40
1011 #define LANG_LAO 0x54
1012 #define LANG_LATVIAN 0x26
1013 #define LANG_LITHUANIAN 0x27
1014 #define LANG_LOWER_SORBIAN 0x2e
1015 #define LANG_LUXEMBOURGISH 0x6e
1016 #define LANG_MACEDONIAN 0x2f
1017 #define LANG_MALAY 0x3e
1018 #define LANG_MALAYALAM 0x4c
1019 #define LANG_MALTESE 0x3a
1020 #define LANG_MANIPURI 0x58
1021 #define LANG_MAORI 0x81
1022 #define LANG_MAPUDUNGUN 0x7a
1023 #define LANG_MARATHI 0x4e
1024 #define LANG_MOHAWK 0x7c
1025 #define LANG_MONGOLIAN 0x50
1026 #define LANG_NEPALI 0x61
1027 #define LANG_NORWEGIAN 0x14
1028 #define LANG_OCCITAN 0x82
1029 #define LANG_ODIA 0x48
1030 #define LANG_ORIYA 0x48
1031 #define LANG_PASHTO 0x63
1032 #define LANG_PERSIAN 0x29
1033 #define LANG_POLISH 0x15
1034 #define LANG_PORTUGUESE 0x16
1035 #define LANG_PULAR 0x67
1036 #define LANG_PUNJABI 0x46
1037 #define LANG_QUECHUA 0x6b
1038 #define LANG_ROMANIAN 0x18
1039 #define LANG_ROMANSH 0x17
1040 #define LANG_RUSSIAN 0x19
1041 #define LANG_SAKHA 0x85
1042 #define LANG_SAMI 0x3b
1043 #define LANG_SANSKRIT 0x4f
1044 #define LANG_SCOTTISH_GAELIC 0x91
1045 #define LANG_SERBIAN 0x1a
1046 #define LANG_SERBIAN_NEUTRAL 0x7c1a
1047 #define LANG_SINDHI 0x59
1048 #define LANG_SINHALESE 0x5b
1049 #define LANG_SLOVAK 0x1b
1050 #define LANG_SLOVENIAN 0x24
1051 #define LANG_SOTHO 0x6c
1052 #define LANG_SPANISH 0x0a
1053 #define LANG_SWAHILI 0x41
1054 #define LANG_SWEDISH 0x1d
1055 #define LANG_SYRIAC 0x5a
1056 #define LANG_TAJIK 0x28
1057 #define LANG_TAMAZIGHT 0x5f
1058 #define LANG_TAMIL 0x49
1059 #define LANG_TATAR 0x44
1060 #define LANG_TELUGU 0x4a
1061 #define LANG_THAI 0x1e
1062 #define LANG_TIBETAN 0x51
1063 #define LANG_TIGRIGNA 0x73
1064 #define LANG_TIGRINYA 0x73
1065 #define LANG_TSWANA 0x32
1066 #define LANG_TURKISH 0x1f
1067 #define LANG_TURKMEN 0x42
1068 #define LANG_UIGHUR 0x80
1069 #define LANG_UKRAINIAN 0x22
1070 #define LANG_UPPER_SORBIAN 0x2e
1071 #define LANG_URDU 0x20
1072 #define LANG_UZBEK 0x43
1073 #define LANG_VALENCIAN 0x03
1074 #define LANG_VIETNAMESE 0x2a
1075 #define LANG_WELSH 0x52
1076 #define LANG_WOLOF 0x88
1077 #define LANG_XHOSA 0x34
1078 #define LANG_YAKUT 0x85
1079 #define LANG_YI 0x78
1080 #define LANG_YORUBA 0x6a
1081 #define LANG_ZULU 0x35
1082
1083 #define SUBLANG_NEUTRAL 0x00
1084 #define SUBLANG_DEFAULT 0x01
1085 #define SUBLANG_SYS_DEFAULT 0x02
1086 #define SUBLANG_CUSTOM_DEFAULT 0x03
1087 #define SUBLANG_CUSTOM_UNSPECIFIED 0x04
1088 #define SUBLANG_UI_CUSTOM_DEFAULT 0x05
1089 #define SUBLANG_AFRIKAANS_SOUTH_AFRICA 0x01
1090 #define SUBLANG_ALBANIAN_ALBANIA 0x01
1091 #define SUBLANG_ALSATIAN_FRANCE 0x01
1092 #define SUBLANG_AMHARIC_ETHIOPIA 0x01
1093 #define SUBLANG_ARABIC_SAUDI_ARABIA 0x01
1094 #define SUBLANG_ARABIC_IRAQ 0x02
1095 #define SUBLANG_ARABIC_EGYPT 0x03
1096 #define SUBLANG_ARABIC_LIBYA 0x04
1097 #define SUBLANG_ARABIC_ALGERIA 0x05
1098 #define SUBLANG_ARABIC_MOROCCO 0x06
1099 #define SUBLANG_ARABIC_TUNISIA 0x07
1100 #define SUBLANG_ARABIC_OMAN 0x08
1101 #define SUBLANG_ARABIC_YEMEN 0x09
1102 #define SUBLANG_ARABIC_SYRIA 0x0a
1103 #define SUBLANG_ARABIC_JORDAN 0x0b
1104 #define SUBLANG_ARABIC_LEBANON 0x0c
1105 #define SUBLANG_ARABIC_KUWAIT 0x0d
1106 #define SUBLANG_ARABIC_UAE 0x0e
1107 #define SUBLANG_ARABIC_BAHRAIN 0x0f
1108 #define SUBLANG_ARABIC_QATAR 0x10
1109 #define SUBLANG_ARMENIAN_ARMENIA 0x01
1110 #define SUBLANG_ASSAMESE_INDIA 0x01
1111 #define SUBLANG_AZERI_LATIN 0x01
1112 #define SUBLANG_AZERI_CYRILLIC 0x02
1113 #define SUBLANG_AZERBAIJANI_AZERBAIJAN_LATIN 0x01
1114 #define SUBLANG_AZERBAIJANI_AZERBAIJAN_CYRILLIC 0x02
1115 #define SUBLANG_BANGLA_INDIA 0x01
1116 #define SUBLANG_BANGLA_BANGLADESH 0x02
1117 #define SUBLANG_BASHKIR_RUSSIA 0x01
1118 #define SUBLANG_BASQUE_BASQUE 0x01
1119 #define SUBLANG_BELARUSIAN_BELARUS 0x01
1120 #define SUBLANG_BENGALI_INDIA 0x01
1121 #define SUBLANG_BENGALI_BANGLADESH 0x02
1122 #define SUBLANG_BOSNIAN_BOSNIA_HERZEGOVINA_LATIN 0x05
1123 #define SUBLANG_BOSNIAN_BOSNIA_HERZEGOVINA_CYRILLIC 0x08
1124 #define SUBLANG_BRETON_FRANCE 0x01
1125 #define SUBLANG_BULGARIAN_BULGARIA 0x01
1126 #define SUBLANG_CATALAN_CATALAN 0x01
1127 #define SUBLANG_CENTRAL_KURDISH_IRAQ 0x01
1128 #define SUBLANG_CHEROKEE_CHEROKEE 0x01
1129 #define SUBLANG_CHINESE_TRADITIONAL 0x01
1130 #define SUBLANG_CHINESE_SIMPLIFIED 0x02
1131 #define SUBLANG_CHINESE_HONGKONG 0x03
1132 #define SUBLANG_CHINESE_SINGAPORE 0x04
1133 #define SUBLANG_CHINESE_MACAU 0x05
1134 #define SUBLANG_CORSICAN_FRANCE 0x01
1135 #define SUBLANG_CZECH_CZECH_REPUBLIC 0x01
1136 #define SUBLANG_CROATIAN_CROATIA 0x01
1137 #define SUBLANG_CROATIAN_BOSNIA_HERZEGOVINA_LATIN 0x04
1138 #define SUBLANG_DANISH_DENMARK 0x01
1139 #define SUBLANG_DARI_AFGHANISTAN 0x01
1140 #define SUBLANG_DIVEHI_MALDIVES 0x01
1141 #define SUBLANG_DUTCH 0x01
1142 #define SUBLANG_DUTCH_BELGIAN 0x02
1143 #define SUBLANG_ENGLISH_US 0x01
1144 #define SUBLANG_ENGLISH_UK 0x02
1145 #define SUBLANG_ENGLISH_AUS 0x03
1146 #define SUBLANG_ENGLISH_CAN 0x04
1147 #define SUBLANG_ENGLISH_NZ 0x05
1148 #define SUBLANG_ENGLISH_EIRE 0x06
1149 #define SUBLANG_ENGLISH_SOUTH_AFRICA 0x07
1150 #define SUBLANG_ENGLISH_JAMAICA 0x08
1151 #define SUBLANG_ENGLISH_CARIBBEAN 0x09
1152 #define SUBLANG_ENGLISH_BELIZE 0x0a
1153 #define SUBLANG_ENGLISH_TRINIDAD 0x0b
1154 #define SUBLANG_ENGLISH_ZIMBABWE 0x0c
1155 #define SUBLANG_ENGLISH_PHILIPPINES 0x0d
1156 #define SUBLANG_ENGLISH_INDIA 0x10
1157 #define SUBLANG_ENGLISH_MALAYSIA 0x11
1158 #define SUBLANG_ENGLISH_SINGAPORE 0x12
1159 #define SUBLANG_ESTONIAN_ESTONIA 0x01
1160 #define SUBLANG_FAEROESE_FAROE_ISLANDS 0x01
1161 #define SUBLANG_FILIPINO_PHILIPPINES 0x01
1162 #define SUBLANG_FINNISH_FINLAND 0x01
1163 #define SUBLANG_FRENCH 0x01
1164 #define SUBLANG_FRENCH_BELGIAN 0x02
1165 #define SUBLANG_FRENCH_CANADIAN 0x03
1166 #define SUBLANG_FRENCH_SWISS 0x04
1167 #define SUBLANG_FRENCH_LUXEMBOURG 0x05
1168 #define SUBLANG_FRENCH_MONACO 0x06
1169 #define SUBLANG_FRISIAN_NETHERLANDS 0x01
1170 #define SUBLANG_FULAH_SENEGAL 0x02
1171 #define SUBLANG_GALICIAN_GALICIAN 0x01
1172 #define SUBLANG_GEORGIAN_GEORGIA 0x01
1173 #define SUBLANG_GERMAN 0x01
1174 #define SUBLANG_GERMAN_SWISS 0x02
1175 #define SUBLANG_GERMAN_AUSTRIAN 0x03
1176 #define SUBLANG_GERMAN_LUXEMBOURG 0x04
1177 #define SUBLANG_GERMAN_LIECHTENSTEIN 0x05
1178 #define SUBLANG_GREEK_GREECE 0x01
1179 #define SUBLANG_GREENLANDIC_GREENLAND 0x01
1180 #define SUBLANG_GUJARATI_INDIA 0x01
1181 #define SUBLANG_HAUSA_NIGERIA_LATIN 0x01
1182 #define SUBLANG_HAWAIIAN_US 0x01
1183 #define SUBLANG_HEBREW_ISRAEL 0x01
1184 #define SUBLANG_HINDI_INDIA 0x01
1185 #define SUBLANG_HUNGARIAN_HUNGARY 0x01
1186 #define SUBLANG_ICELANDIC_ICELAND 0x01
1187 #define SUBLANG_IGBO_NIGERIA 0x01
1188 #define SUBLANG_INDONESIAN_INDONESIA 0x01
1189 #define SUBLANG_INUKTITUT_CANADA 0x01
1190 #define SUBLANG_INUKTITUT_CANADA_LATIN 0x02
1191 #define SUBLANG_IRISH_IRELAND 0x02
1192 #define SUBLANG_ITALIAN 0x01
1193 #define SUBLANG_ITALIAN_SWISS 0x02
1194 #define SUBLANG_JAPANESE_JAPAN 0x01
1195 #define SUBLANG_KANNADA_INDIA 0x01
1196 #define SUBLANG_KASHMIRI_SASIA 0x02
1197 #define SUBLANG_KASHMIRI_INDIA 0x02
1198 #define SUBLANG_KAZAK_KAZAKHSTAN 0x01
1199 #define SUBLANG_KHMER_CAMBODIA 0x01
1200 #define SUBLANG_KICHE_GUATEMALA 0x01
1201 #define SUBLANG_KINYARWANDA_RWANDA 0x01
1202 #define SUBLANG_KONKANI_INDIA 0x01
1203 #define SUBLANG_KOREAN 0x01
1204 #define SUBLANG_KYRGYZ_KYRGYZSTAN 0x01
1205 #define SUBLANG_LAO_LAO 0x01
1206 #define SUBLANG_LATVIAN_LATVIA 0x01
1207 #define SUBLANG_LITHUANIAN 0x01
1208 #define SUBLANG_LOWER_SORBIAN_GERMANY 0x02
1209 #define SUBLANG_LUXEMBOURGISH_LUXEMBOURG 0x01
1210 #define SUBLANG_MACEDONIAN_MACEDONIA 0x01
1211 #define SUBLANG_MALAY_MALAYSIA 0x01
1212 #define SUBLANG_MALAY_BRUNEI_DARUSSALAM 0x02
1213 #define SUBLANG_MALAYALAM_INDIA 0x01
1214 #define SUBLANG_MALTESE_MALTA 0x01
1215 #define SUBLANG_MAORI_NEW_ZEALAND 0x01
1216 #define SUBLANG_MAPUDUNGUN_CHILE 0x01
1217 #define SUBLANG_MARATHI_INDIA 0x01
1218 #define SUBLANG_MOHAWK_MOHAWK 0x01
1219 #define SUBLANG_MONGOLIAN_CYRILLIC_MONGOLIA 0x01
1220 #define SUBLANG_MONGOLIAN_PRC 0x02
1221 #define SUBLANG_NEPALI_INDIA 0x02
1222 #define SUBLANG_NEPALI_NEPAL 0x01
1223 #define SUBLANG_NORWEGIAN_BOKMAL 0x01
1224 #define SUBLANG_NORWEGIAN_NYNORSK 0x02
1225 #define SUBLANG_OCCITAN_FRANCE 0x01
1226 #define SUBLANG_ODIA_INDIA 0x01
1227 #define SUBLANG_ORIYA_INDIA 0x01
1228 #define SUBLANG_PASHTO_AFGHANISTAN 0x01
1229 #define SUBLANG_PERSIAN_IRAN 0x01
1230 #define SUBLANG_POLISH_POLAND 0x01
1231 #define SUBLANG_PORTUGUESE 0x02
1232 #define SUBLANG_PORTUGUESE_BRAZILIAN 0x01
1233 #define SUBLANG_PULAR_SENEGAL 0x02
1234 #define SUBLANG_PUNJABI_INDIA 0x01
1235 #define SUBLANG_PUNJABI_PAKISTAN 0x02
1236 #define SUBLANG_QUECHUA_BOLIVIA 0x01
1237 #define SUBLANG_QUECHUA_ECUADOR 0x02
1238 #define SUBLANG_QUECHUA_PERU 0x03
1239 #define SUBLANG_ROMANIAN_ROMANIA 0x01
1240 #define SUBLANG_ROMANSH_SWITZERLAND 0x01
1241 #define SUBLANG_RUSSIAN_RUSSIA 0x01
1242 #define SUBLANG_SAKHA_RUSSIA 0x01
1243 #define SUBLANG_SAMI_NORTHERN_NORWAY 0x01
1244 #define SUBLANG_SAMI_NORTHERN_SWEDEN 0x02
1245 #define SUBLANG_SAMI_NORTHERN_FINLAND 0x03
1246 #define SUBLANG_SAMI_LULE_NORWAY 0x04
1247 #define SUBLANG_SAMI_LULE_SWEDEN 0x05
1248 #define SUBLANG_SAMI_SOUTHERN_NORWAY 0x06
1249 #define SUBLANG_SAMI_SOUTHERN_SWEDEN 0x07
1250 #define SUBLANG_SAMI_SKOLT_FINLAND 0x08
1251 #define SUBLANG_SAMI_INARI_FINLAND 0x09
1252 #define SUBLANG_SANSKRIT_INDIA 0x01
1253 #define SUBLANG_SCOTTISH_GAELIC 0x01
1254 #define SUBLANG_SERBIAN_BOSNIA_HERZEGOVINA_LATIN 0x06
1255 #define SUBLANG_SERBIAN_BOSNIA_HERZEGOVINA_CYRILLIC 0x07
1256 #define SUBLANG_SERBIAN_MONTENEGRO_LATIN 0x0b
1257 #define SUBLANG_SERBIAN_MONTENEGRO_CYRILLIC 0x0c
1258 #define SUBLANG_SERBIAN_SERBIA_LATIN 0x09
1259 #define SUBLANG_SERBIAN_SERBIA_CYRILLIC 0x0a
1260 #define SUBLANG_SERBIAN_CROATIA 0x01
1261 #define SUBLANG_SERBIAN_LATIN 0x02
1262 #define SUBLANG_SERBIAN_CYRILLIC 0x03
1263 #define SUBLANG_SINDHI_INDIA 0x01
1264 #define SUBLANG_SINDHI_PAKISTAN 0x02
1265 #define SUBLANG_SINDHI_AFGHANISTAN 0x02
1266 #define SUBLANG_SINHALESE_SRI_LANKA 0x01
1267 #define SUBLANG_SOTHO_NORTHERN_SOUTH_AFRICA 0x01
1268 #define SUBLANG_SLOVAK_SLOVAKIA 0x01
1269 #define SUBLANG_SLOVENIAN_SLOVENIA 0x01
1270 #define SUBLANG_SPANISH 0x01
1271 #define SUBLANG_SPANISH_MEXICAN 0x02
1272 #define SUBLANG_SPANISH_MODERN 0x03
1273 #define SUBLANG_SPANISH_GUATEMALA 0x04
1274 #define SUBLANG_SPANISH_COSTA_RICA 0x05
1275 #define SUBLANG_SPANISH_PANAMA 0x06
1276 #define SUBLANG_SPANISH_DOMINICAN_REPUBLIC 0x07
1277 #define SUBLANG_SPANISH_VENEZUELA 0x08
1278 #define SUBLANG_SPANISH_COLOMBIA 0x09
1279 #define SUBLANG_SPANISH_PERU 0x0a
1280 #define SUBLANG_SPANISH_ARGENTINA 0x0b
1281 #define SUBLANG_SPANISH_ECUADOR 0x0c
1282 #define SUBLANG_SPANISH_CHILE 0x0d
1283 #define SUBLANG_SPANISH_URUGUAY 0x0e
1284 #define SUBLANG_SPANISH_PARAGUAY 0x0f
1285 #define SUBLANG_SPANISH_BOLIVIA 0x10
1286 #define SUBLANG_SPANISH_EL_SALVADOR 0x11
1287 #define SUBLANG_SPANISH_HONDURAS 0x12
1288 #define SUBLANG_SPANISH_NICARAGUA 0x13
1289 #define SUBLANG_SPANISH_PUERTO_RICO 0x14
1290 #define SUBLANG_SPANISH_US 0x15
1291 #define SUBLANG_SWAHILI_KENYA 0x01
1292 #define SUBLANG_SWEDISH 0x01
1293 #define SUBLANG_SWEDISH_FINLAND 0x02
1294 #define SUBLANG_SYRIAC_SYRIA 0x01
1295 #define SUBLANG_TAJIK_TAJIKISTAN 0x01
1296 #define SUBLANG_TAMAZIGHT_ALGERIA_LATIN 0x02
1297 #define SUBLANG_TAMAZIGHT_MOROCCO_TIFINAGH 0x04
1298 #define SUBLANG_TAMIL_INDIA 0x01
1299 #define SUBLANG_TAMIL_SRI_LANKA 0x02
1300 #define SUBLANG_TATAR_RUSSIA 0x01
1301 #define SUBLANG_TELUGU_INDIA 0x01
1302 #define SUBLANG_THAI_THAILAND 0x01
1303 #define SUBLANG_TIBETAN_PRC 0x01
1304 #define SUBLANG_TIGRIGNA_ERITREA 0x02
1305 #define SUBLANG_TIGRINYA_ERITREA 0x02
1306 #define SUBLANG_TIGRINYA_ETHIOPIA 0x01
1307 #define SUBLANG_TSWANA_BOTSWANA 0x02
1308 #define SUBLANG_TSWANA_SOUTH_AFRICA 0x01
1309 #define SUBLANG_TURKISH_TURKEY 0x01
1310 #define SUBLANG_TURKMEN_TURKMENISTAN 0x01
1311 #define SUBLANG_UIGHUR_PRC 0x01
1312 #define SUBLANG_UKRAINIAN_UKRAINE 0x01
1313 #define SUBLANG_UPPER_SORBIAN_GERMANY 0x01
1314 #define SUBLANG_URDU_PAKISTAN 0x01
1315 #define SUBLANG_URDU_INDIA 0x02
1316 #define SUBLANG_UZBEK_LATIN 0x01
1317 #define SUBLANG_UZBEK_CYRILLIC 0x02
1318 #define SUBLANG_VALENCIAN_VALENCIA 0x02
1319 #define SUBLANG_VIETNAMESE_VIETNAM 0x01
1320 #define SUBLANG_WELSH_UNITED_KINGDOM 0x01
1321 #define SUBLANG_WOLOF_SENEGAL 0x01
1322 #define SUBLANG_XHOSA_SOUTH_AFRICA 0x01
1323 #define SUBLANG_YAKUT_RUSSIA 0x01
1324 #define SUBLANG_YI_PRC 0x01
1325 #define SUBLANG_YORUBA_NIGERIA 0x01
1326 #define SUBLANG_ZULU_SOUTH_AFRICA 0x01
1327
1328 #define SORT_DEFAULT 0x0
1329 #define SORT_INVARIANT_MATH 0x1
1330 #define SORT_JAPANESE_XJIS 0x0
1331 #define SORT_JAPANESE_UNICODE 0x1
1332 #define SORT_JAPANESE_RADICALSTROKE 0x4
1333 #define SORT_CHINESE_BIG5 0x0
1334 #define SORT_CHINESE_PRCP 0x0
1335 #define SORT_CHINESE_UNICODE 0x1
1336 #define SORT_CHINESE_PRC 0x2
1337 #define SORT_CHINESE_BOPOMOFO 0x3
1338 #define SORT_CHINESE_RADICALSTROKE 0x4
1339 #define SORT_KOREAN_KSC 0x0
1340 #define SORT_KOREAN_UNICODE 0x1
1341 #define SORT_GERMAN_PHONE_BOOK 0x1
1342 #define SORT_HUNGARIAN_DEFAULT 0x0
1343 #define SORT_HUNGARIAN_TECHNICAL 0x1
1344 #define SORT_GEORGIAN_TRADITIONAL 0x0
1345 #define SORT_GEORGIAN_MODERN 0x1
1346
1347 #define LANG_SYSTEM_DEFAULT MAKELANGID(LANG_NEUTRAL, SUBLANG_SYS_DEFAULT)
1348 #define LANG_USER_DEFAULT MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT)
1349
1350 #define LOCALE_SYSTEM_DEFAULT MAKELCID(LANG_SYSTEM_DEFAULT, SORT_DEFAULT)
1351 #define LOCALE_USER_DEFAULT MAKELCID(LANG_USER_DEFAULT, SORT_DEFAULT)
1352 #define LOCALE_CUSTOM_DEFAULT MAKELCID(MAKELANGID(LANG_NEUTRAL, SUBLANG_CUSTOM_DEFAULT), SORT_DEFAULT)
1353 #define LOCALE_CUSTOM_UNSPECIFIED MAKELCID(MAKELANGID(LANG_NEUTRAL, SUBLANG_CUSTOM_UNSPECIFIED), SORT_DEFAULT)
1354 #define LOCALE_CUSTOM_UI_DEFAULT MAKELCID(MAKELANGID(LANG_NEUTRAL, SUBLANG_UI_CUSTOM_DEFAULT), SORT_DEFAULT)
1355 #define LOCALE_NEUTRAL MAKELCID(MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL), SORT_DEFAULT)
1356 #define LOCALE_INVARIANT MAKELCID(MAKELANGID(LANG_INVARIANT, SUBLANG_NEUTRAL), SORT_DEFAULT)
1357
1358 #undef __C89_NAMELESS
1359 #undef __C89_NAMELESSSTRUCTNAME
1360 #undef __C89_NAMELESSSTRUCTNAME1
1361 #undef __C89_NAMELESSSTRUCTNAME2
1362 #undef __C89_NAMELESSSTRUCTNAME3
1363 #undef __C89_NAMELESSSTRUCTNAME4
1364 #undef __C89_NAMELESSSTRUCTNAME5
1365 #undef __C89_NAMELESSUNIONNAME
1366 #undef __C89_NAMELESSUNIONNAME1
1367 #undef __C89_NAMELESSUNIONNAME2
1368 #undef __C89_NAMELESSUNIONNAME3
1369 #undef __C89_NAMELESSUNIONNAME4
1370 #undef __C89_NAMELESSUNIONNAME5
1371 #undef __C89_NAMELESSUNIONNAME6
1372 #undef __C89_NAMELESSUNIONNAME7
1373 #undef __C89_NAMELESSUNIONNAME8
1374
1375 #if !defined(__WINESRC__) && !defined(WINE_NO_NAMELESS_EXTENSION)
1376 # ifdef __GNUC__
1377 /* Anonymous structs support starts with gcc 2.96/g++ 2.95 */
1378 # if (__GNUC__ > 2) || ((__GNUC__ == 2) && ((__GNUC_MINOR__ > 95) || ((__GNUC_MINOR__ == 95) && defined(__cplusplus))))
1379 # define __C89_NAMELESS __extension__
1380 # endif
1381 # elif defined(_MSC_VER)
1382 # define __C89_NAMELESS
1383 # endif
1384 #endif
1385
1386 #ifdef __C89_NAMELESS
1387 # define __C89_NAMELESSSTRUCTNAME
1388 # define __C89_NAMELESSSTRUCTNAME1
1389 # define __C89_NAMELESSSTRUCTNAME2
1390 # define __C89_NAMELESSSTRUCTNAME3
1391 # define __C89_NAMELESSSTRUCTNAME4
1392 # define __C89_NAMELESSSTRUCTNAME5
1393 # define __C89_NAMELESSUNIONNAME
1394 # define __C89_NAMELESSUNIONNAME1
1395 # define __C89_NAMELESSUNIONNAME2
1396 # define __C89_NAMELESSUNIONNAME3
1397 # define __C89_NAMELESSUNIONNAME4
1398 # define __C89_NAMELESSUNIONNAME5
1399 # define __C89_NAMELESSUNIONNAME6
1400 # define __C89_NAMELESSUNIONNAME7
1401 # define __C89_NAMELESSUNIONNAME8
1402 #else
1403 # define __C89_NAMELESS
1404 # define __C89_NAMELESSSTRUCTNAME DUMMYSTRUCTNAME
1405 # define __C89_NAMELESSSTRUCTNAME1 DUMMYSTRUCTNAME1
1406 # define __C89_NAMELESSSTRUCTNAME2 DUMMYSTRUCTNAME2
1407 # define __C89_NAMELESSSTRUCTNAME3 DUMMYSTRUCTNAME3
1408 # define __C89_NAMELESSSTRUCTNAME4 DUMMYSTRUCTNAME4
1409 # define __C89_NAMELESSSTRUCTNAME5 DUMMYSTRUCTNAME5
1410 # define __C89_NAMELESSUNIONNAME DUMMYUNIONNAME
1411 # define __C89_NAMELESSUNIONNAME1 DUMMYUNIONNAME1
1412 # define __C89_NAMELESSUNIONNAME2 DUMMYUNIONNAME2
1413 # define __C89_NAMELESSUNIONNAME3 DUMMYUNIONNAME3
1414 # define __C89_NAMELESSUNIONNAME4 DUMMYUNIONNAME4
1415 # define __C89_NAMELESSUNIONNAME5 DUMMYUNIONNAME5
1416 # define __C89_NAMELESSUNIONNAME6 DUMMYUNIONNAME6
1417 # define __C89_NAMELESSUNIONNAME7 DUMMYUNIONNAME7
1418 # define __C89_NAMELESSUNIONNAME8 DUMMYUNIONNAME8
1419 #endif
1420
1421 #define DECLSPEC_HIDDEN
1422
1423 /*#ifdef _WINE*/
1424 #if defined(__GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 3)))
1425 # define __WINE_ALLOC_SIZE(x) __attribute__((__alloc_size__(x)))
1426 #else
1427 # define __WINE_ALLOC_SIZE(x)
1428 #endif
1429 /*#endif*/
1430
1431 #ifdef __GNUC__
1432 # define _HAVE_INT64
1433 # ifndef _INTEGRAL_MAX_BITS
1434 # define _INTEGRAL_MAX_BITS 64
1435 # endif
1436 # undef __int64
1437 # define __int64 long long
1438 #elif (defined(__WATCOMC__) || defined(_MSC_VER)) && (defined(_INTEGRAL_MAX_BITS) && _INTEGRAL_MAX_BITS >= 64 )
1439 # define _HAVE_INT64
1440 #endif /* __GNUC__/__WATCOMC */
1441
1442 #ifdef _MSC_VER
1443 # pragma warning(push)
1444 # pragma warning(disable:4201)
1445 # pragma warning(disable:4214)
1446 # pragma warning(disable:4820)
1447 #endif
1448
1449 #define ACE_OBJECT_TYPE_PRESENT 0x00000001
1450 #define ACE_INHERITED_OBJECT_TYPE_PRESENT 0x00000002
1451
1452 /* also in ddk/ntifs.h */
1453 #define COMPRESSION_FORMAT_NONE (0x0000)
1454 #define COMPRESSION_FORMAT_DEFAULT (0x0001)
1455 #define COMPRESSION_FORMAT_LZNT1 (0x0002)
1456 #define COMPRESSION_ENGINE_STANDARD (0x0000)
1457 #define COMPRESSION_ENGINE_MAXIMUM (0x0100)
1458 #define COMPRESSION_ENGINE_HIBER (0x0200)
1459 #define ACCESS_ALLOWED_ACE_TYPE (0x0)
1460 #define ACCESS_DENIED_ACE_TYPE (0x1)
1461 #define SYSTEM_AUDIT_ACE_TYPE (0x2)
1462 #define SYSTEM_ALARM_ACE_TYPE (0x3)
1463 /*end ntifs.h */
1464 #define OBJECT_INHERIT_ACE 1
1465 #define CONTAINER_INHERIT_ACE 2
1466 #define NO_PROPAGATE_INHERIT_ACE 4
1467 #define INHERIT_ONLY_ACE 8
1468 #define INHERITED_ACE 16
1469 #define VALID_INHERIT_FLAGS 0x1F
1470 #define SUCCESSFUL_ACCESS_ACE_FLAG 64
1471 #define FAILED_ACCESS_ACE_FLAG 128
1472 #define DELETE 0x00010000L
1473 #define READ_CONTROL 0x20000L
1474 #define WRITE_DAC 0x40000L
1475 #define WRITE_OWNER 0x80000L
1476 #define SYNCHRONIZE 0x100000L
1477 #define STANDARD_RIGHTS_REQUIRED 0xF0000
1478 #define STANDARD_RIGHTS_READ 0x20000
1479 #define STANDARD_RIGHTS_WRITE 0x20000
1480 #define STANDARD_RIGHTS_EXECUTE 0x20000
1481 #define STANDARD_RIGHTS_ALL 0x1F0000
1482 #define SPECIFIC_RIGHTS_ALL 0xFFFF
1483 #define ACCESS_SYSTEM_SECURITY 0x1000000
1484
1485 #define REG_STANDARD_FORMAT 1
1486 #define REG_LATEST_FORMAT 2
1487 #define REG_NO_COMPRESSION 4
1488
1489 #ifndef WIN32_NO_STATUS
1490
1491 #define STATUS_WAIT_0 ((DWORD)0x00000000)
1492 #define STATUS_ABANDONED_WAIT_0 ((DWORD)0x00000080)
1493 #define STATUS_USER_APC ((DWORD)0x000000C0)
1494 #define STATUS_TIMEOUT ((DWORD)0x00000102)
1495 #define STATUS_PENDING ((DWORD)0x00000103)
1496 #define STATUS_SEGMENT_NOTIFICATION ((DWORD)0x40000005)
1497 #define STATUS_GUARD_PAGE_VIOLATION ((DWORD)0x80000001)
1498 #define STATUS_DATATYPE_MISALIGNMENT ((DWORD)0x80000002)
1499 #define STATUS_BREAKPOINT ((DWORD)0x80000003)
1500 #define STATUS_SINGLE_STEP ((DWORD)0x80000004)
1501 #define STATUS_ACCESS_VIOLATION ((DWORD)0xC0000005)
1502 #define STATUS_IN_PAGE_ERROR ((DWORD)0xC0000006)
1503 #define STATUS_INVALID_HANDLE ((DWORD)0xC0000008)
1504 #define STATUS_NO_MEMORY ((DWORD)0xC0000017)
1505 #define STATUS_ILLEGAL_INSTRUCTION ((DWORD)0xC000001D)
1506 #define STATUS_NONCONTINUABLE_EXCEPTION ((DWORD)0xC0000025)
1507 #define STATUS_INVALID_DISPOSITION ((DWORD)0xC0000026)
1508 #define STATUS_ARRAY_BOUNDS_EXCEEDED ((DWORD)0xC000008C)
1509 #define STATUS_FLOAT_DENORMAL_OPERAND ((DWORD)0xC000008D)
1510 #define STATUS_FLOAT_DIVIDE_BY_ZERO ((DWORD)0xC000008E)
1511 #define STATUS_FLOAT_INEXACT_RESULT ((DWORD)0xC000008F)
1512 #define STATUS_FLOAT_INVALID_OPERATION ((DWORD)0xC0000090)
1513 #define STATUS_FLOAT_OVERFLOW ((DWORD)0xC0000091)
1514 #define STATUS_FLOAT_STACK_CHECK ((DWORD)0xC0000092)
1515 #define STATUS_FLOAT_UNDERFLOW ((DWORD)0xC0000093)
1516 #define STATUS_INTEGER_DIVIDE_BY_ZERO ((DWORD)0xC0000094)
1517 #define STATUS_INTEGER_OVERFLOW ((DWORD)0xC0000095)
1518 #define STATUS_PRIVILEGED_INSTRUCTION ((DWORD)0xC0000096)
1519 #define STATUS_STACK_OVERFLOW ((DWORD)0xC00000FD)
1520 #define STATUS_CONTROL_C_EXIT ((DWORD)0xC000013A)
1521 #define STATUS_FLOAT_MULTIPLE_FAULTS ((DWORD)0xC00002B4)
1522 #define STATUS_FLOAT_MULTIPLE_TRAPS ((DWORD)0xC00002B5)
1523 #define STATUS_REG_NAT_CONSUMPTION ((DWORD)0xC00002C9)
1524 #define STATUS_SXS_EARLY_DEACTIVATION ((DWORD)0xC015000F)
1525 #define STATUS_SXS_INVALID_DEACTIVATION ((DWORD)0xC0150010)
1526
1527 #define DBG_EXCEPTION_HANDLED ((DWORD)0x00010001)
1528 #define DBG_CONTINUE ((DWORD)0x00010002)
1529 #define DBG_TERMINATE_THREAD ((DWORD)0x40010003)
1530 #define DBG_TERMINATE_PROCESS ((DWORD)0x40010004)
1531 #define DBG_CONTROL_C ((DWORD)0x40010005)
1532 #define DBG_CONTROL_BREAK ((DWORD)0x40010008)
1533 #define DBG_COMMAND_EXCEPTION ((DWORD)0x40010009)
1534 #define DBG_EXCEPTION_NOT_HANDLED ((DWORD)0x80010001)
1535
1536 #endif /* WIN32_NO_STATUS */
1537
1538 #define MAXIMUM_ALLOWED 0x2000000
1539 #define GENERIC_READ 0x80000000
1540 #define GENERIC_WRITE 0x40000000
1541 #define GENERIC_EXECUTE 0x20000000
1542 #define GENERIC_ALL 0x10000000
1543
1544 #define INVALID_FILE_ATTRIBUTES ((DWORD)-1)
1545
1546 /* Also in ddk/winddk.h */
1547 #define FILE_LIST_DIRECTORY 0x00000001
1548 #define FILE_READ_DATA 0x00000001
1549 #define FILE_ADD_FILE 0x00000002
1550 #define FILE_WRITE_DATA 0x00000002
1551 #define FILE_ADD_SUBDIRECTORY 0x00000004
1552 #define FILE_APPEND_DATA 0x00000004
1553 #define FILE_CREATE_PIPE_INSTANCE 0x00000004
1554 #define FILE_READ_EA 0x00000008
1555 #define FILE_READ_PROPERTIES 0x00000008
1556 #define FILE_WRITE_EA 0x00000010
1557 #define FILE_WRITE_PROPERTIES 0x00000010
1558 #define FILE_EXECUTE 0x00000020
1559 #define FILE_TRAVERSE 0x00000020
1560 #define FILE_DELETE_CHILD 0x00000040
1561 #define FILE_READ_ATTRIBUTES 0x00000080
1562 #define FILE_WRITE_ATTRIBUTES 0x00000100
1563
1564 #define FILE_SHARE_READ 0x00000001
1565 #define FILE_SHARE_WRITE 0x00000002
1566 #define FILE_SHARE_DELETE 0x00000004
1567 #define FILE_SHARE_VALID_FLAGS 0x00000007
1568
1569 #define FILE_ATTRIBUTE_READONLY 0x00000001
1570 #define FILE_ATTRIBUTE_HIDDEN 0x00000002
1571 #define FILE_ATTRIBUTE_SYSTEM 0x00000004
1572 #define FILE_ATTRIBUTE_DIRECTORY 0x00000010
1573 #define FILE_ATTRIBUTE_ARCHIVE 0x00000020
1574 #define FILE_ATTRIBUTE_DEVICE 0x00000040
1575 #define FILE_ATTRIBUTE_NORMAL 0x00000080
1576 #define FILE_ATTRIBUTE_TEMPORARY 0x00000100
1577 #define FILE_ATTRIBUTE_SPARSE_FILE 0x00000200
1578 #define FILE_ATTRIBUTE_REPARSE_POINT 0x00000400
1579 #define FILE_ATTRIBUTE_COMPRESSED 0x00000800
1580 #define FILE_ATTRIBUTE_OFFLINE 0x00001000
1581 #define FILE_ATTRIBUTE_NOT_CONTENT_INDEXED 0x00002000
1582 #define FILE_ATTRIBUTE_ENCRYPTED 0x00004000
1583 #define FILE_ATTRIBUTE_VALID_FLAGS 0x00007fb7
1584 #define FILE_ATTRIBUTE_VALID_SET_FLAGS 0x000031a7
1585
1586 #define FILE_COPY_STRUCTURED_STORAGE 0x00000041
1587 #define FILE_STRUCTURED_STORAGE 0x00000441
1588
1589 #define FILE_VALID_OPTION_FLAGS 0x00ffffff
1590 #define FILE_VALID_PIPE_OPTION_FLAGS 0x00000032
1591 #define FILE_VALID_MAILSLOT_OPTION_FLAGS 0x00000032
1592 #define FILE_VALID_SET_FLAGS 0x00000036
1593
1594 #define FILE_DIRECTORY_FILE 0x00000001
1595 #define FILE_WRITE_THROUGH 0x00000002
1596 #define FILE_SEQUENTIAL_ONLY 0x00000004
1597 #define FILE_NO_INTERMEDIATE_BUFFERING 0x00000008
1598 #define FILE_SYNCHRONOUS_IO_ALERT 0x00000010
1599 #define FILE_SYNCHRONOUS_IO_NONALERT 0x00000020
1600 #define FILE_NON_DIRECTORY_FILE 0x00000040
1601 #define FILE_CREATE_TREE_CONNECTION 0x00000080
1602 #define FILE_COMPLETE_IF_OPLOCKED 0x00000100
1603 #define FILE_NO_EA_KNOWLEDGE 0x00000200
1604 #define FILE_OPEN_REMOTE_INSTANCE 0x00000400
1605 #define FILE_RANDOM_ACCESS 0x00000800
1606 #define FILE_DELETE_ON_CLOSE 0x00001000
1607 #define FILE_OPEN_BY_FILE_ID 0x00002000
1608 #define FILE_OPEN_FOR_BACKUP_INTENT 0x00004000
1609 #define FILE_NO_COMPRESSION 0x00008000
1610 #define FILE_RESERVE_OPFILTER 0x00100000
1611 #define FILE_OPEN_REPARSE_POINT 0x00200000
1612 #define FILE_OPEN_NO_RECALL 0x00400000
1613 #define FILE_OPEN_FOR_FREE_SPACE_QUERY 0x00800000
1614
1615 #define FILE_ALL_ACCESS \
1616 (STANDARD_RIGHTS_REQUIRED | \
1617 SYNCHRONIZE | \
1618 0x1FF)
1619
1620 #define FILE_GENERIC_EXECUTE \
1621 (STANDARD_RIGHTS_EXECUTE | \
1622 FILE_READ_ATTRIBUTES | \
1623 FILE_EXECUTE | \
1624 SYNCHRONIZE)
1625
1626 #define FILE_GENERIC_READ \
1627 (STANDARD_RIGHTS_READ | \
1628 FILE_READ_DATA | \
1629 FILE_READ_ATTRIBUTES | \
1630 FILE_READ_EA | \
1631 SYNCHRONIZE)
1632
1633 #define FILE_GENERIC_WRITE \
1634 (STANDARD_RIGHTS_WRITE | \
1635 FILE_WRITE_DATA | \
1636 FILE_WRITE_ATTRIBUTES | \
1637 FILE_WRITE_EA | \
1638 FILE_APPEND_DATA | \
1639 SYNCHRONIZE)
1640 /* end winddk.h */
1641 /* also in ddk/ntifs.h */
1642 #define FILE_NOTIFY_CHANGE_FILE_NAME 0x00000001
1643 #define FILE_NOTIFY_CHANGE_DIR_NAME 0x00000002
1644 #define FILE_NOTIFY_CHANGE_NAME 0x00000003
1645 #define FILE_NOTIFY_CHANGE_ATTRIBUTES 0x00000004
1646 #define FILE_NOTIFY_CHANGE_SIZE 0x00000008
1647 #define FILE_NOTIFY_CHANGE_LAST_WRITE 0x00000010
1648 #define FILE_NOTIFY_CHANGE_LAST_ACCESS 0x00000020
1649 #define FILE_NOTIFY_CHANGE_CREATION 0x00000040
1650 #define FILE_NOTIFY_CHANGE_EA 0x00000080
1651 #define FILE_NOTIFY_CHANGE_SECURITY 0x00000100
1652 #define FILE_NOTIFY_CHANGE_STREAM_NAME 0x00000200
1653 #define FILE_NOTIFY_CHANGE_STREAM_SIZE 0x00000400
1654 #define FILE_NOTIFY_CHANGE_STREAM_WRITE 0x00000800
1655 #define FILE_NOTIFY_VALID_MASK 0x00000fff
1656
1657 #define FILE_CASE_SENSITIVE_SEARCH 0x00000001
1658 #define FILE_CASE_PRESERVED_NAMES 0x00000002
1659 #define FILE_UNICODE_ON_DISK 0x00000004
1660 #define FILE_PERSISTENT_ACLS 0x00000008
1661 #define FILE_FILE_COMPRESSION 0x00000010
1662 #define FILE_VOLUME_QUOTAS 0x00000020
1663 #define FILE_SUPPORTS_SPARSE_FILES 0x00000040
1664 #define FILE_SUPPORTS_REPARSE_POINTS 0x00000080
1665 #define FILE_SUPPORTS_REMOTE_STORAGE 0x00000100
1666 #define FS_LFN_APIS 0x00004000
1667 #define FILE_VOLUME_IS_COMPRESSED 0x00008000
1668 #define FILE_SUPPORTS_OBJECT_IDS 0x00010000
1669 #define FILE_SUPPORTS_ENCRYPTION 0x00020000
1670 #define FILE_NAMED_STREAMS 0x00040000
1671
1672 #define IO_COMPLETION_QUERY_STATE 0x0001
1673 #define IO_COMPLETION_MODIFY_STATE 0x0002
1674 #define IO_COMPLETION_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
1675 /* end ntifs.h */
1676
1677 /* also in ddk/winddk.h */
1678 #define DUPLICATE_CLOSE_SOURCE 0x00000001
1679 #define DUPLICATE_SAME_ACCESS 0x00000002
1680 /* end winddk.k */
1681
1682 #define MAILSLOT_NO_MESSAGE ((DWORD)-1)
1683 #define MAILSLOT_WAIT_FOREVER ((DWORD)-1)
1684 #define PROCESS_TERMINATE 1
1685 #define PROCESS_CREATE_THREAD 2
1686 #define PROCESS_SET_SESSIONID 4
1687 #define PROCESS_VM_OPERATION 8
1688 #define PROCESS_VM_READ 16
1689 #define PROCESS_VM_WRITE 32
1690 #define PROCESS_CREATE_PROCESS 128
1691 #define PROCESS_SET_QUOTA 256
1692 #define PROCESS_SET_INFORMATION 512
1693 #define PROCESS_QUERY_INFORMATION 1024
1694 #define PROCESS_SUSPEND_RESUME 2048
1695 #define PROCESS_QUERY_LIMITED_INFORMATION 0x1000
1696 #define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xFFF)
1697 #define PROCESS_DUP_HANDLE 64
1698 #define THREAD_TERMINATE 1
1699 #define THREAD_SUSPEND_RESUME 2
1700 #define THREAD_GET_CONTEXT 8
1701 #define THREAD_SET_CONTEXT 16
1702 #define THREAD_SET_INFORMATION 32
1703 #define THREAD_QUERY_INFORMATION 64
1704 #define THREAD_SET_THREAD_TOKEN 128
1705 #define THREAD_IMPERSONATE 256
1706 #define THREAD_DIRECT_IMPERSONATION 0x200
1707 #define THREAD_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3FF)
1708 #define MUTANT_QUERY_STATE 0x0001
1709 #define MUTANT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|MUTANT_QUERY_STATE)
1710 #define TIMER_QUERY_STATE 0x0001
1711 #define TIMER_MODIFY_STATE 0x0002
1712 #define TIMER_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|TIMER_QUERY_STATE|TIMER_MODIFY_STATE)
1713 #define THREAD_BASE_PRIORITY_LOWRT 15
1714 #define THREAD_BASE_PRIORITY_MAX 2
1715 #define THREAD_BASE_PRIORITY_MIN (-2)
1716 #define THREAD_BASE_PRIORITY_IDLE (-15)
1717
1718 #define PROCESS_SET_LIMITED_INFORMATION 0x2000
1719 #define THREAD_RESUME 0x1000
1720
1721 /*
1722 * To prevent gcc compiler warnings, bracket these defines when initialising
1723 * a SID_IDENTIFIER_AUTHORITY, eg.
1724 * SID_IDENTIFIER_AUTHORITY aNullSidAuthority = {SECURITY_NULL_SID_AUTHORITY};
1725 */
1726 #define SID_MAX_SUB_AUTHORITIES 15
1727
1728 /* security entities */
1729 #define SECURITY_NULL_RID (0x00000000L)
1730 #define SECURITY_WORLD_RID (0x00000000L)
1731 #define SECURITY_LOCAL_RID (0X00000000L)
1732
1733 #define SECURITY_NULL_SID_AUTHORITY {0,0,0,0,0,0}
1734
1735 /* S-1-1 */
1736 #define SECURITY_WORLD_SID_AUTHORITY {0,0,0,0,0,1}
1737
1738 /* S-1-2 */
1739 #define SECURITY_LOCAL_SID_AUTHORITY {0,0,0,0,0,2}
1740
1741 /* S-1-3 */
1742 #define SECURITY_CREATOR_SID_AUTHORITY {0,0,0,0,0,3}
1743 #define SECURITY_CREATOR_OWNER_RID (0x00000000L)
1744 #define SECURITY_CREATOR_GROUP_RID (0x00000001L)
1745 #define SECURITY_CREATOR_OWNER_SERVER_RID (0x00000002L)
1746 #define SECURITY_CREATOR_GROUP_SERVER_RID (0x00000003L)
1747
1748 /* S-1-4 */
1749 #define SECURITY_NON_UNIQUE_AUTHORITY {0,0,0,0,0,4}
1750
1751 /* S-1-5 */
1752 #define SECURITY_NT_AUTHORITY {0,0,0,0,0,5}
1753 #define SECURITY_DIALUP_RID 0x00000001L
1754 #define SECURITY_NETWORK_RID 0x00000002L
1755 #define SECURITY_BATCH_RID 0x00000003L
1756 #define SECURITY_INTERACTIVE_RID 0x00000004L
1757 #define SECURITY_LOGON_IDS_RID 0x00000005L
1758 #define SECURITY_SERVICE_RID 0x00000006L
1759 #define SECURITY_ANONYMOUS_LOGON_RID 0x00000007L
1760 #define SECURITY_PROXY_RID 0x00000008L
1761 #define SECURITY_ENTERPRISE_CONTROLLERS_RID 0x00000009L
1762 #define SECURITY_SERVER_LOGON_RID SECURITY_ENTERPRISE_CONTROLLERS_RID
1763 #define SECURITY_PRINCIPAL_SELF_RID 0x0000000AL
1764 #define SECURITY_AUTHENTICATED_USER_RID 0x0000000BL
1765 #define SECURITY_RESTRICTED_CODE_RID 0x0000000CL
1766 #define SECURITY_TERMINAL_SERVER_RID 0x0000000DL
1767 #define SECURITY_REMOTE_LOGON_RID 0x0000000EL
1768 #define SECURITY_THIS_ORGANIZATION_RID 0x0000000FL
1769 #define SECURITY_LOCAL_SYSTEM_RID 0x00000012L
1770 #define SECURITY_LOCAL_SERVICE_RID 0x00000013L
1771 #define SECURITY_NETWORK_SERVICE_RID 0x00000014L
1772 #define SECURITY_NT_NON_UNIQUE 0x00000015L
1773 #define SECURITY_BUILTIN_DOMAIN_RID 0x00000020L
1774
1775 #define SECURITY_PACKAGE_BASE_RID 0x00000040L
1776 #define SECURITY_PACKAGE_NTLM_RID 0x0000000AL
1777 #define SECURITY_PACKAGE_SCHANNEL_RID 0x0000000EL
1778 #define SECURITY_PACKAGE_DIGEST_RID 0x00000015L
1779 #define SECURITY_OTHER_ORGANIZATION_RID 0x000003E8L
1780
1781 #define SECURITY_LOGON_IDS_RID_COUNT 0x3
1782 #define SID_REVISION 1
1783
1784 #define FOREST_USER_RID_MAX 0x000001F3L
1785 #define DOMAIN_USER_RID_ADMIN 0x000001F4L
1786 #define DOMAIN_USER_RID_GUEST 0x000001F5L
1787 #define DOMAIN_USER_RID_KRBTGT 0x000001F6L
1788 #define DOMAIN_USER_RID_MAX 0x000003E7L
1789
1790 #define DOMAIN_GROUP_RID_ADMINS 0x00000200L
1791 #define DOMAIN_GROUP_RID_USERS 0x00000201L
1792 #define DOMAIN_GROUP_RID_GUESTS 0x00000202L
1793 #define DOMAIN_GROUP_RID_COMPUTERS 0x00000203L
1794 #define DOMAIN_GROUP_RID_CONTROLLERS 0x00000204L
1795 #define DOMAIN_GROUP_RID_CERT_ADMINS 0x00000205L
1796 #define DOMAIN_GROUP_RID_SCHEMA_ADMINS 0x00000206L
1797 #define DOMAIN_GROUP_RID_ENTERPRISE_ADMINS 0x00000207L
1798 #define DOMAIN_GROUP_RID_POLICY_ADMINS 0x00000208L
1799
1800 #define SECURITY_MANDATORY_LABEL_AUTHORITY {0,0,0,0,0,16}
1801 #define SECURITY_MANDATORY_UNTRUSTED_RID 0x00000000L
1802 #define SECURITY_MANDATORY_LOW_RID 0x00001000L
1803 #define SECURITY_MANDATORY_MEDIUM_RID 0x00002000L
1804 #define SECURITY_MANDATORY_HIGH_RID 0x00003000L
1805 #define SECURITY_MANDATORY_SYSTEM_RID 0x00004000L
1806 #define SECURITY_MANDATORY_PROTECTED_PROCESS_RID 0x00005000L
1807
1808 #define DOMAIN_ALIAS_RID_ADMINS 0x00000220L
1809 #define DOMAIN_ALIAS_RID_USERS 0x00000221L
1810 #define DOMAIN_ALIAS_RID_GUESTS 0x00000222L
1811 #define DOMAIN_ALIAS_RID_POWER_USERS 0x00000223L
1812
1813 #define DOMAIN_ALIAS_RID_ACCOUNT_OPS 0x00000224L
1814 #define DOMAIN_ALIAS_RID_SYSTEM_OPS 0x00000225L
1815 #define DOMAIN_ALIAS_RID_PRINT_OPS 0x00000226L
1816 #define DOMAIN_ALIAS_RID_BACKUP_OPS 0x00000227L
1817
1818 #define DOMAIN_ALIAS_RID_REPLICATOR 0x00000228L
1819 #define DOMAIN_ALIAS_RID_RAS_SERVERS 0x00000229L
1820 #define DOMAIN_ALIAS_RID_PREW2KCOMPACCESS 0x0000022AL
1821 #define DOMAIN_ALIAS_RID_REMOTE_DESKTOP_USERS 0x0000022BL
1822 #define DOMAIN_ALIAS_RID_NETWORK_CONFIGURATION_OPS 0x0000022CL
1823 #define DOMAIN_ALIAS_RID_INCOMING_FOREST_TRUST_BUILDERS 0x0000022DL
1824
1825 #define DOMAIN_ALIAS_RID_MONITORING_USERS 0x0000022EL
1826 #define DOMAIN_ALIAS_RID_LOGGING_USERS 0x0000022FL
1827 #define DOMAIN_ALIAS_RID_AUTHORIZATIONACCESS 0x00000230L
1828 #define DOMAIN_ALIAS_RID_TS_LICENSE_SERVERS 0x00000231L
1829 #define DOMAIN_ALIAS_RID_DCOM_USERS 0x00000232L
1830
1831 #define SECURITY_MANDATORY_LABEL_AUTHORITY {0,0,0,0,0,16}
1832
1833 typedef enum {
1834 WinNullSid = 0,
1835 WinWorldSid = 1,
1836 WinLocalSid = 2,
1837 WinCreatorOwnerSid = 3,
1838 WinCreatorGroupSid = 4,
1839 WinCreatorOwnerServerSid = 5,
1840 WinCreatorGroupServerSid = 6,
1841 WinNtAuthoritySid = 7,
1842 WinDialupSid = 8,
1843 WinNetworkSid = 9,
1844 WinBatchSid = 10,
1845 WinInteractiveSid = 11,
1846 WinServiceSid = 12,
1847 WinAnonymousSid = 13,
1848 WinProxySid = 14,
1849 WinEnterpriseControllersSid = 15,
1850 WinSelfSid = 16,
1851 WinAuthenticatedUserSid = 17,
1852 WinRestrictedCodeSid = 18,
1853 WinTerminalServerSid = 19,
1854 WinRemoteLogonIdSid = 20,
1855 WinLogonIdsSid = 21,
1856 WinLocalSystemSid = 22,
1857 WinLocalServiceSid = 23,
1858 WinNetworkServiceSid = 24,
1859 WinBuiltinDomainSid = 25,
1860 WinBuiltinAdministratorsSid = 26,
1861 WinBuiltinUsersSid = 27,
1862 WinBuiltinGuestsSid = 28,
1863 WinBuiltinPowerUsersSid = 29,
1864 WinBuiltinAccountOperatorsSid = 30,
1865 WinBuiltinSystemOperatorsSid = 31,
1866 WinBuiltinPrintOperatorsSid = 32,
1867 WinBuiltinBackupOperatorsSid = 33,
1868 WinBuiltinReplicatorSid = 34,
1869 WinBuiltinPreWindows2000CompatibleAccessSid = 35,
1870 WinBuiltinRemoteDesktopUsersSid = 36,
1871 WinBuiltinNetworkConfigurationOperatorsSid = 37,
1872 WinAccountAdministratorSid = 38,
1873 WinAccountGuestSid = 39,
1874 WinAccountKrbtgtSid = 40,
1875 WinAccountDomainAdminsSid = 41,
1876 WinAccountDomainUsersSid = 42,
1877 WinAccountDomainGuestsSid = 43,
1878 WinAccountComputersSid = 44,
1879 WinAccountControllersSid = 45,
1880 WinAccountCertAdminsSid = 46,
1881 WinAccountSchemaAdminsSid = 47,
1882 WinAccountEnterpriseAdminsSid = 48,
1883 WinAccountPolicyAdminsSid = 49,
1884 WinAccountRasAndIasServersSid = 50,
1885 WinNTLMAuthenticationSid = 51,
1886 WinDigestAuthenticationSid = 52,
1887 WinSChannelAuthenticationSid = 53,
1888 WinThisOrganizationSid = 54,
1889 WinOtherOrganizationSid = 55,
1890 WinBuiltinIncomingForestTrustBuildersSid = 56,
1891 WinBuiltinPerfMonitoringUsersSid = 57,
1892 WinBuiltinPerfLoggingUsersSid = 58,
1893 WinBuiltinAuthorizationAccessSid = 59,
1894 WinBuiltinTerminalServerLicenseServersSid = 60,
1895 WinBuiltinDCOMUsersSid = 61,
1896 WinBuiltinIUsersSid = 62,
1897 WinIUserSid = 63,
1898 WinBuiltinCryptoOperatorsSid = 64,
1899 WinUntrustedLabelSid = 65,
1900 WinLowLabelSid = 66,
1901 WinMediumLabelSid = 67,
1902 WinHighLabelSid = 68,
1903 WinSystemLabelSid = 69,
1904 WinWriteRestrictedCodeSid = 70,
1905 WinCreatorOwnerRightsSid = 71,
1906 WinCacheablePrincipalsGroupSid = 72,
1907 WinNonCacheablePrincipalsGroupSid = 73,
1908 WinEnterpriseReadonlyControllersSid = 74,
1909 WinAccountReadonlyControllersSid = 75,
1910 WinBuiltinEventLogReadersGroup = 76,
1911 WinNewEnterpriseReadonlyControllersSid = 77,
1912 WinBuiltinCertSvcDComAccessGroup = 78,
1913 WinMediumPlusLabelSid = 79,
1914 WinLocalLogonSid = 80,
1915 WinConsoleLogonSid = 81,
1916 WinThisOrganizationCertificateSid = 82,
1917 } WELL_KNOWN_SID_TYPE;
1918
1919 #define SE_CREATE_TOKEN_NAME TEXT("SeCreateTokenPrivilege")
1920 #define SE_ASSIGNPRIMARYTOKEN_NAME TEXT("SeAssignPrimaryTokenPrivilege")
1921 #define SE_LOCK_MEMORY_NAME TEXT("SeLockMemoryPrivilege")
1922 #define SE_INCREASE_QUOTA_NAME TEXT("SeIncreaseQuotaPrivilege")
1923 #define SE_UNSOLICITED_INPUT_NAME TEXT("SeUnsolicitedInputPrivilege")
1924 #define SE_MACHINE_ACCOUNT_NAME TEXT("SeMachineAccountPrivilege")
1925 #define SE_TCB_NAME TEXT("SeTcbPrivilege")
1926 #define SE_SECURITY_NAME TEXT("SeSecurityPrivilege")
1927 #define SE_TAKE_OWNERSHIP_NAME TEXT("SeTakeOwnershipPrivilege")
1928 #define SE_LOAD_DRIVER_NAME TEXT("SeLoadDriverPrivilege")
1929 #define SE_SYSTEM_PROFILE_NAME TEXT("SeSystemProfilePrivilege")
1930 #define SE_SYSTEMTIME_NAME TEXT("SeSystemtimePrivilege")
1931 #define SE_PROF_SINGLE_PROCESS_NAME TEXT("SeProfileSingleProcessPrivilege")
1932 #define SE_INC_BASE_PRIORITY_NAME TEXT("SeIncreaseBasePriorityPrivilege")
1933 #define SE_CREATE_PAGEFILE_NAME TEXT("SeCreatePagefilePrivilege")
1934 #define SE_CREATE_PERMANENT_NAME TEXT("SeCreatePermanentPrivilege")
1935 #define SE_BACKUP_NAME TEXT("SeBackupPrivilege")
1936 #define SE_RESTORE_NAME TEXT("SeRestorePrivilege")
1937 #define SE_SHUTDOWN_NAME TEXT("SeShutdownPrivilege")
1938 #define SE_DEBUG_NAME TEXT("SeDebugPrivilege")
1939 #define SE_AUDIT_NAME TEXT("SeAuditPrivilege")
1940 #define SE_SYSTEM_ENVIRONMENT_NAME TEXT("SeSystemEnvironmentPrivilege")
1941 #define SE_CHANGE_NOTIFY_NAME TEXT("SeChangeNotifyPrivilege")
1942 #define SE_REMOTE_SHUTDOWN_NAME TEXT("SeRemoteShutdownPrivilege")
1943 #define SE_UNDOCK_NAME TEXT("SeUndockPrivilege")
1944 #define SE_SYNC_AGENT_NAME TEXT("SeSyncAgentPrivilege")
1945 #define SE_ENABLE_DELEGATION_NAME TEXT("SeEnableDelegationPrivilege")
1946 #define SE_MANAGE_VOLUME_NAME TEXT("SeManageVolumePrivilege")
1947 #define SE_IMPERSONATE_NAME TEXT("SeImpersonatePrivilege")
1948 #define SE_CREATE_GLOBAL_NAME TEXT("SeCreateGlobalPrivilege")
1949
1950 #define SE_GROUP_MANDATORY 0x00000001
1951 #define SE_GROUP_ENABLED_BY_DEFAULT 0x00000002
1952 #define SE_GROUP_ENABLED 0x00000004
1953 #define SE_GROUP_OWNER 0x00000008
1954 #define SE_GROUP_USE_FOR_DENY_ONLY 0x00000010
1955 #define SE_GROUP_INTEGRITY 0x00000020
1956 #define SE_GROUP_INTEGRITY_ENABLED 0x00000040
1957 #define SE_GROUP_LOGON_ID 0xC0000000
1958 #define SE_GROUP_RESOURCE 0x20000000
1959 #define SE_GROUP_VALID_ATTRIBUTES 0xE000007F
1960
1961 /* FIXME: non-standard */
1962 #define LANG_ESPERANTO 0x8f
1963 #define LANG_WALON 0x90
1964 #define LANG_CORNISH 0x92
1965
1966 /* FIXME: not present in the official headers */
1967 #define LANG_MALAGASY 0x8d
1968 #define LANG_GAELIC 0x94
1969 #define LANG_SAAMI 0x3b
1970 #define LANG_SUTU 0x30
1971 #define LANG_TSONGA 0x31
1972 #define LANG_VENDA 0x33
1973 #define LANG_MANX_GAELIC 0x94
1974 #define SUBLANG_PORTUGUESE_PORTUGAL 0x02
1975
1976 #define ACL_REVISION 2
1977 #define ACL_REVISION_DS 4
1978 #define ACL_REVISION1 1
1979 #define ACL_REVISION2 2
1980 #define ACL_REVISION3 3
1981 #define ACL_REVISION4 4
1982 #define MIN_ACL_REVISION 2
1983 #define MAX_ACL_REVISION 4
1984 #define PROCESSOR_INTEL_386 386
1985 #define PROCESSOR_INTEL_486 486
1986 #define PROCESSOR_INTEL_PENTIUM 586
1987 #define PROCESSOR_MIPS_R4000 4000
1988 #define PROCESSOR_ALPHA_21064 21064
1989 #define PROCESSOR_INTEL_IA64 2200
1990 #define PROCESSOR_PPC_601 601
1991 #define PROCESSOR_PPC_603 603
1992 #define PROCESSOR_PPC_604 604
1993 #define PROCESSOR_PPC_620 620
1994 #define PROCESSOR_INTEL_860 860
1995 #define PROCESSOR_AMD_X8664 8664
1996 #define PROCESSOR_MIPS_R2000 2000
1997 #define PROCESSOR_MIPS_R3000 3000
1998 #define PROCESSOR_HITACHI_SH3 10003
1999 #define PROCESSOR_HITACHI_SH3E 10004
2000 #define PROCESSOR_HITACHI_SH4 10005
2001 #define PROCESSOR_MOTOROLA_821 821
2002 #define PROCESSOR_SHx_SH3 103
2003 #define PROCESSOR_SHx_SH4 104
2004 #define PROCESSOR_STRONGARM 2577
2005 #define PROCESSOR_ARM720 1824
2006 #define PROCESSOR_ARM820 2080
2007 #define PROCESSOR_ARM920 2336
2008 #define PROCESSOR_ARM_7TDMI 70001
2009 #define PROCESSOR_ARCHITECTURE_INTEL 0
2010 #define PROCESSOR_ARCHITECTURE_MIPS 1
2011 #define PROCESSOR_ARCHITECTURE_ALPHA 2
2012 #define PROCESSOR_ARCHITECTURE_PPC 3
2013 #define PROCESSOR_ARCHITECTURE_SHX 4
2014 #define PROCESSOR_ARCHITECTURE_ARM 5
2015 #define PROCESSOR_ARCHITECTURE_IA64 6
2016 #define PROCESSOR_ARCHITECTURE_ALPHA64 7
2017 #define PROCESSOR_ARCHITECTURE_MSIL 8
2018 #define PROCESSOR_ARCHITECTURE_AMD64 9
2019 #define PROCESSOR_ARCHITECTURE_UNKNOWN 0xFFFF
2020 #define PF_FLOATING_POINT_PRECISION_ERRATA 0
2021 #define PF_FLOATING_POINT_EMULATED 1
2022 #define PF_COMPARE_EXCHANGE_DOUBLE 2
2023 #define PF_MMX_INSTRUCTIONS_AVAILABLE 3
2024 #define PF_PPC_MOVEMEM_64BIT_OK 4
2025 #define PF_ALPHA_BYTE_INSTRUCTIONS 5
2026 #define PF_XMMI_INSTRUCTIONS_AVAILABLE 6
2027 #define PF_3DNOW_INSTRUCTIONS_AVAILABLE 7
2028 #define PF_RDTSC_INSTRUCTION_AVAILABLE 8
2029 #define PF_PAE_ENABLED 9
2030 #define PF_XMMI64_INSTRUCTIONS_AVAILABLE 10
2031 /* also in ddk/ntifs.h */
2032 #define FILE_ACTION_ADDED 0x00000001
2033 #define FILE_ACTION_REMOVED 0x00000002
2034 #define FILE_ACTION_MODIFIED 0x00000003
2035 #define FILE_ACTION_RENAMED_OLD_NAME 0x00000004
2036 #define FILE_ACTION_RENAMED_NEW_NAME 0x00000005
2037 #define FILE_ACTION_ADDED_STREAM 0x00000006
2038 #define FILE_ACTION_REMOVED_STREAM 0x00000007
2039 #define FILE_ACTION_MODIFIED_STREAM 0x00000008
2040 #define FILE_ACTION_REMOVED_BY_DELETE 0x00000009
2041 #define FILE_ACTION_ID_NOT_TUNNELLED 0x0000000A
2042 #define FILE_ACTION_TUNNELLED_ID_COLLISION 0x0000000B
2043 /* end ntifs.h */
2044 #define HEAP_NO_SERIALIZE 1
2045 #define HEAP_GROWABLE 2
2046 #define HEAP_GENERATE_EXCEPTIONS 4
2047 #define HEAP_ZERO_MEMORY 8
2048 #define HEAP_REALLOC_IN_PLACE_ONLY 16
2049 #define HEAP_TAIL_CHECKING_ENABLED 32
2050 #define HEAP_FREE_CHECKING_ENABLED 64
2051 #define HEAP_DISABLE_COALESCE_ON_FREE 128
2052 #define HEAP_CREATE_ALIGN_16 0x10000
2053 #define HEAP_CREATE_ENABLE_TRACING 0x20000
2054 #define HEAP_CREATE_ENABLE_EXECUTE 0x00040000
2055 #define HEAP_MAXIMUM_TAG 0xFFF
2056 #define HEAP_PSEUDO_TAG_FLAG 0x8000
2057 #define HEAP_TAG_SHIFT 16
2058 #define HEAP_MAKE_TAG_FLAGS(b,o) ((DWORD)((b)+(o)<<16)))
2059
2060 #define KEY_QUERY_VALUE 1
2061 #define KEY_SET_VALUE 2
2062 #define KEY_CREATE_SUB_KEY 4
2063 #define KEY_ENUMERATE_SUB_KEYS 8
2064 #define KEY_NOTIFY 16
2065 #define KEY_CREATE_LINK 32
2066 #define KEY_WOW64_64KEY 0x00000100
2067 #define KEY_WOW64_32KEY 0x00000200
2068 #define KEY_WOW64_RES 0x00000300
2069
2070 #define KEY_WRITE 0x20006
2071 #define KEY_EXECUTE 0x20019
2072 #define KEY_READ 0x20019
2073 #define KEY_ALL_ACCESS 0xf003f
2074 #define REG_WHOLE_HIVE_VOLATILE 1
2075 #define REG_REFRESH_HIVE 2
2076 #define REG_NO_LAZY_FLUSH 4
2077 #define REG_FORCE_RESTORE 8
2078 #define REG_OPTION_RESERVED 0
2079 #define REG_OPTION_NON_VOLATILE 0
2080 #define REG_OPTION_VOLATILE 1
2081 #define REG_OPTION_CREATE_LINK 2
2082 #define REG_OPTION_BACKUP_RESTORE 4
2083 #define REG_OPTION_OPEN_LINK 8
2084 #define REG_LEGAL_OPTION 15
2085 #define OWNER_SECURITY_INFORMATION 1
2086 #define GROUP_SECURITY_INFORMATION 2
2087 #define DACL_SECURITY_INFORMATION 4
2088 #define SACL_SECURITY_INFORMATION 8
2089 #define PROTECTED_DACL_SECURITY_INFORMATION 0x80000000
2090 #define PROTECTED_SACL_SECURITY_INFORMATION 0x40000000
2091 #define UNPROTECTED_DACL_SECURITY_INFORMATION 0x20000000
2092 #define UNPROTECTED_SACL_SECURITY_INFORMATION 0x10000000
2093 #define MAXIMUM_PROCESSORS 32
2094 #define PAGE_NOACCESS 0x0001
2095 #define PAGE_READONLY 0x0002
2096 #define PAGE_READWRITE 0x0004
2097 #define PAGE_WRITECOPY 0x0008
2098 #define PAGE_EXECUTE 0x0010
2099 #define PAGE_EXECUTE_READ 0x0020
2100 #define PAGE_EXECUTE_READWRITE 0x0040
2101 #define PAGE_EXECUTE_WRITECOPY 0x0080
2102 #define PAGE_GUARD 0x0100
2103 #define PAGE_NOCACHE 0x0200
2104 #define PAGE_WRITECOMBINE 0x0400
2105 #define MEM_COMMIT 0x1000
2106 #define MEM_RESERVE 0x2000
2107 #define MEM_DECOMMIT 0x4000
2108 #define MEM_RELEASE 0x8000
2109 #define MEM_FREE 0x10000
2110 #define MEM_PRIVATE 0x20000
2111 #define MEM_MAPPED 0x40000
2112 #define MEM_RESET 0x80000
2113 #define MEM_TOP_DOWN 0x100000
2114 #define MEM_WRITE_WATCH 0x200000 /* 98/Me */
2115 #define MEM_PHYSICAL 0x400000
2116 #define MEM_4MB_PAGES 0x80000000
2117 #define MEM_IMAGE SEC_IMAGE
2118 #define SEC_NO_CHANGE 0x00400000
2119 #define SEC_FILE 0x00800000
2120 #define SEC_IMAGE 0x01000000
2121 #define SEC_VLM 0x02000000
2122 #define SEC_RESERVE 0x04000000
2123 #define SEC_COMMIT 0x08000000
2124 #define SEC_NOCACHE 0x10000000
2125 #define SEC_WRITECOMBINE 0x40000000
2126 #define SEC_LARGE_PAGES 0x80000000
2127 #define SECTION_MAP_EXECUTE_EXPLICIT 0x0020
2128 #define SECTION_EXTEND_SIZE 16
2129 #define SECTION_MAP_READ 4
2130 #define SECTION_MAP_WRITE 2
2131 #define SECTION_QUERY 1
2132 #define SECTION_MAP_EXECUTE 8
2133 #define SECTION_ALL_ACCESS 0xf001f
2134 #define WRITE_WATCH_FLAG_RESET 0x01
2135 #define MESSAGE_RESOURCE_UNICODE 1
2136 #define RTL_CRITSECT_TYPE 0
2137 #define RTL_RESOURCE_TYPE 1
2138
2139 #define IMAGE_SIZEOF_FILE_HEADER 20
2140 #define IMAGE_FILE_RELOCS_STRIPPED 1
2141 #define IMAGE_FILE_EXECUTABLE_IMAGE 2
2142 #define IMAGE_FILE_LINE_NUMS_STRIPPED 4
2143 #define IMAGE_FILE_LOCAL_SYMS_STRIPPED 8
2144 #define IMAGE_FILE_AGGRESIVE_WS_TRIM 16
2145 #define IMAGE_FILE_LARGE_ADDRESS_AWARE 32
2146 #define IMAGE_FILE_BYTES_REVERSED_LO 128
2147 #define IMAGE_FILE_32BIT_MACHINE 256
2148 #define IMAGE_FILE_DEBUG_STRIPPED 512
2149 #define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP 1024
2150 #define IMAGE_FILE_NET_RUN_FROM_SWAP 2048
2151 #define IMAGE_FILE_SYSTEM 4096
2152 #define IMAGE_FILE_DLL 8192
2153 #define IMAGE_FILE_UP_SYSTEM_ONLY 16384
2154 #define IMAGE_FILE_BYTES_REVERSED_HI 32768
2155 #define IMAGE_FILE_MACHINE_UNKNOWN 0
2156
2157 #define IMAGE_FILE_MACHINE_AM33 0x1d3
2158 #define IMAGE_FILE_MACHINE_AMD64 0x8664
2159 #define IMAGE_FILE_MACHINE_ARM 0x1c0
2160 #define IMAGE_FILE_MACHINE_ARMNT 0x1c4
2161 #define IMAGE_FILE_MACHINE_EBC 0xebc
2162 #define IMAGE_FILE_MACHINE_I386 0x14c
2163 #define IMAGE_FILE_MACHINE_IA64 0x200
2164 #define IMAGE_FILE_MACHINE_M32R 0x9041
2165 #define IMAGE_FILE_MACHINE_MIPS16 0x266
2166 #define IMAGE_FILE_MACHINE_MIPSFPU 0x366
2167 #define IMAGE_FILE_MACHINE_MIPSFPU16 0x466
2168 #define IMAGE_FILE_MACHINE_POWERPC 0x1f0
2169 #define IMAGE_FILE_MACHINE_POWERPCFP 0x1f1
2170 #define IMAGE_FILE_MACHINE_R4000 0x166
2171 #define IMAGE_FILE_MACHINE_SH3 0x1a2
2172 #define IMAGE_FILE_MACHINE_SH3E 0x01a4
2173 #define IMAGE_FILE_MACHINE_SH3DSP 0x1a3
2174 #define IMAGE_FILE_MACHINE_SH4 0x1a6
2175 #define IMAGE_FILE_MACHINE_SH5 0x1a8
2176 #define IMAGE_FILE_MACHINE_THUMB 0x1c2
2177 #define IMAGE_FILE_MACHINE_WCEMIPSV2 0x169
2178 #define IMAGE_FILE_MACHINE_R3000 0x162
2179 #define IMAGE_FILE_MACHINE_R10000 0x168
2180 #define IMAGE_FILE_MACHINE_ALPHA 0x184
2181 #define IMAGE_FILE_MACHINE_ALPHA64 0x0284
2182 #define IMAGE_FILE_MACHINE_AXP64 IMAGE_FILE_MACHINE_ALPHA64
2183 #define IMAGE_FILE_MACHINE_CEE 0xC0EE
2184 #define IMAGE_FILE_MACHINE_TRICORE 0x0520
2185 #define IMAGE_FILE_MACHINE_CEF 0x0CEF
2186
2187 /* Wine extension */
2188 #define IMAGE_FILE_MACHINE_ARM64 0x1c5
2189
2190 #define IMAGE_FILE_EXPORT_DIRECTORY 0
2191 #define IMAGE_FILE_IMPORT_DIRECTORY 1
2192 #define IMAGE_FILE_RESOURCE_DIRECTORY 2
2193 #define IMAGE_FILE_EXCEPTION_DIRECTORY 3
2194 #define IMAGE_FILE_SECURITY_DIRECTORY 4
2195 #define IMAGE_FILE_BASE_RELOCATION_TABLE 5
2196 #define IMAGE_FILE_DEBUG_DIRECTORY 6
2197 #define IMAGE_FILE_DESCRIPTION_STRING 7
2198 #define IMAGE_FILE_MACHINE_VALUE 8 /* Mips */
2199 #define IMAGE_FILE_THREAD_LOCAL_STORAGE 9
2200 #define IMAGE_FILE_CALLBACK_DIRECTORY 10
2201
2202 #define IMAGE_DOS_SIGNATURE 0x5A4D
2203 #define IMAGE_OS2_SIGNATURE 0x454E
2204 #define IMAGE_OS2_SIGNATURE_LE 0x454C
2205 #define IMAGE_VXD_SIGNATURE 0x454C
2206 #define IMAGE_NT_SIGNATURE 0x00004550
2207 #define IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x10b
2208 #define IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x20b
2209 #ifdef _WIN64
2210 #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR64_MAGIC
2211 #else
2212 #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR32_MAGIC
2213 #endif
2214 #define IMAGE_ROM_OPTIONAL_HDR_MAGIC 0x107
2215 #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
2216 #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
2217 #define IMAGE_SIZEOF_ROM_OPTIONAL_HEADER 56
2218 #define IMAGE_SIZEOF_STD_OPTIONAL_HEADER 28
2219 #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER 224
2220 #define IMAGE_SIZEOF_SHORT_NAME 8
2221 #define IMAGE_SIZEOF_SECTION_HEADER 40
2222 #define IMAGE_SIZEOF_SYMBOL 18
2223 #define IMAGE_SIZEOF_AUX_SYMBOL 18
2224 #define IMAGE_SIZEOF_RELOCATION 10
2225 #define IMAGE_SIZEOF_BASE_RELOCATION 8
2226 #define IMAGE_SIZEOF_LINENUMBER 6
2227 #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
2228 #define SIZEOF_RFPO_DATA 16
2229
2230 #define IMAGE_SUBSYSTEM_UNKNOWN 0
2231 #define IMAGE_SUBSYSTEM_NATIVE 1
2232 #define IMAGE_SUBSYSTEM_WINDOWS_GUI 2
2233 #define IMAGE_SUBSYSTEM_WINDOWS_CUI 3
2234 #define IMAGE_SUBSYSTEM_OS2_CUI 5
2235 #define IMAGE_SUBSYSTEM_POSIX_CUI 7
2236 #define IMAGE_SUBSYSTEM_NATIVE_WINDOWS 8
2237 #define IMAGE_SUBSYSTEM_WINDOWS_CE_GUI 9
2238 #define IMAGE_SUBSYSTEM_EFI_APPLICATION 10
2239 #define IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER 11
2240 #define IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER 12
2241 #define IMAGE_SUBSYSTEM_EFI_ROM 13
2242 #define IMAGE_SUBSYSTEM_XBOX 14
2243
2244 #define IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE 0x0040
2245 #define IMAGE_DLLCHARACTERISTICS_FORCE_INTEGRITY 0x0080
2246 #define IMAGE_DLLCHARACTERISTICS_NX_COMPAT 0x0100
2247 #define IMAGE_DLLCHARACTERISTICS_NO_ISOLATION 0x0200
2248 #define IMAGE_DLLCHARACTERISTICS_NO_SEH 0x0400
2249 #define IMAGE_DLLCHARACTERISTICS_NO_BIND 0x0800
2250 #define IMAGE_DLLCHARACTERISTICS_WDM_DRIVER 0x2000
2251 #define IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE 0x8000
2252 #define IMAGE_FIRST_SECTION(h) ((PIMAGE_SECTION_HEADER) ((ULONG_PTR)h+FIELD_OFFSET(IMAGE_NT_HEADERS,OptionalHeader)+((PIMAGE_NT_HEADERS)(h))->FileHeader.SizeOfOptionalHeader))
2253 #define IMAGE_DIRECTORY_ENTRY_EXPORT 0
2254 #define IMAGE_DIRECTORY_ENTRY_IMPORT 1
2255 #define IMAGE_DIRECTORY_ENTRY_RESOURCE 2
2256 #define IMAGE_DIRECTORY_ENTRY_EXCEPTION 3
2257 #define IMAGE_DIRECTORY_ENTRY_SECURITY 4
2258 #define IMAGE_DIRECTORY_ENTRY_BASERELOC 5
2259 #define IMAGE_DIRECTORY_ENTRY_DEBUG 6
2260 #define IMAGE_DIRECTORY_ENTRY_COPYRIGHT 7
2261 #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR 8
2262 #define IMAGE_DIRECTORY_ENTRY_TLS 9
2263 #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG 10
2264 #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT 11
2265 #define IMAGE_DIRECTORY_ENTRY_IAT 12
2266 #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT 13
2267 #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14
2268 #define IMAGE_SCN_TYPE_REG 0
2269 #define IMAGE_SCN_TYPE_DSECT 1
2270 //#define IMAGE_SCN_TYPE_NOLOAD 2
2271 #define IMAGE_SCN_TYPE_GROUP 4
2272 #define IMAGE_SCN_TYPE_NO_PAD 8
2273 #define IMAGE_SCN_CNT_CODE 32
2274 #define IMAGE_SCN_CNT_INITIALIZED_DATA 64
2275 #define IMAGE_SCN_CNT_UNINITIALIZED_DATA 128
2276 #define IMAGE_SCN_LNK_OTHER 256
2277 #define IMAGE_SCN_LNK_INFO 512
2278 #define IMAGE_SCN_LNK_REMOVE 2048
2279 #define IMAGE_SCN_LNK_COMDAT 4096
2280 #define IMAGE_SCN_MEM_FARDATA 0x8000
2281 #define IMAGE_SCN_MEM_PURGEABLE 0x20000
2282 #define IMAGE_SCN_MEM_16BIT 0x20000
2283 #define IMAGE_SCN_MEM_LOCKED 0x40000
2284 #define IMAGE_SCN_MEM_PRELOAD 0x80000
2285 #define IMAGE_SCN_ALIGN_1BYTES 0x100000
2286 #define IMAGE_SCN_ALIGN_2BYTES 0x200000
2287 #define IMAGE_SCN_ALIGN_4BYTES 0x300000
2288 #define IMAGE_SCN_ALIGN_8BYTES 0x400000
2289 #define IMAGE_SCN_ALIGN_16BYTES 0x500000
2290 #define IMAGE_SCN_ALIGN_32BYTES 0x600000
2291 #define IMAGE_SCN_ALIGN_64BYTES 0x700000
2292 #define IMAGE_SCN_LNK_NRELOC_OVFL 0x1000000
2293 #define IMAGE_SCN_MEM_DISCARDABLE 0x2000000
2294 #define IMAGE_SCN_MEM_NOT_CACHED 0x4000000
2295 #define IMAGE_SCN_MEM_NOT_PAGED 0x8000000
2296 #define IMAGE_SCN_MEM_SHARED 0x10000000
2297 #define IMAGE_SCN_MEM_EXECUTE 0x20000000
2298 #define IMAGE_SCN_MEM_READ 0x40000000
2299 #define IMAGE_SCN_MEM_WRITE 0x80000000
2300 #define IMAGE_SYM_UNDEFINED 0
2301 #define IMAGE_SYM_ABSOLUTE (-1)
2302 #define IMAGE_SYM_DEBUG (-2)
2303 #define IMAGE_SYM_TYPE_NULL 0
2304 #define IMAGE_SYM_TYPE_VOID 1
2305 #define IMAGE_SYM_TYPE_CHAR 2
2306 #define IMAGE_SYM_TYPE_SHORT 3
2307 #define IMAGE_SYM_TYPE_INT 4
2308 #define IMAGE_SYM_TYPE_LONG 5
2309 #define IMAGE_SYM_TYPE_FLOAT 6
2310 #define IMAGE_SYM_TYPE_DOUBLE 7
2311 #define IMAGE_SYM_TYPE_STRUCT 8
2312 #define IMAGE_SYM_TYPE_UNION 9
2313 #define IMAGE_SYM_TYPE_ENUM 10
2314 #define IMAGE_SYM_TYPE_MOE 11
2315 #define IMAGE_SYM_TYPE_BYTE 12
2316 #define IMAGE_SYM_TYPE_WORD 13
2317 #define IMAGE_SYM_TYPE_UINT 14
2318 #define IMAGE_SYM_TYPE_DWORD 15
2319 #define IMAGE_SYM_TYPE_PCODE 32768
2320 #define IMAGE_SYM_DTYPE_NULL 0
2321 #define IMAGE_SYM_DTYPE_POINTER 1
2322 #define IMAGE_SYM_DTYPE_FUNCTION 2
2323 #define IMAGE_SYM_DTYPE_ARRAY 3
2324 #define IMAGE_SYM_CLASS_END_OF_FUNCTION (-1)
2325 #define IMAGE_SYM_CLASS_NULL 0
2326 #define IMAGE_SYM_CLASS_AUTOMATIC 1
2327 #define IMAGE_SYM_CLASS_EXTERNAL 2
2328 #define IMAGE_SYM_CLASS_STATIC 3
2329 #define IMAGE_SYM_CLASS_REGISTER 4
2330 #define IMAGE_SYM_CLASS_EXTERNAL_DEF 5
2331 #define IMAGE_SYM_CLASS_LABEL 6
2332 #define IMAGE_SYM_CLASS_UNDEFINED_LABEL 7
2333 #define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT 8
2334 #define IMAGE_SYM_CLASS_ARGUMENT 9
2335 #define IMAGE_SYM_CLASS_STRUCT_TAG 10
2336 #define IMAGE_SYM_CLASS_MEMBER_OF_UNION 11
2337 #define IMAGE_SYM_CLASS_UNION_TAG 12
2338 #define IMAGE_SYM_CLASS_TYPE_DEFINITION 13
2339 #define IMAGE_SYM_CLASS_UNDEFINED_STATIC 14
2340 #define IMAGE_SYM_CLASS_ENUM_TAG 15
2341 #define IMAGE_SYM_CLASS_MEMBER_OF_ENUM 16
2342 #define IMAGE_SYM_CLASS_REGISTER_PARAM 17
2343 #define IMAGE_SYM_CLASS_BIT_FIELD 18
2344 #define IMAGE_SYM_CLASS_FAR_EXTERNAL 68
2345 #define IMAGE_SYM_CLASS_BLOCK 100
2346 #define IMAGE_SYM_CLASS_FUNCTION 101
2347 #define IMAGE_SYM_CLASS_END_OF_STRUCT 102
2348 #define IMAGE_SYM_CLASS_FILE 103
2349 #define IMAGE_SYM_CLASS_SECTION 104
2350 #define IMAGE_SYM_CLASS_WEAK_EXTERNAL 105
2351 #define IMAGE_COMDAT_SELECT_NODUPLICATES 1
2352 #define IMAGE_COMDAT_SELECT_ANY 2
2353 #define IMAGE_COMDAT_SELECT_SAME_SIZE 3
2354 #define IMAGE_COMDAT_SELECT_EXACT_MATCH 4
2355 #define IMAGE_COMDAT_SELECT_ASSOCIATIVE 5
2356 #define IMAGE_COMDAT_SELECT_LARGEST 6
2357 #define IMAGE_COMDAT_SELECT_NEWEST 7
2358 #define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY 1
2359 #define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY 2
2360 #define IMAGE_WEAK_EXTERN_SEARCH_ALIAS 3
2361 #define IMAGE_REL_I386_ABSOLUTE 0
2362 #define IMAGE_REL_I386_DIR16 1
2363 #define IMAGE_REL_I386_REL16 2
2364 #define IMAGE_REL_I386_DIR32 6
2365 #define IMAGE_REL_I386_DIR32NB 7
2366 #define IMAGE_REL_I386_SEG12 9
2367 #define IMAGE_REL_I386_SECTION 10
2368 #define IMAGE_REL_I386_SECREL 11
2369 #define IMAGE_REL_I386_REL32 20
2370 #define IMAGE_REL_MIPS_ABSOLUTE 0
2371 #define IMAGE_REL_MIPS_REFHALF 1
2372 #define IMAGE_REL_MIPS_REFWORD 2
2373 #define IMAGE_REL_MIPS_JMPADDR 3
2374 #define IMAGE_REL_MIPS_REFHI 4
2375 #define IMAGE_REL_MIPS_REFLO 5
2376 #define IMAGE_REL_MIPS_GPREL 6
2377 #define IMAGE_REL_MIPS_LITERAL 7
2378 #define IMAGE_REL_MIPS_SECTION 10
2379 #define IMAGE_REL_MIPS_SECREL 11
2380 #define IMAGE_REL_MIPS_SECRELLO 12
2381 #define IMAGE_REL_MIPS_SECRELHI 13
2382 #define IMAGE_REL_MIPS_REFWORDNB 34
2383 #define IMAGE_REL_MIPS_PAIR 35
2384 #define IMAGE_REL_ALPHA_ABSOLUTE 0
2385 #define IMAGE_REL_ALPHA_REFLONG 1
2386 #define IMAGE_REL_ALPHA_REFQUAD 2
2387 #define IMAGE_REL_ALPHA_GPREL32 3
2388 #define IMAGE_REL_ALPHA_LITERAL 4
2389 #define IMAGE_REL_ALPHA_LITUSE 5
2390 #define IMAGE_REL_ALPHA_GPDISP 6
2391 #define IMAGE_REL_ALPHA_BRADDR 7
2392 #define IMAGE_REL_ALPHA_HINT 8
2393 #define IMAGE_REL_ALPHA_INLINE_REFLONG 9
2394 #define IMAGE_REL_ALPHA_REFHI 10
2395 #define IMAGE_REL_ALPHA_REFLO 11
2396 #define IMAGE_REL_ALPHA_PAIR 12
2397 #define IMAGE_REL_ALPHA_MATCH 13
2398 #define IMAGE_REL_ALPHA_SECTION 14
2399 #define IMAGE_REL_ALPHA_SECREL 15
2400 #define IMAGE_REL_ALPHA_REFLONGNB 16
2401 #define IMAGE_REL_ALPHA_SECRELLO 17
2402 #define IMAGE_REL_ALPHA_SECRELHI 18
2403 #define IMAGE_REL_PPC_ABSOLUTE 0
2404 #define IMAGE_REL_PPC_ADDR64 1
2405 #define IMAGE_REL_PPC_ADDR32 2
2406 #define IMAGE_REL_PPC_ADDR24 3
2407 #define IMAGE_REL_PPC_ADDR16 4
2408 #define IMAGE_REL_PPC_ADDR14 5
2409 #define IMAGE_REL_PPC_REL24 6
2410 #define IMAGE_REL_PPC_REL14 7
2411 #define IMAGE_REL_PPC_TOCREL16 8
2412 #define IMAGE_REL_PPC_TOCREL14 9
2413 #define IMAGE_REL_PPC_ADDR32NB 10
2414 #define IMAGE_REL_PPC_SECREL 11
2415 #define IMAGE_REL_PPC_SECTION 12
2416 #define IMAGE_REL_PPC_IFGLUE 13
2417 #define IMAGE_REL_PPC_IMGLUE 14
2418 #define IMAGE_REL_PPC_SECREL16 15
2419 #define IMAGE_REL_PPC_REFHI 16
2420 #define IMAGE_REL_PPC_REFLO 17
2421 #define IMAGE_REL_PPC_PAIR 18
2422 #define IMAGE_REL_PPC_TYPEMASK 255
2423 #define IMAGE_REL_PPC_NEG 256
2424 #define IMAGE_REL_PPC_BRTAKEN 512
2425 #define IMAGE_REL_PPC_BRNTAKEN 1024
2426 #define IMAGE_REL_PPC_TOCDEFN 2048
2427 #define IMAGE_REL_BASED_ABSOLUTE 0
2428 #define IMAGE_REL_BASED_HIGH 1
2429 #define IMAGE_REL_BASED_LOW 2
2430 #define IMAGE_REL_BASED_HIGHLOW 3
2431 #define IMAGE_REL_BASED_HIGHADJ 4
2432 #define IMAGE_REL_BASED_MIPS_JMPADDR 5
2433 #define IMAGE_REL_BASED_MIPS_JMPADDR16 9
2434 #define IMAGE_REL_BASED_IA64_IMM64 9
2435 #define IMAGE_REL_BASED_DIR64 10
2436 #define IMAGE_ARCHIVE_START_SIZE 8
2437 #define IMAGE_ARCHIVE_START "!<arch>\n"
2438 #define IMAGE_ARCHIVE_END "`\n"
2439 #define IMAGE_ARCHIVE_PAD "\n"
2440 #define IMAGE_ARCHIVE_LINKER_MEMBER "/ "
2441 #define IMAGE_ARCHIVE_LONGNAMES_MEMBER "// "
2442 #define IMAGE_RESOURCE_NAME_IS_STRING 0x80000000
2443 #define IMAGE_RESOURCE_DATA_IS_DIRECTORY 0x80000000
2444 #define IMAGE_DEBUG_TYPE_UNKNOWN 0
2445 #define IMAGE_DEBUG_TYPE_COFF 1
2446 #define IMAGE_DEBUG_TYPE_CODEVIEW 2
2447 #define IMAGE_DEBUG_TYPE_FPO 3
2448 #define IMAGE_DEBUG_TYPE_MISC 4
2449 #define IMAGE_DEBUG_TYPE_EXCEPTION 5
2450 #define IMAGE_DEBUG_TYPE_FIXUP 6
2451 #define IMAGE_DEBUG_TYPE_OMAP_TO_SRC 7
2452 #define IMAGE_DEBUG_TYPE_OMAP_FROM_SRC 8
2453 #define FRAME_FPO 0
2454 #define FRAME_TRAP 1
2455 #define FRAME_TSS 2
2456 #define FRAME_NONFPO 3
2457 #define IMAGE_DEBUG_MISC_EXENAME 1
2458 #define N_BTMASK 0x000F
2459 #define N_TMASK 0x0030
2460 #define N_TMASK1 0x00C0
2461 #define N_TMASK2 0x00F0
2462 #define N_BTSHFT 4
2463 #define N_TSHIFT 2
2464 #define IS_TEXT_UNICODE_ASCII16 1
2465 #define IS_TEXT_UNICODE_REVERSE_ASCII16 16
2466 #define IS_TEXT_UNICODE_STATISTICS 2
2467 #define IS_TEXT_UNICODE_REVERSE_STATISTICS 32
2468 #define IS_TEXT_UNICODE_CONTROLS 4
2469 #define IS_TEXT_UNICODE_REVERSE_CONTROLS 64
2470 #define IS_TEXT_UNICODE_SIGNATURE 8
2471 #define IS_TEXT_UNICODE_REVERSE_SIGNATURE 128
2472 #define IS_TEXT_UNICODE_ILLEGAL_CHARS 256
2473 #define IS_TEXT_UNICODE_ODD_LENGTH 512
2474 #define IS_TEXT_UNICODE_NULL_BYTES 4096
2475 #define IS_TEXT_UNICODE_UNICODE_MASK 15
2476 #define IS_TEXT_UNICODE_REVERSE_MASK 240
2477 #define IS_TEXT_UNICODE_NOT_UNICODE_MASK 3840
2478 #define IS_TEXT_UNICODE_NOT_ASCII_MASK 61440
2479 #define SERVICE_KERNEL_DRIVER 1
2480 #define SERVICE_FILE_SYSTEM_DRIVER 2
2481 #define SERVICE_ADAPTER 4
2482 #define SERVICE_RECOGNIZER_DRIVER 8
2483 #define SERVICE_DRIVER (SERVICE_KERNEL_DRIVER|SERVICE_FILE_SYSTEM_DRIVER|SERVICE_RECOGNIZER_DRIVER)
2484 #define SERVICE_WIN32_OWN_PROCESS 16
2485 #define SERVICE_WIN32_SHARE_PROCESS 32
2486 #define SERVICE_WIN32 (SERVICE_WIN32_OWN_PROCESS|SERVICE_WIN32_SHARE_PROCESS)
2487 #define SERVICE_INTERACTIVE_PROCESS 256
2488 #define SERVICE_TYPE_ALL (SERVICE_WIN32|SERVICE_ADAPTER|SERVICE_DRIVER|SERVICE_INTERACTIVE_PROCESS)
2489 #define SERVICE_BOOT_START 0
2490 #define SERVICE_SYSTEM_START 1
2491 #define SERVICE_AUTO_START 2
2492 #define SERVICE_DEMAND_START 3
2493 #define SERVICE_DISABLED 4
2494 #define SERVICE_ERROR_IGNORE 0
2495 #define SERVICE_ERROR_NORMAL 1
2496 #define SERVICE_ERROR_SEVERE 2
2497 #define SERVICE_ERROR_CRITICAL 3
2498 #define SE_OWNER_DEFAULTED 0x0001
2499 #define SE_GROUP_DEFAULTED 0x0002
2500 #define SE_DACL_PRESENT 0x0004
2501 #define SE_DACL_DEFAULTED 0x0008
2502 #define SE_SACL_PRESENT 0x0010
2503 #define SE_SACL_DEFAULTED 0x0020
2504 #define SE_DACL_UNTRUSTED 0x0040
2505 #define SE_SERVER_SECURITY 0x0080
2506 #define SE_DACL_AUTO_INHERIT_REQ 0x0100
2507 #define SE_SACL_AUTO_INHERIT_REQ 0x0200
2508 #define SE_DACL_AUTO_INHERITED 0x0400
2509 #define SE_SACL_AUTO_INHERITED 0x0800
2510 #define SE_DACL_PROTECTED 0x1000
2511 #define SE_SACL_PROTECTED 0x2000
2512 #define SE_RM_CONTROL_VALID 0x4000
2513 #define SE_SELF_RELATIVE 0x8000
2514 #define SECURITY_DESCRIPTOR_MIN_LENGTH 20
2515 #define SECURITY_DESCRIPTOR_REVISION 1
2516 #define SECURITY_DESCRIPTOR_REVISION1 1
2517 #define SE_PRIVILEGE_ENABLED_BY_DEFAULT 1
2518 #define SE_PRIVILEGE_ENABLED 2
2519 #define SE_PRIVILEGE_USED_FOR_ACCESS 0x80000000
2520 #define PRIVILEGE_SET_ALL_NECESSARY 1
2521 #define SECURITY_MAX_IMPERSONATION_LEVEL SecurityDelegation
2522 #define DEFAULT_IMPERSONATION_LEVEL SecurityImpersonation
2523 #define SECURITY_DYNAMIC_TRACKING TRUE
2524 #define SECURITY_STATIC_TRACKING FALSE
2525 /* also in ddk/ntifs.h */
2526 #define TOKEN_ASSIGN_PRIMARY (0x0001)
2527 #define TOKEN_DUPLICATE (0x0002)
2528 #define TOKEN_IMPERSONATE (0x0004)
2529 #define TOKEN_QUERY (0x0008)
2530 #define TOKEN_QUERY_SOURCE (0x0010)
2531 #define TOKEN_ADJUST_PRIVILEGES (0x0020)
2532 #define TOKEN_ADJUST_GROUPS (0x0040)
2533 #define TOKEN_ADJUST_DEFAULT (0x0080)
2534 #define TOKEN_ADJUST_SESSIONID (0x0100)
2535 #define TOKEN_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED |\
2536 TOKEN_ASSIGN_PRIMARY |\
2537 TOKEN_DUPLICATE |\
2538 TOKEN_IMPERSONATE |\
2539 TOKEN_QUERY |\
2540 TOKEN_QUERY_SOURCE |\
2541 TOKEN_ADJUST_PRIVILEGES |\
2542 TOKEN_ADJUST_GROUPS |\
2543 TOKEN_ADJUST_DEFAULT |\
2544 TOKEN_ADJUST_SESSIONID)
2545 #define TOKEN_READ (STANDARD_RIGHTS_READ |\
2546 TOKEN_QUERY)
2547 #define TOKEN_WRITE (STANDARD_RIGHTS_WRITE |\
2548 TOKEN_ADJUST_PRIVILEGES |\
2549 TOKEN_ADJUST_GROUPS |\
2550 TOKEN_ADJUST_DEFAULT)
2551
2552 #define TOKEN_EXECUTE (STANDARD_RIGHTS_EXECUTE)
2553 #define TOKEN_SOURCE_LENGTH 8
2554 /* end ddk/ntifs.h */
2555 #define DLL_PROCESS_DETACH 0
2556 #define DLL_PROCESS_ATTACH 1
2557 #define DLL_THREAD_ATTACH 2
2558 #define DLL_THREAD_DETACH 3
2559 #ifdef __WINESRC__
2560 #define DLL_WINE_PREATTACH 8 /* Never called, but defined for compatibility with Wine source */
2561 #endif
2562 #define TAPE_ABSOLUTE_POSITION 0
2563 #define TAPE_LOGICAL_POSITION 1
2564 #define TAPE_PSEUDO_LOGICAL_POSITION 2
2565 #define TAPE_REWIND 0
2566 #define TAPE_ABSOLUTE_BLOCK 1
2567 #define TAPE_LOGICAL_BLOCK 2
2568 #define TAPE_PSEUDO_LOGICAL_BLOCK 3
2569 #define TAPE_SPACE_END_OF_DATA 4
2570 #define TAPE_SPACE_RELATIVE_BLOCKS 5
2571 #define TAPE_SPACE_FILEMARKS 6
2572 #define TAPE_SPACE_SEQUENTIAL_FMKS 7
2573 #define TAPE_SPACE_SETMARKS 8
2574 #define TAPE_SPACE_SEQUENTIAL_SMKS 9
2575 #define TAPE_DRIVE_FIXED 1
2576 #define TAPE_DRIVE_SELECT 2
2577 #define TAPE_DRIVE_INITIATOR 4
2578 #define TAPE_DRIVE_ERASE_SHORT 16
2579 #define TAPE_DRIVE_ERASE_LONG 32
2580 #define TAPE_DRIVE_ERASE_BOP_ONLY 64
2581 #define TAPE_DRIVE_ERASE_IMMEDIATE 128
2582 #define TAPE_DRIVE_TAPE_CAPACITY 256
2583 #define TAPE_DRIVE_TAPE_REMAINING 512
2584 #define TAPE_DRIVE_FIXED_BLOCK 1024
2585 #define TAPE_DRIVE_VARIABLE_BLOCK 2048
2586 #define TAPE_DRIVE_WRITE_PROTECT 4096
2587 #define TAPE_DRIVE_EOT_WZ_SIZE 8192
2588 #define TAPE_DRIVE_ECC 0x10000
2589 #define TAPE_DRIVE_COMPRESSION 0x20000
2590 #define TAPE_DRIVE_PADDING 0x40000
2591 #define TAPE_DRIVE_REPORT_SMKS 0x80000
2592 #define TAPE_DRIVE_GET_ABSOLUTE_BLK 0x100000
2593 #define TAPE_DRIVE_GET_LOGICAL_BLK 0x200000
2594 #define TAPE_DRIVE_SET_EOT_WZ_SIZE 0x400000
2595 #define TAPE_DRIVE_EJECT_MEDIA 0x1000000
2596 #define TAPE_DRIVE_CLEAN_REQUESTS 0x2000000
2597 #define TAPE_DRIVE_SET_CMP_BOP_ONLY 0x4000000
2598 #define TAPE_DRIVE_RESERVED_BIT 0x80000000
2599 #define TAPE_DRIVE_LOAD_UNLOAD 0x80000001
2600 #define TAPE_DRIVE_TENSION 0x80000002
2601 #define TAPE_DRIVE_LOCK_UNLOCK 0x80000004
2602 #define TAPE_DRIVE_REWIND_IMMEDIATE 0x80000008
2603 #define TAPE_DRIVE_SET_BLOCK_SIZE 0x80000010
2604 #define TAPE_DRIVE_LOAD_UNLD_IMMED 0x80000020
2605 #define TAPE_DRIVE_TENSION_IMMED 0x80000040
2606 #define TAPE_DRIVE_LOCK_UNLK_IMMED 0x80000080
2607 #define TAPE_DRIVE_SET_ECC 0x80000100
2608 #define TAPE_DRIVE_SET_COMPRESSION 0x80000200
2609 #define TAPE_DRIVE_SET_PADDING 0x80000400
2610 #define TAPE_DRIVE_SET_REPORT_SMKS 0x80000800
2611 #define TAPE_DRIVE_ABSOLUTE_BLK 0x80001000
2612 #define TAPE_DRIVE_ABS_BLK_IMMED 0x80002000
2613 #define TAPE_DRIVE_LOGICAL_BLK 0x80004000
2614 #define TAPE_DRIVE_LOG_BLK_IMMED 0x80008000
2615 #define TAPE_DRIVE_END_OF_DATA 0x80010000
2616 #define TAPE_DRIVE_RELATIVE_BLKS 0x80020000
2617 #define TAPE_DRIVE_FILEMARKS 0x80040000
2618 #define TAPE_DRIVE_SEQUENTIAL_FMKS 0x80080000
2619 #define TAPE_DRIVE_SETMARKS 0x80100000
2620 #define TAPE_DRIVE_SEQUENTIAL_SMKS 0x80200000
2621 #define TAPE_DRIVE_REVERSE_POSITION 0x80400000
2622 #define TAPE_DRIVE_SPACE_IMMEDIATE 0x80800000
2623 #define TAPE_DRIVE_WRITE_SETMARKS 0x81000000
2624 #define TAPE_DRIVE_WRITE_FILEMARKS 0x82000000
2625 #define TAPE_DRIVE_WRITE_SHORT_FMKS 0x84000000
2626 #define TAPE_DRIVE_WRITE_LONG_FMKS 0x88000000
2627 #define TAPE_DRIVE_WRITE_MARK_IMMED 0x90000000
2628 #define TAPE_DRIVE_FORMAT 0xA0000000
2629 #define TAPE_DRIVE_FORMAT_IMMEDIATE 0xC0000000
2630 #define TAPE_DRIVE_HIGH_FEATURES 0x80000000
2631 #define TAPE_FIXED_PARTITIONS 0
2632 #define TAPE_INITIATOR_PARTITIONS 2
2633 #define TAPE_SELECT_PARTITIONS 1
2634 #define TAPE_FILEMARKS 1
2635 #define TAPE_LONG_FILEMARKS 3
2636 #define TAPE_SETMARKS 0
2637 #define TAPE_SHORT_FILEMARKS 2
2638 #define TAPE_ERASE_LONG 1
2639 #define TAPE_ERASE_SHORT 0
2640 #define TAPE_LOAD 0
2641 #define TAPE_UNLOAD 1
2642 #define TAPE_TENSION 2
2643 #define TAPE_LOCK 3
2644 #define TAPE_UNLOCK 4
2645 #define TAPE_FORMAT 5
2646 #if (_WIN32_WINNT >= 0x0500)
2647 #define VER_MINORVERSION 0x0000001
2648 #define VER_MAJORVERSION 0x0000002
2649 #define VER_BUILDNUMBER 0x0000004
2650 #define VER_PLATFORMID 0x0000008
2651 #define VER_SERVICEPACKMINOR 0x0000010
2652 #define VER_SERVICEPACKMAJOR 0x0000020
2653 #define VER_SUITENAME 0x0000040
2654 #define VER_PRODUCT_TYPE 0x0000080
2655 #define VER_EQUAL 1
2656 #define VER_GREATER 2
2657 #define VER_GREATER_EQUAL 3
2658 #define VER_LESS 4
2659 #define VER_LESS_EQUAL 5
2660 #define VER_AND 6
2661 #define VER_OR 7
2662 #endif
2663
2664 #define VER_PLATFORM_WIN32s 0
2665 #define VER_PLATFORM_WIN32_WINDOWS 1
2666 #define VER_PLATFORM_WIN32_NT 2
2667 #define VER_NT_WORKSTATION 1
2668 #define VER_NT_DOMAIN_CONTROLLER 2
2669 #define VER_NT_SERVER 3
2670
2671 #define WT_EXECUTEDEFAULT 0x00000000
2672 #define WT_EXECUTEINIOTHREAD 0x00000001
2673 #define WT_EXECUTEINUITHREAD 0x00000002
2674 #define WT_EXECUTEINWAITTHREAD 0x00000004
2675 #define WT_EXECUTEONLYONCE 0x00000008
2676 #define WT_EXECUTELONGFUNCTION 0x00000010
2677 #define WT_EXECUTEINTIMERTHREAD 0x00000020
2678 #define WT_EXECUTEINPERSISTENTIOTHREAD 0x00000040
2679 #define WT_EXECUTEINPERSISTENTTHREAD 0x00000080
2680 #define WT_TRANSFER_IMPERSONATION 0x00000100
2681 #define WT_SET_MAX_THREADPOOL_THREADS(flags,limit) ((flags)|=(limit)<<16)
2682 typedef VOID (NTAPI *WORKERCALLBACKFUNC)(PVOID);
2683 #if (_WIN32_WINNT >= 0x0501)
2684 #define ACTIVATION_CONTEXT_SECTION_ASSEMBLY_INFORMATION 1
2685 #define ACTIVATION_CONTEXT_SECTION_DLL_REDIRECTION 2
2686 #define ACTIVATION_CONTEXT_SECTION_WINDOW_CLASS_REDIRECTION 3
2687 #define ACTIVATION_CONTEXT_SECTION_COM_SERVER_REDIRECTION 4
2688 #define ACTIVATION_CONTEXT_SECTION_COM_INTERFACE_REDIRECTION 5
2689 #define ACTIVATION_CONTEXT_SECTION_COM_TYPE_LIBRARY_REDIRECTION 6
2690 #define ACTIVATION_CONTEXT_SECTION_COM_PROGID_REDIRECTION 7
2691 #define ACTIVATION_CONTEXT_SECTION_CLR_SURROGATES 9
2692 #endif /* (_WIN32_WINNT >= 0x0501) */
2693 #define BTYPE(x) ((x)&N_BTMASK)
2694 #define ISPTR(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT))
2695 #define ISFCN(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_FUNCTION<<N_BTSHFT))
2696 #define ISARY(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_ARRAY<<N_BTSHFT))
2697 #define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG||(x)==IMAGE_SYM_CLASS_UNION_TAG||(x)==IMAGE_SYM_CLASS_ENUM_TAG)
2698 #define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
2699 #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
2700 #define TLS_MINIMUM_AVAILABLE 64
2701 #define FLS_MAXIMUM_AVAILABLE 128
2702 #define REPARSE_GUID_DATA_BUFFER_HEADER_SIZE FIELD_OFFSET(REPARSE_GUID_DATA_BUFFER, GenericReparseBuffer)
2703 #define MAXIMUM_REPARSE_DATA_BUFFER_SIZE 16384
2704 #define IO_REPARSE_TAG_RESERVED_ZERO 0
2705 #define IO_REPARSE_TAG_RESERVED_ONE 1
2706 #define IO_REPARSE_TAG_RESERVED_RANGE IO_REPARSE_TAG_RESERVED_ONE
2707 #define IsReparseTagMicrosoft(x) ((x)&0x80000000)
2708 #define IsReparseTagHighLatency(x) ((x)&0x40000000)
2709 #define IsReparseTagNameSurrogate(x) ((x)&0x20000000)
2710 #define IO_REPARSE_TAG_VALID_VALUES 0xE000FFFF
2711 #define IsReparseTagValid(x) (!((x)&~IO_REPARSE_TAG_VALID_VALUES)&&((x)>IO_REPARSE_TAG_RESERVED_RANGE))
2712 #define IO_REPARSE_TAG_SYMBOLIC_LINK IO_REPARSE_TAG_RESERVED_ZERO
2713 #define IO_REPARSE_TAG_MOUNT_POINT 0xA0000003
2714 #define IO_REPARSE_TAG_SYMLINK 0xA000000CL
2715 #ifndef RC_INVOKED
2716 typedef DWORD ACCESS_MASK, *PACCESS_MASK;
2717
2718 #ifdef _GUID_DEFINED
2719 # warning _GUID_DEFINED is deprecated, use GUID_DEFINED instead
2720 #endif
2721
2722 #if ! (defined _GUID_DEFINED || defined GUID_DEFINED) /* also defined in basetyps.h */
2723 #define GUID_DEFINED
2724 typedef struct _GUID {
2725 unsigned long Data1;
2726 unsigned short Data2;
2727 unsigned short Data3;
2728 unsigned char Data4[8];
2729 } GUID, *REFGUID, *LPGUID;
2730 #endif /* GUID_DEFINED */
2731
2732 #define SYSTEM_LUID { 0x3E7, 0x0 }
2733
2734 /* ACE Access Types, also in ntifs.h */
2735 #define ACCESS_MIN_MS_ACE_TYPE (0x0)
2736 #define ACCESS_ALLOWED_ACE_TYPE (0x0)
2737 #define ACCESS_DENIED_ACE_TYPE (0x1)
2738 #define SYSTEM_AUDIT_ACE_TYPE (0x2)
2739 #define SYSTEM_ALARM_ACE_TYPE (0x3)
2740 #define ACCESS_MAX_MS_V2_ACE_TYPE (0x3)
2741 #define ACCESS_ALLOWED_COMPOUND_ACE_TYPE (0x4)
2742 #define ACCESS_MAX_MS_V3_ACE_TYPE (0x4)
2743 #define ACCESS_MIN_MS_OBJECT_ACE_TYPE (0x5)
2744 #define ACCESS_ALLOWED_OBJECT_ACE_TYPE (0x5)
2745 #define ACCESS_DENIED_OBJECT_ACE_TYPE (0x6)
2746 #define SYSTEM_AUDIT_OBJECT_ACE_TYPE (0x7)
2747 #define SYSTEM_ALARM_OBJECT_ACE_TYPE (0x8)
2748 #define ACCESS_MAX_MS_OBJECT_ACE_TYPE (0x8)
2749 #define ACCESS_MAX_MS_V4_ACE_TYPE (0x8)
2750 #define ACCESS_MAX_MS_ACE_TYPE (0x8)
2751 #define ACCESS_ALLOWED_CALLBACK_ACE_TYPE (0x9)
2752 #define ACCESS_DENIED_CALLBACK_ACE_TYPE (0xA)
2753 #define ACCESS_ALLOWED_CALLBACK_OBJECT_ACE_TYPE (0xB)
2754 #define ACCESS_DENIED_CALLBACK_OBJECT_ACE_TYPE (0xC)
2755 #define SYSTEM_AUDIT_CALLBACK_ACE_TYPE (0xD)
2756 #define SYSTEM_ALARM_CALLBACK_ACE_TYPE (0xE)
2757 #define SYSTEM_AUDIT_CALLBACK_OBJECT_ACE_TYPE (0xF)
2758 #define SYSTEM_ALARM_CALLBACK_OBJECT_ACE_TYPE (0x10)
2759 #define SYSTEM_MANDATORY_LABEL_ACE_TYPE (0x11)
2760 #define ACCESS_MAX_MS_V5_ACE_TYPE (0x11)
2761 /* end ntifs.h */
2762
2763 typedef struct _GENERIC_MAPPING {
2764 ACCESS_MASK GenericRead;
2765 ACCESS_MASK GenericWrite;
2766 ACCESS_MASK GenericExecute;
2767 ACCESS_MASK GenericAll;
2768 } GENERIC_MAPPING, *PGENERIC_MAPPING;
2769
2770 typedef struct _ACE_HEADER {
2771 BYTE AceType;
2772 BYTE AceFlags;
2773 WORD AceSize;
2774 } ACE_HEADER, *PACE_HEADER;
2775
2776 typedef struct _ACCESS_ALLOWED_ACE {
2777 ACE_HEADER Header;
2778 ACCESS_MASK Mask;
2779 DWORD SidStart;
2780 } ACCESS_ALLOWED_ACE, *PACCESS_ALLOWED_ACE;
2781
2782 typedef struct _ACCESS_DENIED_ACE {
2783 ACE_HEADER Header;
2784 ACCESS_MASK Mask;
2785 DWORD SidStart;
2786 } ACCESS_DENIED_ACE, *PACCESS_DENIED_ACE;
2787
2788 typedef struct _SYSTEM_AUDIT_ACE {
2789 ACE_HEADER Header;
2790 ACCESS_MASK Mask;
2791 DWORD SidStart;
2792 } SYSTEM_AUDIT_ACE, *PSYSTEM_AUDIT_ACE;
2793
2794 typedef struct _SYSTEM_ALARM_ACE {
2795 ACE_HEADER Header;
2796 ACCESS_MASK Mask;
2797 DWORD SidStart;
2798 } SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
2799
2800 typedef struct _SYSTEM_MANDATORY_LABEL_ACE {
2801 ACE_HEADER Header;
2802 ACCESS_MASK Mask;
2803 DWORD SidStart;
2804 } SYSTEM_MANDATORY_LABEL_ACE, *PSYSTEM_MANDATORY_LABEL_ACE;
2805
2806 #define SYSTEM_MANDATORY_LABEL_NO_WRITE_UP 0x1
2807 #define SYSTEM_MANDATORY_LABEL_NO_READ_UP 0x2
2808 #define SYSTEM_MANDATORY_LABEL_NO_EXECUTE_UP 0x4
2809 #define SYSTEM_MANDATORY_LABEL_VALID_MASK (SYSTEM_MANDATORY_LABEL_NO_WRITE_UP | SYSTEM_MANDATORY_LABEL_NO_READ_UP | SYSTEM_MANDATORY_LABEL_NO_EXECUTE_UP)
2810
2811 typedef struct _ACCESS_ALLOWED_OBJECT_ACE {
2812 ACE_HEADER Header;
2813 ACCESS_MASK Mask;
2814 DWORD Flags;
2815 GUID ObjectType;
2816 GUID InheritedObjectType;
2817 DWORD SidStart;
2818 } ACCESS_ALLOWED_OBJECT_ACE,*PACCESS_ALLOWED_OBJECT_ACE;
2819
2820 typedef struct _ACCESS_DENIED_OBJECT_ACE {
2821 ACE_HEADER Header;
2822 ACCESS_MASK Mask;
2823 DWORD Flags;
2824 GUID ObjectType;
2825 GUID InheritedObjectType;
2826 DWORD SidStart;
2827 } ACCESS_DENIED_OBJECT_ACE,*PACCESS_DENIED_OBJECT_ACE;
2828
2829 typedef struct _SYSTEM_AUDIT_OBJECT_ACE {
2830 ACE_HEADER Header;
2831 ACCESS_MASK Mask;
2832 DWORD Flags;
2833 GUID ObjectType;
2834 GUID InheritedObjectType;
2835 DWORD SidStart;
2836 } SYSTEM_AUDIT_OBJECT_ACE,*PSYSTEM_AUDIT_OBJECT_ACE;
2837
2838 typedef struct _SYSTEM_ALARM_OBJECT_ACE {
2839 ACE_HEADER Header;
2840 ACCESS_MASK Mask;
2841 DWORD Flags;
2842 GUID ObjectType;
2843 GUID InheritedObjectType;
2844 DWORD SidStart;
2845 } SYSTEM_ALARM_OBJECT_ACE,*PSYSTEM_ALARM_OBJECT_ACE;
2846
2847 typedef struct _ACCESS_ALLOWED_CALLBACK_ACE {
2848 ACE_HEADER Header;
2849 ACCESS_MASK Mask;
2850 DWORD SidStart;
2851 } ACCESS_ALLOWED_CALLBACK_ACE, *PACCESS_ALLOWED_CALLBACK_ACE;
2852
2853 typedef struct _ACCESS_DENIED_CALLBACK_ACE {
2854 ACE_HEADER Header;
2855 ACCESS_MASK Mask;
2856 DWORD SidStart;
2857 } ACCESS_DENIED_CALLBACK_ACE, *PACCESS_DENIED_CALLBACK_ACE;
2858
2859 typedef struct _SYSTEM_AUDIT_CALLBACK_ACE {
2860 ACE_HEADER Header;
2861 ACCESS_MASK Mask;
2862 DWORD SidStart;
2863 } SYSTEM_AUDIT_CALLBACK_ACE, *PSYSTEM_AUDIT_CALLBACK_ACE;
2864
2865 typedef struct _SYSTEM_ALARM_CALLBACK_ACE {
2866 ACE_HEADER Header;
2867 ACCESS_MASK Mask;
2868 DWORD SidStart;
2869 } SYSTEM_ALARM_CALLBACK_ACE, *PSYSTEM_ALARM_CALLBACK_ACE;
2870
2871 typedef struct _ACCESS_ALLOWED_CALLBACK_OBJECT_ACE {
2872 ACE_HEADER Header;
2873 ACCESS_MASK Mask;
2874 DWORD Flags;
2875 GUID ObjectType;
2876 GUID InheritedObjectType;
2877 DWORD SidStart;
2878 } ACCESS_ALLOWED_CALLBACK_OBJECT_ACE, *PACCESS_ALLOWED_CALLBACK_OBJECT_ACE;
2879
2880 typedef struct _ACCESS_DENIED_CALLBACK_OBJECT_ACE {
2881 ACE_HEADER Header;
2882 ACCESS_MASK Mask;
2883 DWORD Flags;
2884 GUID ObjectType;
2885 GUID InheritedObjectType;
2886 DWORD SidStart;
2887 } ACCESS_DENIED_CALLBACK_OBJECT_ACE, *PACCESS_DENIED_CALLBACK_OBJECT_ACE;
2888
2889 typedef struct _SYSTEM_AUDIT_CALLBACK_OBJECT_ACE {
2890 ACE_HEADER Header;
2891 ACCESS_MASK Mask;
2892 DWORD Flags;
2893 GUID ObjectType;
2894 GUID InheritedObjectType;
2895 DWORD SidStart;
2896 } SYSTEM_AUDIT_CALLBACK_OBJECT_ACE, *PSYSTEM_AUDIT_CALLBACK_OBJECT_ACE;
2897
2898 typedef struct _SYSTEM_ALARM_CALLBACK_OBJECT_ACE {
2899 ACE_HEADER Header;
2900 ACCESS_MASK Mask;
2901 DWORD Flags;
2902 GUID ObjectType;
2903 GUID InheritedObjectType;
2904 DWORD SidStart;
2905 } SYSTEM_ALARM_CALLBACK_OBJECT_ACE, *PSYSTEM_ALARM_CALLBACK_OBJECT_ACE;
2906
2907 typedef struct _ACL {
2908 BYTE AclRevision;
2909 BYTE Sbz1;
2910 WORD AclSize;
2911 WORD AceCount;
2912 WORD Sbz2;
2913 } ACL,*PACL;
2914
2915 typedef enum _ACL_INFORMATION_CLASS {
2916 AclRevisionInformation = 1,
2917 AclSizeInformation
2918 } ACL_INFORMATION_CLASS;
2919
2920 typedef struct _ACL_REVISION_INFORMATION {
2921 DWORD AclRevision;
2922 } ACL_REVISION_INFORMATION, *PACL_REVISION_INFORMATION;
2923
2924 typedef struct _ACL_SIZE_INFORMATION {
2925 DWORD AceCount;
2926 DWORD AclBytesInUse;
2927 DWORD AclBytesFree;
2928 } ACL_SIZE_INFORMATION, *PACL_SIZE_INFORMATION;
2929
2930 #ifndef _LDT_ENTRY_DEFINED
2931 #define _LDT_ENTRY_DEFINED
2932
2933 typedef struct _LDT_ENTRY {
2934 WORD LimitLow;
2935 WORD BaseLow;
2936 union {
2937 struct {
2938 BYTE BaseMid;
2939 BYTE Flags1;
2940 BYTE Flags2;
2941 BYTE BaseHi;
2942 } Bytes;
2943 struct {
2944 DWORD BaseMid:8;
2945 DWORD Type:5;
2946 DWORD Dpl:2;
2947 DWORD Pres:1;
2948 DWORD LimitHi:4;
2949 DWORD Sys:1;
2950 DWORD Reserved_0:1;
2951 DWORD Default_Big:1;
2952 DWORD Granularity:1;
2953 DWORD BaseHi:8;
2954 } Bits;
2955 } HighWord;
2956 } LDT_ENTRY, *PLDT_ENTRY, *LPLDT_ENTRY;
2957
2958 #endif /* _LDT_ENTRY_DEFINED */
2959
2960 /* FIXME: add more machines */
2961 #if defined(_X86_) && !defined(__PowerPC__)
2962 #define SIZE_OF_80387_REGISTERS 80
2963 #define CONTEXT_i386 0x10000
2964 #define CONTEXT_i486 0x10000
2965 #define CONTEXT_CONTROL (CONTEXT_i386|0x00000001L)
2966 #define CONTEXT_INTEGER (CONTEXT_i386|0x00000002L)
2967 #define CONTEXT_SEGMENTS (CONTEXT_i386|0x00000004L)
2968 #define CONTEXT_FLOATING_POINT (CONTEXT_i386|0x00000008L)
2969 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_i386|0x00000010L)
2970 #define CONTEXT_EXTENDED_REGISTERS (CONTEXT_i386|0x00000020L)
2971 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_INTEGER|CONTEXT_SEGMENTS)
2972 #define MAXIMUM_SUPPORTED_EXTENSION 512
2973
2974 #define EXCEPTION_READ_FAULT 0
2975 #define EXCEPTION_WRITE_FAULT 1
2976 #define EXCEPTION_EXECUTE_FAULT 8
2977
2978 typedef struct _FLOATING_SAVE_AREA {
2979 DWORD ControlWord;
2980 DWORD StatusWord;
2981 DWORD TagWord;
2982 DWORD ErrorOffset;
2983 DWORD ErrorSelector;
2984 DWORD DataOffset;
2985 DWORD DataSelector;
2986 BYTE RegisterArea[SIZE_OF_80387_REGISTERS];
2987 DWORD Cr0NpxState;
2988 } FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
2989
2990 typedef struct _CONTEXT {
2991 DWORD ContextFlags;
2992 DWORD Dr0;
2993 DWORD Dr1;
2994 DWORD Dr2;
2995 DWORD Dr3;
2996 DWORD Dr6;
2997 DWORD Dr7;
2998 FLOATING_SAVE_AREA FloatSave;
2999 DWORD SegGs;
3000 DWORD SegFs;
3001 DWORD SegEs;
3002 DWORD SegDs;
3003 DWORD Edi;
3004 DWORD Esi;
3005 DWORD Ebx;
3006 DWORD Edx;
3007 DWORD Ecx;
3008 DWORD Eax;
3009 DWORD Ebp;
3010 DWORD Eip;
3011 DWORD SegCs;
3012 DWORD EFlags;
3013 DWORD Esp;
3014 DWORD SegSs;
3015 BYTE ExtendedRegisters[MAXIMUM_SUPPORTED_EXTENSION];
3016 } CONTEXT;
3017 #elif defined(__x86_64__)
3018
3019 #define CONTEXT_AMD64 0x100000
3020
3021 #if !defined(RC_INVOKED)
3022 #define CONTEXT_CONTROL (CONTEXT_AMD64 | 0x1L)
3023 #define CONTEXT_INTEGER (CONTEXT_AMD64 | 0x2L)
3024 #define CONTEXT_SEGMENTS (CONTEXT_AMD64 | 0x4L)
3025 #define CONTEXT_FLOATING_POINT (CONTEXT_AMD64 | 0x8L)
3026 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_AMD64 | 0x10L)
3027
3028 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
3029 #define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS)
3030
3031 #define CONTEXT_EXCEPTION_ACTIVE 0x8000000
3032 #define CONTEXT_SERVICE_ACTIVE 0x10000000
3033 #define CONTEXT_EXCEPTION_REQUEST 0x40000000
3034 #define CONTEXT_EXCEPTION_REPORTING 0x80000000
3035 #endif
3036
3037 #define INITIAL_MXCSR 0x1f80
3038 #define INITIAL_FPCSR 0x027f
3039 #define EXCEPTION_READ_FAULT 0
3040 #define EXCEPTION_WRITE_FAULT 1
3041 #define EXCEPTION_EXECUTE_FAULT 8
3042
3043 typedef struct DECLSPEC_ALIGN(16) _M128A {
3044 ULONGLONG Low;
3045 LONGLONG High;
3046 } M128A, *PM128A;
3047
3048 typedef struct _XMM_SAVE_AREA32 {
3049 WORD ControlWord;
3050 WORD StatusWord;
3051 BYTE TagWord;
3052 BYTE Reserved1;
3053 WORD ErrorOpcode;
3054 DWORD ErrorOffset;
3055 WORD ErrorSelector;
3056 WORD Reserved2;
3057 DWORD DataOffset;
3058 WORD DataSelector;
3059 WORD Reserved3;
3060 DWORD MxCsr;
3061 DWORD MxCsr_Mask;
3062 M128A FloatRegisters[8];
3063 M128A XmmRegisters[16];
3064 BYTE Reserved4[96];
3065 } XMM_SAVE_AREA32, *PXMM_SAVE_AREA32;
3066
3067 typedef struct DECLSPEC_ALIGN(16) _CONTEXT {
3068 DWORD64 P1Home;
3069 DWORD64 P2Home;
3070 DWORD64 P3Home;
3071 DWORD64 P4Home;
3072 DWORD64 P5Home;
3073 DWORD64 P6Home;
3074
3075 /* Control flags */
3076 DWORD ContextFlags;
3077 DWORD MxCsr;
3078
3079 /* Segment */
3080 WORD SegCs;
3081 WORD SegDs;
3082 WORD SegEs;
3083 WORD SegFs;
3084 WORD SegGs;
3085 WORD SegSs;
3086 DWORD EFlags;
3087
3088 /* Debug */
3089 DWORD64 Dr0;
3090 DWORD64 Dr1;
3091 DWORD64 Dr2;
3092 DWORD64 Dr3;
3093 DWORD64 Dr6;
3094 DWORD64 Dr7;
3095
3096 /* Integer */
3097 DWORD64 Rax;
3098 DWORD64 Rcx;
3099 DWORD64 Rdx;
3100 DWORD64 Rbx;
3101 DWORD64 Rsp;
3102 DWORD64 Rbp;
3103 DWORD64 Rsi;
3104 DWORD64 Rdi;
3105 DWORD64 R8;
3106 DWORD64 R9;
3107 DWORD64 R10;
3108 DWORD64 R11;
3109 DWORD64 R12;
3110 DWORD64 R13;
3111 DWORD64 R14;
3112 DWORD64 R15;
3113
3114 /* Counter */
3115 DWORD64 Rip;
3116
3117 /* Floating point */
3118 union {
3119 XMM_SAVE_AREA32 FltSave;
3120 struct {
3121 M128A Header[2];
3122 M128A Legacy[8];
3123 M128A Xmm0;
3124 M128A Xmm1;
3125 M128A Xmm2;
3126 M128A Xmm3;
3127 M128A Xmm4;
3128 M128A Xmm5;
3129 M128A Xmm6;
3130 M128A Xmm7;
3131 M128A Xmm8;
3132 M128A Xmm9;
3133 M128A Xmm10;
3134 M128A Xmm11;
3135 M128A Xmm12;
3136 M128A Xmm13;
3137 M128A Xmm14;
3138 M128A Xmm15;
3139 } DUMMYSTRUCTNAME;
3140 } DUMMYUNIONNAME;
3141
3142 /* Vector */
3143 M128A VectorRegister[26];
3144 DWORD64 VectorControl;
3145
3146 /* Debug control */
3147 DWORD64 DebugControl;
3148 DWORD64 LastBranchToRip;
3149 DWORD64 LastBranchFromRip;
3150 DWORD64 LastExceptionToRip;
3151 DWORD64 LastExceptionFromRip;
3152 } CONTEXT;
3153
3154
3155 typedef struct _KNONVOLATILE_CONTEXT_POINTERS {
3156 union {
3157 PM128A FloatingContext[16];
3158 struct {
3159 PM128A Xmm0;
3160 PM128A Xmm1;
3161 PM128A Xmm2;
3162 PM128A Xmm3;
3163 PM128A Xmm4;
3164 PM128A Xmm5;
3165 PM128A Xmm6;
3166 PM128A Xmm7;
3167 PM128A Xmm8;
3168 PM128A Xmm9;
3169 PM128A Xmm10;
3170 PM128A Xmm11;
3171 PM128A Xmm12;
3172 PM128A Xmm13;
3173 PM128A Xmm14;
3174 PM128A Xmm15;
3175 } DUMMYSTRUCTNAME;
3176 } DUMMYUNIONNAME;
3177
3178 union {
3179 PULONG64 IntegerContext[16];
3180 struct {
3181 PULONG64 Rax;
3182 PULONG64 Rcx;
3183 PULONG64 Rdx;
3184 PULONG64 Rbx;
3185 PULONG64 Rsp;
3186 PULONG64 Rbp;
3187 PULONG64 Rsi;
3188 PULONG64 Rdi;
3189 PULONG64 R8;
3190 PULONG64 R9;
3191 PULONG64 R10;
3192 PULONG64 R11;
3193 PULONG64 R12;
3194 PULONG64 R13;
3195 PULONG64 R14;
3196 PULONG64 R15;
3197 } DUMMYSTRUCTNAME;
3198 } DUMMYUNIONNAME2;
3199 } KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS;
3200
3201 #define RUNTIME_FUNCTION_INDIRECT 0x1
3202
3203 typedef struct _RUNTIME_FUNCTION {
3204 DWORD BeginAddress;
3205 DWORD EndAddress;
3206 DWORD UnwindData;
3207 } RUNTIME_FUNCTION,*PRUNTIME_FUNCTION;
3208
3209 #define UNWIND_HISTORY_TABLE_SIZE 12
3210
3211 typedef struct _UNWIND_HISTORY_TABLE_ENTRY
3212 {
3213 DWORD64 ImageBase;
3214 PRUNTIME_FUNCTION FunctionEntry;
3215 } UNWIND_HISTORY_TABLE_ENTRY, *PUNWIND_HISTORY_TABLE_ENTRY;
3216
3217 typedef struct _UNWIND_HISTORY_TABLE
3218 {
3219 DWORD Count;
3220 UCHAR Search;
3221 ULONG64 LowAddress;
3222 ULONG64 HighAddress;
3223 UNWIND_HISTORY_TABLE_ENTRY Entry[UNWIND_HISTORY_TABLE_SIZE];
3224 } UNWIND_HISTORY_TABLE, *PUNWIND_HISTORY_TABLE;
3225
3226 typedef
3227 _Function_class_(GET_RUNTIME_FUNCTION_CALLBACK)
3228 PRUNTIME_FUNCTION
3229 (*PGET_RUNTIME_FUNCTION_CALLBACK)(
3230 _In_ DWORD64 ControlPc,
3231 _In_opt_ PVOID Context);
3232
3233 typedef
3234 _Function_class_(OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK)
3235 _Must_inspect_result_
3236 DWORD
3237 (*POUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK)(
3238 _In_ HANDLE Process,
3239 _In_ PVOID TableAddress,
3240 _Out_ PDWORD Entries,
3241 _Out_ PRUNTIME_FUNCTION *Functions);
3242
3243 #define OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK_EXPORT_NAME "OutOfProcessFunctionTableCallback"
3244
3245 NTSYSAPI
3246 VOID
3247 __cdecl
3248 RtlRestoreContext(struct _CONTEXT *ContextRecord,
3249 struct _EXCEPTION_RECORD *ExceptionRecord);
3250
3251 NTSYSAPI
3252 BOOLEAN
3253 __cdecl
3254 RtlAddFunctionTable(PRUNTIME_FUNCTION FunctionTable,
3255 DWORD EntryCount,
3256 DWORD64 BaseAddress);
3257
3258 NTSYSAPI
3259 BOOLEAN
3260 __cdecl
3261 RtlInstallFunctionTableCallback(DWORD64 TableIdentifier,
3262 DWORD64 BaseAddress,
3263 DWORD Length,
3264 PGET_RUNTIME_FUNCTION_CALLBACK Callback,
3265 PVOID Context,
3266 PCWSTR OutOfProcessCallbackDll);
3267
3268 NTSYSAPI
3269 BOOLEAN
3270 __cdecl
3271 RtlDeleteFunctionTable(PRUNTIME_FUNCTION FunctionTable);
3272
3273 NTSYSAPI
3274 PRUNTIME_FUNCTION
3275 NTAPI
3276 RtlLookupFunctionEntry(
3277 _In_ DWORD64 ControlPc,
3278 _Out_ PDWORD64 ImageBase,
3279 _Inout_opt_ PUNWIND_HISTORY_TABLE HistoryTable);
3280
3281 NTSYSAPI
3282 PEXCEPTION_ROUTINE
3283 NTAPI
3284 RtlVirtualUnwind(
3285 _In_ DWORD HandlerType,
3286 _In_ DWORD64 ImageBase,
3287 _In_ DWORD64 ControlPc,
3288 _In_ PRUNTIME_FUNCTION FunctionEntry,
3289 _Inout_ struct _CONTEXT *ContextRecord,
3290 _Out_ PVOID *HandlerData,
3291 _Out_ PDWORD64 EstablisherFrame,
3292 _Inout_opt_ PKNONVOLATILE_CONTEXT_POINTERS ContextPointers);
3293
3294 #elif defined(_PPC_)
3295 #define CONTEXT_CONTROL 1L
3296 #define CONTEXT_FLOATING_POINT 2L
3297 #define CONTEXT_INTEGER 4L
3298 #define CONTEXT_DEBUG_REGISTERS 8L
3299 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_FLOATING_POINT|CONTEXT_INTEGER)
3300 typedef struct _FLOATING_SAVE_AREA
3301 {
3302 double Fpr0;
3303 double Fpr1;
3304 double Fpr2;
3305 double Fpr3;
3306 double Fpr4;
3307 double Fpr5;
3308 double Fpr6;
3309 double Fpr7;
3310 double Fpr8;
3311 double Fpr9;
3312 double Fpr10;
3313 double Fpr11;
3314 double Fpr12;
3315 double Fpr13;
3316 double Fpr14;
3317 double Fpr15;
3318 double Fpr16;
3319 double Fpr17;
3320 double Fpr18;
3321 double Fpr19;
3322 double Fpr20;
3323 double Fpr21;
3324 double Fpr22;
3325 double Fpr23;
3326 double Fpr24;
3327 double Fpr25;
3328 double Fpr26;
3329 double Fpr27;
3330 double Fpr28;
3331 double Fpr29;
3332 double Fpr30;
3333 double Fpr31;
3334 double Fpscr;
3335 } FLOATING_SAVE_AREA;
3336
3337 typedef struct _CONTEXT {
3338 FLOATING_SAVE_AREA FloatSave;
3339 DWORD Gpr0;
3340 DWORD Gpr1;
3341 DWORD Gpr2;
3342 DWORD Gpr3;
3343 DWORD Gpr4;
3344 DWORD Gpr5;
3345 DWORD Gpr6;
3346 DWORD Gpr7;
3347 DWORD Gpr8;
3348 DWORD Gpr9;
3349 DWORD Gpr10;
3350 DWORD Gpr11;
3351 DWORD Gpr12;
3352 DWORD Gpr13;
3353 DWORD Gpr14;
3354 DWORD Gpr15;
3355 DWORD Gpr16;
3356 DWORD Gpr17;
3357 DWORD Gpr18;
3358 DWORD Gpr19;
3359 DWORD Gpr20;
3360 DWORD Gpr21;
3361 DWORD Gpr22;
3362 DWORD Gpr23;
3363 DWORD Gpr24;
3364 DWORD Gpr25;
3365 DWORD Gpr26;
3366 DWORD Gpr27;
3367 DWORD Gpr28;
3368 DWORD Gpr29;
3369 DWORD Gpr30;
3370 DWORD Gpr31;
3371 DWORD Cr;
3372 DWORD Xer;
3373 DWORD Msr;
3374 DWORD Iar;
3375 DWORD Lr;
3376 DWORD Ctr;
3377 DWORD ContextFlags;
3378 DWORD Fill[3];
3379 DWORD Dr0;
3380 DWORD Dr1;
3381 DWORD Dr2;
3382 DWORD Dr3;
3383 DWORD Dr4;
3384 DWORD Dr5;
3385 DWORD Dr6;
3386 DWORD Dr7;
3387 } CONTEXT;
3388 #elif defined(_ALPHA_)
3389 #define CONTEXT_ALPHA 0x20000
3390 #define CONTEXT_CONTROL (CONTEXT_ALPHA|1L)
3391 #define CONTEXT_FLOATING_POINT (CONTEXT_ALPHA|2L)
3392 #define CONTEXT_INTEGER (CONTEXT_ALPHA|4L)
3393 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_FLOATING_POINT|CONTEXT_INTEGER)
3394 typedef struct _CONTEXT {
3395 ULONGLONG FltF0;
3396 ULONGLONG FltF1;
3397 ULONGLONG FltF2;
3398 ULONGLONG FltF3;
3399 ULONGLONG FltF4;
3400 ULONGLONG FltF5;
3401 ULONGLONG FltF6;
3402 ULONGLONG FltF7;
3403 ULONGLONG FltF8;
3404 ULONGLONG FltF9;
3405 ULONGLONG FltF10;
3406 ULONGLONG FltF11;
3407 ULONGLONG FltF12;
3408 ULONGLONG FltF13;
3409 ULONGLONG FltF14;
3410 ULONGLONG FltF15;
3411 ULONGLONG FltF16;
3412 ULONGLONG FltF17;
3413 ULONGLONG FltF18;
3414 ULONGLONG FltF19;
3415 ULONGLONG FltF20;
3416 ULONGLONG FltF21;
3417 ULONGLONG FltF22;
3418 ULONGLONG FltF23;
3419 ULONGLONG FltF24;
3420 ULONGLONG FltF25;
3421 ULONGLONG FltF26;
3422 ULONGLONG FltF27;
3423 ULONGLONG FltF28;
3424 ULONGLONG FltF29;
3425 ULONGLONG FltF30;
3426 ULONGLONG FltF31;
3427 ULONGLONG IntV0;
3428 ULONGLONG IntT0;
3429 ULONGLONG IntT1;
3430 ULONGLONG IntT2;
3431 ULONGLONG IntT3;
3432 ULONGLONG IntT4;
3433 ULONGLONG IntT5;
3434 ULONGLONG IntT6;
3435 ULONGLONG IntT7;
3436 ULONGLONG IntS0;
3437 ULONGLONG IntS1;
3438 ULONGLONG IntS2;
3439 ULONGLONG IntS3;
3440 ULONGLONG IntS4;
3441 ULONGLONG IntS5;
3442 ULONGLONG IntFp;
3443 ULONGLONG IntA0;
3444 ULONGLONG IntA1;
3445 ULONGLONG IntA2;
3446 ULONGLONG IntA3;
3447 ULONGLONG IntA4;
3448 ULONGLONG IntA5;
3449 ULONGLONG IntT8;
3450 ULONGLONG IntT9;
3451 ULONGLONG IntT10;
3452 ULONGLONG IntT11;
3453 ULONGLONG IntRa;
3454 ULONGLONG IntT12;
3455 ULONGLONG IntAt;
3456 ULONGLONG IntGp;
3457 ULONGLONG IntSp;
3458 ULONGLONG IntZero;
3459 ULONGLONG Fpcr;
3460 ULONGLONG SoftFpcr;
3461 ULONGLONG Fir;
3462 DWORD Psr;
3463 DWORD ContextFlags;
3464 DWORD Fill[4];
3465 } CONTEXT;
3466 #elif defined(SHx)
3467
3468 /* These are the debug or break registers on the SH3 */
3469 typedef struct _DEBUG_REGISTERS {
3470 DWORD BarA;
3471 UCHAR BasrA;
3472 UCHAR BamrA;
3473 USHORT BbrA;
3474 DWORD BarB;
3475 UCHAR BasrB;
3476 UCHAR BamrB;
3477 USHORT BbrB;
3478 DWORD BdrB;
3479 DWORD BdmrB;
3480 USHORT Brcr;
3481 USHORT Align;
3482 } DEBUG_REGISTERS, *PDEBUG_REGISTERS;
3483
3484 /* The following flags control the contents of the CONTEXT structure. */
3485
3486 #define CONTEXT_SH3 0x00000040
3487 #define CONTEXT_SH4 0x000000c0 /* CONTEXT_SH3 | 0x80 - must contain the SH3 bits */
3488
3489 #ifdef SH3
3490 #define CONTEXT_CONTROL (CONTEXT_SH3 | 0x00000001L)
3491 #define CONTEXT_INTEGER (CONTEXT_SH3 | 0x00000002L)
3492 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_SH3 | 0x00000008L)
3493 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_DEBUG_REGISTERS)
3494 #else /* SH4 */
3495 #define CONTEXT_CONTROL (CONTEXT_SH4 | 0x00000001L)
3496 #define CONTEXT_INTEGER (CONTEXT_SH4 | 0x00000002L)
3497 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_SH4 | 0x00000008L)
3498 #define CONTEXT_FLOATING_POINT (CONTEXT_SH4 | 0x00000004L)
3499 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_DEBUG_REGISTERS | CONTEXT_FLOATING_POINT)
3500 #endif
3501
3502 /* Context Frame */
3503
3504 /* This frame is used to store a limited processor context into the */
3505 /* Thread structure for CPUs which have no floating point support. */
3506
3507 typedef struct _CONTEXT {
3508 /* The flags values within this flag control the contents of */
3509 /* a CONTEXT record. */
3510
3511 /* If the context record is used as an input parameter, then */
3512 /* for each portion of the context record controlled by a flag */
3513 /* whose value is set, it is assumed that that portion of the */
3514 /* context record contains valid context. If the context record */
3515 /* is being used to modify a thread's context, then only that */
3516 /* portion of the threads context will be modified. */
3517
3518 /* If the context record is used as an IN OUT parameter to capture */
3519 /* the context of a thread, then only those portions of the thread's */
3520 /* context corresponding to set flags will be returned. */
3521
3522 /* The context record is never used as an OUT only parameter. */
3523
3524
3525 DWORD ContextFlags;
3526
3527 /* This section is specified/returned if the ContextFlags word contains */
3528 /* the flag CONTEXT_INTEGER. */
3529
3530 /* N.B. The registers RA and R15 are defined in this section, but are */
3531 /* considered part of the control context rather than part of the integer */
3532 /* context. */
3533
3534 DWORD PR;
3535 DWORD MACH;
3536 DWORD MACL;
3537 DWORD GBR;
3538 DWORD R0;
3539 DWORD R1;
3540 DWORD R2;
3541 DWORD R3;
3542 DWORD R4;
3543 DWORD R5;
3544 DWORD R6;
3545 DWORD R7;
3546 DWORD R8;
3547 DWORD R9;
3548 DWORD R10;
3549 DWORD R11;
3550 DWORD R12;
3551 DWORD R13;
3552 DWORD R14;
3553 DWORD R15;
3554
3555 /* This section is specified/returned if the ContextFlags word contains */
3556 /* the flag CONTEXT_CONTROL. */
3557
3558 /* N.B. The registers r15 and ra are defined in the integer section, */
3559 /* but are considered part of the control context rather than part of */
3560 /* the integer context. */
3561
3562 DWORD Fir;
3563 DWORD Psr;
3564
3565 #if !defined(SH3e) && !defined(SH4)
3566 DWORD OldStuff[2];
3567 DEBUG_REGISTERS DebugRegisters;
3568 #else
3569 DWORD Fpscr;
3570 DWORD Fpul;
3571 DWORD FRegs[16];
3572 #if defined(SH4)
3573 DWORD xFRegs[16];
3574 #endif
3575 #endif
3576 } CONTEXT;
3577
3578 #elif defined(_MIPS_)
3579
3580 /* The following flags control the contents of the CONTEXT structure. */
3581
3582 #define CONTEXT_R4000 0x00010000 /* r4000 context */
3583
3584 #define CONTEXT_CONTROL (CONTEXT_R4000 | 0x00000001L)
3585 #define CONTEXT_FLOATING_POINT (CONTEXT_R4000 | 0x00000002L)
3586 #define CONTEXT_INTEGER (CONTEXT_R4000 | 0x00000004L)
3587
3588 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
3589
3590 /* Context Frame */
3591
3592 /* N.B. This frame must be exactly a multiple of 16 bytes in length. */
3593
3594 /* This frame has a several purposes: 1) it is used as an argument to */
3595 /* NtContinue, 2) it is used to constuct a call frame for APC delivery, */
3596 /* 3) it is used to construct a call frame for exception dispatching */
3597 /* in user mode, and 4) it is used in the user level thread creation */
3598 /* routines. */
3599
3600 /* The layout of the record conforms to a standard call frame. */
3601
3602
3603 typedef struct _CONTEXT {
3604
3605 /* This section is always present and is used as an argument build */
3606 /* area. */
3607
3608 DWORD Argument[4];
3609
3610 /* This section is specified/returned if the ContextFlags word contains */
3611 /* the flag CONTEXT_FLOATING_POINT. */
3612
3613 DWORD FltF0;
3614 DWORD FltF1;
3615 DWORD FltF2;
3616 DWORD FltF3;
3617 DWORD FltF4;
3618 DWORD FltF5;
3619 DWORD FltF6;
3620 DWORD FltF7;
3621 DWORD FltF8;
3622 DWORD FltF9;
3623 DWORD FltF10;
3624 DWORD FltF11;
3625 DWORD FltF12;
3626 DWORD FltF13;
3627 DWORD FltF14;
3628 DWORD FltF15;
3629 DWORD FltF16;
3630 DWORD FltF17;
3631 DWORD FltF18;
3632 DWORD FltF19;
3633 DWORD FltF20;
3634 DWORD FltF21;
3635 DWORD FltF22;
3636 DWORD FltF23;
3637 DWORD FltF24;
3638 DWORD FltF25;
3639 DWORD FltF26;
3640 DWORD FltF27;
3641 DWORD FltF28;
3642 DWORD FltF29;
3643 DWORD FltF30;
3644 DWORD FltF31;
3645
3646 /* This section is specified/returned if the ContextFlags word contains */
3647 /* the flag CONTEXT_INTEGER. */
3648
3649 /* N.B. The registers gp, sp, and ra are defined in this section, but are */
3650 /* considered part of the control context rather than part of the integer */
3651 /* context. */
3652
3653 /* N.B. Register zero is not stored in the frame. */
3654
3655 DWORD IntZero;
3656 DWORD IntAt;
3657 DWORD IntV0;
3658 DWORD IntV1;
3659 DWORD IntA0;
3660 DWORD IntA1;
3661 DWORD IntA2;
3662 DWORD IntA3;
3663 DWORD IntT0;
3664 DWORD IntT1;
3665 DWORD IntT2;
3666 DWORD IntT3;
3667 DWORD IntT4;
3668 DWORD IntT5;
3669 DWORD IntT6;
3670 DWORD IntT7;
3671 DWORD IntS0;
3672 DWORD IntS1;
3673 DWORD IntS2;
3674 DWORD IntS3;
3675 DWORD IntS4;
3676 DWORD IntS5;
3677 DWORD IntS6;
3678 DWORD IntS7;
3679 DWORD IntT8;
3680 DWORD IntT9;
3681 DWORD IntK0;
3682 DWORD IntK1;
3683 DWORD IntGp;
3684 DWORD IntSp;
3685 DWORD IntS8;
3686 DWORD IntRa;
3687 DWORD IntLo;
3688 DWORD IntHi;
3689
3690 /* This section is specified/returned if the ContextFlags word contains */
3691 /* the flag CONTEXT_FLOATING_POINT. */
3692
3693 DWORD Fsr;
3694
3695 /* This section is specified/returned if the ContextFlags word contains */
3696 /* the flag CONTEXT_CONTROL. */
3697
3698 /* N.B. The registers gp, sp, and ra are defined in the integer section, */
3699 /* but are considered part of the control context rather than part of */
3700 /* the integer context. */
3701
3702 DWORD Fir;
3703 DWORD Psr;
3704
3705 /* The flags values within this flag control the contents of */
3706 /* a CONTEXT record. */
3707
3708 /* If the context record is used as an input parameter, then */
3709 /* for each portion of the context record controlled by a flag */
3710 /* whose value is set, it is assumed that that portion of the */
3711 /* context record contains valid context. If the context record */
3712 /* is being used to modify a thread's context, then only that */
3713 /* portion of the threads context will be modified. */
3714
3715 /* If the context record is used as an IN OUT parameter to capture */
3716 /* the context of a thread, then only those portions of the thread's */
3717 /* context corresponding to set flags will be returned. */
3718
3719 /* The context record is never used as an OUT only parameter. */
3720
3721 DWORD ContextFlags;
3722
3723 DWORD Fill[2];
3724
3725 } CONTEXT;
3726 #elif defined(_ARM_)
3727
3728 #ifndef PAGE_SIZE
3729 #define PAGE_SIZE 0x1000 // FIXME: This should probably go elsewhere
3730 #endif
3731
3732 /* The following flags control the contents of the CONTEXT structure. */
3733
3734 #define CONTEXT_ARM 0x0000040
3735 #define CONTEXT_CONTROL (CONTEXT_ARM | 0x00000001L)
3736 #define CONTEXT_INTEGER (CONTEXT_ARM | 0x00000002L)
3737
3738 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
3739
3740 typedef struct _CONTEXT {
3741 /* The flags values within this flag control the contents of
3742 a CONTEXT record.
3743
3744 If the context record is used as an input parameter, then
3745 for each portion of the context record controlled by a flag
3746 whose value is set, it is assumed that that portion of the
3747 context record contains valid context. If the context record
3748 is being used to modify a thread's context, then only that
3749 portion of the threads context will be modified.
3750
3751 If the context record is used as an IN OUT parameter to capture
3752 the context of a thread, then only those portions of the thread's
3753 context corresponding to set flags will be returned.
3754
3755 The context record is never used as an OUT only parameter. */
3756
3757 DWORD ContextFlags;
3758
3759 /* This section is specified/returned if the ContextFlags word contains
3760 the flag CONTEXT_INTEGER. */
3761 DWORD R0;
3762 DWORD R1;
3763 DWORD R2;
3764 DWORD R3;
3765 DWORD R4;
3766 DWORD R5;
3767 DWORD R6;
3768 DWORD R7;
3769 DWORD R8;
3770 DWORD R9;
3771 DWORD R10;
3772 DWORD R11;
3773 DWORD R12;
3774
3775 DWORD Sp;
3776 DWORD Lr;
3777 DWORD Pc;
3778 DWORD Psr;
3779 } CONTEXT;
3780
3781 #else
3782 #error "undefined processor type"
3783 #endif
3784 typedef CONTEXT *PCONTEXT,*LPCONTEXT;
3785
3786 #define EXCEPTION_MAXIMUM_PARAMETERS 15
3787 #define EXCEPTION_NONCONTINUABLE 0x01
3788 #define EXCEPTION_UNWINDING 0x02
3789 #define EXCEPTION_EXIT_UNWIND 0x04
3790 #define EXCEPTION_STACK_INVALID 0x08
3791 #define EXCEPTION_NESTED_CALL 0x10
3792 #define EXCEPTION_TARGET_UNWIND 0x20
3793 #define EXCEPTION_COLLIDED_UNWIND 0x40
3794 #define EXCEPTION_UNWIND (EXCEPTION_UNWINDING | EXCEPTION_EXIT_UNWIND | \
3795 EXCEPTION_TARGET_UNWIND | EXCEPTION_COLLIDED_UNWIND)
3796
3797 #define IS_UNWINDING(Flag) ((Flag & EXCEPTION_UNWIND) != 0)
3798 #define IS_DISPATCHING(Flag) ((Flag & EXCEPTION_UNWIND) == 0)
3799 #define IS_TARGET_UNWIND(Flag) (Flag & EXCEPTION_TARGET_UNWIND)
3800
3801 typedef struct _EXCEPTION_RECORD {
3802 DWORD ExceptionCode;
3803 DWORD ExceptionFlags;
3804 struct _EXCEPTION_RECORD *ExceptionRecord;
3805 PVOID ExceptionAddress;
3806 DWORD NumberParameters;
3807 ULONG_PTR ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
3808 } EXCEPTION_RECORD, *PEXCEPTION_RECORD;
3809
3810 typedef struct _EXCEPTION_RECORD32 {
3811 DWORD ExceptionCode;
3812 DWORD ExceptionFlags;
3813 DWORD ExceptionRecord;
3814 DWORD ExceptionAddress;
3815 DWORD NumberParameters;
3816 DWORD ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
3817 } EXCEPTION_RECORD32,*PEXCEPTION_RECORD32;
3818
3819 typedef struct _EXCEPTION_RECORD64 {
3820 DWORD ExceptionCode;
3821 DWORD ExceptionFlags;
3822 DWORD64 ExceptionRecord;
3823 DWORD64 ExceptionAddress;
3824 DWORD NumberParameters;
3825 DWORD __unusedAlignment;
3826 DWORD64 ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
3827 } EXCEPTION_RECORD64,*PEXCEPTION_RECORD64;
3828
3829 typedef struct _EXCEPTION_POINTERS {
3830 PEXCEPTION_RECORD ExceptionRecord;
3831 PCONTEXT ContextRecord;
3832 } EXCEPTION_POINTERS,*PEXCEPTION_POINTERS, *LPEXCEPTION_POINTERS;
3833
3834 #include <pshpack4.h>
3835
3836 typedef struct _LUID_AND_ATTRIBUTES {
3837 LUID Luid;
3838 DWORD Attributes;
3839 } LUID_AND_ATTRIBUTES, *PLUID_AND_ATTRIBUTES;
3840 typedef LUID_AND_ATTRIBUTES LUID_AND_ATTRIBUTES_ARRAY[ANYSIZE_ARRAY];
3841 typedef LUID_AND_ATTRIBUTES_ARRAY *PLUID_AND_ATTRIBUTES_ARRAY;
3842
3843 #include <poppack.h>
3844
3845 typedef struct _PRIVILEGE_SET {
3846 DWORD PrivilegeCount;
3847 DWORD Control;
3848 LUID_AND_ATTRIBUTES Privilege[ANYSIZE_ARRAY];
3849 } PRIVILEGE_SET,*PPRIVILEGE_SET;
3850
3851 typedef struct _SECURITY_ATTRIBUTES {
3852 DWORD nLength;
3853 LPVOID lpSecurityDescriptor;
3854 BOOL bInheritHandle;
3855 } SECURITY_ATTRIBUTES,*PSECURITY_ATTRIBUTES,*LPSECURITY_ATTRIBUTES;
3856
3857 typedef enum _SECURITY_IMPERSONATION_LEVEL {
3858 SecurityAnonymous,
3859 SecurityIdentification,
3860 SecurityImpersonation,
3861 SecurityDelegation
3862 } SECURITY_IMPERSONATION_LEVEL,*PSECURITY_IMPERSONATION_LEVEL;
3863
3864 typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,*PSECURITY_CONTEXT_TRACKING_MODE;
3865
3866 typedef struct _SECURITY_QUALITY_OF_SERVICE {
3867 DWORD Length;
3868 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
3869 SECURITY_CONTEXT_TRACKING_MODE ContextTrackingMode;
3870 BOOLEAN EffectiveOnly;
3871 } SECURITY_QUALITY_OF_SERVICE,*PSECURITY_QUALITY_OF_SERVICE;
3872
3873 typedef PVOID PACCESS_TOKEN;
3874
3875 typedef struct _SE_IMPERSONATION_STATE {
3876 PACCESS_TOKEN Token;
3877 BOOLEAN CopyOnOpen;
3878 BOOLEAN EffectiveOnly;
3879 SECURITY_IMPERSONATION_LEVEL Level;
3880 } SE_IMPERSONATION_STATE,*PSE_IMPERSONATION_STATE;
3881
3882 typedef struct _SID_IDENTIFIER_AUTHORITY {
3883 BYTE Value[6];
3884 } SID_IDENTIFIER_AUTHORITY,*PSID_IDENTIFIER_AUTHORITY,*LPSID_IDENTIFIER_AUTHORITY;
3885
3886 typedef PVOID PSID;
3887
3888 typedef struct _SID {
3889 BYTE Revision;
3890 BYTE SubAuthorityCount;
3891 SID_IDENTIFIER_AUTHORITY IdentifierAuthority;
3892 DWORD SubAuthority[ANYSIZE_ARRAY];
3893 } SID, *PISID;
3894
3895 #define SECURITY_MIN_SID_SIZE (sizeof(SID))
3896 #define SECURITY_MAX_SID_SIZE (FIELD_OFFSET(SID, SubAuthority) + SID_MAX_SUB_AUTHORITIES * sizeof(DWORD))
3897
3898 typedef struct _SID_AND_ATTRIBUTES {
3899 PSID Sid;
3900 DWORD Attributes;
3901 } SID_AND_ATTRIBUTES, *PSID_AND_ATTRIBUTES;
3902 typedef SID_AND_ATTRIBUTES SID_AND_ATTRIBUTES_ARRAY[ANYSIZE_ARRAY];
3903 typedef SID_AND_ATTRIBUTES_ARRAY *PSID_AND_ATTRIBUTES_ARRAY;
3904
3905 typedef struct _TOKEN_SOURCE {
3906 CHAR SourceName[TOKEN_SOURCE_LENGTH];
3907 LUID SourceIdentifier;
3908 } TOKEN_SOURCE,*PTOKEN_SOURCE;
3909
3910 typedef struct _TOKEN_CONTROL {
3911 LUID TokenId;
3912 LUID AuthenticationId;
3913 LUID ModifiedId;
3914 TOKEN_SOURCE TokenSource;
3915 } TOKEN_CONTROL,*PTOKEN_CONTROL;
3916
3917 typedef struct _TOKEN_DEFAULT_DACL {
3918 PACL DefaultDacl;
3919 } TOKEN_DEFAULT_DACL,*PTOKEN_DEFAULT_DACL;
3920
3921 typedef struct _TOKEN_GROUPS {
3922 DWORD GroupCount;
3923 SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY];
3924 } TOKEN_GROUPS,*PTOKEN_GROUPS,*LPTOKEN_GROUPS;
3925
3926 typedef struct _TOKEN_GROUPS_AND_PRIVILEGES {
3927 DWORD SidCount;
3928 DWORD SidLength;
3929 PSID_AND_ATTRIBUTES Sids;
3930 DWORD RestrictedSidCount;
3931 DWORD RestrictedSidLength;
3932 PSID_AND_ATTRIBUTES RestrictedSids;
3933 DWORD PrivilegeCount;
3934 DWORD PrivilegeLength;
3935 PLUID_AND_ATTRIBUTES Privileges;
3936 LUID AuthenticationId;
3937 } TOKEN_GROUPS_AND_PRIVILEGES, *PTOKEN_GROUPS_AND_PRIVILEGES;
3938
3939 typedef struct _TOKEN_ORIGIN {
3940 LUID OriginatingLogonSession;
3941 } TOKEN_ORIGIN, *PTOKEN_ORIGIN;
3942
3943 typedef struct _TOKEN_OWNER {
3944 PSID Owner;
3945 } TOKEN_OWNER,*PTOKEN_OWNER;
3946
3947 typedef struct _TOKEN_PRIMARY_GROUP {
3948 PSID PrimaryGroup;
3949 } TOKEN_PRIMARY_GROUP,*PTOKEN_PRIMARY_GROUP;
3950
3951 typedef struct _TOKEN_PRIVILEGES {
3952 DWORD PrivilegeCount;
3953 LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
3954 } TOKEN_PRIVILEGES,*PTOKEN_PRIVILEGES,*LPTOKEN_PRIVILEGES;
3955
3956 typedef enum tagTOKEN_TYPE {
3957 TokenPrimary = 1,
3958 TokenImpersonation
3959 } TOKEN_TYPE,*PTOKEN_TYPE;
3960
3961 typedef enum _TOKEN_ELEVATION_TYPE {
3962 TokenElevationTypeDefault = 1,
3963 TokenElevationTypeFull,
3964 TokenElevationTypeLimited,
3965 } TOKEN_ELEVATION_TYPE, *PTOKEN_ELEVATION_TYPE;
3966
3967 typedef struct _TOKEN_MANDATORY_LABEL {
3968 SID_AND_ATTRIBUTES Label;
3969 } TOKEN_MANDATORY_LABEL, * PTOKEN_MANDATORY_LABEL;
3970
3971 #include <pshpack4.h>
3972 typedef struct _TOKEN_STATISTICS {
3973 LUID TokenId;
3974 LUID AuthenticationId;
3975 LARGE_INTEGER ExpirationTime;
3976 TOKEN_TYPE TokenType;
3977 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
3978 DWORD DynamicCharged;
3979 DWORD DynamicAvailable;
3980 DWORD GroupCount;
3981 DWORD PrivilegeCount;
3982 LUID ModifiedId;
3983 } TOKEN_STATISTICS, *PTOKEN_STATISTICS;
3984 #include <poppack.h>
3985
3986 typedef struct _TOKEN_USER {
3987 SID_AND_ATTRIBUTES User;
3988 } TOKEN_USER, *PTOKEN_USER;
3989
3990 typedef DWORD SECURITY_INFORMATION,*PSECURITY_INFORMATION;
3991 typedef WORD SECURITY_DESCRIPTOR_CONTROL,*PSECURITY_DESCRIPTOR_CONTROL;
3992
3993 #ifndef _SECURITY_ATTRIBUTES_
3994 #define _SECURITY_ATTRIBUTES_
3995 typedef struct _SECURITY_DESCRIPTOR {
3996 BYTE Revision;
3997 BYTE Sbz1;
3998 SECURITY_DESCRIPTOR_CONTROL Control;
3999 PSID Owner;
4000 PSID Group;
4001 PACL Sacl;
4002 PACL Dacl;
4003 } SECURITY_DESCRIPTOR, *PISECURITY_DESCRIPTOR;
4004 typedef PVOID PSECURITY_DESCRIPTOR;
4005 #endif
4006
4007 typedef struct _SECURITY_DESCRIPTOR_RELATIVE {
4008 BYTE Revision;
4009 BYTE Sbz1;
4010 SECURITY_DESCRIPTOR_CONTROL Control;
4011 DWORD Owner;
4012 DWORD Group;
4013 DWORD Sacl;
4014 DWORD Dacl;
4015 } SECURITY_DESCRIPTOR_RELATIVE, *PISECURITY_DESCRIPTOR_RELATIVE;
4016
4017 typedef enum _TOKEN_INFORMATION_CLASS {
4018 TokenUser = 1,
4019 TokenGroups,
4020 TokenPrivileges,
4021 TokenOwner,
4022 TokenPrimaryGroup,
4023 TokenDefaultDacl,
4024 TokenSource,
4025 TokenType,
4026 TokenImpersonationLevel,
4027 TokenStatistics,
4028 TokenRestrictedSids,
4029 TokenSessionId,
4030 TokenGroupsAndPrivileges,
4031 TokenSessionReference,
4032 TokenSandBoxInert,
4033 TokenAuditPolicy,
4034 TokenOrigin,
4035 TokenElevationType,
4036 TokenLinkedToken,
4037 TokenElevation,
4038 TokenHasRestrictions,
4039 TokenAccessInformation,
4040 TokenVirtualizationAllowed,
4041 TokenVirtualizationEnabled,
4042 TokenIntegrityLevel,
4043 TokenUIAccess,
4044 TokenMandatoryPolicy,
4045 TokenLogonSid,
4046 MaxTokenInfoClass
4047 } TOKEN_INFORMATION_CLASS;
4048
4049 typedef enum _SID_NAME_USE {
4050 SidTypeUser=1,
4051 SidTypeGroup,
4052 SidTypeDomain,
4053 SidTypeAlias,
4054 SidTypeWellKnownGroup,
4055 SidTypeDeletedAccount,
4056 SidTypeInvalid,
4057 SidTypeUnknown,
4058 SidTypeComputer,
4059 SidTypeLabel
4060 } SID_NAME_USE,*PSID_NAME_USE;
4061
4062 typedef struct _QUOTA_LIMITS {
4063 SIZE_T PagedPoolLimit;
4064 SIZE_T NonPagedPoolLimit;
4065 SIZE_T MinimumWorkingSetSize;
4066 SIZE_T MaximumWorkingSetSize;
4067 SIZE_T PagefileLimit;
4068 LARGE_INTEGER TimeLimit;
4069 } QUOTA_LIMITS,*PQUOTA_LIMITS;
4070
4071 typedef union _RATE_QUOTA_LIMIT {
4072 DWORD RateData;
4073 struct {
4074 DWORD RatePercent : 7;
4075 DWORD Reserved0 : 25;
4076 } DUMMYSTRUCTNAME;
4077 } RATE_QUOTA_LIMIT, *PRATE_QUOTA_LIMIT;
4078
4079 typedef struct _QUOTA_LIMITS_EX {
4080 SIZE_T PagedPoolLimit;
4081 SIZE_T NonPagedPoolLimit;
4082 SIZE_T MinimumWorkingSetSize;
4083 SIZE_T MaximumWorkingSetSize;
4084 SIZE_T PagefileLimit;
4085 LARGE_INTEGER TimeLimit;
4086 SIZE_T Reserved1;
4087 SIZE_T Reserved2;
4088 SIZE_T Reserved3;
4089 SIZE_T Reserved4;
4090 DWORD Flags;
4091 RATE_QUOTA_LIMIT CpuRateLimit;
4092 } QUOTA_LIMITS_EX, *PQUOTA_LIMITS_EX;
4093
4094 typedef struct _IO_COUNTERS {
4095 ULONGLONG ReadOperationCount;
4096 ULONGLONG WriteOperationCount;
4097 ULONGLONG OtherOperationCount;
4098 ULONGLONG ReadTransferCount;
4099 ULONGLONG WriteTransferCount;
4100 ULONGLONG OtherTransferCount;
4101 } IO_COUNTERS, *PIO_COUNTERS;
4102
4103 typedef struct _FILE_NOTIFY_INFORMATION {
4104 DWORD NextEntryOffset;
4105 DWORD Action;
4106 DWORD FileNameLength;
4107 WCHAR FileName[1];
4108 } FILE_NOTIFY_INFORMATION,*PFILE_NOTIFY_INFORMATION;
4109
4110 typedef struct _TAPE_ERASE {
4111 DWORD Type;
4112 BOOLEAN Immediate;
4113 } TAPE_ERASE, *PTAPE_ERASE;
4114
4115 typedef struct _TAPE_GET_DRIVE_PARAMETERS {
4116 BOOLEAN ECC;
4117 BOOLEAN Compression;
4118 BOOLEAN DataPadding;
4119 BOOLEAN ReportSetmarks;
4120 DWORD DefaultBlockSize;
4121 DWORD MaximumBlockSize;
4122 DWORD MinimumBlockSize;
4123 DWORD MaximumPartitionCount;
4124 DWORD FeaturesLow;
4125 DWORD FeaturesHigh;
4126 DWORD EOTWarningZoneSize;
4127 } TAPE_GET_DRIVE_PARAMETERS, *PTAPE_GET_DRIVE_PARAMETERS;
4128
4129 typedef struct _TAPE_GET_MEDIA_PARAMETERS {
4130 LARGE_INTEGER Capacity;
4131 LARGE_INTEGER Remaining;
4132 DWORD BlockSize;
4133 DWORD PartitionCount;
4134 BOOLEAN WriteProtected;
4135 } TAPE_GET_MEDIA_PARAMETERS, *PTAPE_GET_MEDIA_PARAMETERS;
4136
4137 typedef struct _TAPE_GET_POSITION {
4138 DWORD Type;
4139 DWORD Partition;
4140 LARGE_INTEGER Offset;
4141 } TAPE_GET_POSITION, *PTAPE_GET_POSITION;
4142
4143 typedef struct _TAPE_PREPARE {
4144 DWORD Operation;
4145 BOOLEAN Immediate;
4146 } TAPE_PREPARE, *PTAPE_PREPARE;
4147
4148 typedef struct _TAPE_SET_DRIVE_PARAMETERS {
4149 BOOLEAN ECC;
4150 BOOLEAN Compression;
4151 BOOLEAN DataPadding;
4152 BOOLEAN ReportSetmarks;
4153 DWORD EOTWarningZoneSize;
4154 } TAPE_SET_DRIVE_PARAMETERS, *PTAPE_SET_DRIVE_PARAMETERS;
4155
4156 typedef struct _TAPE_SET_MEDIA_PARAMETERS {
4157 DWORD BlockSize;
4158 } TAPE_SET_MEDIA_PARAMETERS,*PTAPE_SET_MEDIA_PARAMETERS;
4159
4160 typedef struct _TAPE_SET_POSITION {
4161 DWORD Method;
4162 DWORD Partition;
4163 LARGE_INTEGER Offset;
4164 BOOLEAN Immediate;
4165 } TAPE_SET_POSITION, *PTAPE_SET_POSITION;
4166
4167 typedef struct _TAPE_WRITE_MARKS {
4168 DWORD Type;
4169 DWORD Count;
4170 BOOLEAN Immediate;
4171 } TAPE_WRITE_MARKS, *PTAPE_WRITE_MARKS;
4172
4173 typedef struct _TAPE_CREATE_PARTITION {
4174 DWORD Method;
4175 DWORD Count;
4176 DWORD Size;
4177 } TAPE_CREATE_PARTITION, *PTAPE_CREATE_PARTITION;
4178
4179 typedef struct _MEMORY_BASIC_INFORMATION {
4180 PVOID BaseAddress;
4181 PVOID AllocationBase;
4182 DWORD AllocationProtect;
4183 SIZE_T RegionSize;
4184 DWORD State;
4185 DWORD Protect;
4186 DWORD Type;
4187 } MEMORY_BASIC_INFORMATION, *PMEMORY_BASIC_INFORMATION;
4188
4189 typedef struct _MESSAGE_RESOURCE_ENTRY {
4190 WORD Length;
4191 WORD Flags;
4192 BYTE Text[1];
4193 } MESSAGE_RESOURCE_ENTRY, *PMESSAGE_RESOURCE_ENTRY;
4194
4195 typedef struct _MESSAGE_RESOURCE_BLOCK {
4196 DWORD LowId;
4197 DWORD HighId;
4198 DWORD OffsetToEntries;
4199 } MESSAGE_RESOURCE_BLOCK, *PMESSAGE_RESOURCE_BLOCK;
4200
4201 typedef struct _MESSAGE_RESOURCE_DATA {
4202 DWORD NumberOfBlocks;
4203 MESSAGE_RESOURCE_BLOCK Blocks[1];
4204 } MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA;
4205
4206 //
4207 // Slist Header
4208 //
4209 #ifndef _SLIST_HEADER_
4210 #define _SLIST_HEADER_
4211
4212 #if defined(_WIN64)
4213
4214 typedef struct DECLSPEC_ALIGN(16) _SLIST_ENTRY {
4215 struct _SLIST_ENTRY *Next;
4216 } SLIST_ENTRY, *PSLIST_ENTRY;
4217
4218 typedef struct _SLIST_ENTRY32 {
4219 DWORD Next;
4220 } SLIST_ENTRY32, *PSLIST_ENTRY32;
4221
4222 typedef union DECLSPEC_ALIGN(16) _SLIST_HEADER {
4223 _ANONYMOUS_STRUCT struct {
4224 ULONGLONG Alignment;
4225 ULONGLONG Region;
4226 } DUMMYSTRUCTNAME;
4227 struct {
4228 ULONGLONG Depth:16;
4229 ULONGLONG Sequence:9;
4230 ULONGLONG NextEntry:39;
4231 ULONGLONG HeaderType:1;
4232 ULONGLONG Init:1;
4233 ULONGLONG Reserved:59;
4234 ULONGLONG Region:3;
4235 } Header8;
4236 struct {
4237 ULONGLONG Depth:16;
4238 ULONGLONG Sequence:48;
4239 ULONGLONG HeaderType:1;
4240 ULONGLONG Init:1;
4241 ULONGLONG Reserved:2;
4242 ULONGLONG NextEntry:60;
4243 } Header16;
4244 struct {
4245 ULONGLONG Depth:16;
4246 ULONGLONG Sequence:48;
4247 ULONGLONG HeaderType:1;
4248 ULONGLONG Reserved:3;
4249 ULONGLONG NextEntry:60;
4250 } HeaderX64;
4251 } SLIST_HEADER, *PSLIST_HEADER;
4252
4253 typedef union _SLIST_HEADER32{
4254 ULONGLONG Alignment;
4255 _ANONYMOUS_STRUCT struct {
4256 SLIST_ENTRY32 Next;
4257 WORD Depth;
4258 WORD Sequence;
4259 } DUMMYSTRUCTNAME;
4260 } SLIST_HEADER32, *PSLIST_HEADER32;
4261
4262 #else
4263
4264 #define SLIST_ENTRY SINGLE_LIST_ENTRY
4265 #define _SLIST_ENTRY _SINGLE_LIST_ENTRY
4266 #define PSLIST_ENTRY PSINGLE_LIST_ENTRY
4267
4268 typedef SLIST_ENTRY SLIST_ENTRY32, *PSLIST_ENTRY32;
4269
4270 typedef union _SLIST_HEADER {
4271 ULONGLONG Alignment;
4272 _ANONYMOUS_STRUCT struct {
4273 SLIST_ENTRY Next;
4274 WORD Depth;
4275 WORD Sequence;
4276 } DUMMYSTRUCTNAME;
4277 } SLIST_HEADER, *PSLIST_HEADER;
4278
4279 typedef SLIST_HEADER SLIST_HEADER32, *PSLIST_HEADER32;
4280
4281 #endif /* defined(_WIN64) */
4282
4283 #endif /* _SLIST_HEADER_ */
4284
4285 NTSYSAPI
4286 VOID
4287 NTAPI
4288 RtlInitializeSListHead(
4289 _Out_ PSLIST_HEADER ListHead);
4290
4291 _Must_inspect_result_
4292 NTSYSAPI
4293 PSLIST_ENTRY
4294 NTAPI
4295 RtlFirstEntrySList(
4296 _In_ const SLIST_HEADER *ListHead);
4297
4298 NTSYSAPI
4299 PSLIST_ENTRY
4300 NTAPI
4301 RtlInterlockedPopEntrySList(
4302 _Inout_ PSLIST_HEADER ListHead);
4303
4304 NTSYSAPI
4305 PSLIST_ENTRY
4306 NTAPI
4307 RtlInterlockedPushEntrySList(
4308 _Inout_ PSLIST_HEADER ListHead,
4309 _Inout_ __drv_aliasesMem PSLIST_ENTRY ListEntry);
4310
4311 NTSYSAPI
4312 PSLIST_ENTRY
4313 NTAPI
4314 RtlInterlockedFlushSList(
4315 _Inout_ PSLIST_HEADER ListHead);
4316
4317 NTSYSAPI
4318 WORD
4319 NTAPI
4320 RtlQueryDepthSList(
4321 _In_ PSLIST_HEADER ListHead);
4322
4323 #ifndef _RTL_RUN_ONCE_DEF
4324 #define _RTL_RUN_ONCE_DEF
4325
4326 #define RTL_RUN_ONCE_CHECK_ONLY 0x00000001UL
4327 #define RTL_RUN_ONCE_ASYNC 0x00000002UL
4328 #define RTL_RUN_ONCE_INIT_FAILED 0x00000004UL
4329
4330 typedef union _RTL_RUN_ONCE {
4331 PVOID Ptr;
4332 } RTL_RUN_ONCE, *PRTL_RUN_ONCE;
4333
4334 #endif
4335
4336 #define RTL_CONDITION_VARIABLE_INIT {0}
4337 #define RTL_CONDITION_VARIABLE_LOCKMODE_SHARED 0x1
4338
4339 typedef struct _RTL_CONDITION_VARIABLE {
4340 PVOID Ptr;
4341 } RTL_CONDITION_VARIABLE, *PRTL_CONDITION_VARIABLE;
4342
4343 typedef struct _RTL_CRITICAL_SECTION_DEBUG {
4344 WORD Type;
4345 WORD CreatorBackTraceIndex;
4346 struct _RTL_CRITICAL_SECTION *CriticalSection;
4347 LIST_ENTRY ProcessLocksList;
4348 DWORD EntryCount;
4349 DWORD ContentionCount;
4350 DWORD Flags;
4351 WORD CreatorBackTraceIndexHigh;
4352 WORD SpareWORD;
4353 } RTL_CRITICAL_SECTION_DEBUG, *PRTL_CRITICAL_SECTION_DEBUG, RTL_RESOURCE_DEBUG, *PRTL_RESOURCE_DEBUG;
4354
4355 #include "pshpack8.h"
4356 typedef struct _RTL_CRITICAL_SECTION {
4357 PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
4358 LONG LockCount;
4359 LONG RecursionCount;
4360 HANDLE OwningThread;
4361 HANDLE LockSemaphore;
4362 ULONG_PTR SpinCount;
4363 } RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;
4364 #include "poppack.h"
4365
4366 NTSYSAPI
4367 WORD
4368 NTAPI
4369 RtlCaptureStackBackTrace(
4370 IN DWORD FramesToSkip,
4371 IN DWORD FramesToCapture,
4372 OUT PVOID *BackTrace,
4373 OUT PDWORD BackTraceHash OPTIONAL
4374 );
4375
4376 NTSYSAPI
4377 VOID
4378 NTAPI
4379 RtlCaptureContext(
4380 _Out_ PCONTEXT ContextRecord
4381 );
4382
4383 NTSYSAPI
4384 PVOID
4385 NTAPI
4386 RtlPcToFileHeader(
4387 _In_ PVOID PcValue,
4388 _Out_ PVOID* BaseOfImage);
4389
4390 NTSYSAPI
4391 VOID
4392 NTAPI
4393 RtlUnwind(
4394 _In_opt_ PVOID TargetFrame,
4395 _In_opt_ PVOID TargetIp,
4396 _In_opt_ PEXCEPTION_RECORD ExceptionRecord,
4397 _In_ PVOID ReturnValue);
4398
4399 #define RTL_SRWLOCK_INIT {0}
4400
4401 typedef struct _RTL_SRWLOCK {
4402 PVOID Ptr;
4403 } RTL_SRWLOCK, *PRTL_SRWLOCK;
4404
4405 typedef LONG
4406 (NTAPI *PVECTORED_EXCEPTION_HANDLER)(
4407 struct _EXCEPTION_POINTERS *ExceptionInfo
4408 );
4409
4410 typedef struct _EVENTLOGRECORD {
4411 DWORD Length;
4412 DWORD Reserved;
4413 DWORD RecordNumber;
4414 DWORD TimeGenerated;
4415 DWORD TimeWritten;
4416 DWORD EventID;
4417 WORD EventType;
4418 WORD NumStrings;
4419 WORD EventCategory;
4420 WORD ReservedFlags;
4421 DWORD ClosingRecordNumber;
4422 DWORD StringOffset;
4423 DWORD UserSidLength;
4424 DWORD UserSidOffset;
4425 DWORD DataLength;
4426 DWORD DataOffset;
4427 } EVENTLOGRECORD, *PEVENTLOGRECORD;
4428
4429 typedef struct _OSVERSIONINFOA {
4430 DWORD dwOSVersionInfoSize;
4431 DWORD dwMajorVersion;
4432 DWORD dwMinorVersion;
4433 DWORD dwBuildNumber;
4434 DWORD dwPlatformId;
4435 CHAR szCSDVersion[128];
4436 } OSVERSIONINFOA, *POSVERSIONINFOA, *LPOSVERSIONINFOA;
4437
4438 typedef struct _OSVERSIONINFOW {
4439 DWORD dwOSVersionInfoSize;
4440 DWORD dwMajorVersion;
4441 DWORD dwMinorVersion;
4442 DWORD dwBuildNumber;
4443 DWORD dwPlatformId;
4444 WCHAR szCSDVersion[128];
4445 } OSVERSIONINFOW, *POSVERSIONINFOW, *LPOSVERSIONINFOW, RTL_OSVERSIONINFOW, *PRTL_OSVERSIONINFOW;
4446
4447 typedef struct _OSVERSIONINFOEXA {
4448 DWORD dwOSVersionInfoSize;
4449 DWORD dwMajorVersion;
4450 DWORD dwMinorVersion;
4451 DWORD dwBuildNumber;
4452 DWORD dwPlatformId;
4453 CHAR szCSDVersion[128];
4454 WORD wServicePackMajor;
4455 WORD wServicePackMinor;
4456 WORD wSuiteMask;
4457 BYTE wProductType;
4458 BYTE wReserved;
4459 } OSVERSIONINFOEXA, *POSVERSIONINFOEXA, *LPOSVERSIONINFOEXA;
4460
4461 typedef struct _OSVERSIONINFOEXW {
4462 DWORD dwOSVersionInfoSize;
4463 DWORD dwMajorVersion;
4464 DWORD dwMinorVersion;
4465 DWORD dwBuildNumber;
4466 DWORD dwPlatformId;
4467 WCHAR szCSDVersion[128];
4468 WORD wServicePackMajor;
4469 WORD wServicePackMinor;
4470 WORD wSuiteMask;
4471 BYTE wProductType;
4472 BYTE wReserved;
4473 } OSVERSIONINFOEXW, *POSVERSIONINFOEXW, *LPOSVERSIONINFOEXW, RTL_OSVERSIONINFOEXW, *PRTL_OSVERSIONINFOEXW;
4474
4475 #include <pshpack2.h>
4476
4477 typedef struct _IMAGE_VXD_HEADER {
4478 WORD e32_magic;
4479 BYTE e32_border;
4480 BYTE e32_worder;
4481 DWORD e32_level;
4482 WORD e32_cpu;
4483 WORD e32_os;
4484 DWORD e32_ver;
4485 DWORD e32_mflags;
4486 DWORD e32_mpages;
4487 DWORD e32_startobj;
4488 DWORD e32_eip;
4489 DWORD e32_stackobj;
4490 DWORD e32_esp;
4491 DWORD e32_pagesize;
4492 DWORD e32_lastpagesize;
4493 DWORD e32_fixupsize;
4494 DWORD e32_fixupsum;
4495 DWORD e32_ldrsize;
4496 DWORD e32_ldrsum;
4497 DWORD e32_objtab;
4498 DWORD e32_objcnt;
4499 DWORD e32_objmap;
4500 DWORD e32_itermap;
4501 DWORD e32_rsrctab;
4502 DWORD e32_rsrccnt;
4503 DWORD e32_restab;
4504 DWORD e32_enttab;
4505 DWORD e32_dirtab;
4506 DWORD e32_dircnt;
4507 DWORD e32_fpagetab;
4508 DWORD e32_frectab;
4509 DWORD e32_impmod;
4510 DWORD e32_impmodcnt;
4511 DWORD e32_impproc;
4512 DWORD e32_pagesum;
4513 DWORD e32_datapage;
4514 DWORD e32_preload;
4515 DWORD e32_nrestab;
4516 DWORD e32_cbnrestab;
4517 DWORD e32_nressum;
4518 DWORD e32_autodata;
4519 DWORD e32_debuginfo;
4520 DWORD e32_debuglen;
4521 DWORD e32_instpreload;
4522 DWORD e32_instdemand;
4523 DWORD e32_heapsize;
4524 BYTE e32_res3[12];
4525 DWORD e32_winresoff;
4526 DWORD e32_winreslen;
4527 WORD e32_devid;
4528 WORD e32_ddkver;
4529 } IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
4530
4531 typedef struct _IMAGE_DOS_HEADER {
4532 WORD e_magic;
4533 WORD e_cblp;
4534 WORD e_cp;
4535 WORD e_crlc;
4536 WORD e_cparhdr;
4537 WORD e_minalloc;
4538 WORD e_maxalloc;
4539 WORD e_ss;
4540 WORD e_sp;
4541 WORD e_csum;
4542 WORD e_ip;
4543 WORD e_cs;
4544 WORD e_lfarlc;
4545 WORD e_ovno;
4546 WORD e_res[4];
4547 WORD e_oemid;
4548 WORD e_oeminfo;
4549 WORD e_res2[10];
4550 LONG e_lfanew;
4551 } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
4552
4553 typedef struct _IMAGE_OS2_HEADER {
4554 WORD ne_magic;
4555 CHAR ne_ver;
4556 CHAR ne_rev;
4557 WORD ne_enttab;
4558 WORD ne_cbenttab;
4559 LONG ne_crc;
4560 WORD ne_flags;
4561 WORD ne_autodata;
4562 WORD ne_heap;
4563 WORD ne_stack;
4564 LONG ne_csip;
4565 LONG ne_sssp;
4566 WORD ne_cseg;
4567 WORD ne_cmod;
4568 WORD ne_cbnrestab;
4569 WORD ne_segtab;
4570 WORD ne_rsrctab;
4571 WORD ne_restab;
4572 WORD ne_modtab;
4573 WORD ne_imptab;
4574 LONG ne_nrestab;
4575 WORD ne_cmovent;
4576 WORD ne_align;
4577 WORD ne_cres;
4578 BYTE ne_exetyp;
4579 BYTE ne_flagsothers;
4580 WORD ne_pretthunks;
4581 WORD ne_psegrefbytes;
4582 WORD ne_swaparea;
4583 WORD ne_expver;
4584 } IMAGE_OS2_HEADER, *PIMAGE_OS2_HEADER;
4585
4586 #include <poppack.h>
4587
4588 typedef struct _IMAGE_FILE_HEADER {
4589 WORD Machine;
4590 WORD NumberOfSections;
4591 DWORD TimeDateStamp;
4592 DWORD PointerToSymbolTable;
4593 DWORD NumberOfSymbols;
4594 WORD SizeOfOptionalHeader;
4595 WORD Characteristics;
4596 } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
4597
4598 typedef struct _IMAGE_DATA_DIRECTORY {
4599 DWORD VirtualAddress;
4600 DWORD Size;
4601 } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
4602
4603 typedef struct _IMAGE_OPTIONAL_HEADER32 {
4604 WORD Magic;
4605 BYTE MajorLinkerVersion;
4606 BYTE MinorLinkerVersion;
4607 DWORD SizeOfCode;
4608 DWORD SizeOfInitializedData;
4609 DWORD SizeOfUninitializedData;
4610 DWORD AddressOfEntryPoint;
4611 DWORD BaseOfCode;
4612 DWORD BaseOfData;
4613 DWORD ImageBase;
4614 DWORD SectionAlignment;
4615 DWORD FileAlignment;
4616 WORD MajorOperatingSystemVersion;
4617 WORD MinorOperatingSystemVersion;
4618 WORD MajorImageVersion;
4619 WORD MinorImageVersion;
4620 WORD MajorSubsystemVersion;
4621 WORD MinorSubsystemVersion;
4622 DWORD Win32VersionValue;
4623 DWORD SizeOfImage;
4624 DWORD SizeOfHeaders;
4625 DWORD CheckSum;
4626 WORD Subsystem;
4627 WORD DllCharacteristics;
4628 DWORD SizeOfStackReserve;
4629 DWORD SizeOfStackCommit;
4630 DWORD SizeOfHeapReserve;
4631 DWORD SizeOfHeapCommit;
4632 DWORD LoaderFlags;
4633 DWORD NumberOfRvaAndSizes;
4634 IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
4635 } IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
4636
4637 typedef struct _IMAGE_OPTIONAL_HEADER64 {
4638 WORD Magic;
4639 BYTE MajorLinkerVersion;
4640 BYTE MinorLinkerVersion;
4641 DWORD SizeOfCode;
4642 DWORD SizeOfInitializedData;
4643 DWORD SizeOfUninitializedData;
4644 DWORD AddressOfEntryPoint;
4645 DWORD BaseOfCode;
4646 ULONGLONG ImageBase;
4647 DWORD SectionAlignment;
4648 DWORD FileAlignment;
4649 WORD MajorOperatingSystemVersion;
4650 WORD MinorOperatingSystemVersion;
4651 WORD MajorImageVersion;
4652 WORD MinorImageVersion;
4653 WORD MajorSubsystemVersion;
4654 WORD MinorSubsystemVersion;
4655 DWORD Win32VersionValue;
4656 DWORD SizeOfImage;
4657 DWORD SizeOfHeaders;
4658 DWORD CheckSum;
4659 WORD Subsystem;
4660 WORD DllCharacteristics;
4661 ULONGLONG SizeOfStackReserve;
4662 ULONGLONG SizeOfStackCommit;
4663 ULONGLONG SizeOfHeapReserve;
4664 ULONGLONG SizeOfHeapCommit;
4665 DWORD LoaderFlags;
4666 DWORD NumberOfRvaAndSizes;
4667 IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
4668 } IMAGE_OPTIONAL_HEADER64, *PIMAGE_OPTIONAL_HEADER64;
4669
4670 typedef struct _IMAGE_ROM_OPTIONAL_HEADER {
4671 WORD Magic;
4672 BYTE MajorLinkerVersion;
4673 BYTE MinorLinkerVersion;
4674 DWORD SizeOfCode;
4675 DWORD SizeOfInitializedData;
4676 DWORD SizeOfUninitializedData;
4677 DWORD AddressOfEntryPoint;
4678 DWORD BaseOfCode;
4679 DWORD BaseOfData;
4680 DWORD BaseOfBss;
4681 DWORD GprMask;
4682 DWORD CprMask[4];
4683 DWORD GpValue;
4684 } IMAGE_ROM_OPTIONAL_HEADER, *PIMAGE_ROM_OPTIONAL_HEADER;
4685
4686 typedef struct _IMAGE_NT_HEADERS32 {
4687 DWORD Signature;
4688 IMAGE_FILE_HEADER FileHeader;
4689 IMAGE_OPTIONAL_HEADER32 OptionalHeader;
4690 } IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;
4691
4692 typedef struct _IMAGE_NT_HEADERS64 {
4693 DWORD Signature;
4694 IMAGE_FILE_HEADER FileHeader;
4695 IMAGE_OPTIONAL_HEADER64 OptionalHeader;
4696 } IMAGE_NT_HEADERS64, *PIMAGE_NT_HEADERS64;
4697
4698 #ifdef _WIN64
4699 typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
4700 typedef PIMAGE_OPTIONAL_HEADER64 PIMAGE_OPTIONAL_HEADER;
4701 typedef IMAGE_NT_HEADERS64 IMAGE_NT_HEADERS;
4702 typedef PIMAGE_NT_HEADERS64 PIMAGE_NT_HEADERS;
4703 #else
4704 typedef IMAGE_OPTIONAL_HEADER32 IMAGE_OPTIONAL_HEADER;
4705 typedef PIMAGE_OPTIONAL_HEADER32 PIMAGE_OPTIONAL_HEADER;
4706 typedef IMAGE_NT_HEADERS32 IMAGE_NT_HEADERS;
4707 typedef PIMAGE_NT_HEADERS32 PIMAGE_NT_HEADERS;
4708 #endif
4709
4710 typedef struct _IMAGE_ROM_HEADERS {
4711 IMAGE_FILE_HEADER FileHeader;
4712 IMAGE_ROM_OPTIONAL_HEADER OptionalHeader;
4713 } IMAGE_ROM_HEADERS, *PIMAGE_ROM_HEADERS;
4714
4715 typedef struct _IMAGE_SECTION_HEADER {
4716 BYTE Name[IMAGE_SIZEOF_SHORT_NAME];
4717 union {
4718 DWORD PhysicalAddress;
4719 DWORD VirtualSize;
4720 } Misc;
4721 DWORD VirtualAddress;
4722 DWORD SizeOfRawData;
4723 DWORD PointerToRawData;
4724 DWORD PointerToRelocations;
4725 DWORD PointerToLinenumbers;
4726 WORD NumberOfRelocations;
4727 WORD NumberOfLinenumbers;
4728 DWORD Characteristics;
4729 } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
4730
4731 #include <pshpack2.h>
4732
4733 typedef struct _IMAGE_SYMBOL {
4734 union {
4735 BYTE ShortName[8];
4736 struct {
4737 DWORD Short;
4738 DWORD Long;
4739 } Name;
4740 PBYTE LongName[2];
4741 } N;
4742 DWORD Value;
4743 SHORT SectionNumber;
4744 WORD Type;
4745 BYTE StorageClass;
4746 BYTE NumberOfAuxSymbols;
4747 } IMAGE_SYMBOL, *PIMAGE_SYMBOL;
4748
4749 typedef struct _IMAGE_LINENUMBER {
4750 union {
4751 DWORD SymbolTableIndex;
4752 DWORD VirtualAddress;
4753 } Type;
4754 WORD Linenumber;
4755 } IMAGE_LINENUMBER, UNALIGNED *PIMAGE_LINENUMBER;
4756
4757 typedef struct IMAGE_AUX_SYMBOL_TOKEN_DEF {
4758 BYTE bAuxType;
4759 BYTE bReserved;
4760 DWORD SymbolTableIndex;
4761 BYTE rgbReserved[12];
4762 } IMAGE_AUX_SYMBOL_TOKEN_DEF, UNALIGNED *PIMAGE_AUX_SYMBOL_TOKEN_DEF;
4763
4764 typedef union _IMAGE_AUX_SYMBOL {
4765 struct {
4766 DWORD TagIndex;
4767 union {
4768 struct {
4769 WORD Linenumber;
4770 WORD Size;
4771 } LnSz;
4772 DWORD TotalSize;
4773 } Misc;
4774 union {
4775 struct {
4776 DWORD PointerToLinenumber;
4777 DWORD PointerToNextFunction;
4778 } Function;
4779 struct {
4780 WORD Dimension[4];
4781 } Array;
4782 } FcnAry;
4783 WORD TvIndex;
4784 } Sym;
4785 struct {
4786 BYTE Name[IMAGE_SIZEOF_SYMBOL];
4787 } File;
4788 struct {
4789 DWORD Length;
4790 WORD NumberOfRelocations;
4791 WORD NumberOfLinenumbers;
4792 DWORD CheckSum;
4793 SHORT Number;
4794 BYTE Selection;
4795 BYTE bReserved;
4796 SHORT HighNumber;
4797 } Section;
4798 IMAGE_AUX_SYMBOL_TOKEN_DEF TokenDef;
4799 struct {
4800 DWORD crc;
4801 BYTE rgbReserved[14];
4802 } CRC;
4803 } IMAGE_AUX_SYMBOL, *PIMAGE_AUX_SYMBOL;
4804
4805 typedef struct _IMAGE_RELOCATION {
4806 _ANONYMOUS_UNION union {
4807 DWORD VirtualAddress;
4808 DWORD RelocCount;
4809 } DUMMYUNIONNAME;
4810 DWORD SymbolTableIndex;
4811 WORD Type;
4812 } IMAGE_RELOCATION, UNALIGNED *PIMAGE_RELOCATION;
4813
4814 #include <poppack.h>
4815
4816 #ifndef __IMAGE_COR20_HEADER_DEFINED__
4817 #define __IMAGE_COR20_HEADER_DEFINED__
4818
4819 typedef enum ReplacesCorHdrNumericDefines {
4820 COMIMAGE_FLAGS_ILONLY = 0x00000001,
4821 COMIMAGE_FLAGS_32BITREQUIRED = 0x00000002,
4822 COMIMAGE_FLAGS_IL_LIBRARY = 0x00000004,
4823 COMIMAGE_FLAGS_STRONGNAMESIGNED = 0x00000008,
4824 COMIMAGE_FLAGS_NATIVE_ENTRYPOINT = 0x00000010,
4825 COMIMAGE_FLAGS_TRACKDEBUGDATA = 0x00010000,
4826 COR_VERSION_MAJOR_V2 = 2,
4827 COR_VERSION_MAJOR = COR_VERSION_MAJOR_V2,
4828 COR_VERSION_MINOR = 0,
4829 COR_DELETED_NAME_LENGTH = 8,
4830 COR_VTABLEGAP_NAME_LENGTH = 8,
4831 NATIVE_TYPE_MAX_CB = 1,
4832 COR_ILMETHOD_SECT_SMALL_MAX_DATASIZE = 0xFF,
4833 IMAGE_COR_MIH_METHODRVA = 0x01,
4834 IMAGE_COR_MIH_EHRVA = 0x02,
4835 IMAGE_COR_MIH_BASICBLOCK = 0x08,
4836 COR_VTABLE_32BIT = 0x01,
4837 COR_VTABLE_64BIT = 0x02,
4838 COR_VTABLE_FROM_UNMANAGED = 0x04,
4839 COR_VTABLE_FROM_UNMANAGED_RETAIN_APPDOMAIN = 0x08,
4840 COR_VTABLE_CALL_MOST_DERIVED = 0x10,
4841 IMAGE_COR_EATJ_THUNK_SIZE = 32,
4842 MAX_CLASS_NAME = 1024,
4843 MAX_PACKAGE_NAME = 1024
4844 } ReplacesCorHdrNumericDefines;
4845
4846 typedef struct IMAGE_COR20_HEADER {
4847 DWORD cb;
4848 WORD MajorRuntimeVersion;
4849 WORD MinorRuntimeVersion;
4850 IMAGE_DATA_DIRECTORY MetaData;
4851 DWORD Flags;
4852 _ANONYMOUS_UNION union {
4853 DWORD EntryPointToken;
4854 DWORD EntryPointRVA;
4855 } DUMMYUNIONNAME;
4856 IMAGE_DATA_DIRECTORY Resources;
4857 IMAGE_DATA_DIRECTORY StrongNameSignature;
4858 IMAGE_DATA_DIRECTORY CodeManagerTable;
4859 IMAGE_DATA_DIRECTORY VTableFixups;
4860 IMAGE_DATA_DIRECTORY ExportAddressTableJumps;
4861 IMAGE_DATA_DIRECTORY ManagedNativeHeader;
4862 } IMAGE_COR20_HEADER, *PIMAGE_COR20_HEADER;
4863
4864 #endif /* __IMAGE_COR20_HEADER_DEFINED__ */
4865
4866 typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
4867 DWORD NumberOfSymbols;
4868 DWORD LvaToFirstSymbol;
4869 DWORD NumberOfLinenumbers;
4870 DWORD LvaToFirstLinenumber;
4871 DWORD RvaToFirstByteOfCode;
4872 DWORD RvaToLastByteOfCode;
4873 DWORD RvaToFirstByteOfData;
4874 DWORD RvaToLastByteOfData;
4875 } IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
4876
4877 typedef struct _IMAGE_BASE_RELOCATION {
4878 DWORD VirtualAddress;
4879 DWORD SizeOfBlock;
4880 } IMAGE_BASE_RELOCATION, UNALIGNED *PIMAGE_BASE_RELOCATION;
4881
4882 typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER {
4883 BYTE Name[16];
4884 BYTE Date[12];
4885 BYTE UserID[6];
4886 BYTE GroupID[6];
4887 BYTE Mode[8];
4888 BYTE Size[10];
4889 BYTE EndHeader[2];
4890 } IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
4891
4892 typedef struct _IMAGE_EXPORT_DIRECTORY {
4893 DWORD Characteristics;
4894 DWORD TimeDateStamp;
4895 WORD MajorVersion;
4896 WORD MinorVersion;
4897 DWORD Name;
4898 DWORD Base;
4899 DWORD NumberOfFunctions;
4900 DWORD NumberOfNames;
4901 DWORD AddressOfFunctions;
4902 DWORD AddressOfNames;
4903 DWORD AddressOfNameOrdinals;
4904 } IMAGE_EXPORT_DIRECTORY, *PIMAGE_EXPORT_DIRECTORY;
4905
4906 typedef struct _IMAGE_IMPORT_BY_NAME {
4907 WORD Hint;
4908 BYTE Name[1];
4909 } IMAGE_IMPORT_BY_NAME, *PIMAGE_IMPORT_BY_NAME;
4910
4911 #include <pshpack8.h>
4912 typedef struct _IMAGE_THUNK_DATA64 {
4913 union {
4914 ULONGLONG ForwarderString;
4915 ULONGLONG Function;
4916 ULONGLONG Ordinal;
4917 ULONGLONG AddressOfData;
4918 } u1;
4919 } IMAGE_THUNK_DATA64, *PIMAGE_THUNK_DATA64;
4920 #include <poppack.h>
4921
4922 typedef struct _IMAGE_THUNK_DATA32 {
4923 union {
4924 DWORD ForwarderString;
4925 DWORD Function;
4926 DWORD Ordinal;
4927 DWORD AddressOfData;
4928 } u1;
4929 } IMAGE_THUNK_DATA32, *PIMAGE_THUNK_DATA32;
4930
4931 #define IMAGE_ORDINAL_FLAG64 0x8000000000000000ULL
4932 #define IMAGE_ORDINAL_FLAG32 0x80000000
4933 #define IMAGE_ORDINAL64(Ordinal) (Ordinal & 0xffff)
4934 #define IMAGE_ORDINAL32(Ordinal) (Ordinal & 0xffff)
4935 #define IMAGE_SNAP_BY_ORDINAL64(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG64)!=0)
4936 #define IMAGE_SNAP_BY_ORDINAL32(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG32)!=0)
4937
4938 typedef VOID
4939 (NTAPI *PIMAGE_TLS_CALLBACK)(PVOID DllHandle,DWORD Reason,PVOID Reserved);
4940
4941 typedef struct _IMAGE_TLS_DIRECTORY64 {
4942 ULONGLONG StartAddressOfRawData;
4943 ULONGLONG EndAddressOfRawData;
4944 ULONGLONG AddressOfIndex;
4945 ULONGLONG AddressOfCallBacks;
4946 DWORD SizeOfZeroFill;
4947 DWORD Characteristics;
4948 } IMAGE_TLS_DIRECTORY64, *PIMAGE_TLS_DIRECTORY64;
4949
4950 typedef struct _IMAGE_TLS_DIRECTORY32 {
4951 DWORD StartAddressOfRawData;
4952 DWORD EndAddressOfRawData;
4953 DWORD AddressOfIndex;
4954 DWORD AddressOfCallBacks;
4955 DWORD SizeOfZeroFill;
4956 DWORD Characteristics;
4957 } IMAGE_TLS_DIRECTORY32, *PIMAGE_TLS_DIRECTORY32;
4958
4959 #ifdef _WIN64
4960 #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG64
4961 #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL64(Ordinal)
4962 typedef IMAGE_THUNK_DATA64 IMAGE_THUNK_DATA;
4963 typedef PIMAGE_THUNK_DATA64 PIMAGE_THUNK_DATA;
4964 #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL64(Ordinal)
4965 typedef IMAGE_TLS_DIRECTORY64 IMAGE_TLS_DIRECTORY;
4966 typedef PIMAGE_TLS_DIRECTORY64 PIMAGE_TLS_DIRECTORY;
4967 #else
4968 #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG32
4969 #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL32(Ordinal)
4970 typedef IMAGE_THUNK_DATA32 IMAGE_THUNK_DATA;
4971 typedef PIMAGE_THUNK_DATA32 PIMAGE_THUNK_DATA;
4972 #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL32(Ordinal)
4973 typedef IMAGE_TLS_DIRECTORY32 IMAGE_TLS_DIRECTORY;
4974 typedef PIMAGE_TLS_DIRECTORY32 PIMAGE_TLS_DIRECTORY;
4975 #endif
4976
4977 typedef struct _IMAGE_IMPORT_DESCRIPTOR {
4978 _ANONYMOUS_UNION union {
4979 DWORD Characteristics;
4980 DWORD OriginalFirstThunk;
4981 } DUMMYUNIONNAME;
4982 DWORD TimeDateStamp;
4983 DWORD ForwarderChain;
4984 DWORD Name;
4985 DWORD FirstThunk;
4986 } IMAGE_IMPORT_DESCRIPTOR, UNALIGNED *PIMAGE_IMPORT_DESCRIPTOR;
4987
4988 typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR {
4989 DWORD TimeDateStamp;
4990 WORD OffsetModuleName;
4991 WORD NumberOfModuleForwarderRefs;
4992 } IMAGE_BOUND_IMPORT_DESCRIPTOR, *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
4993
4994 typedef struct _IMAGE_BOUND_FORWARDER_REF {
4995 DWORD TimeDateStamp;
4996 WORD OffsetModuleName;
4997 WORD Reserved;
4998 } IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
4999
5000 typedef struct _IMAGE_DELAYLOAD_DESCRIPTOR {
5001 union {
5002 DWORD AllAttributes;
5003 struct {
5004 DWORD RvaBased:1;
5005 DWORD ReservedAttributes:31;
5006 };
5007 } Attributes;
5008 DWORD DllNameRVA;
5009 DWORD ModuleHandleRVA;
5010 DWORD ImportAddressTableRVA;
5011 DWORD ImportNameTableRVA;
5012 DWORD BoundImportAddressTableRVA;
5013 DWORD UnloadInformationTableRVA;
5014 DWORD TimeDateStamp;
5015 } IMAGE_DELAYLOAD_DESCRIPTOR, *PIMAGE_DELAYLOAD_DESCRIPTOR;
5016
5017 typedef const IMAGE_DELAYLOAD_DESCRIPTOR *PCIMAGE_DELAYLOAD_DESCRIPTOR;
5018
5019 typedef struct _IMAGE_RESOURCE_DIRECTORY {
5020 DWORD Characteristics;
5021 DWORD TimeDateStamp;
5022 WORD MajorVersion;
5023 WORD MinorVersion;
5024 WORD NumberOfNamedEntries;
5025 WORD NumberOfIdEntries;
5026 } IMAGE_RESOURCE_DIRECTORY, *PIMAGE_RESOURCE_DIRECTORY;
5027
5028 typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
5029 _ANONYMOUS_UNION union {
5030 _ANONYMOUS_STRUCT struct {
5031 DWORD NameOffset:31;
5032 DWORD NameIsString:1;
5033 } DUMMYSTRUCTNAME;
5034 DWORD Name;
5035 WORD Id;
5036 } DUMMYUNIONNAME;
5037 _ANONYMOUS_UNION union {
5038 DWORD OffsetToData;
5039 _ANONYMOUS_STRUCT struct {
5040 DWORD OffsetToDirectory:31;
5041 DWORD DataIsDirectory:1;
5042 } DUMMYSTRUCTNAME2;
5043 } DUMMYUNIONNAME2;
5044 } IMAGE_RESOURCE_DIRECTORY_ENTRY, *PIMAGE_RESOURCE_DIRECTORY_ENTRY;
5045
5046 typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
5047 WORD Length;
5048 CHAR NameString[1];
5049 } IMAGE_RESOURCE_DIRECTORY_STRING, *PIMAGE_RESOURCE_DIRECTORY_STRING;
5050
5051 typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
5052 WORD Length;
5053 WCHAR NameString[1];
5054 } IMAGE_RESOURCE_DIR_STRING_U, *PIMAGE_RESOURCE_DIR_STRING_U;
5055
5056 typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
5057 DWORD OffsetToData;
5058 DWORD Size;
5059 DWORD CodePage;
5060 DWORD Reserved;
5061 } IMAGE_RESOURCE_DATA_ENTRY, *PIMAGE_RESOURCE_DATA_ENTRY;
5062
5063 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY32 {
5064 DWORD Size;
5065 DWORD TimeDateStamp;
5066 WORD MajorVersion;
5067 WORD MinorVersion;
5068 DWORD GlobalFlagsClear;
5069 DWORD GlobalFlagsSet;
5070 DWORD CriticalSectionDefaultTimeout;
5071 DWORD DeCommitFreeBlockThreshold;
5072 DWORD DeCommitTotalFreeThreshold;
5073 DWORD LockPrefixTable;
5074 DWORD MaximumAllocationSize;
5075 DWORD VirtualMemoryThreshold;
5076 DWORD ProcessHeapFlags;
5077 DWORD ProcessAffinityMask;
5078 WORD CSDVersion;
5079 WORD Reserved1;
5080 DWORD EditList;
5081 DWORD SecurityCookie;
5082 DWORD SEHandlerTable;
5083 DWORD SEHandlerCount;
5084 } IMAGE_LOAD_CONFIG_DIRECTORY32, *PIMAGE_LOAD_CONFIG_DIRECTORY32;
5085
5086 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY64 {
5087 DWORD Size;
5088 DWORD TimeDateStamp;
5089 WORD MajorVersion;
5090 WORD MinorVersion;
5091 DWORD GlobalFlagsClear;
5092 DWORD GlobalFlagsSet;
5093 DWORD CriticalSectionDefaultTimeout;
5094 ULONGLONG DeCommitFreeBlockThreshold;
5095 ULONGLONG DeCommitTotalFreeThreshold;
5096 ULONGLONG LockPrefixTable;
5097 ULONGLONG MaximumAllocationSize;
5098 ULONGLONG VirtualMemoryThreshold;
5099 ULONGLONG ProcessAffinityMask;
5100 DWORD ProcessHeapFlags;
5101 WORD CSDVersion;
5102 WORD Reserved1;
5103 ULONGLONG EditList;
5104 ULONGLONG SecurityCookie;
5105 ULONGLONG SEHandlerTable;
5106 ULONGLONG SEHandlerCount;
5107 } IMAGE_LOAD_CONFIG_DIRECTORY64, *PIMAGE_LOAD_CONFIG_DIRECTORY64;
5108
5109 #ifdef _WIN64
5110 typedef IMAGE_LOAD_CONFIG_DIRECTORY64 IMAGE_LOAD_CONFIG_DIRECTORY;
5111 typedef PIMAGE_LOAD_CONFIG_DIRECTORY64 PIMAGE_LOAD_CONFIG_DIRECTORY;
5112 #else
5113 typedef IMAGE_LOAD_CONFIG_DIRECTORY32 IMAGE_LOAD_CONFIG_DIRECTORY;
5114 typedef PIMAGE_LOAD_CONFIG_DIRECTORY32 PIMAGE_LOAD_CONFIG_DIRECTORY;
5115 #endif
5116
5117 typedef struct _IMAGE_RUNTIME_FUNCTION_ENTRY {
5118 DWORD BeginAddress;
5119 DWORD EndAddress;
5120 DWORD UnwindInfoAddress;
5121 } IMAGE_RUNTIME_FUNCTION_ENTRY, *PIMAGE_RUNTIME_FUNCTION_ENTRY;
5122
5123 typedef struct _IMAGE_DEBUG_DIRECTORY {
5124 DWORD Characteristics;
5125 DWORD TimeDateStamp;
5126 WORD MajorVersion;
5127 WORD MinorVersion;
5128 DWORD Type;
5129 DWORD SizeOfData;
5130 DWORD AddressOfRawData;
5131 DWORD PointerToRawData;
5132 } IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
5133
5134 typedef struct _FPO_DATA {
5135 DWORD ulOffStart;
5136 DWORD cbProcSize;
5137 DWORD cdwLocals;
5138 WORD cdwParams;
5139 WORD cbProlog:8;
5140 WORD cbRegs:3;
5141 WORD fHasSEH:1;
5142 WORD fUseBP:1;
5143 WORD reserved:1;
5144 WORD cbFrame:2;
5145 } FPO_DATA, *PFPO_DATA;
5146
5147 typedef struct _IMAGE_DEBUG_MISC {
5148 DWORD DataType;
5149 DWORD Length;
5150 BOOLEAN Unicode;
5151 BYTE Reserved[3];
5152 BYTE Data[1];
5153 } IMAGE_DEBUG_MISC, *PIMAGE_DEBUG_MISC;
5154
5155 typedef struct _IMAGE_FUNCTION_ENTRY {
5156 DWORD StartingAddress;
5157 DWORD EndingAddress;
5158 DWORD EndOfPrologue;
5159 } IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
5160
5161 typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
5162 WORD Signature;
5163 WORD Flags;
5164 WORD Machine;
5165 WORD Characteristics;
5166 DWORD TimeDateStamp;
5167 DWORD CheckSum;
5168 DWORD ImageBase;
5169 DWORD SizeOfImage;
5170 DWORD NumberOfSections;
5171 DWORD ExportedNamesSize;
5172 DWORD DebugDirectorySize;
5173 DWORD SectionAlignment;
5174 DWORD Reserved[2];
5175 } IMAGE_SEPARATE_DEBUG_HEADER, *PIMAGE_SEPARATE_DEBUG_HEADER;
5176
5177 typedef enum _CM_SERVICE_NODE_TYPE {
5178 DriverType = SERVICE_KERNEL_DRIVER,
5179 FileSystemType = SERVICE_FILE_SYSTEM_DRIVER,
5180 Win32ServiceOwnProcess = SERVICE_WIN32_OWN_PROCESS,
5181 Win32ServiceShareProcess = SERVICE_WIN32_SHARE_PROCESS,
5182 AdapterType = SERVICE_ADAPTER,
5183 RecognizerType = SERVICE_RECOGNIZER_DRIVER
5184 } SERVICE_NODE_TYPE;
5185
5186 typedef enum _CM_SERVICE_LOAD_TYPE {
5187 BootLoad = SERVICE_BOOT_START,
5188 SystemLoad = SERVICE_SYSTEM_START,
5189 AutoLoad = SERVICE_AUTO_START,
5190 DemandLoad = SERVICE_DEMAND_START,
5191 DisableLoad = SERVICE_DISABLED
5192 } SERVICE_LOAD_TYPE;
5193
5194 typedef enum _CM_ERROR_CONTROL_TYPE {
5195 IgnoreError = SERVICE_ERROR_IGNORE,
5196 NormalError = SERVICE_ERROR_NORMAL,
5197 SevereError = SERVICE_ERROR_SEVERE,
5198 CriticalError = SERVICE_ERROR_CRITICAL
5199 } SERVICE_ERROR_TYPE;
5200
5201 typedef struct _NT_TIB {
5202 struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList;
5203 PVOID StackBase;
5204 PVOID StackLimit;
5205 PVOID SubSystemTib;
5206 _ANONYMOUS_UNION union {
5207 PVOID FiberData;
5208 DWORD Version;
5209 } DUMMYUNIONNAME;
5210 PVOID ArbitraryUserPointer;
5211 struct _NT_TIB *Self;
5212 } NT_TIB,*PNT_TIB;
5213
5214 typedef struct _NT_TIB32 {
5215 DWORD ExceptionList;
5216 DWORD StackBase;
5217 DWORD StackLimit;
5218 DWORD SubSystemTib;
5219 _ANONYMOUS_UNION union {
5220 DWORD FiberData;
5221 DWORD Version;
5222 } DUMMYUNIONNAME;
5223 DWORD ArbitraryUserPointer;
5224 DWORD Self;
5225 } NT_TIB32,*PNT_TIB32;
5226
5227 typedef struct _NT_TIB64 {
5228 DWORD64 ExceptionList;
5229 DWORD64 StackBase;
5230 DWORD64 StackLimit;
5231 DWORD64 SubSystemTib;
5232 _ANONYMOUS_UNION union {
5233 DWORD64 FiberData;
5234 DWORD Version;
5235 } DUMMYUNIONNAME;
5236 DWORD64 ArbitraryUserPointer;
5237 DWORD64 Self;
5238 } NT_TIB64,*PNT_TIB64;
5239
5240 typedef struct _REPARSE_GUID_DATA_BUFFER {
5241 DWORD ReparseTag;
5242 WORD ReparseDataLength;
5243 WORD Reserved;
5244 GUID ReparseGuid;
5245 struct {
5246 BYTE DataBuffer[1];
5247 } GenericReparseBuffer;
5248 } REPARSE_GUID_DATA_BUFFER, *PREPARSE_GUID_DATA_BUFFER;
5249
5250 typedef struct _REPARSE_POINT_INFORMATION {
5251 WORD ReparseDataLength;
5252 WORD UnparsedNameLength;
5253 } REPARSE_POINT_INFORMATION, *PREPARSE_POINT_INFORMATION;
5254
5255 typedef union _FILE_SEGMENT_ELEMENT {
5256 PVOID64 Buffer;
5257 ULONGLONG Alignment;
5258 } FILE_SEGMENT_ELEMENT, *PFILE_SEGMENT_ELEMENT;
5259
5260 /* JOBOBJECT_BASIC_LIMIT_INFORMATION.LimitFlags constants */
5261 #define JOB_OBJECT_LIMIT_WORKINGSET 0x0001
5262 #define JOB_OBJECT_LIMIT_PROCESS_TIME 0x0002
5263 #define JOB_OBJECT_LIMIT_JOB_TIME 0x0004
5264 #define JOB_OBJECT_LIMIT_ACTIVE_PROCESS 0x0008
5265 #define JOB_OBJECT_LIMIT_AFFINITY 0x0010
5266 #define JOB_OBJECT_LIMIT_PRIORITY_CLASS 0x0020
5267 #define JOB_OBJECT_LIMIT_PRESERVE_JOB_TIME 0x0040
5268 #define JOB_OBJECT_LIMIT_SCHEDULING_CLASS 0x0080
5269 #define JOB_OBJECT_LIMIT_PROCESS_MEMORY 0x0100
5270 #define JOB_OBJECT_LIMIT_JOB_MEMORY 0x0200
5271 #define JOB_OBJECT_LIMIT_DIE_ON_UNHANDLED_EXCEPTION 0x0400
5272 #define JOB_OBJECT_BREAKAWAY_OK 0x0800
5273 #define JOB_OBJECT_SILENT_BREAKAWAY 0x1000
5274
5275 /* JOBOBJECT_BASIC_UI_RESTRICTIONS.UIRestrictionsClass constants */
5276 #define JOB_OBJECT_UILIMIT_HANDLES 0x0001
5277 #define JOB_OBJECT_UILIMIT_READCLIPBOARD 0x0002
5278 #define JOB_OBJECT_UILIMIT_WRITECLIPBOARD 0x0004
5279 #define JOB_OBJECT_UILIMIT_SYSTEMPARAMETERS 0x0008
5280 #define JOB_OBJECT_UILIMIT_DISPLAYSETTINGS 0x0010
5281 #define JOB_OBJECT_UILIMIT_GLOBALATOMS 0x0020
5282 #define JOB_OBJECT_UILIMIT_DESKTOP 0x0040
5283 #define JOB_OBJECT_UILIMIT_EXITWINDOWS 0x0080
5284
5285 /* JOBOBJECT_SECURITY_LIMIT_INFORMATION.SecurityLimitFlags constants */
5286 #define JOB_OBJECT_SECURITY_NO_ADMIN 0x0001
5287 #define JOB_OBJECT_SECURITY_RESTRICTED_TOKEN 0x0002
5288 #define JOB_OBJECT_SECURITY_ONLY_TOKEN 0x0004
5289 #define JOB_OBJECT_SECURITY_FILTER_TOKENS 0x0008
5290
5291 /* JOBOBJECT_END_OF_JOB_TIME_INFORMATION.EndOfJobTimeAction constants */
5292 #define JOB_OBJECT_TERMINATE_AT_END_OF_JOB 0
5293 #define JOB_OBJECT_POST_AT_END_OF_JOB 1
5294
5295 #define JOB_OBJECT_MSG_END_OF_JOB_TIME 1
5296 #define JOB_OBJECT_MSG_END_OF_PROCESS_TIME 2
5297 #define JOB_OBJECT_MSG_ACTIVE_PROCESS_LIMIT 3
5298 #define JOB_OBJECT_MSG_ACTIVE_PROCESS_ZERO 4
5299 #define JOB_OBJECT_MSG_NEW_PROCESS 6
5300 #define JOB_OBJECT_MSG_EXIT_PROCESS 7
5301 #define JOB_OBJECT_MSG_ABNORMAL_EXIT_PROCESS 8
5302 #define JOB_OBJECT_MSG_PROCESS_MEMORY_LIMIT 9
5303 #define JOB_OBJECT_MSG_JOB_MEMORY_LIMIT 10
5304
5305 #define JOB_OBJECT_ASSIGN_PROCESS 1
5306 #define JOB_OBJECT_SET_ATTRIBUTES 2
5307 #define JOB_OBJECT_QUERY 4
5308 #define JOB_OBJECT_TERMINATE 8
5309 #define JOB_OBJECT_SET_SECURITY_ATTRIBUTES 16
5310 #define JOB_OBJECT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|31)
5311
5312 typedef enum _JOBOBJECTINFOCLASS {
5313 JobObjectBasicAccountingInformation = 1,
5314 JobObjectBasicLimitInformation,
5315 JobObjectBasicProcessIdList,
5316 JobObjectBasicUIRestrictions,
5317 JobObjectSecurityLimitInformation,
5318 JobObjectEndOfJobTimeInformation,
5319 JobObjectAssociateCompletionPortInformation,
5320 JobObjectBasicAndIoAccountingInformation,
5321 JobObjectExtendedLimitInformation,
5322 JobObjectJobSetInformation,
5323 JobObjectGroupInformation,
5324 MaxJobObjectInfoClass
5325 } JOBOBJECTINFOCLASS;
5326
5327 typedef struct _JOB_SET_ARRAY {
5328 HANDLE JobHandle;
5329 DWORD MemberLevel;
5330 DWORD Flags;
5331 } JOB_SET_ARRAY, *PJOB_SET_ARRAY;
5332
5333 typedef struct _JOBOBJECT_BASIC_ACCOUNTING_INFORMATION {
5334 LARGE_INTEGER TotalUserTime;
5335 LARGE_INTEGER TotalKernelTime;
5336 LARGE_INTEGER ThisPeriodTotalUserTime;
5337 LARGE_INTEGER ThisPeriodTotalKernelTime;
5338 DWORD TotalPageFaultCount;
5339 DWORD TotalProcesses;
5340 DWORD ActiveProcesses;
5341 DWORD TotalTerminatedProcesses;
5342 } JOBOBJECT_BASIC_ACCOUNTING_INFORMATION,*PJOBOBJECT_BASIC_ACCOUNTING_INFORMATION;
5343
5344 typedef struct _JOBOBJECT_BASIC_LIMIT_INFORMATION {
5345 LARGE_INTEGER PerProcessUserTimeLimit;
5346 LARGE_INTEGER PerJobUserTimeLimit;
5347 DWORD LimitFlags;
5348 SIZE_T MinimumWorkingSetSize;
5349 SIZE_T MaximumWorkingSetSize;
5350 DWORD ActiveProcessLimit;
5351 ULONG_PTR Affinity;
5352 DWORD PriorityClass;
5353 DWORD SchedulingClass;
5354 } JOBOBJECT_BASIC_LIMIT_INFORMATION,*PJOBOBJECT_BASIC_LIMIT_INFORMATION;
5355
5356 typedef struct _JOBOBJECT_BASIC_PROCESS_ID_LIST {
5357 DWORD NumberOfAssignedProcesses;
5358 DWORD NumberOfProcessIdsInList;
5359 ULONG_PTR ProcessIdList[1];
5360 } JOBOBJECT_BASIC_PROCESS_ID_LIST, *PJOBOBJECT_BASIC_PROCESS_ID_LIST;
5361
5362 typedef struct _JOBOBJECT_BASIC_UI_RESTRICTIONS {
5363 DWORD UIRestrictionsClass;
5364 } JOBOBJECT_BASIC_UI_RESTRICTIONS,*PJOBOBJECT_BASIC_UI_RESTRICTIONS;
5365
5366 typedef struct _JOBOBJECT_SECURITY_LIMIT_INFORMATION {
5367 DWORD SecurityLimitFlags;
5368 HANDLE JobToken;
5369 PTOKEN_GROUPS SidsToDisable;
5370 PTOKEN_PRIVILEGES PrivilegesToDelete;
5371 PTOKEN_GROUPS RestrictedSids;
5372 } JOBOBJECT_SECURITY_LIMIT_INFORMATION,*PJOBOBJECT_SECURITY_LIMIT_INFORMATION;
5373
5374 typedef struct _JOBOBJECT_END_OF_JOB_TIME_INFORMATION {
5375 DWORD EndOfJobTimeAction;
5376 } JOBOBJECT_END_OF_JOB_TIME_INFORMATION,*PJOBOBJECT_END_OF_JOB_TIME_INFORMATION;
5377
5378 typedef struct _JOBOBJECT_ASSOCIATE_COMPLETION_PORT {
5379 PVOID CompletionKey;
5380 HANDLE CompletionPort;
5381 } JOBOBJECT_ASSOCIATE_COMPLETION_PORT,*PJOBOBJECT_ASSOCIATE_COMPLETION_PORT;
5382
5383 typedef struct _JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION {
5384 JOBOBJECT_BASIC_ACCOUNTING_INFORMATION BasicInfo;
5385 IO_COUNTERS IoInfo;
5386 } JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION,*PJOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION;
5387
5388 typedef struct _JOBOBJECT_EXTENDED_LIMIT_INFORMATION {
5389 JOBOBJECT_BASIC_LIMIT_INFORMATION BasicLimitInformation;
5390 IO_COUNTERS IoInfo;
5391 SIZE_T ProcessMemoryLimit;
5392 SIZE_T JobMemoryLimit;
5393 SIZE_T PeakProcessMemoryUsed;
5394 SIZE_T PeakJobMemoryUsed;
5395 } JOBOBJECT_EXTENDED_LIMIT_INFORMATION,*PJOBOBJECT_EXTENDED_LIMIT_INFORMATION;
5396
5397 typedef struct _JOBOBJECT_JOBSET_INFORMATION {
5398 DWORD MemberLevel;
5399 } JOBOBJECT_JOBSET_INFORMATION,*PJOBOBJECT_JOBSET_INFORMATION;
5400
5401 /* Fixme: Making these defines conditional on WINVER will break ddk includes */
5402 #if 1 /* (WINVER >= 0x0500) */
5403
5404 #define ES_SYSTEM_REQUIRED 0x00000001
5405 #define ES_DISPLAY_REQUIRED 0x00000002
5406 #define ES_USER_PRESENT 0x00000004
5407 #define ES_CONTINUOUS 0x80000000
5408
5409 typedef enum _LATENCY_TIME {
5410 LT_DONT_CARE,
5411 LT_LOWEST_LATENCY
5412 } LATENCY_TIME, *PLATENCY_TIME;
5413
5414 typedef enum _SYSTEM_POWER_STATE {
5415 PowerSystemUnspecified = 0,
5416 PowerSystemWorking,
5417 PowerSystemSleeping1,
5418 PowerSystemSleeping2,
5419 PowerSystemSleeping3,
5420 PowerSystemHibernate,
5421 PowerSystemShutdown,
5422 PowerSystemMaximum
5423 } SYSTEM_POWER_STATE, *PSYSTEM_POWER_STATE;
5424
5425 #define POWER_SYSTEM_MAXIMUM PowerSystemMaximum
5426
5427 typedef enum {
5428 PowerActionNone = 0,
5429 PowerActionReserved,
5430 PowerActionSleep,
5431 PowerActionHibernate,
5432 PowerActionShutdown,
5433 PowerActionShutdownReset,
5434 PowerActionShutdownOff,
5435 PowerActionWarmEject
5436 } POWER_ACTION, *PPOWER_ACTION;
5437
5438 typedef enum _DEVICE_POWER_STATE {
5439 PowerDeviceUnspecified = 0,
5440 PowerDeviceD0,
5441 PowerDeviceD1,
5442 PowerDeviceD2,
5443 PowerDeviceD3,
5444 PowerDeviceMaximum
5445 } DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;
5446
5447 #if (NTDDI_VERSION >= NTDDI_WINXP) || !defined(_BATCLASS_)
5448 typedef struct {
5449 DWORD Granularity;
5450 DWORD Capacity;
5451 } BATTERY_REPORTING_SCALE, *PBATTERY_REPORTING_SCALE;
5452 #endif
5453
5454 typedef struct _POWER_ACTION_POLICY {
5455 POWER_ACTION Action;
5456 DWORD Flags;
5457 DWORD EventCode;
5458 } POWER_ACTION_POLICY, *PPOWER_ACTION_POLICY;
5459
5460 /* POWER_ACTION_POLICY.Flags constants */
5461 #define POWER_ACTION_QUERY_ALLOWED 0x00000001
5462 #define POWER_ACTION_UI_ALLOWED 0x00000002
5463 #define POWER_ACTION_OVERRIDE_APPS 0x00000004
5464 #define POWER_ACTION_LIGHTEST_FIRST 0x10000000
5465 #define POWER_ACTION_LOCK_CONSOLE 0x20000000
5466 #define POWER_ACTION_DISABLE_WAKES 0x40000000
5467 #define POWER_ACTION_CRITICAL 0x80000000
5468
5469 /* POWER_ACTION_POLICY.EventCode constants */
5470 #define POWER_LEVEL_USER_NOTIFY_TEXT 0x00000001
5471 #define POWER_LEVEL_USER_NOTIFY_SOUND 0x00000002
5472 #define POWER_LEVEL_USER_NOTIFY_EXEC 0x00000004
5473 #define POWER_USER_NOTIFY_BUTTON 0x00000008
5474 #define POWER_USER_NOTIFY_SHUTDOWN 0x00000010
5475 #define POWER_FORCE_TRIGGER_RESET 0x80000000
5476
5477 #define DISCHARGE_POLICY_CRITICAL 0
5478 #define DISCHARGE_POLICY_LOW 1
5479 #define NUM_DISCHARGE_POLICIES 4
5480
5481 #define PO_THROTTLE_NONE 0
5482 #define PO_THROTTLE_CONSTANT 1
5483 #define PO_THROTTLE_DEGRADE 2
5484 #define PO_THROTTLE_ADAPTIVE 3
5485 #define PO_THROTTLE_MAXIMUM 4
5486
5487 typedef struct _SYSTEM_POWER_LEVEL {
5488 BOOLEAN Enable;
5489 BYTE Spare[3];
5490 DWORD BatteryLevel;
5491 POWER_ACTION_POLICY PowerPolicy;
5492 SYSTEM_POWER_STATE MinSystemState;
5493 } SYSTEM_POWER_LEVEL, *PSYSTEM_POWER_LEVEL;
5494
5495 typedef struct _SYSTEM_POWER_POLICY {
5496 DWORD Revision;
5497 POWER_ACTION_POLICY PowerButton;
5498 POWER_ACTION_POLICY SleepButton;
5499 POWER_ACTION_POLICY LidClose;
5500 SYSTEM_POWER_STATE LidOpenWake;
5501 DWORD Reserved;
5502 POWER_ACTION_POLICY Idle;
5503 DWORD IdleTimeout;
5504 BYTE IdleSensitivity;
5505 BYTE DynamicThrottle;
5506 BYTE Spare2[2];
5507 SYSTEM_POWER_STATE MinSleep;
5508 SYSTEM_POWER_STATE MaxSleep;
5509 SYSTEM_POWER_STATE ReducedLatencySleep;
5510 DWORD WinLogonFlags;
5511 DWORD Spare3;
5512 DWORD DozeS4Timeout;
5513 DWORD BroadcastCapacityResolution;
5514 SYSTEM_POWER_LEVEL DischargePolicy[NUM_DISCHARGE_POLICIES];
5515 DWORD VideoTimeout;
5516 BOOLEAN VideoDimDisplay;
5517 DWORD VideoReserved[3];
5518 DWORD SpindownTimeout;
5519 BOOLEAN OptimizeForPower;
5520 BYTE FanThrottleTolerance;
5521 BYTE ForcedThrottle;
5522 BYTE MinThrottle;
5523 POWER_ACTION_POLICY OverThrottled;
5524 } SYSTEM_POWER_POLICY, *PSYSTEM_POWER_POLICY;
5525
5526 typedef struct _SYSTEM_POWER_CAPABILITIES {
5527 BOOLEAN PowerButtonPresent;
5528 BOOLEAN SleepButtonPresent;
5529 BOOLEAN LidPresent;
5530 BOOLEAN SystemS1;
5531 BOOLEAN SystemS2;
5532 BOOLEAN SystemS3;
5533 BOOLEAN SystemS4;
5534 BOOLEAN SystemS5;
5535 BOOLEAN HiberFilePresent;
5536 BOOLEAN FullWake;
5537 BOOLEAN VideoDimPresent;
5538 BOOLEAN ApmPresent;
5539 BOOLEAN UpsPresent;
5540 BOOLEAN ThermalControl;
5541 BOOLEAN ProcessorThrottle;
5542 BYTE ProcessorMinThrottle;
5543 #if (NTDDI_VERSION < NTDDI_WINXP)
5544 BYTE ProcessorThrottleScale;
5545 BYTE spare2[4];
5546 #else
5547 BYTE ProcessorMaxThrottle;
5548 BOOLEAN FastSystemS4;
5549 BYTE spare2[3];
5550 #endif /* (NTDDI_VERSION < NTDDI_WINXP) */
5551 BOOLEAN DiskSpinDown;
5552 BYTE spare3[8];
5553 BOOLEAN SystemBatteriesPresent;
5554 BOOLEAN BatteriesAreShortTerm;
5555 BATTERY_REPORTING_SCALE BatteryScale[3];
5556 SYSTEM_POWER_STATE AcOnLineWake;
5557 SYSTEM_POWER_STATE SoftLidWake;
5558 SYSTEM_POWER_STATE RtcWake;
5559 SYSTEM_POWER_STATE MinDeviceWakeState;
5560 SYSTEM_POWER_STATE DefaultLowLatencyWake;
5561 } SYSTEM_POWER_CAPABILITIES, *PSYSTEM_POWER_CAPABILITIES;
5562
5563 typedef struct _SYSTEM_BATTERY_STATE {
5564 BOOLEAN AcOnLine;
5565 BOOLEAN BatteryPresent;
5566 BOOLEAN Charging;
5567 BOOLEAN Discharging;
5568 BOOLEAN Spare1[4];
5569 DWORD MaxCapacity;
5570 DWORD RemainingCapacity;
5571 DWORD Rate;
5572 DWORD EstimatedTime;
5573 DWORD DefaultAlert1;
5574 DWORD DefaultAlert2;
5575 } SYSTEM_BATTERY_STATE, *PSYSTEM_BATTERY_STATE;
5576
5577 // FIXME: This should not be here!
5578 typedef struct _PROCESSOR_POWER_INFORMATION {
5579 ULONG Number;
5580 ULONG MaxMhz;
5581 ULONG CurrentMhz;
5582 ULONG MhzLimit;
5583 ULONG MaxIdleState;
5584 ULONG CurrentIdleState;
5585 } PROCESSOR_POWER_INFORMATION, *PPROCESSOR_POWER_INFORMATION;
5586
5587 typedef DWORD EXECUTION_STATE, *PEXECUTION_STATE;
5588
5589 typedef enum _POWER_INFORMATION_LEVEL {
5590 SystemPowerPolicyAc,
5591 SystemPowerPolicyDc,
5592 VerifySystemPolicyAc,
5593 VerifySystemPolicyDc,
5594 SystemPowerCapabilities,
5595 SystemBatteryState,
5596 SystemPowerStateHandler,
5597 ProcessorStateHandler,
5598 SystemPowerPolicyCurrent,
5599 AdministratorPowerPolicy,
5600 SystemReserveHiberFile,
5601 ProcessorInformation,
5602 SystemPowerInformation,
5603 ProcessorStateHandler2,
5604 LastWakeTime,
5605 LastSleepTime,
5606 SystemExecutionState,
5607 SystemPowerStateNotifyHandler,
5608 ProcessorPowerPolicyAc,
5609 ProcessorPowerPolicyDc,
5610 VerifyProcessorPowerPolicyAc,
5611 VerifyProcessorPowerPolicyDc,
5612 ProcessorPowerPolicyCurrent,
5613 SystemPowerStateLogging,
5614 SystemPowerLoggingEntry,
5615 SetPowerSettingValue,
5616 NotifyUserPowerSetting,
5617 PowerInformationLevelUnused0,
5618 PowerInformationLevelUnused1,
5619 SystemVideoState,
5620 TraceApplicationPowerMessage,
5621 TraceApplicationPowerMessageEnd,
5622 ProcessorPerfStates,
5623 ProcessorIdleStates,
5624 ProcessorCap,
5625 SystemWakeSource,
5626 SystemHiberFileInformation,
5627 TraceServicePowerMessage,
5628 ProcessorLoad,
5629 PowerShutdownNotification,
5630 MonitorCapabilities,
5631 SessionPowerInit,
5632 SessionDisplayState,
5633 PowerRequestCreate,
5634 PowerRequestAction,
5635 GetPowerRequestList,
5636 ProcessorInformationEx,
5637 NotifyUserModeLegacyPowerEvent,
5638 GroupPark,
5639 ProcessorIdleDomains,
5640 WakeTimerList,
5641 SystemHiberFileSize,
5642 PowerInformationLevelMaximum
5643 } POWER_INFORMATION_LEVEL;
5644
5645 #if 1 /* (WIN32_WINNT >= 0x0500) */
5646 typedef struct _SYSTEM_POWER_INFORMATION {
5647 ULONG MaxIdlenessAllowed;
5648 ULONG Idleness;
5649 ULONG TimeRemaining;
5650 UCHAR CoolingMode;
5651 } SYSTEM_POWER_INFORMATION,*PSYSTEM_POWER_INFORMATION;
5652 #endif
5653
5654 #if (_WIN32_WINNT >= 0x0500)
5655 #define _AUDIT_EVENT_TYPE_HACK 1
5656 typedef enum _AUDIT_EVENT_TYPE {
5657 AuditEventObjectAccess,
5658 AuditEventDirectoryServiceAccess
5659 } AUDIT_EVENT_TYPE, *PAUDIT_EVENT_TYPE;
5660 #endif
5661
5662 #if (_WIN32_WINNT >= 0x0501)
5663
5664 typedef enum _ACTIVATION_CONTEXT_INFO_CLASS {
5665 ActivationContextBasicInformation = 1,
5666 ActivationContextDetailedInformation = 2,
5667 AssemblyDetailedInformationInActivationContext = 3,
5668 FileInformationInAssemblyOfAssemblyInActivationContext = 4,
5669 RunlevelInformationInActivationContext = 5,
5670 CompatibilityInformationInActivationContext = 6,
5671 ActivationContextManifestResourceName = 7,
5672 MaxActivationContextInfoClass,
5673 /* For compatibility with the old names */
5674 AssemblyDetailedInformationInActivationContxt = 3,
5675 FileInformationInAssemblyOfAssemblyInActivationContxt = 4
5676 } ACTIVATION_CONTEXT_INFO_CLASS;
5677
5678 typedef struct _ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION {
5679 DWORD ulFlags;
5680 DWORD ulEncodedAssemblyIdentityLength;
5681 DWORD ulManifestPathType;
5682 DWORD ulManifestPathLength;
5683 LARGE_INTEGER liManifestLastWriteTime;
5684 DWORD ulPolicyPathType;
5685 DWORD ulPolicyPathLength;
5686 LARGE_INTEGER liPolicyLastWriteTime;
5687 DWORD ulMetadataSatelliteRosterIndex;
5688 DWORD ulManifestVersionMajor;
5689 DWORD ulManifestVersionMinor;
5690 DWORD ulPolicyVersionMajor;
5691 DWORD ulPolicyVersionMinor;
5692 DWORD ulAssemblyDirectoryNameLength;
5693 PCWSTR lpAssemblyEncodedAssemblyIdentity;
5694 PCWSTR lpAssemblyManifestPath;
5695 PCWSTR lpAssemblyPolicyPath;
5696 PCWSTR lpAssemblyDirectoryName;
5697 } ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION;
5698 typedef const ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION *PCACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION;
5699
5700 typedef struct _ACTIVATION_CONTEXT_DETAILED_INFORMATION {
5701 DWORD dwFlags;
5702 DWORD ulFormatVersion;
5703 DWORD ulAssemblyCount;
5704 DWORD ulRootManifestPathType;
5705 DWORD ulRootManifestPathChars;
5706 DWORD ulRootConfigurationPathType;
5707 DWORD ulRootConfigurationPathChars;
5708 DWORD ulAppDirPathType;
5709 DWORD ulAppDirPathChars;
5710 PCWSTR lpRootManifestPath;
5711 PCWSTR lpRootConfigurationPath;
5712 PCWSTR lpAppDirPath;
5713 } ACTIVATION_CONTEXT_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_DETAILED_INFORMATION;
5714 typedef const ACTIVATION_CONTEXT_DETAILED_INFORMATION *PCACTIVATION_CONTEXT_DETAILED_INFORMATION;
5715
5716 typedef struct _ACTIVATION_CONTEXT_QUERY_INDEX {
5717 DWORD ulAssemblyIndex;
5718 DWORD ulFileIndexInAssembly;
5719 } ACTIVATION_CONTEXT_QUERY_INDEX,*PACTIVATION_CONTEXT_QUERY_INDEX;
5720 typedef const ACTIVATION_CONTEXT_QUERY_INDEX *PCACTIVATION_CONTEXT_QUERY_INDEX;
5721
5722 typedef struct _ASSEMBLY_FILE_DETAILED_INFORMATION {
5723 DWORD ulFlags;
5724 DWORD ulFilenameLength;
5725 DWORD ulPathLength;
5726 PCWSTR lpFileName;
5727 PCWSTR lpFilePath;
5728 } ASSEMBLY_FILE_DETAILED_INFORMATION,*PASSEMBLY_FILE_DETAILED_INFORMATION;
5729 typedef const ASSEMBLY_FILE_DETAILED_INFORMATION *PCASSEMBLY_FILE_DETAILED_INFORMATION;
5730
5731 #define ACTIVATION_CONTEXT_PATH_TYPE_NONE 1
5732 #define ACTIVATION_CONTEXT_PATH_TYPE_WIN32_FILE 2
5733 #define ACTIVATION_CONTEXT_PATH_TYPE_URL 3
5734 #define ACTIVATION_CONTEXT_PATH_TYPE_ASSEMBLYREF 4
5735
5736 #define ACTIVATION_CONTEXT_SECTION_ASSEMBLY_INFORMATION 1
5737 #define ACTIVATION_CONTEXT_SECTION_DLL_REDIRECTION 2
5738 #define ACTIVATION_CONTEXT_SECTION_WINDOW_CLASS_REDIRECTION 3
5739 #define ACTIVATION_CONTEXT_SECTION_COM_SERVER_REDIRECTION 4
5740 #define ACTIVATION_CONTEXT_SECTION_COM_INTERFACE_REDIRECTION 5
5741 #define ACTIVATION_CONTEXT_SECTION_COM_TYPE_LIBRARY_REDIRECTION 6
5742 #define ACTIVATION_CONTEXT_SECTION_COM_PROGID_REDIRECTION 7
5743 #define ACTIVATION_CONTEXT_SECTION_GLOBAL_OBJECT_RENAME_TABLE 8
5744 #define ACTIVATION_CONTEXT_SECTION_CLR_SURROGATES 9
5745
5746 #endif /* (WIN32_WINNT >= 0x0501) */
5747
5748 typedef struct _PROCESSOR_POWER_POLICY_INFO {
5749 DWORD TimeCheck;
5750 DWORD DemoteLimit;
5751 DWORD PromoteLimit;
5752 BYTE DemotePercent;
5753 BYTE PromotePercent;
5754 BYTE Spare[2];
5755 DWORD AllowDemotion:1;
5756 DWORD AllowPromotion:1;
5757 DWORD Reserved:30;
5758 } PROCESSOR_POWER_POLICY_INFO, *PPROCESSOR_POWER_POLICY_INFO;
5759
5760 typedef struct _PROCESSOR_POWER_POLICY {
5761 DWORD Revision;
5762 BYTE DynamicThrottle;
5763 BYTE Spare[3];
5764 DWORD DisableCStates:1;
5765 DWORD Reserved:31;
5766 DWORD PolicyCount;
5767 PROCESSOR_POWER_POLICY_INFO Policy[3];
5768 } PROCESSOR_POWER_POLICY, *PPROCESSOR_POWER_POLICY;
5769
5770 typedef struct _ADMINISTRATOR_POWER_POLICY {
5771 SYSTEM_POWER_STATE MinSleep;
5772 SYSTEM_POWER_STATE MaxSleep;
5773 DWORD MinVideoTimeout;
5774 DWORD MaxVideoTimeout;
5775 DWORD MinSpindownTimeout;
5776 DWORD MaxSpindownTimeout;
5777 } ADMINISTRATOR_POWER_POLICY, *PADMINISTRATOR_POWER_POLICY;
5778
5779 #endif /* WINVER >= 0x0500 */
5780
5781 typedef VOID (NTAPI *WAITORTIMERCALLBACKFUNC)(PVOID,BOOLEAN);
5782
5783 #ifdef UNICODE
5784 typedef OSVERSIONINFOW OSVERSIONINFO,*POSVERSIONINFO,*LPOSVERSIONINFO;
5785 typedef OSVERSIONINFOEXW OSVERSIONINFOEX,*POSVERSIONINFOEX,*LPOSVERSIONINFOEX;
5786 #else
5787 typedef OSVERSIONINFOA OSVERSIONINFO,*POSVERSIONINFO,*LPOSVERSIONINFO;
5788 typedef OSVERSIONINFOEXA OSVERSIONINFOEX,*POSVERSIONINFOEX,*LPOSVERSIONINFOEX;
5789 #endif
5790
5791 #define VER_SET_CONDITION(lc,t,c) ((lc) = VerSetConditionMask((lc),(t),(c)))
5792
5793 #if (_WIN32_WINNT >= 0x0500)
5794 ULONGLONG WINAPI VerSetConditionMask(_In_ ULONGLONG, _In_ DWORD, _In_ BYTE);
5795 #endif
5796
5797 typedef enum _HEAP_INFORMATION_CLASS {
5798 HeapCompatibilityInformation,
5799 HeapEnableTerminationOnCorruption
5800 } HEAP_INFORMATION_CLASS;
5801
5802 typedef enum _PROCESSOR_CACHE_TYPE {
5803 CacheUnified,
5804 CacheInstruction,
5805 CacheData,
5806 CacheTrace
5807 } PROCESSOR_CACHE_TYPE;
5808
5809 typedef enum _LOGICAL_PROCESSOR_RELATIONSHIP {
5810 RelationProcessorCore,
5811 RelationNumaNode,
5812 RelationCache,
5813 RelationProcessorPackage,
5814 RelationGroup,
5815 RelationAll = 0xffff
5816 } LOGICAL_PROCESSOR_RELATIONSHIP;
5817
5818 #define CACHE_FULLY_ASSOCIATIVE 0xFF
5819
5820 typedef struct _CACHE_DESCRIPTOR {
5821 BYTE Level;
5822 BYTE Associativity;
5823 WORD LineSize;
5824 DWORD Size;
5825 PROCESSOR_CACHE_TYPE Type;
5826 } CACHE_DESCRIPTOR, *PCACHE_DESCRIPTOR;
5827
5828 typedef struct _SYSTEM_LOGICAL_PROCESSOR_INFORMATION {
5829 ULONG_PTR ProcessorMask;
5830 LOGICAL_PROCESSOR_RELATIONSHIP Relationship;
5831 _ANONYMOUS_UNION union {
5832 struct {
5833 BYTE Flags;
5834 } ProcessorCore;
5835 struct {
5836 DWORD NodeNumber;
5837 } NumaNode;
5838 CACHE_DESCRIPTOR Cache;
5839 ULONGLONG Reserved[2];
5840 } DUMMYUNIONNAME;
5841 } SYSTEM_LOGICAL_PROCESSOR_INFORMATION, *PSYSTEM_LOGICAL_PROCESSOR_INFORMATION;
5842
5843 _Check_return_
5844 NTSYSAPI
5845 SIZE_T
5846 NTAPI
5847 RtlCompareMemory (
5848 _In_ const VOID *Source1,
5849 _In_ const VOID *Source2,
5850 _In_ SIZE_T Length);
5851
5852 #define RtlMoveMemory memmove
5853 #define RtlCopyMemory memcpy
5854 #define RtlFillMemory(d,l,f) memset((d), (f), (l))
5855 #define RtlZeroMemory(d,l) RtlFillMemory((d),(l),0)
5856
5857 FORCEINLINE
5858 PVOID
5859 RtlSecureZeroMemory(_Out_writes_bytes_all_(Length) PVOID Buffer,
5860 _In_ SIZE_T Length)
5861 {
5862 volatile char *VolatilePointer;
5863
5864 /* Get a volatile pointer to prevent any compiler optimizations */
5865 VolatilePointer = (volatile char *)Buffer;
5866
5867 /* Loop the whole buffer */
5868 while (Length)
5869 {
5870 /* Zero the current byte and move on */
5871 *VolatilePointer++ = 0;
5872 Length--;
5873 }
5874
5875 /* Return the pointer to ensure the compiler won't optimize this away */
5876 return Buffer;
5877 }
5878
5879 typedef struct _OBJECT_TYPE_LIST {
5880 WORD Level;
5881 WORD Sbz;
5882 GUID *ObjectType;
5883 } OBJECT_TYPE_LIST, *POBJECT_TYPE_LIST;
5884
5885 #if defined(_M_IX86)
5886 FORCEINLINE struct _TEB * NtCurrentTeb(void)
5887 {
5888 return (struct _TEB *)__readfsdword(0x18);
5889 }
5890 FORCEINLINE PVOID GetCurrentFiber(VOID)
5891 {
5892 return (PVOID)(ULONG_PTR)__readfsdword(0x10);
5893 }
5894 #elif defined (_M_AMD64)
5895 FORCEINLINE struct _TEB * NtCurrentTeb(void)
5896 {
5897 return (struct _TEB *)__readgsqword(FIELD_OFFSET(NT_TIB, Self));
5898 }
5899 FORCEINLINE PVOID GetCurrentFiber(VOID)
5900 {
5901 #ifdef NONAMELESSUNION
5902 return (PVOID)__readgsqword(FIELD_OFFSET(NT_TIB, DUMMYUNIONNAME.FiberData));
5903 #else
5904 return (PVOID)__readgsqword(FIELD_OFFSET(NT_TIB, FiberData));
5905 #endif
5906 }
5907 #elif defined (_M_ARM)
5908 #define CP15_PMSELR 15, 0, 9, 12, 5
5909 #define CP15_PMXEVCNTR 15, 0, 9, 13, 2
5910 #define CP15_TPIDRURW 15, 0, 13, 0, 2
5911 #define CP15_TPIDRURO 15, 0, 13, 0, 3
5912 #define CP15_TPIDRPRW 15, 0, 13, 0, 4
5913 FORCEINLINE struct _TEB * NtCurrentTeb(void)
5914 {
5915 return (struct _TEB *)(ULONG_PTR)_MoveFromCoprocessor(CP15_TPIDRURW);
5916 }
5917 FORCEINLINE PVOID GetCurrentFiber(VOID)
5918 {
5919 return ((PNT_TIB )(ULONG_PTR)_MoveFromCoprocessor(CP15_TPIDRURW))->FiberData;
5920 }
5921 #elif defined(_M_PPC)
5922 FORCEINLINE unsigned long _read_teb_dword(const unsigned long Offset)
5923 {
5924 unsigned long result;
5925 __asm__("\tadd 7,13,%1\n"
5926 "\tlwz %0,0(7)\n"
5927 : "=r" (result)
5928 : "r" (Offset)
5929 : "r7");
5930 return result;
5931 }
5932 FORCEINLINE struct _TEB * NtCurrentTeb(void)
5933 {
5934 return (struct _TEB *)_read_teb_dword(0x18);
5935 }
5936 FORCEINLINE PVOID GetCurrentFiber(void)
5937 {
5938 return _read_teb_dword(0x10);
5939 }
5940 #else
5941 #error Unknown architecture
5942 #endif
5943
5944 FORCEINLINE PVOID GetFiberData(void)
5945 {
5946 return *((PVOID *)GetCurrentFiber());
5947 }
5948
5949 #define BitScanForward _BitScanForward
5950 #define BitScanReverse _BitScanReverse
5951 #define BitTest _bittest
5952 #define BitTestAndComplement _bittestandcomplement
5953 #define BitTestAndSet _bittestandset
5954 #define BitTestAndReset _bittestandreset
5955 #define InterlockedBitTestAndSet _interlockedbittestandset
5956 #define InterlockedBitTestAndReset _interlockedbittestandreset
5957 #define InterlockedAnd16 _InterlockedAnd16
5958 #define InterlockedCompareExchange16 _InterlockedCompareExchange16
5959 #define InterlockedOr16 _InterlockedOr16
5960 #define InterlockedIncrement16 _InterlockedIncrement16
5961 #define InterlockedDecrement16 _InterlockedDecrement16
5962
5963 #ifdef _M_AMD64
5964 #define BitScanForward64 _BitScanForward64
5965 #define BitScanReverse64 _BitScanReverse64
5966
5967 #define InterlockedAnd _InterlockedAnd
5968 #define InterlockedExchange _InterlockedExchange
5969 #define InterlockedOr _InterlockedOr
5970
5971 #define InterlockedAnd64 _InterlockedAnd64
5972 #define InterlockedOr64 _InterlockedOr64
5973
5974 #define InterlockedBitTestAndSet64 _interlockedbittestandset64
5975 #define InterlockedBitTestAndReset64 _interlockedbittestandreset64
5976
5977 #endif
5978
5979 #ifdef _WIN64
5980 #define InterlockedExchangeAddSizeT(a, b) InterlockedExchangeAdd64((LONG64 *)a, b)
5981 #else
5982 #define InterlockedExchangeAddSizeT(a, b) InterlockedExchangeAdd((LONG *)a, b)
5983 #endif
5984
5985 /* TODO: Other architectures than X86 */
5986 #if defined(_M_IX86)
5987 #define PF_TEMPORAL_LEVEL_1
5988 #define PF_NON_TEMPORAL_LEVEL_ALL
5989 #define PreFetchCacheLine(l, a)
5990 #elif defined (_M_AMD64)
5991 #define PreFetchCacheLine(l, a)
5992 #elif defined(_M_PPC)
5993 #define PreFetchCacheLine(l, a)
5994 #elif defined(_M_ARM)
5995 #define PreFetchCacheLine(l, a)
5996 #else
5997 #error Unknown architecture
5998 #endif
5999
6000 /* TODO: Other architectures than X86 */
6001 #if defined(_M_IX86)
6002 #if defined(_MSC_VER)
6003 FORCEINLINE
6004 VOID
6005 MemoryBarrier (VOID)
6006 {
6007 LONG Barrier;
6008 __asm { xchg Barrier, eax }
6009 }
6010 #else
6011 FORCEINLINE
6012 VOID
6013 MemoryBarrier(VOID)
6014 {
6015 LONG Barrier, *Dummy = &Barrier;
6016 UNREFERENCED_LOCAL_VARIABLE(Dummy);
6017 __asm__ __volatile__("xchgl %%eax, %[Barrier]" : : [Barrier] "m" (Barrier) : "memory");
6018 }
6019 #endif
6020 #elif defined (_M_AMD64)
6021 #define MemoryBarrier __faststorefence
6022 #elif defined(_M_PPC)
6023 #define MemoryBarrier()
6024 #elif defined(_M_ARM)
6025 #define MemoryBarrier()
6026 #else
6027 #error Unknown architecture
6028 #endif
6029
6030 #if defined(_M_IX86) || defined(_M_AMD64)
6031
6032 #define YieldProcessor _mm_pause
6033
6034 __analysis_noreturn
6035 FORCEINLINE
6036 VOID
6037 DbgRaiseAssertionFailure(VOID)
6038 {
6039 __int2c();
6040 }
6041
6042 #elif defined(_M_PPC)
6043 #define YieldProcessor() __asm__ __volatile__("nop");
6044 #elif defined(_M_MIPS)
6045 #define YieldProcessor() __asm__ __volatile__("nop");
6046 #elif defined(_M_ARM)
6047 #define YieldProcessor __yield
6048 #else
6049 #error Unknown architecture
6050 #endif
6051
6052 typedef struct _TP_POOL TP_POOL, *PTP_POOL;
6053 typedef struct _TP_WORK TP_WORK, *PTP_WORK;
6054 typedef struct _TP_CALLBACK_INSTANCE TP_CALLBACK_INSTANCE, *PTP_CALLBACK_INSTANCE;
6055
6056 typedef DWORD TP_VERSION, *PTP_VERSION;
6057
6058 typedef enum _TP_CALLBACK_PRIORITY {
6059 TP_CALLBACK_PRIORITY_HIGH,
6060 TP_CALLBACK_PRIORITY_NORMAL,
6061 TP_CALLBACK_PRIORITY_LOW,
6062 TP_CALLBACK_PRIORITY_INVALID,
6063 TP_CALLBACK_PRIORITY_COUNT = TP_CALLBACK_PRIORITY_INVALID
6064 } TP_CALLBACK_PRIORITY;
6065
6066 typedef VOID
6067 (NTAPI *PTP_WORK_CALLBACK)(
6068 _Inout_ PTP_CALLBACK_INSTANCE Instance,
6069 _Inout_opt_ PVOID Context,
6070 _Inout_ PTP_WORK Work);
6071
6072 typedef struct _TP_CLEANUP_GROUP TP_CLEANUP_GROUP, *PTP_CLEANUP_GROUP;
6073
6074 typedef VOID
6075 (NTAPI *PTP_SIMPLE_CALLBACK)(
6076 _Inout_ PTP_CALLBACK_INSTANCE Instance,
6077 _Inout_opt_ PVOID Context);
6078
6079 typedef VOID
6080 (NTAPI *PTP_CLEANUP_GROUP_CANCEL_CALLBACK)(
6081 _Inout_opt_ PVOID ObjectContext,
6082 _Inout_opt_ PVOID CleanupContext);
6083
6084 #if (_WIN32_WINNT >= _WIN32_WINNT_WIN7)
6085 typedef struct _TP_CALLBACK_ENVIRON_V3 {
6086 TP_VERSION Version;
6087 PTP_POOL Pool;
6088 PTP_CLEANUP_GROUP CleanupGroup;
6089 PTP_CLEANUP_GROUP_CANCEL_CALLBACK CleanupGroupCancelCallback;
6090 PVOID RaceDll;
6091 struct _ACTIVATION_CONTEXT *ActivationContext;
6092 PTP_SIMPLE_CALLBACK FinalizationCallback;
6093 union {
6094 DWORD Flags;
6095 struct {
6096 DWORD LongFunction:1;
6097 DWORD Persistent:1;
6098 DWORD Private:30;
6099 } s;
6100 } u;
6101 TP_CALLBACK_PRIORITY CallbackPriority;
6102 DWORD Size;
6103 } TP_CALLBACK_ENVIRON_V3, TP_CALLBACK_ENVIRON, *PTP_CALLBACK_ENVIRON;
6104 #else
6105 typedef struct _TP_CALLBACK_ENVIRON_V1 {
6106 TP_VERSION Version;
6107 PTP_POOL Pool;
6108 PTP_CLEANUP_GROUP CleanupGroup;
6109 PTP_CLEANUP_GROUP_CANCEL_CALLBACK CleanupGroupCancelCallback;
6110 PVOID RaceDll;
6111 struct _ACTIVATION_CONTEXT *ActivationContext;
6112 PTP_SIMPLE_CALLBACK FinalizationCallback;
6113 union {
6114 DWORD Flags;
6115 struct {
6116 DWORD LongFunction:1;
6117 DWORD Persistent:1;
6118 DWORD Private:30;
6119 } s;
6120 } u;
6121 } TP_CALLBACK_ENVIRON_V1, TP_CALLBACK_ENVIRON, *PTP_CALLBACK_ENVIRON;
6122 #endif /* (_WIN32_WINNT >= _WIN32_WINNT_WIN7) */
6123
6124 #ifdef _MSC_VER
6125 #pragma warning(pop)
6126 #endif
6127
6128 #endif /* RC_INVOKED */
6129
6130 #ifdef __cplusplus
6131 } // extern "C"
6132 #endif