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