1
2 #if defined(__ROS_LONG64__)
3 #undef InterlockedExchange
4 #define InterlockedExchange(a,b) _InterlockedExchange((long*)a,b)
5 #undef InterlockedExchangeAdd
6 #define InterlockedExchangeAdd(a,b) _InterlockedExchangeAdd((long*)a,b)
7 #undef InterlockedCompareExchange
8 #define InterlockedCompareExchange(a,b,c) _InterlockedCompareExchange((long*)a,b,c)
9 #undef InterlockedIncrement
10 #define InterlockedIncrement(a) _InterlockedIncrement((long*)a)
11 #undef InterlockedDecrement
12 #define InterlockedDecrement(a) _InterlockedDecrement((long*)a)
13 #endif
14
15 #undef __C89_NAMELESS
16 #undef __C89_NAMELESSSTRUCTNAME
17 #undef __C89_NAMELESSSTRUCTNAME1
18 #undef __C89_NAMELESSSTRUCTNAME2
19 #undef __C89_NAMELESSSTRUCTNAME3
20 #undef __C89_NAMELESSSTRUCTNAME4
21 #undef __C89_NAMELESSSTRUCTNAME5
22 #undef __C89_NAMELESSUNIONNAME
23 #undef __C89_NAMELESSUNIONNAME1
24 #undef __C89_NAMELESSUNIONNAME2
25 #undef __C89_NAMELESSUNIONNAME3
26 #undef __C89_NAMELESSUNIONNAME4
27 #undef __C89_NAMELESSUNIONNAME5
28 #undef __C89_NAMELESSUNIONNAME6
29 #undef __C89_NAMELESSUNIONNAME7
30 #undef __C89_NAMELESSUNIONNAME8
31
32 #if !defined(__WINESRC__) && !defined(WINE_NO_NAMELESS_EXTENSION)
33 # ifdef __GNUC__
34 /* Anonymous structs support starts with gcc 2.96/g++ 2.95 */
35 # if (__GNUC__ > 2) || ((__GNUC__ == 2) && ((__GNUC_MINOR__ > 95) || ((__GNUC_MINOR__ == 95) && defined(__cplusplus))))
36 # define __C89_NAMELESS __extension__
37 # endif
38 # elif defined(_MSC_VER)
39 # define __C89_NAMELESS
40 # endif
41 #endif
42
43 #ifdef __C89_NAMELESS
44 # define __C89_NAMELESSSTRUCTNAME
45 # define __C89_NAMELESSSTRUCTNAME1
46 # define __C89_NAMELESSSTRUCTNAME2
47 # define __C89_NAMELESSSTRUCTNAME3
48 # define __C89_NAMELESSSTRUCTNAME4
49 # define __C89_NAMELESSSTRUCTNAME5
50 # define __C89_NAMELESSUNIONNAME
51 # define __C89_NAMELESSUNIONNAME1
52 # define __C89_NAMELESSUNIONNAME2
53 # define __C89_NAMELESSUNIONNAME3
54 # define __C89_NAMELESSUNIONNAME4
55 # define __C89_NAMELESSUNIONNAME5
56 # define __C89_NAMELESSUNIONNAME6
57 # define __C89_NAMELESSUNIONNAME7
58 # define __C89_NAMELESSUNIONNAME8
59 #else
60 # define __C89_NAMELESS
61 # define __C89_NAMELESSSTRUCTNAME DUMMYSTRUCTNAME
62 # define __C89_NAMELESSSTRUCTNAME1 DUMMYSTRUCTNAME1
63 # define __C89_NAMELESSSTRUCTNAME2 DUMMYSTRUCTNAME2
64 # define __C89_NAMELESSSTRUCTNAME3 DUMMYSTRUCTNAME3
65 # define __C89_NAMELESSSTRUCTNAME4 DUMMYSTRUCTNAME4
66 # define __C89_NAMELESSSTRUCTNAME5 DUMMYSTRUCTNAME5
67 # define __C89_NAMELESSUNIONNAME DUMMYUNIONNAME
68 # define __C89_NAMELESSUNIONNAME1 DUMMYUNIONNAME1
69 # define __C89_NAMELESSUNIONNAME2 DUMMYUNIONNAME2
70 # define __C89_NAMELESSUNIONNAME3 DUMMYUNIONNAME3
71 # define __C89_NAMELESSUNIONNAME4 DUMMYUNIONNAME4
72 # define __C89_NAMELESSUNIONNAME5 DUMMYUNIONNAME5
73 # define __C89_NAMELESSUNIONNAME6 DUMMYUNIONNAME6
74 # define __C89_NAMELESSUNIONNAME7 DUMMYUNIONNAME7
75 # define __C89_NAMELESSUNIONNAME8 DUMMYUNIONNAME8
76 #endif
77
78 #define DECLSPEC_HIDDEN
79
80 /*#ifdef _WINE*/
81 #if defined(__GNUC__) && ((__GNUC__ > 4) || ((__GNUC__ == 4) && (__GNUC_MINOR__ >= 3)))
82 # define __WINE_ALLOC_SIZE(x) __attribute__((__alloc_size__(x)))
83 #else
84 # define __WINE_ALLOC_SIZE(x)
85 #endif
86 /*#endif*/
87
88 #ifdef __GNUC__
89 # define _HAVE_INT64
90 # ifndef _INTEGRAL_MAX_BITS
91 # define _INTEGRAL_MAX_BITS 64
92 # endif
93 # undef __int64
94 # define __int64 long long
95 #elif (defined(__WATCOMC__) || defined(_MSC_VER)) && (defined(_INTEGRAL_MAX_BITS) && _INTEGRAL_MAX_BITS >= 64 )
96 # define _HAVE_INT64
97 #endif /* __GNUC__/__WATCOMC */
98
99 #ifdef _MSC_VER
100 # pragma warning(push)
101 # pragma warning(disable:4201)
102 # pragma warning(disable:4214)
103 # pragma warning(disable:4820)
104 #endif
105
106 #define ACE_OBJECT_TYPE_PRESENT 0x00000001
107 #define ACE_INHERITED_OBJECT_TYPE_PRESENT 0x00000002
108
109 /* also in ddk/ntifs.h */
110 #define COMPRESSION_FORMAT_NONE (0x0000)
111 #define COMPRESSION_FORMAT_DEFAULT (0x0001)
112 #define COMPRESSION_FORMAT_LZNT1 (0x0002)
113 #define COMPRESSION_ENGINE_STANDARD (0x0000)
114 #define COMPRESSION_ENGINE_MAXIMUM (0x0100)
115 #define COMPRESSION_ENGINE_HIBER (0x0200)
116 #define ACCESS_ALLOWED_ACE_TYPE (0x0)
117 #define ACCESS_DENIED_ACE_TYPE (0x1)
118 #define SYSTEM_AUDIT_ACE_TYPE (0x2)
119 #define SYSTEM_ALARM_ACE_TYPE (0x3)
120 /*end ntifs.h */
121
122 #define REG_STANDARD_FORMAT 1
123 #define REG_LATEST_FORMAT 2
124 #define REG_NO_COMPRESSION 4
125
126 #ifndef WIN32_NO_STATUS
127
128 #define STATUS_WAIT_0 ((DWORD)0x00000000)
129 #define STATUS_ABANDONED_WAIT_0 ((DWORD)0x00000080)
130 #define STATUS_USER_APC ((DWORD)0x000000C0)
131 #define STATUS_TIMEOUT ((DWORD)0x00000102)
132 #define STATUS_PENDING ((DWORD)0x00000103)
133 #define DBG_EXCEPTION_HANDLED ((DWORD)0x00010001)
134 #define DBG_CONTINUE ((DWORD)0x00010002)
135 #define STATUS_SEGMENT_NOTIFICATION ((DWORD)0x40000005)
136 #define STATUS_FATAL_APP_EXIT ((DWORD)0x40000015)
137 #define DBG_REPLY_LATER ((DWORD)0x40010001)
138 #define DBG_TERMINATE_THREAD ((DWORD)0x40010003)
139 #define DBG_TERMINATE_PROCESS ((DWORD)0x40010004)
140 #define DBG_CONTROL_C ((DWORD)0x40010005)
141 #define DBG_PRINTEXCEPTION_C ((DWORD)0x40010006)
142 #define DBG_RIPEXCEPTION ((DWORD)0x40010007)
143 #define DBG_CONTROL_BREAK ((DWORD)0x40010008)
144 #define DBG_COMMAND_EXCEPTION ((DWORD)0x40010009)
145 #define DBG_PRINTEXCEPTION_WIDE_C ((DWORD)0x4001000A)
146 #define STATUS_GUARD_PAGE_VIOLATION ((DWORD)0x80000001)
147 #define STATUS_DATATYPE_MISALIGNMENT ((DWORD)0x80000002)
148 #define STATUS_BREAKPOINT ((DWORD)0x80000003)
149 #define STATUS_SINGLE_STEP ((DWORD)0x80000004)
150 #define STATUS_LONGJUMP ((DWORD)0x80000026)
151 #define STATUS_UNWIND_CONSOLIDATE ((DWORD)0x80000029)
152 #define DBG_EXCEPTION_NOT_HANDLED ((DWORD)0x80010001)
153 #define STATUS_ACCESS_VIOLATION ((DWORD)0xC0000005)
154 #define STATUS_IN_PAGE_ERROR ((DWORD)0xC0000006)
155 #define STATUS_INVALID_HANDLE ((DWORD)0xC0000008)
156 #define STATUS_INVALID_PARAMETER ((DWORD)0xC000000D)
157 #define STATUS_NO_MEMORY ((DWORD)0xC0000017)
158 #define STATUS_ILLEGAL_INSTRUCTION ((DWORD)0xC000001D)
159 #define STATUS_NONCONTINUABLE_EXCEPTION ((DWORD)0xC0000025)
160 #define STATUS_INVALID_DISPOSITION ((DWORD)0xC0000026)
161 #define STATUS_ARRAY_BOUNDS_EXCEEDED ((DWORD)0xC000008C)
162 #define STATUS_FLOAT_DENORMAL_OPERAND ((DWORD)0xC000008D)
163 #define STATUS_FLOAT_DIVIDE_BY_ZERO ((DWORD)0xC000008E)
164 #define STATUS_FLOAT_INEXACT_RESULT ((DWORD)0xC000008F)
165 #define STATUS_FLOAT_INVALID_OPERATION ((DWORD)0xC0000090)
166 #define STATUS_FLOAT_OVERFLOW ((DWORD)0xC0000091)
167 #define STATUS_FLOAT_STACK_CHECK ((DWORD)0xC0000092)
168 #define STATUS_FLOAT_UNDERFLOW ((DWORD)0xC0000093)
169 #define STATUS_INTEGER_DIVIDE_BY_ZERO ((DWORD)0xC0000094)
170 #define STATUS_INTEGER_OVERFLOW ((DWORD)0xC0000095)
171 #define STATUS_PRIVILEGED_INSTRUCTION ((DWORD)0xC0000096)
172 #define STATUS_STACK_OVERFLOW ((DWORD)0xC00000FD)
173 #define STATUS_DLL_NOT_FOUND ((DWORD)0xC0000135)
174 #define STATUS_ORDINAL_NOT_FOUND ((DWORD)0xC0000138)
175 #define STATUS_ENTRYPOINT_NOT_FOUND ((DWORD)0xC0000139)
176 #define STATUS_CONTROL_C_EXIT ((DWORD)0xC000013A)
177 #define STATUS_DLL_INIT_FAILED ((DWORD)0xC0000142)
178 #define STATUS_CONTROL_STACK_VIOLATION ((DWORD)0xC00001B2)
179 #define STATUS_FLOAT_MULTIPLE_FAULTS ((DWORD)0xC00002B4)
180 #define STATUS_FLOAT_MULTIPLE_TRAPS ((DWORD)0xC00002B5)
181 #define STATUS_REG_NAT_CONSUMPTION ((DWORD)0xC00002C9)
182 #define STATUS_HEAP_CORRUPTION ((DWORD)0xC0000374)
183 #define STATUS_STACK_BUFFER_OVERRUN ((DWORD)0xC0000409)
184 #define STATUS_INVALID_CRUNTIME_PARAMETER ((DWORD)0xC0000417)
185 #define STATUS_ASSERTION_FAILURE ((DWORD)0xC0000420)
186 #define STATUS_ENCLAVE_VIOLATION ((DWORD)0xC00004A2)
187 #define STATUS_INTERRUPTED ((DWORD)0xC0000515)
188 #define STATUS_THREAD_NOT_RUNNING ((DWORD)0xC0000516)
189 #define STATUS_ALREADY_REGISTERED ((DWORD)0xC0000718)
190 #define STATUS_SXS_EARLY_DEACTIVATION ((DWORD)0xC015000F)
191 #define STATUS_SXS_INVALID_DEACTIVATION ((DWORD)0xC0150010)
192
193 #define DBG_EXCEPTION_HANDLED ((DWORD)0x00010001)
194 #define DBG_CONTINUE ((DWORD)0x00010002)
195 #define DBG_TERMINATE_THREAD ((DWORD)0x40010003)
196 #define DBG_TERMINATE_PROCESS ((DWORD)0x40010004)
197 #define DBG_CONTROL_C ((DWORD)0x40010005)
198 #define DBG_CONTROL_BREAK ((DWORD)0x40010008)
199 #define DBG_COMMAND_EXCEPTION ((DWORD)0x40010009)
200 #define DBG_EXCEPTION_NOT_HANDLED ((DWORD)0x80010001)
201
202 #endif /* WIN32_NO_STATUS */
203
204 #define INVALID_FILE_ATTRIBUTES ((DWORD)-1)
205
206 /* Also in ddk/winddk.h */
207 #define FILE_LIST_DIRECTORY 0x00000001
208 #define FILE_READ_DATA 0x00000001
209 #define FILE_ADD_FILE 0x00000002
210 #define FILE_WRITE_DATA 0x00000002
211 #define FILE_ADD_SUBDIRECTORY 0x00000004
212 #define FILE_APPEND_DATA 0x00000004
213 #define FILE_CREATE_PIPE_INSTANCE 0x00000004
214 #define FILE_READ_EA 0x00000008
215 #define FILE_READ_PROPERTIES 0x00000008
216 #define FILE_WRITE_EA 0x00000010
217 #define FILE_WRITE_PROPERTIES 0x00000010
218 #define FILE_EXECUTE 0x00000020
219 #define FILE_TRAVERSE 0x00000020
220 #define FILE_DELETE_CHILD 0x00000040
221 #define FILE_READ_ATTRIBUTES 0x00000080
222 #define FILE_WRITE_ATTRIBUTES 0x00000100
223
224 #define FILE_SHARE_READ 0x00000001
225 #define FILE_SHARE_WRITE 0x00000002
226 #define FILE_SHARE_DELETE 0x00000004
227 #define FILE_SHARE_VALID_FLAGS 0x00000007
228
229 #define FILE_ATTRIBUTE_READONLY 0x00000001
230 #define FILE_ATTRIBUTE_HIDDEN 0x00000002
231 #define FILE_ATTRIBUTE_SYSTEM 0x00000004
232 #define FILE_ATTRIBUTE_DIRECTORY 0x00000010
233 #define FILE_ATTRIBUTE_ARCHIVE 0x00000020
234 #define FILE_ATTRIBUTE_DEVICE 0x00000040
235 #define FILE_ATTRIBUTE_NORMAL 0x00000080
236 #define FILE_ATTRIBUTE_TEMPORARY 0x00000100
237 #define FILE_ATTRIBUTE_SPARSE_FILE 0x00000200
238 #define FILE_ATTRIBUTE_REPARSE_POINT 0x00000400
239 #define FILE_ATTRIBUTE_COMPRESSED 0x00000800
240 #define FILE_ATTRIBUTE_OFFLINE 0x00001000
241 #define FILE_ATTRIBUTE_NOT_CONTENT_INDEXED 0x00002000
242 #define FILE_ATTRIBUTE_ENCRYPTED 0x00004000
243 #define FILE_ATTRIBUTE_INTEGRITY_STREAM 0x00008000
244 #define FILE_ATTRIBUTE_VIRTUAL 0x00010000
245 #define FILE_ATTRIBUTE_VALID_FLAGS 0x00007fb7
246 #define FILE_ATTRIBUTE_VALID_SET_FLAGS 0x000031a7
247
248 #define FILE_COPY_STRUCTURED_STORAGE 0x00000041
249 #define FILE_STRUCTURED_STORAGE 0x00000441
250
251 #define FILE_VALID_OPTION_FLAGS 0x00ffffff
252 #define FILE_VALID_PIPE_OPTION_FLAGS 0x00000032
253 #define FILE_VALID_MAILSLOT_OPTION_FLAGS 0x00000032
254 #define FILE_VALID_SET_FLAGS 0x00000036
255
256 #define FILE_DIRECTORY_FILE 0x00000001
257 #define FILE_WRITE_THROUGH 0x00000002
258 #define FILE_SEQUENTIAL_ONLY 0x00000004
259 #define FILE_NO_INTERMEDIATE_BUFFERING 0x00000008
260 #define FILE_SYNCHRONOUS_IO_ALERT 0x00000010
261 #define FILE_SYNCHRONOUS_IO_NONALERT 0x00000020
262 #define FILE_NON_DIRECTORY_FILE 0x00000040
263 #define FILE_CREATE_TREE_CONNECTION 0x00000080
264 #define FILE_COMPLETE_IF_OPLOCKED 0x00000100
265 #define FILE_NO_EA_KNOWLEDGE 0x00000200
266 #define FILE_OPEN_REMOTE_INSTANCE 0x00000400
267 #define FILE_RANDOM_ACCESS 0x00000800
268 #define FILE_DELETE_ON_CLOSE 0x00001000
269 #define FILE_OPEN_BY_FILE_ID 0x00002000
270 #define FILE_OPEN_FOR_BACKUP_INTENT 0x00004000
271 #define FILE_NO_COMPRESSION 0x00008000
272 #define FILE_RESERVE_OPFILTER 0x00100000
273 #define FILE_OPEN_REPARSE_POINT 0x00200000
274 #define FILE_OPEN_NO_RECALL 0x00400000
275 #define FILE_OPEN_FOR_FREE_SPACE_QUERY 0x00800000
276
277 #define FILE_ALL_ACCESS \
278 (STANDARD_RIGHTS_REQUIRED | \
279 SYNCHRONIZE | \
280 0x1FF)
281
282 #define FILE_GENERIC_EXECUTE \
283 (STANDARD_RIGHTS_EXECUTE | \
284 FILE_READ_ATTRIBUTES | \
285 FILE_EXECUTE | \
286 SYNCHRONIZE)
287
288 #define FILE_GENERIC_READ \
289 (STANDARD_RIGHTS_READ | \
290 FILE_READ_DATA | \
291 FILE_READ_ATTRIBUTES | \
292 FILE_READ_EA | \
293 SYNCHRONIZE)
294
295 #define FILE_GENERIC_WRITE \
296 (STANDARD_RIGHTS_WRITE | \
297 FILE_WRITE_DATA | \
298 FILE_WRITE_ATTRIBUTES | \
299 FILE_WRITE_EA | \
300 FILE_APPEND_DATA | \
301 SYNCHRONIZE)
302 /* end winddk.h */
303 /* also in ddk/ntifs.h */
304 #define FILE_NOTIFY_CHANGE_FILE_NAME 0x00000001
305 #define FILE_NOTIFY_CHANGE_DIR_NAME 0x00000002
306 #define FILE_NOTIFY_CHANGE_NAME 0x00000003
307 #define FILE_NOTIFY_CHANGE_ATTRIBUTES 0x00000004
308 #define FILE_NOTIFY_CHANGE_SIZE 0x00000008
309 #define FILE_NOTIFY_CHANGE_LAST_WRITE 0x00000010
310 #define FILE_NOTIFY_CHANGE_LAST_ACCESS 0x00000020
311 #define FILE_NOTIFY_CHANGE_CREATION 0x00000040
312 #define FILE_NOTIFY_CHANGE_EA 0x00000080
313 #define FILE_NOTIFY_CHANGE_SECURITY 0x00000100
314 #define FILE_NOTIFY_CHANGE_STREAM_NAME 0x00000200
315 #define FILE_NOTIFY_CHANGE_STREAM_SIZE 0x00000400
316 #define FILE_NOTIFY_CHANGE_STREAM_WRITE 0x00000800
317 #define FILE_NOTIFY_VALID_MASK 0x00000fff
318
319 #define FILE_CASE_SENSITIVE_SEARCH 0x00000001
320 #define FILE_CASE_PRESERVED_NAMES 0x00000002
321 #define FILE_UNICODE_ON_DISK 0x00000004
322 #define FILE_PERSISTENT_ACLS 0x00000008
323 #define FILE_FILE_COMPRESSION 0x00000010
324 #define FILE_VOLUME_QUOTAS 0x00000020
325 #define FILE_SUPPORTS_SPARSE_FILES 0x00000040
326 #define FILE_SUPPORTS_REPARSE_POINTS 0x00000080
327 #define FILE_SUPPORTS_REMOTE_STORAGE 0x00000100
328 #define FS_LFN_APIS 0x00004000
329 #define FILE_VOLUME_IS_COMPRESSED 0x00008000
330 #define FILE_SUPPORTS_OBJECT_IDS 0x00010000
331 #define FILE_SUPPORTS_ENCRYPTION 0x00020000
332 #define FILE_NAMED_STREAMS 0x00040000
333 #define FILE_READ_ONLY_VOLUME 0x00080000
334 #define FILE_SEQUENTIAL_WRITE_ONCE 0x00100000
335 #define FILE_SUPPORTS_TRANSACTIONS 0x00200000
336 #define FILE_SUPPORTS_HARD_LINKS 0x00400000
337 #define FILE_SUPPORTS_EXTENDED_ATTRIBUTES 0x00800000
338 #define FILE_SUPPORTS_OPEN_BY_FILE_ID 0x01000000
339 #define FILE_SUPPORTS_USN_JOURNAL 0x02000000
340 #define FILE_SUPPORTS_INTEGRITY_STREAMS 0x04000000
341 #define FILE_SUPPORTS_BLOCK_REFCOUNTING 0x08000000
342 #define FILE_SUPPORTS_SPARSE_VDL 0x10000000
343 #define FILE_DAX_VOLUME 0x20000000
344
345 #define IO_COMPLETION_QUERY_STATE 0x0001
346 #define IO_COMPLETION_MODIFY_STATE 0x0002
347 #define IO_COMPLETION_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
348 /* end ntifs.h */
349
350 /* also in ddk/winddk.h */
351 #define DUPLICATE_CLOSE_SOURCE 0x00000001
352 #define DUPLICATE_SAME_ACCESS 0x00000002
353 /* end winddk.k */
354
355 #define MAILSLOT_NO_MESSAGE ((DWORD)-1)
356 #define MAILSLOT_WAIT_FOREVER ((DWORD)-1)
357 #define PROCESS_TERMINATE 1
358 #define PROCESS_CREATE_THREAD 2
359 #define PROCESS_SET_SESSIONID 4
360 #define PROCESS_VM_OPERATION 8
361 #define PROCESS_VM_READ 16
362 #define PROCESS_VM_WRITE 32
363 #define PROCESS_CREATE_PROCESS 128
364 #define PROCESS_SET_QUOTA 256
365 #define PROCESS_SET_INFORMATION 512
366 #define PROCESS_QUERY_INFORMATION 1024
367 #define PROCESS_SUSPEND_RESUME 2048
368 #define PROCESS_QUERY_LIMITED_INFORMATION 0x1000
369 #define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xFFF)
370 #define PROCESS_DUP_HANDLE 64
371 #define THREAD_TERMINATE 1
372 #define THREAD_SUSPEND_RESUME 2
373 #define THREAD_GET_CONTEXT 8
374 #define THREAD_SET_CONTEXT 16
375 #define THREAD_SET_INFORMATION 32
376 #define THREAD_QUERY_INFORMATION 64
377 #define THREAD_SET_THREAD_TOKEN 128
378 #define THREAD_IMPERSONATE 256
379 #define THREAD_DIRECT_IMPERSONATION 0x200
380 #define THREAD_QUERY_LIMITED_INFORMATION 0x0800
381 #define THREAD_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3FF)
382 #define MUTANT_QUERY_STATE 0x0001
383 #define MUTANT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|MUTANT_QUERY_STATE)
384 #define TIMER_QUERY_STATE 0x0001
385 #define TIMER_MODIFY_STATE 0x0002
386 #define TIMER_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|TIMER_QUERY_STATE|TIMER_MODIFY_STATE)
387 #define THREAD_BASE_PRIORITY_LOWRT 15
388 #define THREAD_BASE_PRIORITY_MAX 2
389 #define THREAD_BASE_PRIORITY_MIN (-2)
390 #define THREAD_BASE_PRIORITY_IDLE (-15)
391
392 #define PROCESS_SET_LIMITED_INFORMATION 0x2000
393 #define THREAD_RESUME 0x1000
394
395 #define SE_CREATE_TOKEN_NAME TEXT("SeCreateTokenPrivilege")
396 #define SE_ASSIGNPRIMARYTOKEN_NAME TEXT("SeAssignPrimaryTokenPrivilege")
397 #define SE_LOCK_MEMORY_NAME TEXT("SeLockMemoryPrivilege")
398 #define SE_INCREASE_QUOTA_NAME TEXT("SeIncreaseQuotaPrivilege")
399 #define SE_UNSOLICITED_INPUT_NAME TEXT("SeUnsolicitedInputPrivilege")
400 #define SE_MACHINE_ACCOUNT_NAME TEXT("SeMachineAccountPrivilege")
401 #define SE_TCB_NAME TEXT("SeTcbPrivilege")
402 #define SE_SECURITY_NAME TEXT("SeSecurityPrivilege")
403 #define SE_TAKE_OWNERSHIP_NAME TEXT("SeTakeOwnershipPrivilege")
404 #define SE_LOAD_DRIVER_NAME TEXT("SeLoadDriverPrivilege")
405 #define SE_SYSTEM_PROFILE_NAME TEXT("SeSystemProfilePrivilege")
406 #define SE_SYSTEMTIME_NAME TEXT("SeSystemtimePrivilege")
407 #define SE_PROF_SINGLE_PROCESS_NAME TEXT("SeProfileSingleProcessPrivilege")
408 #define SE_INC_BASE_PRIORITY_NAME TEXT("SeIncreaseBasePriorityPrivilege")
409 #define SE_CREATE_PAGEFILE_NAME TEXT("SeCreatePagefilePrivilege")
410 #define SE_CREATE_PERMANENT_NAME TEXT("SeCreatePermanentPrivilege")
411 #define SE_BACKUP_NAME TEXT("SeBackupPrivilege")
412 #define SE_RESTORE_NAME TEXT("SeRestorePrivilege")
413 #define SE_SHUTDOWN_NAME TEXT("SeShutdownPrivilege")
414 #define SE_DEBUG_NAME TEXT("SeDebugPrivilege")
415 #define SE_AUDIT_NAME TEXT("SeAuditPrivilege")
416 #define SE_SYSTEM_ENVIRONMENT_NAME TEXT("SeSystemEnvironmentPrivilege")
417 #define SE_CHANGE_NOTIFY_NAME TEXT("SeChangeNotifyPrivilege")
418 #define SE_REMOTE_SHUTDOWN_NAME TEXT("SeRemoteShutdownPrivilege")
419 #define SE_UNDOCK_NAME TEXT("SeUndockPrivilege")
420 #define SE_SYNC_AGENT_NAME TEXT("SeSyncAgentPrivilege")
421 #define SE_ENABLE_DELEGATION_NAME TEXT("SeEnableDelegationPrivilege")
422 #define SE_MANAGE_VOLUME_NAME TEXT("SeManageVolumePrivilege")
423 #define SE_IMPERSONATE_NAME TEXT("SeImpersonatePrivilege")
424 #define SE_CREATE_GLOBAL_NAME TEXT("SeCreateGlobalPrivilege")
425
426 #define SE_GROUP_MANDATORY 0x00000001
427 #define SE_GROUP_ENABLED_BY_DEFAULT 0x00000002
428 #define SE_GROUP_ENABLED 0x00000004
429 #define SE_GROUP_OWNER 0x00000008
430 #define SE_GROUP_USE_FOR_DENY_ONLY 0x00000010
431 #define SE_GROUP_INTEGRITY 0x00000020
432 #define SE_GROUP_INTEGRITY_ENABLED 0x00000040
433 #define SE_GROUP_LOGON_ID 0xC0000000
434 #define SE_GROUP_RESOURCE 0x20000000
435 #define SE_GROUP_VALID_ATTRIBUTES 0xE000007F
436
437 /* FIXME: non-standard */
438 #define LANG_ESPERANTO 0x8f
439 #define LANG_WALON 0x90
440 #define LANG_CORNISH 0x92
441
442 /* FIXME: not present in the official headers */
443 #define LANG_MALAGASY 0x8d
444 #define LANG_GAELIC 0x94
445 #define LANG_SAAMI 0x3b
446 #define LANG_SUTU 0x30
447 #define LANG_TSONGA 0x31
448 #define LANG_VENDA 0x33
449 #define LANG_MANX_GAELIC 0x94
450 #define SUBLANG_PORTUGUESE_PORTUGAL 0x02
451
452 #define PROCESSOR_INTEL_386 386
453 #define PROCESSOR_INTEL_486 486
454 #define PROCESSOR_INTEL_PENTIUM 586
455 #define PROCESSOR_MIPS_R4000 4000
456 #define PROCESSOR_ALPHA_21064 21064
457 #define PROCESSOR_INTEL_IA64 2200
458 #define PROCESSOR_PPC_601 601
459 #define PROCESSOR_PPC_603 603
460 #define PROCESSOR_PPC_604 604
461 #define PROCESSOR_PPC_620 620
462 #define PROCESSOR_INTEL_860 860
463 #define PROCESSOR_AMD_X8664 8664
464 #define PROCESSOR_MIPS_R2000 2000
465 #define PROCESSOR_MIPS_R3000 3000
466 #define PROCESSOR_HITACHI_SH3 10003
467 #define PROCESSOR_HITACHI_SH3E 10004
468 #define PROCESSOR_HITACHI_SH4 10005
469 #define PROCESSOR_MOTOROLA_821 821
470 #define PROCESSOR_SHx_SH3 103
471 #define PROCESSOR_SHx_SH4 104
472 #define PROCESSOR_STRONGARM 2577
473 #define PROCESSOR_ARM720 1824
474 #define PROCESSOR_ARM820 2080
475 #define PROCESSOR_ARM920 2336
476 #define PROCESSOR_ARM_7TDMI 70001
477 #define PROCESSOR_ARCHITECTURE_INTEL 0
478 #define PROCESSOR_ARCHITECTURE_MIPS 1
479 #define PROCESSOR_ARCHITECTURE_ALPHA 2
480 #define PROCESSOR_ARCHITECTURE_PPC 3
481 #define PROCESSOR_ARCHITECTURE_SHX 4
482 #define PROCESSOR_ARCHITECTURE_ARM 5
483 #define PROCESSOR_ARCHITECTURE_IA64 6
484 #define PROCESSOR_ARCHITECTURE_ALPHA64 7
485 #define PROCESSOR_ARCHITECTURE_MSIL 8
486 #define PROCESSOR_ARCHITECTURE_AMD64 9
487 #define PROCESSOR_ARCHITECTURE_UNKNOWN 0xFFFF
488
489 /* also in ddk/ntifs.h */
490 #define FILE_ACTION_ADDED 0x00000001
491 #define FILE_ACTION_REMOVED 0x00000002
492 #define FILE_ACTION_MODIFIED 0x00000003
493 #define FILE_ACTION_RENAMED_OLD_NAME 0x00000004
494 #define FILE_ACTION_RENAMED_NEW_NAME 0x00000005
495 #define FILE_ACTION_ADDED_STREAM 0x00000006
496 #define FILE_ACTION_REMOVED_STREAM 0x00000007
497 #define FILE_ACTION_MODIFIED_STREAM 0x00000008
498 #define FILE_ACTION_REMOVED_BY_DELETE 0x00000009
499 #define FILE_ACTION_ID_NOT_TUNNELLED 0x0000000A
500 #define FILE_ACTION_TUNNELLED_ID_COLLISION 0x0000000B
501 /* end ntifs.h */
502 #define HEAP_NO_SERIALIZE 1
503 #define HEAP_GROWABLE 2
504 #define HEAP_GENERATE_EXCEPTIONS 4
505 #define HEAP_ZERO_MEMORY 8
506 #define HEAP_REALLOC_IN_PLACE_ONLY 16
507 #define HEAP_TAIL_CHECKING_ENABLED 32
508 #define HEAP_FREE_CHECKING_ENABLED 64
509 #define HEAP_DISABLE_COALESCE_ON_FREE 128
510 #define HEAP_CREATE_ALIGN_16 0x10000
511 #define HEAP_CREATE_ENABLE_TRACING 0x20000
512 #define HEAP_CREATE_ENABLE_EXECUTE 0x00040000
513 #define HEAP_MAXIMUM_TAG 0xFFF
514 #define HEAP_PSEUDO_TAG_FLAG 0x8000
515 #define HEAP_TAG_SHIFT 16
516 #define HEAP_MAKE_TAG_FLAGS(b,o) ((DWORD)((b)+(o)<<16)))
517
518 #define KEY_QUERY_VALUE 1
519 #define KEY_SET_VALUE 2
520 #define KEY_CREATE_SUB_KEY 4
521 #define KEY_ENUMERATE_SUB_KEYS 8
522 #define KEY_NOTIFY 16
523 #define KEY_CREATE_LINK 32
524 #define KEY_WOW64_64KEY 0x00000100
525 #define KEY_WOW64_32KEY 0x00000200
526 #define KEY_WOW64_RES 0x00000300
527
528 #define KEY_WRITE 0x20006
529 #define KEY_EXECUTE 0x20019
530 #define KEY_READ 0x20019
531 #define KEY_ALL_ACCESS 0xf003f
532 #define REG_WHOLE_HIVE_VOLATILE 1
533 #define REG_REFRESH_HIVE 2
534 #define REG_NO_LAZY_FLUSH 4
535 #define REG_FORCE_RESTORE 8
536 #define REG_OPTION_RESERVED 0
537 #define REG_OPTION_NON_VOLATILE 0
538 #define REG_OPTION_VOLATILE 1
539 #define REG_OPTION_CREATE_LINK 2
540 #define REG_OPTION_BACKUP_RESTORE 4
541 #define REG_OPTION_OPEN_LINK 8
542 #define REG_LEGAL_OPTION 15
543 #define MAXIMUM_PROCESSORS 32
544 #define PAGE_NOACCESS 0x0001
545 #define PAGE_READONLY 0x0002
546 #define PAGE_READWRITE 0x0004
547 #define PAGE_WRITECOPY 0x0008
548 #define PAGE_EXECUTE 0x0010
549 #define PAGE_EXECUTE_READ 0x0020
550 #define PAGE_EXECUTE_READWRITE 0x0040
551 #define PAGE_EXECUTE_WRITECOPY 0x0080
552 #define PAGE_GUARD 0x0100
553 #define PAGE_NOCACHE 0x0200
554 #define PAGE_WRITECOMBINE 0x0400
555 #define MEM_COMMIT 0x1000
556 #define MEM_RESERVE 0x2000
557 #define MEM_DECOMMIT 0x4000
558 #define MEM_RELEASE 0x8000
559 #define MEM_FREE 0x10000
560 #define MEM_PRIVATE 0x20000
561 #define MEM_MAPPED 0x40000
562 #define MEM_RESET 0x80000
563 #define MEM_TOP_DOWN 0x100000
564 #define MEM_WRITE_WATCH 0x200000 /* 98/Me */
565 #define MEM_PHYSICAL 0x400000
566 #define MEM_4MB_PAGES 0x80000000
567 #define MEM_IMAGE SEC_IMAGE
568 #define SEC_NO_CHANGE 0x00400000
569 #define SEC_FILE 0x00800000
570 #define SEC_IMAGE 0x01000000
571 #define SEC_VLM 0x02000000
572 #define SEC_RESERVE 0x04000000
573 #define SEC_COMMIT 0x08000000
574 #define SEC_NOCACHE 0x10000000
575 #define SEC_WRITECOMBINE 0x40000000
576 #define SEC_LARGE_PAGES 0x80000000
577 #define SEC_IMAGE_NO_EXECUTE (SEC_IMAGE | SEC_NOCACHE)
578 #define SECTION_MAP_EXECUTE_EXPLICIT 0x0020
579 #define SECTION_EXTEND_SIZE 16
580 #define SECTION_MAP_READ 4
581 #define SECTION_MAP_WRITE 2
582 #define SECTION_QUERY 1
583 #define SECTION_MAP_EXECUTE 8
584 #define SECTION_ALL_ACCESS 0xf001f
585 #define WRITE_WATCH_FLAG_RESET 0x01
586 #define MESSAGE_RESOURCE_UNICODE 1
587 #define RTL_CRITSECT_TYPE 0
588 #define RTL_RESOURCE_TYPE 1
589
590 #define AT_ROUND_TO_PAGE 0x40000000
591
592 #define IMAGE_SIZEOF_FILE_HEADER 20
593 #define IMAGE_FILE_RELOCS_STRIPPED 1
594 #define IMAGE_FILE_EXECUTABLE_IMAGE 2
595 #define IMAGE_FILE_LINE_NUMS_STRIPPED 4
596 #define IMAGE_FILE_LOCAL_SYMS_STRIPPED 8
597 #define IMAGE_FILE_AGGRESIVE_WS_TRIM 16
598 #define IMAGE_FILE_LARGE_ADDRESS_AWARE 32
599 #define IMAGE_FILE_BYTES_REVERSED_LO 128
600 #define IMAGE_FILE_32BIT_MACHINE 256
601 #define IMAGE_FILE_DEBUG_STRIPPED 512
602 #define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP 1024
603 #define IMAGE_FILE_NET_RUN_FROM_SWAP 2048
604 #define IMAGE_FILE_SYSTEM 4096
605 #define IMAGE_FILE_DLL 8192
606 #define IMAGE_FILE_UP_SYSTEM_ONLY 16384
607 #define IMAGE_FILE_BYTES_REVERSED_HI 32768
608 #define IMAGE_FILE_MACHINE_UNKNOWN 0
609
610 #define IMAGE_FILE_MACHINE_AM33 0x1d3
611 #define IMAGE_FILE_MACHINE_AMD64 0x8664
612 #define IMAGE_FILE_MACHINE_ARM 0x1c0
613 #define IMAGE_FILE_MACHINE_ARMNT 0x1c4
614 #define IMAGE_FILE_MACHINE_EBC 0xebc
615 #define IMAGE_FILE_MACHINE_I386 0x14c
616 #define IMAGE_FILE_MACHINE_IA64 0x200
617 #define IMAGE_FILE_MACHINE_M32R 0x9041
618 #define IMAGE_FILE_MACHINE_MIPS16 0x266
619 #define IMAGE_FILE_MACHINE_MIPSFPU 0x366
620 #define IMAGE_FILE_MACHINE_MIPSFPU16 0x466
621 #define IMAGE_FILE_MACHINE_POWERPC 0x1f0
622 #define IMAGE_FILE_MACHINE_POWERPCFP 0x1f1
623 #define IMAGE_FILE_MACHINE_R4000 0x166
624 #define IMAGE_FILE_MACHINE_SH3 0x1a2
625 #define IMAGE_FILE_MACHINE_SH3E 0x01a4
626 #define IMAGE_FILE_MACHINE_SH3DSP 0x1a3
627 #define IMAGE_FILE_MACHINE_SH4 0x1a6
628 #define IMAGE_FILE_MACHINE_SH5 0x1a8
629 #define IMAGE_FILE_MACHINE_THUMB 0x1c2
630 #define IMAGE_FILE_MACHINE_WCEMIPSV2 0x169
631 #define IMAGE_FILE_MACHINE_R3000 0x162
632 #define IMAGE_FILE_MACHINE_R10000 0x168
633 #define IMAGE_FILE_MACHINE_ALPHA 0x184
634 #define IMAGE_FILE_MACHINE_ALPHA64 0x0284
635 #define IMAGE_FILE_MACHINE_AXP64 IMAGE_FILE_MACHINE_ALPHA64
636 #define IMAGE_FILE_MACHINE_CEE 0xC0EE
637 #define IMAGE_FILE_MACHINE_TRICORE 0x0520
638 #define IMAGE_FILE_MACHINE_CEF 0x0CEF
639 #define IMAGE_FILE_MACHINE_ARM64 0xAA64
640
641 #define IMAGE_FILE_EXPORT_DIRECTORY 0
642 #define IMAGE_FILE_IMPORT_DIRECTORY 1
643 #define IMAGE_FILE_RESOURCE_DIRECTORY 2
644 #define IMAGE_FILE_EXCEPTION_DIRECTORY 3
645 #define IMAGE_FILE_SECURITY_DIRECTORY 4
646 #define IMAGE_FILE_BASE_RELOCATION_TABLE 5
647 #define IMAGE_FILE_DEBUG_DIRECTORY 6
648 #define IMAGE_FILE_DESCRIPTION_STRING 7
649 #define IMAGE_FILE_MACHINE_VALUE 8 /* Mips */
650 #define IMAGE_FILE_THREAD_LOCAL_STORAGE 9
651 #define IMAGE_FILE_CALLBACK_DIRECTORY 10
652
653 #define IMAGE_DOS_SIGNATURE 0x5A4D
654 #define IMAGE_OS2_SIGNATURE 0x454E
655 #define IMAGE_OS2_SIGNATURE_LE 0x454C
656 #define IMAGE_VXD_SIGNATURE 0x454C
657 #define IMAGE_NT_SIGNATURE 0x00004550
658 #define IMAGE_NT_OPTIONAL_HDR32_MAGIC 0x10b
659 #define IMAGE_NT_OPTIONAL_HDR64_MAGIC 0x20b
660 #ifdef _WIN64
661 #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR64_MAGIC
662 #else
663 #define IMAGE_NT_OPTIONAL_HDR_MAGIC IMAGE_NT_OPTIONAL_HDR32_MAGIC
664 #endif
665 #define IMAGE_ROM_OPTIONAL_HDR_MAGIC 0x107
666 #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
667 #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
668 #define IMAGE_SIZEOF_ROM_OPTIONAL_HEADER 56
669 #define IMAGE_SIZEOF_STD_OPTIONAL_HEADER 28
670 #define IMAGE_SIZEOF_NT_OPTIONAL_HEADER 224
671 #define IMAGE_SIZEOF_SHORT_NAME 8
672 #define IMAGE_SIZEOF_SECTION_HEADER 40
673 #define IMAGE_SIZEOF_SYMBOL 18
674 #define IMAGE_SIZEOF_AUX_SYMBOL 18
675 #define IMAGE_SIZEOF_RELOCATION 10
676 #define IMAGE_SIZEOF_BASE_RELOCATION 8
677 #define IMAGE_SIZEOF_LINENUMBER 6
678 #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
679 #define SIZEOF_RFPO_DATA 16
680
681 #define IMAGE_SUBSYSTEM_UNKNOWN 0
682 #define IMAGE_SUBSYSTEM_NATIVE 1
683 #define IMAGE_SUBSYSTEM_WINDOWS_GUI 2
684 #define IMAGE_SUBSYSTEM_WINDOWS_CUI 3
685 #define IMAGE_SUBSYSTEM_OS2_CUI 5
686 #define IMAGE_SUBSYSTEM_POSIX_CUI 7
687 #define IMAGE_SUBSYSTEM_NATIVE_WINDOWS 8
688 #define IMAGE_SUBSYSTEM_WINDOWS_CE_GUI 9
689 #define IMAGE_SUBSYSTEM_EFI_APPLICATION 10
690 #define IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER 11
691 #define IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER 12
692 #define IMAGE_SUBSYSTEM_EFI_ROM 13
693 #define IMAGE_SUBSYSTEM_XBOX 14
694
695 #define IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE 0x0040
696 #define IMAGE_DLLCHARACTERISTICS_FORCE_INTEGRITY 0x0080
697 #define IMAGE_DLLCHARACTERISTICS_NX_COMPAT 0x0100
698 #define IMAGE_DLLCHARACTERISTICS_NO_ISOLATION 0x0200
699 #define IMAGE_DLLCHARACTERISTICS_NO_SEH 0x0400
700 #define IMAGE_DLLCHARACTERISTICS_NO_BIND 0x0800
701 #define IMAGE_DLLCHARACTERISTICS_WDM_DRIVER 0x2000
702 #define IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE 0x8000
703 #define IMAGE_FIRST_SECTION(h) ((PIMAGE_SECTION_HEADER) ((ULONG_PTR)h+FIELD_OFFSET(IMAGE_NT_HEADERS,OptionalHeader)+((PIMAGE_NT_HEADERS)(h))->FileHeader.SizeOfOptionalHeader))
704 #define IMAGE_DIRECTORY_ENTRY_EXPORT 0
705 #define IMAGE_DIRECTORY_ENTRY_IMPORT 1
706 #define IMAGE_DIRECTORY_ENTRY_RESOURCE 2
707 #define IMAGE_DIRECTORY_ENTRY_EXCEPTION 3
708 #define IMAGE_DIRECTORY_ENTRY_SECURITY 4
709 #define IMAGE_DIRECTORY_ENTRY_BASERELOC 5
710 #define IMAGE_DIRECTORY_ENTRY_DEBUG 6
711 #define IMAGE_DIRECTORY_ENTRY_COPYRIGHT 7
712 #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR 8
713 #define IMAGE_DIRECTORY_ENTRY_TLS 9
714 #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG 10
715 #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT 11
716 #define IMAGE_DIRECTORY_ENTRY_IAT 12
717 #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT 13
718 #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14
719 #define IMAGE_SCN_TYPE_REG 0
720 #define IMAGE_SCN_TYPE_DSECT 1
721 //#define IMAGE_SCN_TYPE_NOLOAD 2
722 #define IMAGE_SCN_TYPE_GROUP 4
723 #define IMAGE_SCN_TYPE_NO_PAD 8
724 #define IMAGE_SCN_CNT_CODE 32
725 #define IMAGE_SCN_CNT_INITIALIZED_DATA 64
726 #define IMAGE_SCN_CNT_UNINITIALIZED_DATA 128
727 #define IMAGE_SCN_LNK_OTHER 256
728 #define IMAGE_SCN_LNK_INFO 512
729 #define IMAGE_SCN_LNK_REMOVE 2048
730 #define IMAGE_SCN_LNK_COMDAT 4096
731 #define IMAGE_SCN_MEM_FARDATA 0x8000
732 #define IMAGE_SCN_MEM_PURGEABLE 0x20000
733 #define IMAGE_SCN_MEM_16BIT 0x20000
734 #define IMAGE_SCN_MEM_LOCKED 0x40000
735 #define IMAGE_SCN_MEM_PRELOAD 0x80000
736 #define IMAGE_SCN_ALIGN_1BYTES 0x100000
737 #define IMAGE_SCN_ALIGN_2BYTES 0x200000
738 #define IMAGE_SCN_ALIGN_4BYTES 0x300000
739 #define IMAGE_SCN_ALIGN_8BYTES 0x400000
740 #define IMAGE_SCN_ALIGN_16BYTES 0x500000
741 #define IMAGE_SCN_ALIGN_32BYTES 0x600000
742 #define IMAGE_SCN_ALIGN_64BYTES 0x700000
743 #define IMAGE_SCN_LNK_NRELOC_OVFL 0x1000000
744 #define IMAGE_SCN_MEM_DISCARDABLE 0x2000000
745 #define IMAGE_SCN_MEM_NOT_CACHED 0x4000000
746 #define IMAGE_SCN_MEM_NOT_PAGED 0x8000000
747 #define IMAGE_SCN_MEM_SHARED 0x10000000
748 #define IMAGE_SCN_MEM_EXECUTE 0x20000000
749 #define IMAGE_SCN_MEM_READ 0x40000000
750 #define IMAGE_SCN_MEM_WRITE 0x80000000
751 #define IMAGE_SYM_UNDEFINED 0
752 #define IMAGE_SYM_ABSOLUTE (-1)
753 #define IMAGE_SYM_DEBUG (-2)
754 #define IMAGE_SYM_TYPE_NULL 0
755 #define IMAGE_SYM_TYPE_VOID 1
756 #define IMAGE_SYM_TYPE_CHAR 2
757 #define IMAGE_SYM_TYPE_SHORT 3
758 #define IMAGE_SYM_TYPE_INT 4
759 #define IMAGE_SYM_TYPE_LONG 5
760 #define IMAGE_SYM_TYPE_FLOAT 6
761 #define IMAGE_SYM_TYPE_DOUBLE 7
762 #define IMAGE_SYM_TYPE_STRUCT 8
763 #define IMAGE_SYM_TYPE_UNION 9
764 #define IMAGE_SYM_TYPE_ENUM 10
765 #define IMAGE_SYM_TYPE_MOE 11
766 #define IMAGE_SYM_TYPE_BYTE 12
767 #define IMAGE_SYM_TYPE_WORD 13
768 #define IMAGE_SYM_TYPE_UINT 14
769 #define IMAGE_SYM_TYPE_DWORD 15
770 #define IMAGE_SYM_TYPE_PCODE 32768
771 #define IMAGE_SYM_DTYPE_NULL 0
772 #define IMAGE_SYM_DTYPE_POINTER 1
773 #define IMAGE_SYM_DTYPE_FUNCTION 2
774 #define IMAGE_SYM_DTYPE_ARRAY 3
775 #define IMAGE_SYM_CLASS_END_OF_FUNCTION (-1)
776 #define IMAGE_SYM_CLASS_NULL 0
777 #define IMAGE_SYM_CLASS_AUTOMATIC 1
778 #define IMAGE_SYM_CLASS_EXTERNAL 2
779 #define IMAGE_SYM_CLASS_STATIC 3
780 #define IMAGE_SYM_CLASS_REGISTER 4
781 #define IMAGE_SYM_CLASS_EXTERNAL_DEF 5
782 #define IMAGE_SYM_CLASS_LABEL 6
783 #define IMAGE_SYM_CLASS_UNDEFINED_LABEL 7
784 #define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT 8
785 #define IMAGE_SYM_CLASS_ARGUMENT 9
786 #define IMAGE_SYM_CLASS_STRUCT_TAG 10
787 #define IMAGE_SYM_CLASS_MEMBER_OF_UNION 11
788 #define IMAGE_SYM_CLASS_UNION_TAG 12
789 #define IMAGE_SYM_CLASS_TYPE_DEFINITION 13
790 #define IMAGE_SYM_CLASS_UNDEFINED_STATIC 14
791 #define IMAGE_SYM_CLASS_ENUM_TAG 15
792 #define IMAGE_SYM_CLASS_MEMBER_OF_ENUM 16
793 #define IMAGE_SYM_CLASS_REGISTER_PARAM 17
794 #define IMAGE_SYM_CLASS_BIT_FIELD 18
795 #define IMAGE_SYM_CLASS_FAR_EXTERNAL 68
796 #define IMAGE_SYM_CLASS_BLOCK 100
797 #define IMAGE_SYM_CLASS_FUNCTION 101
798 #define IMAGE_SYM_CLASS_END_OF_STRUCT 102
799 #define IMAGE_SYM_CLASS_FILE 103
800 #define IMAGE_SYM_CLASS_SECTION 104
801 #define IMAGE_SYM_CLASS_WEAK_EXTERNAL 105
802 #define IMAGE_COMDAT_SELECT_NODUPLICATES 1
803 #define IMAGE_COMDAT_SELECT_ANY 2
804 #define IMAGE_COMDAT_SELECT_SAME_SIZE 3
805 #define IMAGE_COMDAT_SELECT_EXACT_MATCH 4
806 #define IMAGE_COMDAT_SELECT_ASSOCIATIVE 5
807 #define IMAGE_COMDAT_SELECT_LARGEST 6
808 #define IMAGE_COMDAT_SELECT_NEWEST 7
809 #define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY 1
810 #define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY 2
811 #define IMAGE_WEAK_EXTERN_SEARCH_ALIAS 3
812 #define IMAGE_REL_I386_ABSOLUTE 0
813 #define IMAGE_REL_I386_DIR16 1
814 #define IMAGE_REL_I386_REL16 2
815 #define IMAGE_REL_I386_DIR32 6
816 #define IMAGE_REL_I386_DIR32NB 7
817 #define IMAGE_REL_I386_SEG12 9
818 #define IMAGE_REL_I386_SECTION 10
819 #define IMAGE_REL_I386_SECREL 11
820 #define IMAGE_REL_I386_REL32 20
821 #define IMAGE_REL_MIPS_ABSOLUTE 0
822 #define IMAGE_REL_MIPS_REFHALF 1
823 #define IMAGE_REL_MIPS_REFWORD 2
824 #define IMAGE_REL_MIPS_JMPADDR 3
825 #define IMAGE_REL_MIPS_REFHI 4
826 #define IMAGE_REL_MIPS_REFLO 5
827 #define IMAGE_REL_MIPS_GPREL 6
828 #define IMAGE_REL_MIPS_LITERAL 7
829 #define IMAGE_REL_MIPS_SECTION 10
830 #define IMAGE_REL_MIPS_SECREL 11
831 #define IMAGE_REL_MIPS_SECRELLO 12
832 #define IMAGE_REL_MIPS_SECRELHI 13
833 #define IMAGE_REL_MIPS_REFWORDNB 34
834 #define IMAGE_REL_MIPS_PAIR 35
835 #define IMAGE_REL_ALPHA_ABSOLUTE 0
836 #define IMAGE_REL_ALPHA_REFLONG 1
837 #define IMAGE_REL_ALPHA_REFQUAD 2
838 #define IMAGE_REL_ALPHA_GPREL32 3
839 #define IMAGE_REL_ALPHA_LITERAL 4
840 #define IMAGE_REL_ALPHA_LITUSE 5
841 #define IMAGE_REL_ALPHA_GPDISP 6
842 #define IMAGE_REL_ALPHA_BRADDR 7
843 #define IMAGE_REL_ALPHA_HINT 8
844 #define IMAGE_REL_ALPHA_INLINE_REFLONG 9
845 #define IMAGE_REL_ALPHA_REFHI 10
846 #define IMAGE_REL_ALPHA_REFLO 11
847 #define IMAGE_REL_ALPHA_PAIR 12
848 #define IMAGE_REL_ALPHA_MATCH 13
849 #define IMAGE_REL_ALPHA_SECTION 14
850 #define IMAGE_REL_ALPHA_SECREL 15
851 #define IMAGE_REL_ALPHA_REFLONGNB 16
852 #define IMAGE_REL_ALPHA_SECRELLO 17
853 #define IMAGE_REL_ALPHA_SECRELHI 18
854 #define IMAGE_REL_PPC_ABSOLUTE 0
855 #define IMAGE_REL_PPC_ADDR64 1
856 #define IMAGE_REL_PPC_ADDR32 2
857 #define IMAGE_REL_PPC_ADDR24 3
858 #define IMAGE_REL_PPC_ADDR16 4
859 #define IMAGE_REL_PPC_ADDR14 5
860 #define IMAGE_REL_PPC_REL24 6
861 #define IMAGE_REL_PPC_REL14 7
862 #define IMAGE_REL_PPC_TOCREL16 8
863 #define IMAGE_REL_PPC_TOCREL14 9
864 #define IMAGE_REL_PPC_ADDR32NB 10
865 #define IMAGE_REL_PPC_SECREL 11
866 #define IMAGE_REL_PPC_SECTION 12
867 #define IMAGE_REL_PPC_IFGLUE 13
868 #define IMAGE_REL_PPC_IMGLUE 14
869 #define IMAGE_REL_PPC_SECREL16 15
870 #define IMAGE_REL_PPC_REFHI 16
871 #define IMAGE_REL_PPC_REFLO 17
872 #define IMAGE_REL_PPC_PAIR 18
873 #define IMAGE_REL_PPC_TYPEMASK 255
874 #define IMAGE_REL_PPC_NEG 256
875 #define IMAGE_REL_PPC_BRTAKEN 512
876 #define IMAGE_REL_PPC_BRNTAKEN 1024
877 #define IMAGE_REL_PPC_TOCDEFN 2048
878 #define IMAGE_REL_BASED_ABSOLUTE 0
879 #define IMAGE_REL_BASED_HIGH 1
880 #define IMAGE_REL_BASED_LOW 2
881 #define IMAGE_REL_BASED_HIGHLOW 3
882 #define IMAGE_REL_BASED_HIGHADJ 4
883 #define IMAGE_REL_BASED_MIPS_JMPADDR 5
884 #define IMAGE_REL_BASED_MIPS_JMPADDR16 9
885 #define IMAGE_REL_BASED_IA64_IMM64 9
886 #define IMAGE_REL_BASED_DIR64 10
887 #define IMAGE_ARCHIVE_START_SIZE 8
888 #define IMAGE_ARCHIVE_START "!<arch>\n"
889 #define IMAGE_ARCHIVE_END "`\n"
890 #define IMAGE_ARCHIVE_PAD "\n"
891 #define IMAGE_ARCHIVE_LINKER_MEMBER "/ "
892 #define IMAGE_ARCHIVE_LONGNAMES_MEMBER "// "
893 #define IMAGE_RESOURCE_NAME_IS_STRING 0x80000000
894 #define IMAGE_RESOURCE_DATA_IS_DIRECTORY 0x80000000
895 #define IMAGE_DEBUG_TYPE_UNKNOWN 0
896 #define IMAGE_DEBUG_TYPE_COFF 1
897 #define IMAGE_DEBUG_TYPE_CODEVIEW 2
898 #define IMAGE_DEBUG_TYPE_FPO 3
899 #define IMAGE_DEBUG_TYPE_MISC 4
900 #define IMAGE_DEBUG_TYPE_EXCEPTION 5
901 #define IMAGE_DEBUG_TYPE_FIXUP 6
902 #define IMAGE_DEBUG_TYPE_OMAP_TO_SRC 7
903 #define IMAGE_DEBUG_TYPE_OMAP_FROM_SRC 8
904 #define FRAME_FPO 0
905 #define FRAME_TRAP 1
906 #define FRAME_TSS 2
907 #define FRAME_NONFPO 3
908 #define IMAGE_DEBUG_MISC_EXENAME 1
909 #define N_BTMASK 0x000F
910 #define N_TMASK 0x0030
911 #define N_TMASK1 0x00C0
912 #define N_TMASK2 0x00F0
913 #define N_BTSHFT 4
914 #define N_TSHIFT 2
915 #define IS_TEXT_UNICODE_ASCII16 1
916 #define IS_TEXT_UNICODE_REVERSE_ASCII16 16
917 #define IS_TEXT_UNICODE_STATISTICS 2
918 #define IS_TEXT_UNICODE_REVERSE_STATISTICS 32
919 #define IS_TEXT_UNICODE_CONTROLS 4
920 #define IS_TEXT_UNICODE_REVERSE_CONTROLS 64
921 #define IS_TEXT_UNICODE_SIGNATURE 8
922 #define IS_TEXT_UNICODE_REVERSE_SIGNATURE 128
923 #define IS_TEXT_UNICODE_ILLEGAL_CHARS 256
924 #define IS_TEXT_UNICODE_ODD_LENGTH 512
925 #define IS_TEXT_UNICODE_DBCS_LEADBYTE 1024
926 #define IS_TEXT_UNICODE_NULL_BYTES 4096
927 #define IS_TEXT_UNICODE_UNICODE_MASK 15
928 #define IS_TEXT_UNICODE_REVERSE_MASK 240
929 #define IS_TEXT_UNICODE_NOT_UNICODE_MASK 3840
930 #define IS_TEXT_UNICODE_NOT_ASCII_MASK 61440
931 #define SERVICE_KERNEL_DRIVER 1
932 #define SERVICE_FILE_SYSTEM_DRIVER 2
933 #define SERVICE_ADAPTER 4
934 #define SERVICE_RECOGNIZER_DRIVER 8
935 #define SERVICE_DRIVER (SERVICE_KERNEL_DRIVER|SERVICE_FILE_SYSTEM_DRIVER|SERVICE_RECOGNIZER_DRIVER)
936 #define SERVICE_WIN32_OWN_PROCESS 16
937 #define SERVICE_WIN32_SHARE_PROCESS 32
938 #define SERVICE_WIN32 (SERVICE_WIN32_OWN_PROCESS|SERVICE_WIN32_SHARE_PROCESS)
939 #define SERVICE_INTERACTIVE_PROCESS 256
940 #define SERVICE_TYPE_ALL (SERVICE_WIN32|SERVICE_ADAPTER|SERVICE_DRIVER|SERVICE_INTERACTIVE_PROCESS)
941 #define SERVICE_BOOT_START 0
942 #define SERVICE_SYSTEM_START 1
943 #define SERVICE_AUTO_START 2
944 #define SERVICE_DEMAND_START 3
945 #define SERVICE_DISABLED 4
946 #define SERVICE_ERROR_IGNORE 0
947 #define SERVICE_ERROR_NORMAL 1
948 #define SERVICE_ERROR_SEVERE 2
949 #define SERVICE_ERROR_CRITICAL 3
950
951 #define DLL_PROCESS_DETACH 0
952 #define DLL_PROCESS_ATTACH 1
953 #define DLL_THREAD_ATTACH 2
954 #define DLL_THREAD_DETACH 3
955 #ifdef __WINESRC__
956 #define DLL_WINE_PREATTACH 8 /* Never called, but defined for compatibility with Wine source */
957 #endif
958 #define TAPE_ABSOLUTE_POSITION 0
959 #define TAPE_LOGICAL_POSITION 1
960 #define TAPE_PSEUDO_LOGICAL_POSITION 2
961 #define TAPE_REWIND 0
962 #define TAPE_ABSOLUTE_BLOCK 1
963 #define TAPE_LOGICAL_BLOCK 2
964 #define TAPE_PSEUDO_LOGICAL_BLOCK 3
965 #define TAPE_SPACE_END_OF_DATA 4
966 #define TAPE_SPACE_RELATIVE_BLOCKS 5
967 #define TAPE_SPACE_FILEMARKS 6
968 #define TAPE_SPACE_SEQUENTIAL_FMKS 7
969 #define TAPE_SPACE_SETMARKS 8
970 #define TAPE_SPACE_SEQUENTIAL_SMKS 9
971 #define TAPE_DRIVE_FIXED 1
972 #define TAPE_DRIVE_SELECT 2
973 #define TAPE_DRIVE_INITIATOR 4
974 #define TAPE_DRIVE_ERASE_SHORT 16
975 #define TAPE_DRIVE_ERASE_LONG 32
976 #define TAPE_DRIVE_ERASE_BOP_ONLY 64
977 #define TAPE_DRIVE_ERASE_IMMEDIATE 128
978 #define TAPE_DRIVE_TAPE_CAPACITY 256
979 #define TAPE_DRIVE_TAPE_REMAINING 512
980 #define TAPE_DRIVE_FIXED_BLOCK 1024
981 #define TAPE_DRIVE_VARIABLE_BLOCK 2048
982 #define TAPE_DRIVE_WRITE_PROTECT 4096
983 #define TAPE_DRIVE_EOT_WZ_SIZE 8192
984 #define TAPE_DRIVE_ECC 0x10000
985 #define TAPE_DRIVE_COMPRESSION 0x20000
986 #define TAPE_DRIVE_PADDING 0x40000
987 #define TAPE_DRIVE_REPORT_SMKS 0x80000
988 #define TAPE_DRIVE_GET_ABSOLUTE_BLK 0x100000
989 #define TAPE_DRIVE_GET_LOGICAL_BLK 0x200000
990 #define TAPE_DRIVE_SET_EOT_WZ_SIZE 0x400000
991 #define TAPE_DRIVE_EJECT_MEDIA 0x1000000
992 #define TAPE_DRIVE_CLEAN_REQUESTS 0x2000000
993 #define TAPE_DRIVE_SET_CMP_BOP_ONLY 0x4000000
994 #define TAPE_DRIVE_RESERVED_BIT 0x80000000
995 #define TAPE_DRIVE_LOAD_UNLOAD 0x80000001
996 #define TAPE_DRIVE_TENSION 0x80000002
997 #define TAPE_DRIVE_LOCK_UNLOCK 0x80000004
998 #define TAPE_DRIVE_REWIND_IMMEDIATE 0x80000008
999 #define TAPE_DRIVE_SET_BLOCK_SIZE 0x80000010
1000 #define TAPE_DRIVE_LOAD_UNLD_IMMED 0x80000020
1001 #define TAPE_DRIVE_TENSION_IMMED 0x80000040
1002 #define TAPE_DRIVE_LOCK_UNLK_IMMED 0x80000080
1003 #define TAPE_DRIVE_SET_ECC 0x80000100
1004 #define TAPE_DRIVE_SET_COMPRESSION 0x80000200
1005 #define TAPE_DRIVE_SET_PADDING 0x80000400
1006 #define TAPE_DRIVE_SET_REPORT_SMKS 0x80000800
1007 #define TAPE_DRIVE_ABSOLUTE_BLK 0x80001000
1008 #define TAPE_DRIVE_ABS_BLK_IMMED 0x80002000
1009 #define TAPE_DRIVE_LOGICAL_BLK 0x80004000
1010 #define TAPE_DRIVE_LOG_BLK_IMMED 0x80008000
1011 #define TAPE_DRIVE_END_OF_DATA 0x80010000
1012 #define TAPE_DRIVE_RELATIVE_BLKS 0x80020000
1013 #define TAPE_DRIVE_FILEMARKS 0x80040000
1014 #define TAPE_DRIVE_SEQUENTIAL_FMKS 0x80080000
1015 #define TAPE_DRIVE_SETMARKS 0x80100000
1016 #define TAPE_DRIVE_SEQUENTIAL_SMKS 0x80200000
1017 #define TAPE_DRIVE_REVERSE_POSITION 0x80400000
1018 #define TAPE_DRIVE_SPACE_IMMEDIATE 0x80800000
1019 #define TAPE_DRIVE_WRITE_SETMARKS 0x81000000
1020 #define TAPE_DRIVE_WRITE_FILEMARKS 0x82000000
1021 #define TAPE_DRIVE_WRITE_SHORT_FMKS 0x84000000
1022 #define TAPE_DRIVE_WRITE_LONG_FMKS 0x88000000
1023 #define TAPE_DRIVE_WRITE_MARK_IMMED 0x90000000
1024 #define TAPE_DRIVE_FORMAT 0xA0000000
1025 #define TAPE_DRIVE_FORMAT_IMMEDIATE 0xC0000000
1026 #define TAPE_DRIVE_HIGH_FEATURES 0x80000000
1027 #define TAPE_FIXED_PARTITIONS 0
1028 #define TAPE_INITIATOR_PARTITIONS 2
1029 #define TAPE_SELECT_PARTITIONS 1
1030 #define TAPE_FILEMARKS 1
1031 #define TAPE_LONG_FILEMARKS 3
1032 #define TAPE_SETMARKS 0
1033 #define TAPE_SHORT_FILEMARKS 2
1034 #define TAPE_ERASE_LONG 1
1035 #define TAPE_ERASE_SHORT 0
1036 #define TAPE_LOAD 0
1037 #define TAPE_UNLOAD 1
1038 #define TAPE_TENSION 2
1039 #define TAPE_LOCK 3
1040 #define TAPE_UNLOCK 4
1041 #define TAPE_FORMAT 5
1042 #if (_WIN32_WINNT >= 0x0500)
1043 #define VER_MINORVERSION 0x0000001
1044 #define VER_MAJORVERSION 0x0000002
1045 #define VER_BUILDNUMBER 0x0000004
1046 #define VER_PLATFORMID 0x0000008
1047 #define VER_SERVICEPACKMINOR 0x0000010
1048 #define VER_SERVICEPACKMAJOR 0x0000020
1049 #define VER_SUITENAME 0x0000040
1050 #define VER_PRODUCT_TYPE 0x0000080
1051 #define VER_EQUAL 1
1052 #define VER_GREATER 2
1053 #define VER_GREATER_EQUAL 3
1054 #define VER_LESS 4
1055 #define VER_LESS_EQUAL 5
1056 #define VER_AND 6
1057 #define VER_OR 7
1058 #endif
1059
1060 #define VER_PLATFORM_WIN32s 0
1061 #define VER_PLATFORM_WIN32_WINDOWS 1
1062 #define VER_PLATFORM_WIN32_NT 2
1063 #define VER_NT_WORKSTATION 1
1064 #define VER_NT_DOMAIN_CONTROLLER 2
1065 #define VER_NT_SERVER 3
1066
1067 #define WT_EXECUTEDEFAULT 0x00000000
1068 #define WT_EXECUTEINIOTHREAD 0x00000001
1069 #define WT_EXECUTEINUITHREAD 0x00000002
1070 #define WT_EXECUTEINWAITTHREAD 0x00000004
1071 #define WT_EXECUTEONLYONCE 0x00000008
1072 #define WT_EXECUTELONGFUNCTION 0x00000010
1073 #define WT_EXECUTEINTIMERTHREAD 0x00000020
1074 #define WT_EXECUTEINPERSISTENTIOTHREAD 0x00000040
1075 #define WT_EXECUTEINPERSISTENTTHREAD 0x00000080
1076 #define WT_TRANSFER_IMPERSONATION 0x00000100
1077 #define WT_SET_MAX_THREADPOOL_THREADS(flags,limit) ((flags)|=(limit)<<16)
1078 typedef VOID (NTAPI *WORKERCALLBACKFUNC)(PVOID);
1079 #if (_WIN32_WINNT >= 0x0501)
1080 #define ACTIVATION_CONTEXT_SECTION_ASSEMBLY_INFORMATION 1
1081 #define ACTIVATION_CONTEXT_SECTION_DLL_REDIRECTION 2
1082 #define ACTIVATION_CONTEXT_SECTION_WINDOW_CLASS_REDIRECTION 3
1083 #define ACTIVATION_CONTEXT_SECTION_COM_SERVER_REDIRECTION 4
1084 #define ACTIVATION_CONTEXT_SECTION_COM_INTERFACE_REDIRECTION 5
1085 #define ACTIVATION_CONTEXT_SECTION_COM_TYPE_LIBRARY_REDIRECTION 6
1086 #define ACTIVATION_CONTEXT_SECTION_COM_PROGID_REDIRECTION 7
1087 #define ACTIVATION_CONTEXT_SECTION_CLR_SURROGATES 9
1088 #define ACTIVATION_CONTEXT_SECTION_APPLICATION_SETTINGS 10
1089 #define ACTIVATION_CONTEXT_SECTION_COMPATIBILITY_INFO 11
1090 #endif /* (_WIN32_WINNT >= 0x0501) */
1091 #define BTYPE(x) ((x)&N_BTMASK)
1092 #define ISPTR(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT))
1093 #define ISFCN(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_FUNCTION<<N_BTSHFT))
1094 #define ISARY(x) (((x)&N_TMASK)==(IMAGE_SYM_DTYPE_ARRAY<<N_BTSHFT))
1095 #define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG||(x)==IMAGE_SYM_CLASS_UNION_TAG||(x)==IMAGE_SYM_CLASS_ENUM_TAG)
1096 #define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
1097 #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
1098 #define TLS_MINIMUM_AVAILABLE 64
1099 #define FLS_MAXIMUM_AVAILABLE 128
1100 #define REPARSE_GUID_DATA_BUFFER_HEADER_SIZE FIELD_OFFSET(REPARSE_GUID_DATA_BUFFER, GenericReparseBuffer)
1101 #define MAXIMUM_REPARSE_DATA_BUFFER_SIZE 16384
1102 #define IO_REPARSE_TAG_RESERVED_ZERO 0
1103 #define IO_REPARSE_TAG_RESERVED_ONE 1
1104 #define IO_REPARSE_TAG_RESERVED_RANGE IO_REPARSE_TAG_RESERVED_ONE
1105 #define IsReparseTagMicrosoft(x) ((x)&0x80000000)
1106 #define IsReparseTagHighLatency(x) ((x)&0x40000000)
1107 #define IsReparseTagNameSurrogate(x) ((x)&0x20000000)
1108 #define IO_REPARSE_TAG_VALID_VALUES 0xE000FFFF
1109 #define IsReparseTagValid(x) (!((x)&~IO_REPARSE_TAG_VALID_VALUES)&&((x)>IO_REPARSE_TAG_RESERVED_RANGE))
1110 #define IO_REPARSE_TAG_SYMBOLIC_LINK IO_REPARSE_TAG_RESERVED_ZERO
1111 #define IO_REPARSE_TAG_MOUNT_POINT 0xA0000003
1112 #define IO_REPARSE_TAG_SYMLINK 0xA000000CL
1113
1114 #define RTL_CRITICAL_SECTION_FLAG_NO_DEBUG_INFO 0x01000000
1115 #define RTL_CRITICAL_SECTION_FLAG_DYNAMIC_SPIN 0x02000000
1116 #define RTL_CRITICAL_SECTION_FLAG_STATIC_INIT 0x04000000
1117 #define RTL_CRITICAL_SECTION_FLAG_RESOURCE_TYPE 0x08000000
1118 #define RTL_CRITICAL_SECTION_FLAG_FORCE_DEBUG_INFO 0x10000000
1119 #define RTL_CRITICAL_SECTION_ALL_FLAG_BITS 0xFF000000
1120 #define RTL_CRITICAL_SECTION_FLAG_RESERVED \
1121 (RTL_CRITICAL_SECTION_ALL_FLAG_BITS & \
1122 (~(RTL_CRITICAL_SECTION_FLAG_NO_DEBUG_INFO | \
1123 RTL_CRITICAL_SECTION_FLAG_DYNAMIC_SPIN | \
1124 RTL_CRITICAL_SECTION_FLAG_STATIC_INIT | \
1125 RTL_CRITICAL_SECTION_FLAG_RESOURCE_TYPE | \
1126 RTL_CRITICAL_SECTION_FLAG_FORCE_DEBUG_INFO)))
1127
1128 #ifndef RC_INVOKED
1129
1130 #ifdef _GUID_DEFINED
1131 # warning _GUID_DEFINED is deprecated, use GUID_DEFINED instead
1132 #endif
1133
1134 #if ! (defined _GUID_DEFINED || defined GUID_DEFINED) /* also defined in basetyps.h */
1135 #define GUID_DEFINED
1136 typedef struct _GUID {
1137 unsigned long Data1;
1138 unsigned short Data2;
1139 unsigned short Data3;
1140 unsigned char Data4[8];
1141 } GUID, *REFGUID, *LPGUID;
1142 #endif /* GUID_DEFINED */
1143
1144 typedef enum _ACL_INFORMATION_CLASS {
1145 AclRevisionInformation = 1,
1146 AclSizeInformation
1147 } ACL_INFORMATION_CLASS;
1148
1149 typedef struct _ACL_REVISION_INFORMATION {
1150 DWORD AclRevision;
1151 } ACL_REVISION_INFORMATION, *PACL_REVISION_INFORMATION;
1152
1153 typedef struct _ACL_SIZE_INFORMATION {
1154 DWORD AceCount;
1155 DWORD AclBytesInUse;
1156 DWORD AclBytesFree;
1157 } ACL_SIZE_INFORMATION, *PACL_SIZE_INFORMATION;
1158
1159 #ifndef _LDT_ENTRY_DEFINED
1160 #define _LDT_ENTRY_DEFINED
1161
1162 typedef struct _LDT_ENTRY {
1163 WORD LimitLow;
1164 WORD BaseLow;
1165 union {
1166 struct {
1167 BYTE BaseMid;
1168 BYTE Flags1;
1169 BYTE Flags2;
1170 BYTE BaseHi;
1171 } Bytes;
1172 struct {
1173 DWORD BaseMid:8;
1174 DWORD Type:5;
1175 DWORD Dpl:2;
1176 DWORD Pres:1;
1177 DWORD LimitHi:4;
1178 DWORD Sys:1;
1179 DWORD Reserved_0:1;
1180 DWORD Default_Big:1;
1181 DWORD Granularity:1;
1182 DWORD BaseHi:8;
1183 } Bits;
1184 } HighWord;
1185 } LDT_ENTRY, *PLDT_ENTRY, *LPLDT_ENTRY;
1186
1187 #endif /* _LDT_ENTRY_DEFINED */
1188
1189 /* FIXME: add more machines */
1190 #if defined(_X86_)
1191 #define SIZE_OF_80387_REGISTERS 80
1192 #define CONTEXT_i386 0x10000
1193 #define CONTEXT_i486 0x10000
1194 #define CONTEXT_CONTROL (CONTEXT_i386|0x00000001L)
1195 #define CONTEXT_INTEGER (CONTEXT_i386|0x00000002L)
1196 #define CONTEXT_SEGMENTS (CONTEXT_i386|0x00000004L)
1197 #define CONTEXT_FLOATING_POINT (CONTEXT_i386|0x00000008L)
1198 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_i386|0x00000010L)
1199 #define CONTEXT_EXTENDED_REGISTERS (CONTEXT_i386|0x00000020L)
1200 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_INTEGER|CONTEXT_SEGMENTS)
1201 #define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | \
1202 CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS | \
1203 CONTEXT_EXTENDED_REGISTERS)
1204 #define MAXIMUM_SUPPORTED_EXTENSION 512
1205
1206 #define EXCEPTION_READ_FAULT 0
1207 #define EXCEPTION_WRITE_FAULT 1
1208 #define EXCEPTION_EXECUTE_FAULT 8
1209
1210 typedef struct _FLOATING_SAVE_AREA {
1211 DWORD ControlWord;
1212 DWORD StatusWord;
1213 DWORD TagWord;
1214 DWORD ErrorOffset;
1215 DWORD ErrorSelector;
1216 DWORD DataOffset;
1217 DWORD DataSelector;
1218 BYTE RegisterArea[SIZE_OF_80387_REGISTERS];
1219 DWORD Cr0NpxState;
1220 } FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
1221
1222 typedef struct _CONTEXT {
1223 DWORD ContextFlags;
1224 DWORD Dr0;
1225 DWORD Dr1;
1226 DWORD Dr2;
1227 DWORD Dr3;
1228 DWORD Dr6;
1229 DWORD Dr7;
1230 FLOATING_SAVE_AREA FloatSave;
1231 DWORD SegGs;
1232 DWORD SegFs;
1233 DWORD SegEs;
1234 DWORD SegDs;
1235 DWORD Edi;
1236 DWORD Esi;
1237 DWORD Ebx;
1238 DWORD Edx;
1239 DWORD Ecx;
1240 DWORD Eax;
1241 DWORD Ebp;
1242 DWORD Eip;
1243 DWORD SegCs;
1244 DWORD EFlags;
1245 DWORD Esp;
1246 DWORD SegSs;
1247 BYTE ExtendedRegisters[MAXIMUM_SUPPORTED_EXTENSION];
1248 } CONTEXT;
1249 #elif defined(_AMD64_)
1250
1251 #define CONTEXT_AMD64 0x100000
1252
1253 #if !defined(RC_INVOKED)
1254 #define CONTEXT_CONTROL (CONTEXT_AMD64 | 0x1L)
1255 #define CONTEXT_INTEGER (CONTEXT_AMD64 | 0x2L)
1256 #define CONTEXT_SEGMENTS (CONTEXT_AMD64 | 0x4L)
1257 #define CONTEXT_FLOATING_POINT (CONTEXT_AMD64 | 0x8L)
1258 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_AMD64 | 0x10L)
1259
1260 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
1261 #define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS)
1262
1263 #define CONTEXT_EXCEPTION_ACTIVE 0x8000000
1264 #define CONTEXT_SERVICE_ACTIVE 0x10000000
1265 #define CONTEXT_EXCEPTION_REQUEST 0x40000000
1266 #define CONTEXT_EXCEPTION_REPORTING 0x80000000
1267 #endif
1268
1269 #define INITIAL_MXCSR 0x1f80
1270 #define INITIAL_FPCSR 0x027f
1271 #define EXCEPTION_READ_FAULT 0
1272 #define EXCEPTION_WRITE_FAULT 1
1273 #define EXCEPTION_EXECUTE_FAULT 8
1274
1275 typedef struct DECLSPEC_ALIGN(16) _M128A {
1276 ULONGLONG Low;
1277 LONGLONG High;
1278 } M128A, *PM128A;
1279
1280 typedef struct _XMM_SAVE_AREA32 {
1281 WORD ControlWord;
1282 WORD StatusWord;
1283 BYTE TagWord;
1284 BYTE Reserved1;
1285 WORD ErrorOpcode;
1286 DWORD ErrorOffset;
1287 WORD ErrorSelector;
1288 WORD Reserved2;
1289 DWORD DataOffset;
1290 WORD DataSelector;
1291 WORD Reserved3;
1292 DWORD MxCsr;
1293 DWORD MxCsr_Mask;
1294 M128A FloatRegisters[8];
1295 M128A XmmRegisters[16];
1296 BYTE Reserved4[96];
1297 } XMM_SAVE_AREA32, *PXMM_SAVE_AREA32;
1298
1299 typedef struct DECLSPEC_ALIGN(16) _CONTEXT {
1300 DWORD64 P1Home;
1301 DWORD64 P2Home;
1302 DWORD64 P3Home;
1303 DWORD64 P4Home;
1304 DWORD64 P5Home;
1305 DWORD64 P6Home;
1306
1307 /* Control flags */
1308 DWORD ContextFlags;
1309 DWORD MxCsr;
1310
1311 /* Segment */
1312 WORD SegCs;
1313 WORD SegDs;
1314 WORD SegEs;
1315 WORD SegFs;
1316 WORD SegGs;
1317 WORD SegSs;
1318 DWORD EFlags;
1319
1320 /* Debug */
1321 DWORD64 Dr0;
1322 DWORD64 Dr1;
1323 DWORD64 Dr2;
1324 DWORD64 Dr3;
1325 DWORD64 Dr6;
1326 DWORD64 Dr7;
1327
1328 /* Integer */
1329 DWORD64 Rax;
1330 DWORD64 Rcx;
1331 DWORD64 Rdx;
1332 DWORD64 Rbx;
1333 DWORD64 Rsp;
1334 DWORD64 Rbp;
1335 DWORD64 Rsi;
1336 DWORD64 Rdi;
1337 DWORD64 R8;
1338 DWORD64 R9;
1339 DWORD64 R10;
1340 DWORD64 R11;
1341 DWORD64 R12;
1342 DWORD64 R13;
1343 DWORD64 R14;
1344 DWORD64 R15;
1345
1346 /* Counter */
1347 DWORD64 Rip;
1348
1349 /* Floating point */
1350 union {
1351 XMM_SAVE_AREA32 FltSave;
1352 struct {
1353 M128A Header[2];
1354 M128A Legacy[8];
1355 M128A Xmm0;
1356 M128A Xmm1;
1357 M128A Xmm2;
1358 M128A Xmm3;
1359 M128A Xmm4;
1360 M128A Xmm5;
1361 M128A Xmm6;
1362 M128A Xmm7;
1363 M128A Xmm8;
1364 M128A Xmm9;
1365 M128A Xmm10;
1366 M128A Xmm11;
1367 M128A Xmm12;
1368 M128A Xmm13;
1369 M128A Xmm14;
1370 M128A Xmm15;
1371 } DUMMYSTRUCTNAME;
1372 } DUMMYUNIONNAME;
1373
1374 /* Vector */
1375 M128A VectorRegister[26];
1376 DWORD64 VectorControl;
1377
1378 /* Debug control */
1379 DWORD64 DebugControl;
1380 DWORD64 LastBranchToRip;
1381 DWORD64 LastBranchFromRip;
1382 DWORD64 LastExceptionToRip;
1383 DWORD64 LastExceptionFromRip;
1384 } CONTEXT;
1385
1386
1387 typedef struct _KNONVOLATILE_CONTEXT_POINTERS {
1388 union {
1389 PM128A FloatingContext[16];
1390 struct {
1391 PM128A Xmm0;
1392 PM128A Xmm1;
1393 PM128A Xmm2;
1394 PM128A Xmm3;
1395 PM128A Xmm4;
1396 PM128A Xmm5;
1397 PM128A Xmm6;
1398 PM128A Xmm7;
1399 PM128A Xmm8;
1400 PM128A Xmm9;
1401 PM128A Xmm10;
1402 PM128A Xmm11;
1403 PM128A Xmm12;
1404 PM128A Xmm13;
1405 PM128A Xmm14;
1406 PM128A Xmm15;
1407 } DUMMYSTRUCTNAME;
1408 } DUMMYUNIONNAME;
1409
1410 union {
1411 PULONG64 IntegerContext[16];
1412 struct {
1413 PULONG64 Rax;
1414 PULONG64 Rcx;
1415 PULONG64 Rdx;
1416 PULONG64 Rbx;
1417 PULONG64 Rsp;
1418 PULONG64 Rbp;
1419 PULONG64 Rsi;
1420 PULONG64 Rdi;
1421 PULONG64 R8;
1422 PULONG64 R9;
1423 PULONG64 R10;
1424 PULONG64 R11;
1425 PULONG64 R12;
1426 PULONG64 R13;
1427 PULONG64 R14;
1428 PULONG64 R15;
1429 } DUMMYSTRUCTNAME;
1430 } DUMMYUNIONNAME2;
1431 } KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS;
1432
1433 #define UNW_FLAG_NHANDLER 0x0
1434 #define UNW_FLAG_EHANDLER 0x1
1435 #define UNW_FLAG_UHANDLER 0x2
1436 #define UNW_FLAG_CHAININFO 0x4
1437 #define UNW_FLAG_NO_EPILOGUE 0x80000000UL
1438
1439 #define RUNTIME_FUNCTION_INDIRECT 0x1
1440
1441 typedef struct _RUNTIME_FUNCTION {
1442 DWORD BeginAddress;
1443 DWORD EndAddress;
1444 DWORD UnwindData;
1445 } RUNTIME_FUNCTION,*PRUNTIME_FUNCTION;
1446
1447 #define UNWIND_HISTORY_TABLE_SIZE 12
1448
1449 typedef struct _UNWIND_HISTORY_TABLE_ENTRY
1450 {
1451 DWORD64 ImageBase;
1452 PRUNTIME_FUNCTION FunctionEntry;
1453 } UNWIND_HISTORY_TABLE_ENTRY, *PUNWIND_HISTORY_TABLE_ENTRY;
1454
1455 typedef struct _UNWIND_HISTORY_TABLE
1456 {
1457 DWORD Count;
1458 BYTE LocalHint;
1459 BYTE GlobalHint;
1460 BYTE Search;
1461 BYTE Once;
1462 ULONG64 LowAddress;
1463 ULONG64 HighAddress;
1464 UNWIND_HISTORY_TABLE_ENTRY Entry[UNWIND_HISTORY_TABLE_SIZE];
1465 } UNWIND_HISTORY_TABLE, *PUNWIND_HISTORY_TABLE;
1466
1467 typedef
1468 _Function_class_(GET_RUNTIME_FUNCTION_CALLBACK)
1469 PRUNTIME_FUNCTION
1470 GET_RUNTIME_FUNCTION_CALLBACK(
1471 _In_ DWORD64 ControlPc,
1472 _In_opt_ PVOID Context);
1473 typedef GET_RUNTIME_FUNCTION_CALLBACK *PGET_RUNTIME_FUNCTION_CALLBACK;
1474
1475 typedef
1476 _Function_class_(OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK)
1477 DWORD
1478 OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK(
1479 _In_ HANDLE Process,
1480 _In_ PVOID TableAddress,
1481 _Out_ PDWORD Entries,
1482 _Out_ PRUNTIME_FUNCTION* Functions);
1483 typedef OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK *POUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK;
1484
1485 struct _EXCEPTION_POINTERS;
1486 typedef
1487 LONG
1488 (*PEXCEPTION_FILTER) (
1489 struct _EXCEPTION_POINTERS *ExceptionPointers,
1490 PVOID EstablisherFrame);
1491
1492 typedef
1493 VOID
1494 (*PTERMINATION_HANDLER) (
1495 BOOLEAN AbnormalTermination,
1496 PVOID EstablisherFrame);
1497
1498 typedef struct _DISPATCHER_CONTEXT
1499 {
1500 ULONG64 ControlPc;
1501 ULONG64 ImageBase;
1502 PRUNTIME_FUNCTION FunctionEntry;
1503 ULONG64 EstablisherFrame;
1504 ULONG64 TargetIp;
1505 struct _CONTEXT *ContextRecord;
1506 PEXCEPTION_ROUTINE LanguageHandler;
1507 PVOID HandlerData;
1508 PUNWIND_HISTORY_TABLE HistoryTable;
1509 ULONG ScopeIndex;
1510 ULONG Fill0;
1511 } DISPATCHER_CONTEXT, *PDISPATCHER_CONTEXT;
1512
1513 typedef struct _SCOPE_TABLE_AMD64
1514 {
1515 DWORD Count;
1516 struct
1517 {
1518 DWORD BeginAddress;
1519 DWORD EndAddress;
1520 DWORD HandlerAddress;
1521 DWORD JumpTarget;
1522 } ScopeRecord[1];
1523 } SCOPE_TABLE_AMD64, *PSCOPE_TABLE_AMD64;
1524 typedef SCOPE_TABLE_AMD64 SCOPE_TABLE, *PSCOPE_TABLE;
1525
1526 #define OUT_OF_PROCESS_FUNCTION_TABLE_CALLBACK_EXPORT_NAME "OutOfProcessFunctionTableCallback"
1527
1528 NTSYSAPI
1529 VOID
1530 __cdecl
1531 RtlRestoreContext(struct _CONTEXT *ContextRecord,
1532 struct _EXCEPTION_RECORD *ExceptionRecord);
1533
1534 NTSYSAPI
1535 BOOLEAN
1536 __cdecl
1537 RtlAddFunctionTable(PRUNTIME_FUNCTION FunctionTable,
1538 DWORD EntryCount,
1539 DWORD64 BaseAddress);
1540
1541 NTSYSAPI
1542 BOOLEAN
1543 __cdecl
1544 RtlInstallFunctionTableCallback(DWORD64 TableIdentifier,
1545 DWORD64 BaseAddress,
1546 DWORD Length,
1547 PGET_RUNTIME_FUNCTION_CALLBACK Callback,
1548 PVOID Context,
1549 PCWSTR OutOfProcessCallbackDll);
1550
1551 NTSYSAPI
1552 BOOLEAN
1553 __cdecl
1554 RtlDeleteFunctionTable(PRUNTIME_FUNCTION FunctionTable);
1555
1556 NTSYSAPI
1557 PRUNTIME_FUNCTION
1558 NTAPI
1559 RtlLookupFunctionEntry(
1560 _In_ DWORD64 ControlPc,
1561 _Out_ PDWORD64 ImageBase,
1562 _Inout_opt_ PUNWIND_HISTORY_TABLE HistoryTable);
1563
1564 NTSYSAPI
1565 PEXCEPTION_ROUTINE
1566 NTAPI
1567 RtlVirtualUnwind(
1568 _In_ DWORD HandlerType,
1569 _In_ DWORD64 ImageBase,
1570 _In_ DWORD64 ControlPc,
1571 _In_ PRUNTIME_FUNCTION FunctionEntry,
1572 _Inout_ struct _CONTEXT *ContextRecord,
1573 _Out_ PVOID *HandlerData,
1574 _Out_ PDWORD64 EstablisherFrame,
1575 _Inout_opt_ PKNONVOLATILE_CONTEXT_POINTERS ContextPointers);
1576
1577 NTSYSAPI
1578 VOID
1579 NTAPI
1580 RtlUnwindEx(
1581 _In_opt_ PVOID TargetFrame,
1582 _In_opt_ PVOID TargetIp,
1583 _In_opt_ struct _EXCEPTION_RECORD *ExceptionRecord,
1584 _In_ PVOID ReturnValue,
1585 _In_ struct _CONTEXT *ContextRecord,
1586 _In_opt_ PUNWIND_HISTORY_TABLE HistoryTable);
1587
1588 #elif defined(_PPC_)
1589 #define CONTEXT_CONTROL 1L
1590 #define CONTEXT_FLOATING_POINT 2L
1591 #define CONTEXT_INTEGER 4L
1592 #define CONTEXT_DEBUG_REGISTERS 8L
1593 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_FLOATING_POINT|CONTEXT_INTEGER)
1594 typedef struct _FLOATING_SAVE_AREA
1595 {
1596 double Fpr0;
1597 double Fpr1;
1598 double Fpr2;
1599 double Fpr3;
1600 double Fpr4;
1601 double Fpr5;
1602 double Fpr6;
1603 double Fpr7;
1604 double Fpr8;
1605 double Fpr9;
1606 double Fpr10;
1607 double Fpr11;
1608 double Fpr12;
1609 double Fpr13;
1610 double Fpr14;
1611 double Fpr15;
1612 double Fpr16;
1613 double Fpr17;
1614 double Fpr18;
1615 double Fpr19;
1616 double Fpr20;
1617 double Fpr21;
1618 double Fpr22;
1619 double Fpr23;
1620 double Fpr24;
1621 double Fpr25;
1622 double Fpr26;
1623 double Fpr27;
1624 double Fpr28;
1625 double Fpr29;
1626 double Fpr30;
1627 double Fpr31;
1628 double Fpscr;
1629 } FLOATING_SAVE_AREA;
1630
1631 typedef struct _CONTEXT {
1632 FLOATING_SAVE_AREA FloatSave;
1633 DWORD Gpr0;
1634 DWORD Gpr1;
1635 DWORD Gpr2;
1636 DWORD Gpr3;
1637 DWORD Gpr4;
1638 DWORD Gpr5;
1639 DWORD Gpr6;
1640 DWORD Gpr7;
1641 DWORD Gpr8;
1642 DWORD Gpr9;
1643 DWORD Gpr10;
1644 DWORD Gpr11;
1645 DWORD Gpr12;
1646 DWORD Gpr13;
1647 DWORD Gpr14;
1648 DWORD Gpr15;
1649 DWORD Gpr16;
1650 DWORD Gpr17;
1651 DWORD Gpr18;
1652 DWORD Gpr19;
1653 DWORD Gpr20;
1654 DWORD Gpr21;
1655 DWORD Gpr22;
1656 DWORD Gpr23;
1657 DWORD Gpr24;
1658 DWORD Gpr25;
1659 DWORD Gpr26;
1660 DWORD Gpr27;
1661 DWORD Gpr28;
1662 DWORD Gpr29;
1663 DWORD Gpr30;
1664 DWORD Gpr31;
1665 DWORD Cr;
1666 DWORD Xer;
1667 DWORD Msr;
1668 DWORD Iar;
1669 DWORD Lr;
1670 DWORD Ctr;
1671 DWORD ContextFlags;
1672 DWORD Fill[3];
1673 DWORD Dr0;
1674 DWORD Dr1;
1675 DWORD Dr2;
1676 DWORD Dr3;
1677 DWORD Dr4;
1678 DWORD Dr5;
1679 DWORD Dr6;
1680 DWORD Dr7;
1681 } CONTEXT;
1682 #elif defined(_ALPHA_)
1683 #define CONTEXT_ALPHA 0x20000
1684 #define CONTEXT_CONTROL (CONTEXT_ALPHA|1L)
1685 #define CONTEXT_FLOATING_POINT (CONTEXT_ALPHA|2L)
1686 #define CONTEXT_INTEGER (CONTEXT_ALPHA|4L)
1687 #define CONTEXT_FULL (CONTEXT_CONTROL|CONTEXT_FLOATING_POINT|CONTEXT_INTEGER)
1688 typedef struct _CONTEXT {
1689 ULONGLONG FltF0;
1690 ULONGLONG FltF1;
1691 ULONGLONG FltF2;
1692 ULONGLONG FltF3;
1693 ULONGLONG FltF4;
1694 ULONGLONG FltF5;
1695 ULONGLONG FltF6;
1696 ULONGLONG FltF7;
1697 ULONGLONG FltF8;
1698 ULONGLONG FltF9;
1699 ULONGLONG FltF10;
1700 ULONGLONG FltF11;
1701 ULONGLONG FltF12;
1702 ULONGLONG FltF13;
1703 ULONGLONG FltF14;
1704 ULONGLONG FltF15;
1705 ULONGLONG FltF16;
1706 ULONGLONG FltF17;
1707 ULONGLONG FltF18;
1708 ULONGLONG FltF19;
1709 ULONGLONG FltF20;
1710 ULONGLONG FltF21;
1711 ULONGLONG FltF22;
1712 ULONGLONG FltF23;
1713 ULONGLONG FltF24;
1714 ULONGLONG FltF25;
1715 ULONGLONG FltF26;
1716 ULONGLONG FltF27;
1717 ULONGLONG FltF28;
1718 ULONGLONG FltF29;
1719 ULONGLONG FltF30;
1720 ULONGLONG FltF31;
1721 ULONGLONG IntV0;
1722 ULONGLONG IntT0;
1723 ULONGLONG IntT1;
1724 ULONGLONG IntT2;
1725 ULONGLONG IntT3;
1726 ULONGLONG IntT4;
1727 ULONGLONG IntT5;
1728 ULONGLONG IntT6;
1729 ULONGLONG IntT7;
1730 ULONGLONG IntS0;
1731 ULONGLONG IntS1;
1732 ULONGLONG IntS2;
1733 ULONGLONG IntS3;
1734 ULONGLONG IntS4;
1735 ULONGLONG IntS5;
1736 ULONGLONG IntFp;
1737 ULONGLONG IntA0;
1738 ULONGLONG IntA1;
1739 ULONGLONG IntA2;
1740 ULONGLONG IntA3;
1741 ULONGLONG IntA4;
1742 ULONGLONG IntA5;
1743 ULONGLONG IntT8;
1744 ULONGLONG IntT9;
1745 ULONGLONG IntT10;
1746 ULONGLONG IntT11;
1747 ULONGLONG IntRa;
1748 ULONGLONG IntT12;
1749 ULONGLONG IntAt;
1750 ULONGLONG IntGp;
1751 ULONGLONG IntSp;
1752 ULONGLONG IntZero;
1753 ULONGLONG Fpcr;
1754 ULONGLONG SoftFpcr;
1755 ULONGLONG Fir;
1756 DWORD Psr;
1757 DWORD ContextFlags;
1758 DWORD Fill[4];
1759 } CONTEXT;
1760 #elif defined(_SH_)
1761
1762 /* These are the debug or break registers on the SH3 */
1763 typedef struct _DEBUG_REGISTERS {
1764 DWORD BarA;
1765 UCHAR BasrA;
1766 UCHAR BamrA;
1767 USHORT BbrA;
1768 DWORD BarB;
1769 UCHAR BasrB;
1770 UCHAR BamrB;
1771 USHORT BbrB;
1772 DWORD BdrB;
1773 DWORD BdmrB;
1774 USHORT Brcr;
1775 USHORT Align;
1776 } DEBUG_REGISTERS, *PDEBUG_REGISTERS;
1777
1778 /* The following flags control the contents of the CONTEXT structure. */
1779
1780 #define CONTEXT_SH3 0x00000040
1781 #define CONTEXT_SH4 0x000000c0 /* CONTEXT_SH3 | 0x80 - must contain the SH3 bits */
1782
1783 #ifdef SH3
1784 #define CONTEXT_CONTROL (CONTEXT_SH3 | 0x00000001L)
1785 #define CONTEXT_INTEGER (CONTEXT_SH3 | 0x00000002L)
1786 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_SH3 | 0x00000008L)
1787 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_DEBUG_REGISTERS)
1788 #else /* SH4 */
1789 #define CONTEXT_CONTROL (CONTEXT_SH4 | 0x00000001L)
1790 #define CONTEXT_INTEGER (CONTEXT_SH4 | 0x00000002L)
1791 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_SH4 | 0x00000008L)
1792 #define CONTEXT_FLOATING_POINT (CONTEXT_SH4 | 0x00000004L)
1793 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_DEBUG_REGISTERS | CONTEXT_FLOATING_POINT)
1794 #endif
1795
1796 /* Context Frame */
1797
1798 /* This frame is used to store a limited processor context into the */
1799 /* Thread structure for CPUs which have no floating point support. */
1800
1801 typedef struct _CONTEXT {
1802 /* The flags values within this flag control the contents of */
1803 /* a CONTEXT record. */
1804
1805 /* If the context record is used as an input parameter, then */
1806 /* for each portion of the context record controlled by a flag */
1807 /* whose value is set, it is assumed that that portion of the */
1808 /* context record contains valid context. If the context record */
1809 /* is being used to modify a thread's context, then only that */
1810 /* portion of the threads context will be modified. */
1811
1812 /* If the context record is used as an IN OUT parameter to capture */
1813 /* the context of a thread, then only those portions of the thread's */
1814 /* context corresponding to set flags will be returned. */
1815
1816 /* The context record is never used as an OUT only parameter. */
1817
1818
1819 DWORD ContextFlags;
1820
1821 /* This section is specified/returned if the ContextFlags word contains */
1822 /* the flag CONTEXT_INTEGER. */
1823
1824 /* N.B. The registers RA and R15 are defined in this section, but are */
1825 /* considered part of the control context rather than part of the integer */
1826 /* context. */
1827
1828 DWORD PR;
1829 DWORD MACH;
1830 DWORD MACL;
1831 DWORD GBR;
1832 DWORD R0;
1833 DWORD R1;
1834 DWORD R2;
1835 DWORD R3;
1836 DWORD R4;
1837 DWORD R5;
1838 DWORD R6;
1839 DWORD R7;
1840 DWORD R8;
1841 DWORD R9;
1842 DWORD R10;
1843 DWORD R11;
1844 DWORD R12;
1845 DWORD R13;
1846 DWORD R14;
1847 DWORD R15;
1848
1849 /* This section is specified/returned if the ContextFlags word contains */
1850 /* the flag CONTEXT_CONTROL. */
1851
1852 /* N.B. The registers r15 and ra are defined in the integer section, */
1853 /* but are considered part of the control context rather than part of */
1854 /* the integer context. */
1855
1856 DWORD Fir;
1857 DWORD Psr;
1858
1859 #if !defined(SH3e) && !defined(SH4)
1860 DWORD OldStuff[2];
1861 DEBUG_REGISTERS DebugRegisters;
1862 #else
1863 DWORD Fpscr;
1864 DWORD Fpul;
1865 DWORD FRegs[16];
1866 #if defined(SH4)
1867 DWORD xFRegs[16];
1868 #endif
1869 #endif
1870 } CONTEXT;
1871
1872 #elif defined(_MIPS_)
1873
1874 /* The following flags control the contents of the CONTEXT structure. */
1875
1876 #define CONTEXT_R4000 0x00010000 /* r4000 context */
1877
1878 #define CONTEXT_CONTROL (CONTEXT_R4000 | 0x00000001L)
1879 #define CONTEXT_FLOATING_POINT (CONTEXT_R4000 | 0x00000002L)
1880 #define CONTEXT_INTEGER (CONTEXT_R4000 | 0x00000004L)
1881
1882 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1883
1884 /* Context Frame */
1885
1886 /* N.B. This frame must be exactly a multiple of 16 bytes in length. */
1887
1888 /* This frame has a several purposes: 1) it is used as an argument to */
1889 /* NtContinue, 2) it is used to constuct a call frame for APC delivery, */
1890 /* 3) it is used to construct a call frame for exception dispatching */
1891 /* in user mode, and 4) it is used in the user level thread creation */
1892 /* routines. */
1893
1894 /* The layout of the record conforms to a standard call frame. */
1895
1896
1897 typedef struct _CONTEXT {
1898
1899 /* This section is always present and is used as an argument build */
1900 /* area. */
1901
1902 DWORD Argument[4];
1903
1904 /* This section is specified/returned if the ContextFlags word contains */
1905 /* the flag CONTEXT_FLOATING_POINT. */
1906
1907 DWORD FltF0;
1908 DWORD FltF1;
1909 DWORD FltF2;
1910 DWORD FltF3;
1911 DWORD FltF4;
1912 DWORD FltF5;
1913 DWORD FltF6;
1914 DWORD FltF7;
1915 DWORD FltF8;
1916 DWORD FltF9;
1917 DWORD FltF10;
1918 DWORD FltF11;
1919 DWORD FltF12;
1920 DWORD FltF13;
1921 DWORD FltF14;
1922 DWORD FltF15;
1923 DWORD FltF16;
1924 DWORD FltF17;
1925 DWORD FltF18;
1926 DWORD FltF19;
1927 DWORD FltF20;
1928 DWORD FltF21;
1929 DWORD FltF22;
1930 DWORD FltF23;
1931 DWORD FltF24;
1932 DWORD FltF25;
1933 DWORD FltF26;
1934 DWORD FltF27;
1935 DWORD FltF28;
1936 DWORD FltF29;
1937 DWORD FltF30;
1938 DWORD FltF31;
1939
1940 /* This section is specified/returned if the ContextFlags word contains */
1941 /* the flag CONTEXT_INTEGER. */
1942
1943 /* N.B. The registers gp, sp, and ra are defined in this section, but are */
1944 /* considered part of the control context rather than part of the integer */
1945 /* context. */
1946
1947 /* N.B. Register zero is not stored in the frame. */
1948
1949 DWORD IntZero;
1950 DWORD IntAt;
1951 DWORD IntV0;
1952 DWORD IntV1;
1953 DWORD IntA0;
1954 DWORD IntA1;
1955 DWORD IntA2;
1956 DWORD IntA3;
1957 DWORD IntT0;
1958 DWORD IntT1;
1959 DWORD IntT2;
1960 DWORD IntT3;
1961 DWORD IntT4;
1962 DWORD IntT5;
1963 DWORD IntT6;
1964 DWORD IntT7;
1965 DWORD IntS0;
1966 DWORD IntS1;
1967 DWORD IntS2;
1968 DWORD IntS3;
1969 DWORD IntS4;
1970 DWORD IntS5;
1971 DWORD IntS6;
1972 DWORD IntS7;
1973 DWORD IntT8;
1974 DWORD IntT9;
1975 DWORD IntK0;
1976 DWORD IntK1;
1977 DWORD IntGp;
1978 DWORD IntSp;
1979 DWORD IntS8;
1980 DWORD IntRa;
1981 DWORD IntLo;
1982 DWORD IntHi;
1983
1984 /* This section is specified/returned if the ContextFlags word contains */
1985 /* the flag CONTEXT_FLOATING_POINT. */
1986
1987 DWORD Fsr;
1988
1989 /* This section is specified/returned if the ContextFlags word contains */
1990 /* the flag CONTEXT_CONTROL. */
1991
1992 /* N.B. The registers gp, sp, and ra are defined in the integer section, */
1993 /* but are considered part of the control context rather than part of */
1994 /* the integer context. */
1995
1996 DWORD Fir;
1997 DWORD Psr;
1998
1999 /* The flags values within this flag control the contents of */
2000 /* a CONTEXT record. */
2001
2002 /* If the context record is used as an input parameter, then */
2003 /* for each portion of the context record controlled by a flag */
2004 /* whose value is set, it is assumed that that portion of the */
2005 /* context record contains valid context. If the context record */
2006 /* is being used to modify a thread's context, then only that */
2007 /* portion of the threads context will be modified. */
2008
2009 /* If the context record is used as an IN OUT parameter to capture */
2010 /* the context of a thread, then only those portions of the thread's */
2011 /* context corresponding to set flags will be returned. */
2012
2013 /* The context record is never used as an OUT only parameter. */
2014
2015 DWORD ContextFlags;
2016
2017 DWORD Fill[2];
2018
2019 } CONTEXT;
2020 #elif defined(_ARM_)
2021
2022 #ifndef PAGE_SIZE
2023 #define PAGE_SIZE 0x1000 // FIXME: This should probably go elsewhere
2024 #endif
2025
2026 /* The following flags control the contents of the CONTEXT structure. */
2027
2028 #define CONTEXT_ARM 0x200000L
2029 #define CONTEXT_CONTROL (CONTEXT_ARM | 0x00000001L)
2030 #define CONTEXT_INTEGER (CONTEXT_ARM | 0x00000002L)
2031 #define CONTEXT_FLOATING_POINT (CONTEXT_ARM | 0x00000004L)
2032 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_ARM | 0x00000008L)
2033 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
2034
2035 #define EXCEPTION_READ_FAULT 0
2036 #define EXCEPTION_WRITE_FAULT 1
2037 #define EXCEPTION_EXECUTE_FAULT 8
2038
2039 typedef struct _NEON128
2040 {
2041 ULONGLONG Low;
2042 LONGLONG High;
2043 } NEON128, *PNEON128;
2044
2045 #define ARM_MAX_BREAKPOINTS 8
2046 #define ARM_MAX_WATCHPOINTS 1
2047
2048 typedef struct _CONTEXT
2049 {
2050 /* The flags values within this flag control the contents of
2051 a CONTEXT record.
2052
2053 If the context record is used as an input parameter, then
2054 for each portion of the context record controlled by a flag
2055 whose value is set, it is assumed that that portion of the
2056 context record contains valid context. If the context record
2057 is being used to modify a thread's context, then only that
2058 portion of the threads context will be modified.
2059
2060 If the context record is used as an IN OUT parameter to capture
2061 the context of a thread, then only those portions of the thread's
2062 context corresponding to set flags will be returned.
2063
2064 The context record is never used as an OUT only parameter. */
2065 DWORD ContextFlags;
2066
2067 /* This section is specified/returned if the ContextFlags word contains
2068 the flag CONTEXT_INTEGER. */
2069 DWORD R0;
2070 DWORD R1;
2071 DWORD R2;
2072 DWORD R3;
2073 DWORD R4;
2074 DWORD R5;
2075 DWORD R6;
2076 DWORD R7;
2077 DWORD R8;
2078 DWORD R9;
2079 DWORD R10;
2080 DWORD R11;
2081 DWORD R12;
2082
2083 DWORD Sp;
2084 DWORD Lr;
2085 DWORD Pc;
2086 DWORD Cpsr;
2087
2088 /* Floating Point/NEON Registers */
2089 DWORD Fpscr;
2090 DWORD Padding;
2091 union
2092 {
2093 NEON128 Q[16];
2094 ULONGLONG D[32];
2095 DWORD S[32];
2096 } DUMMYUNIONNAME;
2097
2098 /* Debug registers */
2099 DWORD Bvr[ARM_MAX_BREAKPOINTS];
2100 DWORD Bcr[ARM_MAX_BREAKPOINTS];
2101 DWORD Wvr[ARM_MAX_WATCHPOINTS];
2102 DWORD Wcr[ARM_MAX_WATCHPOINTS];
2103
2104 DWORD Padding2[2];
2105 } CONTEXT, *PCONTEXT;
2106
2107 typedef struct _IMAGE_ARM_RUNTIME_FUNCTION_ENTRY
2108 {
2109 DWORD BeginAddress;
2110 union
2111 {
2112 DWORD UnwindData;
2113 struct
2114 {
2115 DWORD Flag : 2;
2116 DWORD FunctionLength : 11;
2117 DWORD Ret : 2;
2118 DWORD H : 1;
2119 DWORD Reg : 3;
2120 DWORD R : 1;
2121 DWORD L : 1;
2122 DWORD C : 1;
2123 DWORD StackAdjust : 10;
2124 } DUMMYSTRUCTNAME;
2125 } DUMMYUNIONNAME;
2126 } IMAGE_ARM_RUNTIME_FUNCTION_ENTRY, *PIMAGE_ARM_RUNTIME_FUNCTION_ENTRY;
2127 typedef IMAGE_ARM_RUNTIME_FUNCTION_ENTRY RUNTIME_FUNCTION, *PRUNTIME_FUNCTION;
2128
2129 typedef struct _SCOPE_TABLE_ARM
2130 {
2131 DWORD Count;
2132 struct
2133 {
2134 DWORD BeginAddress;
2135 DWORD EndAddress;
2136 DWORD HandlerAddress;
2137 DWORD JumpTarget;
2138 } ScopeRecord[1];
2139 } SCOPE_TABLE_ARM, *PSCOPE_TABLE_ARM;
2140 typedef SCOPE_TABLE_ARM SCOPE_TABLE, *PSCOPE_TABLE;
2141
2142 typedef struct _DISPATCHER_CONTEXT
2143 {
2144 DWORD ControlPc;
2145 DWORD ImageBase;
2146 PRUNTIME_FUNCTION FunctionEntry;
2147 DWORD EstablisherFrame;
2148 DWORD TargetPc;
2149 PCONTEXT ContextRecord;
2150 PEXCEPTION_ROUTINE LanguageHandler;
2151 PVOID HandlerData;
2152 struct _UNWIND_HISTORY_TABLE *HistoryTable;
2153 DWORD ScopeIndex;
2154 BOOLEAN ControlPcIsUnwound;
2155 PBYTE NonVolatileRegisters;
2156 DWORD Reserved;
2157 } DISPATCHER_CONTEXT, *PDISPATCHER_CONTEXT;
2158
2159 #elif defined(_ARM64_)
2160
2161 #define CONTEXT_ARM64 0x00400000L
2162 #define CONTEXT_CONTROL (CONTEXT_ARM64 | 0x1L)
2163 #define CONTEXT_INTEGER (CONTEXT_ARM64 | 0x2L)
2164 #define CONTEXT_FLOATING_POINT (CONTEXT_ARM64 | 0x4L)
2165 #define CONTEXT_DEBUG_REGISTERS (CONTEXT_ARM64 | 0x8L)
2166 #define CONTEXT_X18 (CONTEXT_ARM64 | 0x10L)
2167 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
2168
2169
2170 #define EXCEPTION_READ_FAULT 0
2171 #define EXCEPTION_WRITE_FAULT 1
2172 #define EXCEPTION_EXECUTE_FAULT 8
2173
2174 typedef union NEON128 {
2175 struct {
2176 ULONGLONG Low;
2177 LONGLONG High;
2178 } DUMMYSTRUCTNAME;
2179 double D[2];
2180 float S[4];
2181 WORD H[8];
2182 BYTE B[16];
2183 } NEON128, *PNEON128;
2184
2185 #define ARM64_MAX_BREAKPOINTS 8
2186 #define ARM64_MAX_WATCHPOINTS 2
2187
2188 typedef struct _CONTEXT {
2189
2190 //
2191 // Control flags.
2192 //
2193
2194 DWORD ContextFlags;
2195
2196 //
2197 // Integer registers
2198 //
2199
2200 DWORD Cpsr;
2201 union {
2202 struct {
2203 DWORD64 X0;
2204 DWORD64 X1;
2205 DWORD64 X2;
2206 DWORD64 X3;
2207 DWORD64 X4;
2208 DWORD64 X5;
2209 DWORD64 X6;
2210 DWORD64 X7;
2211 DWORD64 X8;
2212 DWORD64 X9;
2213 DWORD64 X10;
2214 DWORD64 X11;
2215 DWORD64 X12;
2216 DWORD64 X13;
2217 DWORD64 X14;
2218 DWORD64 X15;
2219 DWORD64 X16;
2220 DWORD64 X17;
2221 DWORD64 X18;
2222 DWORD64 X19;
2223 DWORD64 X20;
2224 DWORD64 X21;
2225 DWORD64 X22;
2226 DWORD64 X23;
2227 DWORD64 X24;
2228 DWORD64 X25;
2229 DWORD64 X26;
2230 DWORD64 X27;
2231 DWORD64 X28;
2232 DWORD64 Fp;
2233 DWORD64 Lr;
2234 } DUMMYSTRUCTNAME;
2235 DWORD64 X[31];
2236 } DUMMYUNIONNAME;
2237
2238 DWORD64 Sp;
2239 DWORD64 Pc;
2240
2241 //
2242 // Floating Point/NEON Registers
2243 //
2244
2245 NEON128 V[32];
2246 DWORD Fpcr;
2247 DWORD Fpsr;
2248
2249 //
2250 // Debug registers
2251 //
2252
2253 DWORD Bcr[ARM64_MAX_BREAKPOINTS];
2254 DWORD64 Bvr[ARM64_MAX_BREAKPOINTS];
2255 DWORD Wcr[ARM64_MAX_WATCHPOINTS];
2256 DWORD64 Wvr[ARM64_MAX_WATCHPOINTS];
2257
2258 } _CONTEXT, *P_CONTEXT;
2259 typedef _CONTEXT CONTEXT, *PCONTEXT;
2260
2261 typedef struct _IMAGE_ARM64_RUNTIME_FUNCTION_ENTRY {
2262 DWORD BeginAddress;
2263 union {
2264 DWORD UnwindData;
2265 struct {
2266 DWORD Flag : 2;
2267 DWORD FunctionLength : 11;
2268 DWORD RegF : 3;
2269 DWORD RegI : 4;
2270 DWORD H : 1;
2271 DWORD CR : 2;
2272 DWORD FrameSize : 9;
2273 } DUMMYSTRUCTNAME;
2274 } DUMMYUNIONNAME;
2275 } IMAGE_ARM64_RUNTIME_FUNCTION_ENTRY, * PIMAGE_ARM64_RUNTIME_FUNCTION_ENTRY;
2276 typedef struct _IMAGE_ARM64_RUNTIME_FUNCTION_ENTRY RUNTIME_FUNCTION, *PRUNTIME_FUNCTION;
2277
2278 typedef struct _SCOPE_TABLE_ARM64 {
2279 DWORD Count;
2280 struct
2281 {
2282 DWORD BeginAddress;
2283 DWORD EndAddress;
2284 DWORD HandlerAddress;
2285 DWORD JumpTarget;
2286 } ScopeRecord[1];
2287 } SCOPE_TABLE_ARM64, *PSCOPE_TABLE_ARM64;
2288 typedef SCOPE_TABLE_ARM64 SCOPE_TABLE, *PSCOPE_TABLE;
2289
2290 typedef struct _DISPATCHER_CONTEXT {
2291 ULONG_PTR ControlPc;
2292 ULONG_PTR ImageBase;
2293 PRUNTIME_FUNCTION FunctionEntry;
2294 ULONG_PTR EstablisherFrame;
2295 ULONG_PTR TargetPc;
2296 PCONTEXT ContextRecord;
2297 PEXCEPTION_ROUTINE LanguageHandler;
2298 PVOID HandlerData;
2299 struct _UNWIND_HISTORY_TABLE *HistoryTable;
2300 DWORD ScopeIndex;
2301 BOOLEAN ControlPcIsUnwound;
2302 PBYTE NonVolatileRegisters;
2303 } DISPATCHER_CONTEXT, *PDISPATCHER_CONTEXT;
2304 #else
2305 #error "undefined processor type"
2306 #endif
2307 typedef CONTEXT *PCONTEXT;
2308
2309 /* The WoW64 context */
2310 #define WOW64_CONTEXT_i386 0x00010000
2311 #define WOW64_CONTEXT_i486 0x00010000
2312 #define WOW64_CONTEXT_CONTROL (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000001))
2313 #define WOW64_CONTEXT_INTEGER (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000002))
2314 #define WOW64_CONTEXT_SEGMENTS (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000004))
2315 #define WOW64_CONTEXT_FLOATING_POINT (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000008))
2316 #define WOW64_CONTEXT_DEBUG_REGISTERS (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000010))
2317 #define WOW64_CONTEXT_EXTENDED_REGISTERS (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000020))
2318 #define WOW64_CONTEXT_FULL (WOW64_CONTEXT_CONTROL | WOW64_CONTEXT_INTEGER | WOW64_CONTEXT_SEGMENTS)
2319 #define WOW64_CONTEXT_ALL (WOW64_CONTEXT_CONTROL | WOW64_CONTEXT_INTEGER | \
2320 WOW64_CONTEXT_SEGMENTS | WOW64_CONTEXT_FLOATING_POINT | \
2321 WOW64_CONTEXT_DEBUG_REGISTERS | WOW64_CONTEXT_EXTENDED_REGISTERS)
2322
2323 #define WOW64_CONTEXT_XSTATE (WOW64_CONTEXT_i386 | __MSABI_LONG(0x00000040))
2324
2325 #define WOW64_CONTEXT_EXCEPTION_ACTIVE 0x08000000
2326 #define WOW64_CONTEXT_SERVICE_ACTIVE 0x10000000
2327 #define WOW64_CONTEXT_EXCEPTION_REQUEST 0x40000000
2328 #define WOW64_CONTEXT_EXCEPTION_REPORTING 0x80000000
2329
2330 #define WOW64_SIZE_OF_80387_REGISTERS 80
2331 #define WOW64_MAXIMUM_SUPPORTED_EXTENSION 512
2332
2333 typedef struct _WOW64_FLOATING_SAVE_AREA
2334 {
2335 DWORD ControlWord;
2336 DWORD StatusWord;
2337 DWORD TagWord;
2338 DWORD ErrorOffset;
2339 DWORD ErrorSelector;
2340 DWORD DataOffset;
2341 DWORD DataSelector;
2342 BYTE RegisterArea[WOW64_SIZE_OF_80387_REGISTERS];
2343 DWORD Cr0NpxState;
2344 } WOW64_FLOATING_SAVE_AREA, *PWOW64_FLOATING_SAVE_AREA;
2345
2346 #include "pshpack4.h"
2347 typedef struct _WOW64_CONTEXT
2348 {
2349 DWORD ContextFlags;
2350 DWORD Dr0;
2351 DWORD Dr1;
2352 DWORD Dr2;
2353 DWORD Dr3;
2354 DWORD Dr6;
2355 DWORD Dr7;
2356 WOW64_FLOATING_SAVE_AREA FloatSave;
2357 DWORD SegGs;
2358 DWORD SegFs;
2359 DWORD SegEs;
2360 DWORD SegDs;
2361 DWORD Edi;
2362 DWORD Esi;
2363 DWORD Ebx;
2364 DWORD Edx;
2365 DWORD Ecx;
2366 DWORD Eax;
2367 DWORD Ebp;
2368 DWORD Eip;
2369 DWORD SegCs;
2370 DWORD EFlags;
2371 DWORD Esp;
2372 DWORD SegSs;
2373 BYTE ExtendedRegisters[WOW64_MAXIMUM_SUPPORTED_EXTENSION];
2374 } WOW64_CONTEXT, *PWOW64_CONTEXT;
2375 #include "poppack.h"
2376
2377
2378 #define EXCEPTION_MAXIMUM_PARAMETERS 15
2379 #define EXCEPTION_NONCONTINUABLE 0x01
2380 #define EXCEPTION_UNWINDING 0x02
2381 #define EXCEPTION_EXIT_UNWIND 0x04
2382 #define EXCEPTION_STACK_INVALID 0x08
2383 #define EXCEPTION_NESTED_CALL 0x10
2384 #define EXCEPTION_TARGET_UNWIND 0x20
2385 #define EXCEPTION_COLLIDED_UNWIND 0x40
2386 #define EXCEPTION_UNWIND (EXCEPTION_UNWINDING | EXCEPTION_EXIT_UNWIND | \
2387 EXCEPTION_TARGET_UNWIND | EXCEPTION_COLLIDED_UNWIND)
2388
2389 #define IS_UNWINDING(Flag) ((Flag & EXCEPTION_UNWIND) != 0)
2390 #define IS_DISPATCHING(Flag) ((Flag & EXCEPTION_UNWIND) == 0)
2391 #define IS_TARGET_UNWIND(Flag) (Flag & EXCEPTION_TARGET_UNWIND)
2392
2393 typedef struct _EXCEPTION_RECORD {
2394 DWORD ExceptionCode;
2395 DWORD ExceptionFlags;
2396 struct _EXCEPTION_RECORD *ExceptionRecord;
2397 PVOID ExceptionAddress;
2398 DWORD NumberParameters;
2399 ULONG_PTR ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
2400 } EXCEPTION_RECORD, *PEXCEPTION_RECORD;
2401
2402 typedef struct _EXCEPTION_RECORD32 {
2403 DWORD ExceptionCode;
2404 DWORD ExceptionFlags;
2405 DWORD ExceptionRecord;
2406 DWORD ExceptionAddress;
2407 DWORD NumberParameters;
2408 DWORD ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
2409 } EXCEPTION_RECORD32,*PEXCEPTION_RECORD32;
2410
2411 typedef struct _EXCEPTION_RECORD64 {
2412 DWORD ExceptionCode;
2413 DWORD ExceptionFlags;
2414 DWORD64 ExceptionRecord;
2415 DWORD64 ExceptionAddress;
2416 DWORD NumberParameters;
2417 DWORD __unusedAlignment;
2418 DWORD64 ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
2419 } EXCEPTION_RECORD64,*PEXCEPTION_RECORD64;
2420
2421 typedef struct _EXCEPTION_POINTERS {
2422 PEXCEPTION_RECORD ExceptionRecord;
2423 PCONTEXT ContextRecord;
2424 } EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
2425
2426 typedef struct _SECURITY_ATTRIBUTES {
2427 DWORD nLength;
2428 LPVOID lpSecurityDescriptor;
2429 BOOL bInheritHandle;
2430 } SECURITY_ATTRIBUTES, *PSECURITY_ATTRIBUTES, *LPSECURITY_ATTRIBUTES;
2431
2432 #define SECURITY_MIN_SID_SIZE (sizeof(SID))
2433
2434 $include(setypes.h)
2435
2436 typedef struct _SYSTEM_AUDIT_OBJECT_ACE {
2437 ACE_HEADER Header;
2438 ACCESS_MASK Mask;
2439 DWORD Flags;
2440 GUID ObjectType;
2441 GUID InheritedObjectType;
2442 DWORD SidStart;
2443 } SYSTEM_AUDIT_OBJECT_ACE,*PSYSTEM_AUDIT_OBJECT_ACE;
2444
2445 typedef struct _SYSTEM_ALARM_OBJECT_ACE {
2446 ACE_HEADER Header;
2447 ACCESS_MASK Mask;
2448 DWORD Flags;
2449 GUID ObjectType;
2450 GUID InheritedObjectType;
2451 DWORD SidStart;
2452 } SYSTEM_ALARM_OBJECT_ACE,*PSYSTEM_ALARM_OBJECT_ACE;
2453
2454 typedef struct _ACCESS_ALLOWED_CALLBACK_ACE {
2455 ACE_HEADER Header;
2456 ACCESS_MASK Mask;
2457 DWORD SidStart;
2458 } ACCESS_ALLOWED_CALLBACK_ACE, *PACCESS_ALLOWED_CALLBACK_ACE;
2459
2460 typedef struct _ACCESS_DENIED_CALLBACK_ACE {
2461 ACE_HEADER Header;
2462 ACCESS_MASK Mask;
2463 DWORD SidStart;
2464 } ACCESS_DENIED_CALLBACK_ACE, *PACCESS_DENIED_CALLBACK_ACE;
2465
2466 typedef struct _SYSTEM_AUDIT_CALLBACK_ACE {
2467 ACE_HEADER Header;
2468 ACCESS_MASK Mask;
2469 DWORD SidStart;
2470 } SYSTEM_AUDIT_CALLBACK_ACE, *PSYSTEM_AUDIT_CALLBACK_ACE;
2471
2472 typedef struct _SYSTEM_ALARM_CALLBACK_ACE {
2473 ACE_HEADER Header;
2474 ACCESS_MASK Mask;
2475 DWORD SidStart;
2476 } SYSTEM_ALARM_CALLBACK_ACE, *PSYSTEM_ALARM_CALLBACK_ACE;
2477
2478 typedef struct _ACCESS_ALLOWED_CALLBACK_OBJECT_ACE {
2479 ACE_HEADER Header;
2480 ACCESS_MASK Mask;
2481 DWORD Flags;
2482 GUID ObjectType;
2483 GUID InheritedObjectType;
2484 DWORD SidStart;
2485 } ACCESS_ALLOWED_CALLBACK_OBJECT_ACE, *PACCESS_ALLOWED_CALLBACK_OBJECT_ACE;
2486
2487 typedef struct _ACCESS_DENIED_CALLBACK_OBJECT_ACE {
2488 ACE_HEADER Header;
2489 ACCESS_MASK Mask;
2490 DWORD Flags;
2491 GUID ObjectType;
2492 GUID InheritedObjectType;
2493 DWORD SidStart;
2494 } ACCESS_DENIED_CALLBACK_OBJECT_ACE, *PACCESS_DENIED_CALLBACK_OBJECT_ACE;
2495
2496 typedef struct _SYSTEM_AUDIT_CALLBACK_OBJECT_ACE {
2497 ACE_HEADER Header;
2498 ACCESS_MASK Mask;
2499 DWORD Flags;
2500 GUID ObjectType;
2501 GUID InheritedObjectType;
2502 DWORD SidStart;
2503 } SYSTEM_AUDIT_CALLBACK_OBJECT_ACE, *PSYSTEM_AUDIT_CALLBACK_OBJECT_ACE;
2504
2505 typedef struct _SYSTEM_ALARM_CALLBACK_OBJECT_ACE {
2506 ACE_HEADER Header;
2507 ACCESS_MASK Mask;
2508 DWORD Flags;
2509 GUID ObjectType;
2510 GUID InheritedObjectType;
2511 DWORD SidStart;
2512 } SYSTEM_ALARM_CALLBACK_OBJECT_ACE, *PSYSTEM_ALARM_CALLBACK_OBJECT_ACE;
2513
2514 typedef enum _TOKEN_ELEVATION_TYPE {
2515 TokenElevationTypeDefault = 1,
2516 TokenElevationTypeFull,
2517 TokenElevationTypeLimited,
2518 } TOKEN_ELEVATION_TYPE, *PTOKEN_ELEVATION_TYPE;
2519
2520 typedef struct _QUOTA_LIMITS {
2521 SIZE_T PagedPoolLimit;
2522 SIZE_T NonPagedPoolLimit;
2523 SIZE_T MinimumWorkingSetSize;
2524 SIZE_T MaximumWorkingSetSize;
2525 SIZE_T PagefileLimit;
2526 LARGE_INTEGER TimeLimit;
2527 } QUOTA_LIMITS,*PQUOTA_LIMITS;
2528
2529 typedef union _RATE_QUOTA_LIMIT {
2530 DWORD RateData;
2531 struct {
2532 DWORD RatePercent : 7;
2533 DWORD Reserved0 : 25;
2534 } DUMMYSTRUCTNAME;
2535 } RATE_QUOTA_LIMIT, *PRATE_QUOTA_LIMIT;
2536
2537 typedef struct _QUOTA_LIMITS_EX {
2538 SIZE_T PagedPoolLimit;
2539 SIZE_T NonPagedPoolLimit;
2540 SIZE_T MinimumWorkingSetSize;
2541 SIZE_T MaximumWorkingSetSize;
2542 SIZE_T PagefileLimit;
2543 LARGE_INTEGER TimeLimit;
2544 SIZE_T Reserved1;
2545 SIZE_T Reserved2;
2546 SIZE_T Reserved3;
2547 SIZE_T Reserved4;
2548 DWORD Flags;
2549 RATE_QUOTA_LIMIT CpuRateLimit;
2550 } QUOTA_LIMITS_EX, *PQUOTA_LIMITS_EX;
2551
2552 typedef struct _IO_COUNTERS {
2553 ULONGLONG ReadOperationCount;
2554 ULONGLONG WriteOperationCount;
2555 ULONGLONG OtherOperationCount;
2556 ULONGLONG ReadTransferCount;
2557 ULONGLONG WriteTransferCount;
2558 ULONGLONG OtherTransferCount;
2559 } IO_COUNTERS, *PIO_COUNTERS;
2560
2561 typedef struct _FILE_NOTIFY_INFORMATION {
2562 DWORD NextEntryOffset;
2563 DWORD Action;
2564 DWORD FileNameLength;
2565 WCHAR FileName[1];
2566 } FILE_NOTIFY_INFORMATION,*PFILE_NOTIFY_INFORMATION;
2567
2568 typedef struct _TAPE_ERASE {
2569 DWORD Type;
2570 BOOLEAN Immediate;
2571 } TAPE_ERASE, *PTAPE_ERASE;
2572
2573 typedef struct _TAPE_GET_DRIVE_PARAMETERS {
2574 BOOLEAN ECC;
2575 BOOLEAN Compression;
2576 BOOLEAN DataPadding;
2577 BOOLEAN ReportSetmarks;
2578 DWORD DefaultBlockSize;
2579 DWORD MaximumBlockSize;
2580 DWORD MinimumBlockSize;
2581 DWORD MaximumPartitionCount;
2582 DWORD FeaturesLow;
2583 DWORD FeaturesHigh;
2584 DWORD EOTWarningZoneSize;
2585 } TAPE_GET_DRIVE_PARAMETERS, *PTAPE_GET_DRIVE_PARAMETERS;
2586
2587 typedef struct _TAPE_GET_MEDIA_PARAMETERS {
2588 LARGE_INTEGER Capacity;
2589 LARGE_INTEGER Remaining;
2590 DWORD BlockSize;
2591 DWORD PartitionCount;
2592 BOOLEAN WriteProtected;
2593 } TAPE_GET_MEDIA_PARAMETERS, *PTAPE_GET_MEDIA_PARAMETERS;
2594
2595 typedef struct _TAPE_GET_POSITION {
2596 DWORD Type;
2597 DWORD Partition;
2598 LARGE_INTEGER Offset;
2599 } TAPE_GET_POSITION, *PTAPE_GET_POSITION;
2600
2601 typedef struct _TAPE_PREPARE {
2602 DWORD Operation;
2603 BOOLEAN Immediate;
2604 } TAPE_PREPARE, *PTAPE_PREPARE;
2605
2606 typedef struct _TAPE_SET_DRIVE_PARAMETERS {
2607 BOOLEAN ECC;
2608 BOOLEAN Compression;
2609 BOOLEAN DataPadding;
2610 BOOLEAN ReportSetmarks;
2611 DWORD EOTWarningZoneSize;
2612 } TAPE_SET_DRIVE_PARAMETERS, *PTAPE_SET_DRIVE_PARAMETERS;
2613
2614 typedef struct _TAPE_SET_MEDIA_PARAMETERS {
2615 DWORD BlockSize;
2616 } TAPE_SET_MEDIA_PARAMETERS,*PTAPE_SET_MEDIA_PARAMETERS;
2617
2618 typedef struct _TAPE_SET_POSITION {
2619 DWORD Method;
2620 DWORD Partition;
2621 LARGE_INTEGER Offset;
2622 BOOLEAN Immediate;
2623 } TAPE_SET_POSITION, *PTAPE_SET_POSITION;
2624
2625 typedef struct _TAPE_WRITE_MARKS {
2626 DWORD Type;
2627 DWORD Count;
2628 BOOLEAN Immediate;
2629 } TAPE_WRITE_MARKS, *PTAPE_WRITE_MARKS;
2630
2631 typedef struct _TAPE_CREATE_PARTITION {
2632 DWORD Method;
2633 DWORD Count;
2634 DWORD Size;
2635 } TAPE_CREATE_PARTITION, *PTAPE_CREATE_PARTITION;
2636
2637 typedef struct _MEMORY_BASIC_INFORMATION {
2638 PVOID BaseAddress;
2639 PVOID AllocationBase;
2640 DWORD AllocationProtect;
2641 SIZE_T RegionSize;
2642 DWORD State;
2643 DWORD Protect;
2644 DWORD Type;
2645 } MEMORY_BASIC_INFORMATION, *PMEMORY_BASIC_INFORMATION;
2646
2647 typedef struct _MESSAGE_RESOURCE_ENTRY {
2648 WORD Length;
2649 WORD Flags;
2650 BYTE Text[1];
2651 } MESSAGE_RESOURCE_ENTRY, *PMESSAGE_RESOURCE_ENTRY;
2652
2653 typedef struct _MESSAGE_RESOURCE_BLOCK {
2654 DWORD LowId;
2655 DWORD HighId;
2656 DWORD OffsetToEntries;
2657 } MESSAGE_RESOURCE_BLOCK, *PMESSAGE_RESOURCE_BLOCK;
2658
2659 typedef struct _MESSAGE_RESOURCE_DATA {
2660 DWORD NumberOfBlocks;
2661 MESSAGE_RESOURCE_BLOCK Blocks[1];
2662 } MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA;
2663
2664 //
2665 // Slist Header
2666 //
2667 #ifndef _SLIST_HEADER_
2668 #define _SLIST_HEADER_
2669
2670 #if defined(_WIN64)
2671
2672 typedef struct DECLSPEC_ALIGN(16) _SLIST_ENTRY {
2673 struct _SLIST_ENTRY *Next;
2674 } SLIST_ENTRY, *PSLIST_ENTRY;
2675
2676 typedef struct _SLIST_ENTRY32 {
2677 DWORD Next;
2678 } SLIST_ENTRY32, *PSLIST_ENTRY32;
2679
2680 typedef union DECLSPEC_ALIGN(16) _SLIST_HEADER {
2681 _ANONYMOUS_STRUCT struct {
2682 ULONGLONG Alignment;
2683 ULONGLONG Region;
2684 } DUMMYSTRUCTNAME;
2685 struct {
2686 ULONGLONG Depth:16;
2687 ULONGLONG Sequence:9;
2688 ULONGLONG NextEntry:39;
2689 ULONGLONG HeaderType:1;
2690 ULONGLONG Init:1;
2691 ULONGLONG Reserved:59;
2692 ULONGLONG Region:3;
2693 } Header8;
2694 struct {
2695 ULONGLONG Depth:16;
2696 ULONGLONG Sequence:48;
2697 ULONGLONG HeaderType:1;
2698 ULONGLONG Init:1;
2699 ULONGLONG Reserved:2;
2700 ULONGLONG NextEntry:60;
2701 } Header16;
2702 struct {
2703 ULONGLONG Depth:16;
2704 ULONGLONG Sequence:48;
2705 ULONGLONG HeaderType:1;
2706 ULONGLONG Reserved:3;
2707 ULONGLONG NextEntry:60;
2708 } HeaderX64;
2709 } SLIST_HEADER, *PSLIST_HEADER;
2710
2711 typedef union _SLIST_HEADER32{
2712 ULONGLONG Alignment;
2713 _ANONYMOUS_STRUCT struct {
2714 SLIST_ENTRY32 Next;
2715 WORD Depth;
2716 WORD Sequence;
2717 } DUMMYSTRUCTNAME;
2718 } SLIST_HEADER32, *PSLIST_HEADER32;
2719
2720 #else
2721
2722 #define SLIST_ENTRY SINGLE_LIST_ENTRY
2723 #define _SLIST_ENTRY _SINGLE_LIST_ENTRY
2724 #define PSLIST_ENTRY PSINGLE_LIST_ENTRY
2725
2726 typedef SLIST_ENTRY SLIST_ENTRY32, *PSLIST_ENTRY32;
2727
2728 typedef union _SLIST_HEADER {
2729 ULONGLONG Alignment;
2730 _ANONYMOUS_STRUCT struct {
2731 SLIST_ENTRY Next;
2732 WORD Depth;
2733 WORD Sequence;
2734 } DUMMYSTRUCTNAME;
2735 } SLIST_HEADER, *PSLIST_HEADER;
2736
2737 typedef SLIST_HEADER SLIST_HEADER32, *PSLIST_HEADER32;
2738
2739 #endif /* defined(_WIN64) */
2740
2741 #endif /* _SLIST_HEADER_ */
2742
2743 NTSYSAPI
2744 VOID
2745 NTAPI
2746 RtlInitializeSListHead(
2747 _Out_ PSLIST_HEADER ListHead);
2748
2749 _Must_inspect_result_
2750 NTSYSAPI
2751 PSLIST_ENTRY
2752 NTAPI
2753 RtlFirstEntrySList(
2754 _In_ const SLIST_HEADER *ListHead);
2755
2756 NTSYSAPI
2757 PSLIST_ENTRY
2758 NTAPI
2759 RtlInterlockedPopEntrySList(
2760 _Inout_ PSLIST_HEADER ListHead);
2761
2762 NTSYSAPI
2763 PSLIST_ENTRY
2764 NTAPI
2765 RtlInterlockedPushEntrySList(
2766 _Inout_ PSLIST_HEADER ListHead,
2767 _Inout_ __drv_aliasesMem PSLIST_ENTRY ListEntry);
2768
2769 NTSYSAPI
2770 PSLIST_ENTRY
2771 NTAPI
2772 RtlInterlockedFlushSList(
2773 _Inout_ PSLIST_HEADER ListHead);
2774
2775 NTSYSAPI
2776 WORD
2777 NTAPI
2778 RtlQueryDepthSList(
2779 _In_ PSLIST_HEADER ListHead);
2780
2781
2782 #define RTL_CONDITION_VARIABLE_INIT {0}
2783 #define RTL_CONDITION_VARIABLE_LOCKMODE_SHARED 0x1
2784
2785 typedef struct _RTL_CONDITION_VARIABLE {
2786 PVOID Ptr;
2787 } RTL_CONDITION_VARIABLE, *PRTL_CONDITION_VARIABLE;
2788
2789 typedef struct _RTL_CRITICAL_SECTION_DEBUG {
2790 WORD Type;
2791 WORD CreatorBackTraceIndex;
2792 struct _RTL_CRITICAL_SECTION *CriticalSection;
2793 LIST_ENTRY ProcessLocksList;
2794 DWORD EntryCount;
2795 DWORD ContentionCount;
2796 DWORD Flags;
2797 WORD CreatorBackTraceIndexHigh;
2798 WORD SpareWORD;
2799 } RTL_CRITICAL_SECTION_DEBUG, *PRTL_CRITICAL_SECTION_DEBUG, RTL_RESOURCE_DEBUG, *PRTL_RESOURCE_DEBUG;
2800
2801 #include "pshpack8.h"
2802 typedef struct _RTL_CRITICAL_SECTION {
2803 PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
2804 LONG LockCount;
2805 LONG RecursionCount;
2806 HANDLE OwningThread;
2807 HANDLE LockSemaphore;
2808 ULONG_PTR SpinCount;
2809 } RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;
2810 #include "poppack.h"
2811
2812 NTSYSAPI
2813 WORD
2814 NTAPI
2815 RtlCaptureStackBackTrace(
2816 IN DWORD FramesToSkip,
2817 IN DWORD FramesToCapture,
2818 OUT PVOID *BackTrace,
2819 OUT PDWORD BackTraceHash OPTIONAL
2820 );
2821
2822 NTSYSAPI
2823 VOID
2824 NTAPI
2825 RtlCaptureContext(
2826 _Out_ PCONTEXT ContextRecord
2827 );
2828
2829 NTSYSAPI
2830 PVOID
2831 NTAPI
2832 RtlPcToFileHeader(
2833 _In_ PVOID PcValue,
2834 _Out_ PVOID* BaseOfImage);
2835
2836 NTSYSAPI
2837 VOID
2838 NTAPI
2839 RtlUnwind(
2840 _In_opt_ PVOID TargetFrame,
2841 _In_opt_ PVOID TargetIp,
2842 _In_opt_ PEXCEPTION_RECORD ExceptionRecord,
2843 _In_ PVOID ReturnValue);
2844
2845 #define RTL_SRWLOCK_INIT {0}
2846
2847 typedef struct _RTL_SRWLOCK {
2848 PVOID Ptr;
2849 } RTL_SRWLOCK, *PRTL_SRWLOCK;
2850
2851 typedef LONG
2852 (NTAPI *PVECTORED_EXCEPTION_HANDLER)(
2853 struct _EXCEPTION_POINTERS *ExceptionInfo
2854 );
2855
2856
2857 #define EVENTLOG_SEQUENTIAL_READ 1
2858 #define EVENTLOG_SEEK_READ 2
2859 #define EVENTLOG_FORWARDS_READ 4
2860 #define EVENTLOG_BACKWARDS_READ 8
2861
2862 #define EVENTLOG_SUCCESS 0
2863 #define EVENTLOG_ERROR_TYPE 1
2864 #define EVENTLOG_WARNING_TYPE 2
2865 #define EVENTLOG_INFORMATION_TYPE 4
2866 #define EVENTLOG_AUDIT_SUCCESS 8
2867 #define EVENTLOG_AUDIT_FAILURE 16
2868
2869 typedef struct _EVENTLOGRECORD {
2870 DWORD Length; /* Length of full record, including the data portion */
2871 DWORD Reserved;
2872 DWORD RecordNumber;
2873 DWORD TimeGenerated;
2874 DWORD TimeWritten;
2875 DWORD EventID;
2876 WORD EventType;
2877 WORD NumStrings; /* Number of strings in the 'Strings' array */
2878 WORD EventCategory;
2879 WORD ReservedFlags;
2880 DWORD ClosingRecordNumber;
2881 DWORD StringOffset;
2882 DWORD UserSidLength;
2883 DWORD UserSidOffset;
2884 DWORD DataLength; /* Length of the data portion */
2885 DWORD DataOffset; /* Offset from beginning of record */
2886 /*
2887 * Length-varying data:
2888 *
2889 * WCHAR SourceName[];
2890 * WCHAR ComputerName[];
2891 * SID UserSid; // Must be aligned on a DWORD boundary
2892 * WCHAR Strings[];
2893 * BYTE Data[];
2894 * CHAR Pad[]; // Padding for DWORD boundary
2895 * DWORD Length; // Same as the first 'Length' member at the beginning
2896 */
2897 } EVENTLOGRECORD, *PEVENTLOGRECORD;
2898
2899
2900 typedef struct _OSVERSIONINFOA {
2901 DWORD dwOSVersionInfoSize;
2902 DWORD dwMajorVersion;
2903 DWORD dwMinorVersion;
2904 DWORD dwBuildNumber;
2905 DWORD dwPlatformId;
2906 CHAR szCSDVersion[128];
2907 } OSVERSIONINFOA, *POSVERSIONINFOA, *LPOSVERSIONINFOA;
2908
2909 typedef struct _OSVERSIONINFOW {
2910 DWORD dwOSVersionInfoSize;
2911 DWORD dwMajorVersion;
2912 DWORD dwMinorVersion;
2913 DWORD dwBuildNumber;
2914 DWORD dwPlatformId;
2915 WCHAR szCSDVersion[128];
2916 } OSVERSIONINFOW, *POSVERSIONINFOW, *LPOSVERSIONINFOW, RTL_OSVERSIONINFOW, *PRTL_OSVERSIONINFOW;
2917
2918 typedef struct _OSVERSIONINFOEXA {
2919 DWORD dwOSVersionInfoSize;
2920 DWORD dwMajorVersion;
2921 DWORD dwMinorVersion;
2922 DWORD dwBuildNumber;
2923 DWORD dwPlatformId;
2924 CHAR szCSDVersion[128];
2925 WORD wServicePackMajor;
2926 WORD wServicePackMinor;
2927 WORD wSuiteMask;
2928 BYTE wProductType;
2929 BYTE wReserved;
2930 } OSVERSIONINFOEXA, *POSVERSIONINFOEXA, *LPOSVERSIONINFOEXA;
2931
2932 typedef struct _OSVERSIONINFOEXW {
2933 DWORD dwOSVersionInfoSize;
2934 DWORD dwMajorVersion;
2935 DWORD dwMinorVersion;
2936 DWORD dwBuildNumber;
2937 DWORD dwPlatformId;
2938 WCHAR szCSDVersion[128];
2939 WORD wServicePackMajor;
2940 WORD wServicePackMinor;
2941 WORD wSuiteMask;
2942 BYTE wProductType;
2943 BYTE wReserved;
2944 } OSVERSIONINFOEXW, *POSVERSIONINFOEXW, *LPOSVERSIONINFOEXW, RTL_OSVERSIONINFOEXW, *PRTL_OSVERSIONINFOEXW;
2945
2946 #include <pshpack2.h>
2947
2948 typedef struct _IMAGE_VXD_HEADER {
2949 WORD e32_magic;
2950 BYTE e32_border;
2951 BYTE e32_worder;
2952 DWORD e32_level;
2953 WORD e32_cpu;
2954 WORD e32_os;
2955 DWORD e32_ver;
2956 DWORD e32_mflags;
2957 DWORD e32_mpages;
2958 DWORD e32_startobj;
2959 DWORD e32_eip;
2960 DWORD e32_stackobj;
2961 DWORD e32_esp;
2962 DWORD e32_pagesize;
2963 DWORD e32_lastpagesize;
2964 DWORD e32_fixupsize;
2965 DWORD e32_fixupsum;
2966 DWORD e32_ldrsize;
2967 DWORD e32_ldrsum;
2968 DWORD e32_objtab;
2969 DWORD e32_objcnt;
2970 DWORD e32_objmap;
2971 DWORD e32_itermap;
2972 DWORD e32_rsrctab;
2973 DWORD e32_rsrccnt;
2974 DWORD e32_restab;
2975 DWORD e32_enttab;
2976 DWORD e32_dirtab;
2977 DWORD e32_dircnt;
2978 DWORD e32_fpagetab;
2979 DWORD e32_frectab;
2980 DWORD e32_impmod;
2981 DWORD e32_impmodcnt;
2982 DWORD e32_impproc;
2983 DWORD e32_pagesum;
2984 DWORD e32_datapage;
2985 DWORD e32_preload;
2986 DWORD e32_nrestab;
2987 DWORD e32_cbnrestab;
2988 DWORD e32_nressum;
2989 DWORD e32_autodata;
2990 DWORD e32_debuginfo;
2991 DWORD e32_debuglen;
2992 DWORD e32_instpreload;
2993 DWORD e32_instdemand;
2994 DWORD e32_heapsize;
2995 BYTE e32_res3[12];
2996 DWORD e32_winresoff;
2997 DWORD e32_winreslen;
2998 WORD e32_devid;
2999 WORD e32_ddkver;
3000 } IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
3001
3002 typedef struct _IMAGE_DOS_HEADER {
3003 WORD e_magic;
3004 WORD e_cblp;
3005 WORD e_cp;
3006 WORD e_crlc;
3007 WORD e_cparhdr;
3008 WORD e_minalloc;
3009 WORD e_maxalloc;
3010 WORD e_ss;
3011 WORD e_sp;
3012 WORD e_csum;
3013 WORD e_ip;
3014 WORD e_cs;
3015 WORD e_lfarlc;
3016 WORD e_ovno;
3017 WORD e_res[4];
3018 WORD e_oemid;
3019 WORD e_oeminfo;
3020 WORD e_res2[10];
3021 LONG e_lfanew;
3022 } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
3023
3024 typedef struct _IMAGE_OS2_HEADER {
3025 WORD ne_magic;
3026 CHAR ne_ver;
3027 CHAR ne_rev;
3028 WORD ne_enttab;
3029 WORD ne_cbenttab;
3030 LONG ne_crc;
3031 WORD ne_flags;
3032 WORD ne_autodata;
3033 WORD ne_heap;
3034 WORD ne_stack;
3035 LONG ne_csip;
3036 LONG ne_sssp;
3037 WORD ne_cseg;
3038 WORD ne_cmod;
3039 WORD ne_cbnrestab;
3040 WORD ne_segtab;
3041 WORD ne_rsrctab;
3042 WORD ne_restab;
3043 WORD ne_modtab;
3044 WORD ne_imptab;
3045 LONG ne_nrestab;
3046 WORD ne_cmovent;
3047 WORD ne_align;
3048 WORD ne_cres;
3049 BYTE ne_exetyp;
3050 BYTE ne_flagsothers;
3051 WORD ne_pretthunks;
3052 WORD ne_psegrefbytes;
3053 WORD ne_swaparea;
3054 WORD ne_expver;
3055 } IMAGE_OS2_HEADER, *PIMAGE_OS2_HEADER;
3056
3057 #include <poppack.h>
3058
3059 typedef struct _IMAGE_FILE_HEADER {
3060 WORD Machine;
3061 WORD NumberOfSections;
3062 DWORD TimeDateStamp;
3063 DWORD PointerToSymbolTable;
3064 DWORD NumberOfSymbols;
3065 WORD SizeOfOptionalHeader;
3066 WORD Characteristics;
3067 } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
3068
3069 typedef struct _IMAGE_DATA_DIRECTORY {
3070 DWORD VirtualAddress;
3071 DWORD Size;
3072 } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
3073
3074 typedef struct _IMAGE_OPTIONAL_HEADER32 {
3075 WORD Magic;
3076 BYTE MajorLinkerVersion;
3077 BYTE MinorLinkerVersion;
3078 DWORD SizeOfCode;
3079 DWORD SizeOfInitializedData;
3080 DWORD SizeOfUninitializedData;
3081 DWORD AddressOfEntryPoint;
3082 DWORD BaseOfCode;
3083 DWORD BaseOfData;
3084 DWORD ImageBase;
3085 DWORD SectionAlignment;
3086 DWORD FileAlignment;
3087 WORD MajorOperatingSystemVersion;
3088 WORD MinorOperatingSystemVersion;
3089 WORD MajorImageVersion;
3090 WORD MinorImageVersion;
3091 WORD MajorSubsystemVersion;
3092 WORD MinorSubsystemVersion;
3093 DWORD Win32VersionValue;
3094 DWORD SizeOfImage;
3095 DWORD SizeOfHeaders;
3096 DWORD CheckSum;
3097 WORD Subsystem;
3098 WORD DllCharacteristics;
3099 DWORD SizeOfStackReserve;
3100 DWORD SizeOfStackCommit;
3101 DWORD SizeOfHeapReserve;
3102 DWORD SizeOfHeapCommit;
3103 DWORD LoaderFlags;
3104 DWORD NumberOfRvaAndSizes;
3105 IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
3106 } IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
3107
3108 typedef struct _IMAGE_OPTIONAL_HEADER64 {
3109 WORD Magic;
3110 BYTE MajorLinkerVersion;
3111 BYTE MinorLinkerVersion;
3112 DWORD SizeOfCode;
3113 DWORD SizeOfInitializedData;
3114 DWORD SizeOfUninitializedData;
3115 DWORD AddressOfEntryPoint;
3116 DWORD BaseOfCode;
3117 ULONGLONG ImageBase;
3118 DWORD SectionAlignment;
3119 DWORD FileAlignment;
3120 WORD MajorOperatingSystemVersion;
3121 WORD MinorOperatingSystemVersion;
3122 WORD MajorImageVersion;
3123 WORD MinorImageVersion;
3124 WORD MajorSubsystemVersion;
3125 WORD MinorSubsystemVersion;
3126 DWORD Win32VersionValue;
3127 DWORD SizeOfImage;
3128 DWORD SizeOfHeaders;
3129 DWORD CheckSum;
3130 WORD Subsystem;
3131 WORD DllCharacteristics;
3132 ULONGLONG SizeOfStackReserve;
3133 ULONGLONG SizeOfStackCommit;
3134 ULONGLONG SizeOfHeapReserve;
3135 ULONGLONG SizeOfHeapCommit;
3136 DWORD LoaderFlags;
3137 DWORD NumberOfRvaAndSizes;
3138 IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
3139 } IMAGE_OPTIONAL_HEADER64, *PIMAGE_OPTIONAL_HEADER64;
3140
3141 typedef struct _IMAGE_ROM_OPTIONAL_HEADER {
3142 WORD Magic;
3143 BYTE MajorLinkerVersion;
3144 BYTE MinorLinkerVersion;
3145 DWORD SizeOfCode;
3146 DWORD SizeOfInitializedData;
3147 DWORD SizeOfUninitializedData;
3148 DWORD AddressOfEntryPoint;
3149 DWORD BaseOfCode;
3150 DWORD BaseOfData;
3151 DWORD BaseOfBss;
3152 DWORD GprMask;
3153 DWORD CprMask[4];
3154 DWORD GpValue;
3155 } IMAGE_ROM_OPTIONAL_HEADER, *PIMAGE_ROM_OPTIONAL_HEADER;
3156
3157 typedef struct _IMAGE_NT_HEADERS32 {
3158 DWORD Signature;
3159 IMAGE_FILE_HEADER FileHeader;
3160 IMAGE_OPTIONAL_HEADER32 OptionalHeader;
3161 } IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;
3162
3163 typedef struct _IMAGE_NT_HEADERS64 {
3164 DWORD Signature;
3165 IMAGE_FILE_HEADER FileHeader;
3166 IMAGE_OPTIONAL_HEADER64 OptionalHeader;
3167 } IMAGE_NT_HEADERS64, *PIMAGE_NT_HEADERS64;
3168
3169 #ifdef _WIN64
3170 typedef IMAGE_OPTIONAL_HEADER64 IMAGE_OPTIONAL_HEADER;
3171 typedef PIMAGE_OPTIONAL_HEADER64 PIMAGE_OPTIONAL_HEADER;
3172 typedef IMAGE_NT_HEADERS64 IMAGE_NT_HEADERS;
3173 typedef PIMAGE_NT_HEADERS64 PIMAGE_NT_HEADERS;
3174 #else
3175 typedef IMAGE_OPTIONAL_HEADER32 IMAGE_OPTIONAL_HEADER;
3176 typedef PIMAGE_OPTIONAL_HEADER32 PIMAGE_OPTIONAL_HEADER;
3177 typedef IMAGE_NT_HEADERS32 IMAGE_NT_HEADERS;
3178 typedef PIMAGE_NT_HEADERS32 PIMAGE_NT_HEADERS;
3179 #endif
3180
3181 typedef struct _IMAGE_ROM_HEADERS {
3182 IMAGE_FILE_HEADER FileHeader;
3183 IMAGE_ROM_OPTIONAL_HEADER OptionalHeader;
3184 } IMAGE_ROM_HEADERS, *PIMAGE_ROM_HEADERS;
3185
3186 typedef struct _IMAGE_SECTION_HEADER {
3187 BYTE Name[IMAGE_SIZEOF_SHORT_NAME];
3188 union {
3189 DWORD PhysicalAddress;
3190 DWORD VirtualSize;
3191 } Misc;
3192 DWORD VirtualAddress;
3193 DWORD SizeOfRawData;
3194 DWORD PointerToRawData;
3195 DWORD PointerToRelocations;
3196 DWORD PointerToLinenumbers;
3197 WORD NumberOfRelocations;
3198 WORD NumberOfLinenumbers;
3199 DWORD Characteristics;
3200 } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
3201
3202 #include <pshpack2.h>
3203
3204 typedef struct _IMAGE_SYMBOL {
3205 union {
3206 BYTE ShortName[8];
3207 struct {
3208 DWORD Short;
3209 DWORD Long;
3210 } Name;
3211 PBYTE LongName[2];
3212 } N;
3213 DWORD Value;
3214 SHORT SectionNumber;
3215 WORD Type;
3216 BYTE StorageClass;
3217 BYTE NumberOfAuxSymbols;
3218 } IMAGE_SYMBOL, *PIMAGE_SYMBOL;
3219
3220 typedef struct _IMAGE_LINENUMBER {
3221 union {
3222 DWORD SymbolTableIndex;
3223 DWORD VirtualAddress;
3224 } Type;
3225 WORD Linenumber;
3226 } IMAGE_LINENUMBER, UNALIGNED *PIMAGE_LINENUMBER;
3227
3228 typedef struct IMAGE_AUX_SYMBOL_TOKEN_DEF {
3229 BYTE bAuxType;
3230 BYTE bReserved;
3231 DWORD SymbolTableIndex;
3232 BYTE rgbReserved[12];
3233 } IMAGE_AUX_SYMBOL_TOKEN_DEF, UNALIGNED *PIMAGE_AUX_SYMBOL_TOKEN_DEF;
3234
3235 typedef union _IMAGE_AUX_SYMBOL {
3236 struct {
3237 DWORD TagIndex;
3238 union {
3239 struct {
3240 WORD Linenumber;
3241 WORD Size;
3242 } LnSz;
3243 DWORD TotalSize;
3244 } Misc;
3245 union {
3246 struct {
3247 DWORD PointerToLinenumber;
3248 DWORD PointerToNextFunction;
3249 } Function;
3250 struct {
3251 WORD Dimension[4];
3252 } Array;
3253 } FcnAry;
3254 WORD TvIndex;
3255 } Sym;
3256 struct {
3257 BYTE Name[IMAGE_SIZEOF_SYMBOL];
3258 } File;
3259 struct {
3260 DWORD Length;
3261 WORD NumberOfRelocations;
3262 WORD NumberOfLinenumbers;
3263 DWORD CheckSum;
3264 SHORT Number;
3265 BYTE Selection;
3266 BYTE bReserved;
3267 SHORT HighNumber;
3268 } Section;
3269 IMAGE_AUX_SYMBOL_TOKEN_DEF TokenDef;
3270 struct {
3271 DWORD crc;
3272 BYTE rgbReserved[14];
3273 } CRC;
3274 } IMAGE_AUX_SYMBOL, *PIMAGE_AUX_SYMBOL;
3275
3276 typedef struct _IMAGE_RELOCATION {
3277 _ANONYMOUS_UNION union {
3278 DWORD VirtualAddress;
3279 DWORD RelocCount;
3280 } DUMMYUNIONNAME;
3281 DWORD SymbolTableIndex;
3282 WORD Type;
3283 } IMAGE_RELOCATION, UNALIGNED *PIMAGE_RELOCATION;
3284
3285 #include <poppack.h>
3286
3287 #ifndef __IMAGE_COR20_HEADER_DEFINED__
3288 #define __IMAGE_COR20_HEADER_DEFINED__
3289
3290 typedef enum ReplacesCorHdrNumericDefines {
3291 COMIMAGE_FLAGS_ILONLY = 0x00000001,
3292 COMIMAGE_FLAGS_32BITREQUIRED = 0x00000002,
3293 COMIMAGE_FLAGS_IL_LIBRARY = 0x00000004,
3294 COMIMAGE_FLAGS_STRONGNAMESIGNED = 0x00000008,
3295 COMIMAGE_FLAGS_NATIVE_ENTRYPOINT = 0x00000010,
3296 COMIMAGE_FLAGS_TRACKDEBUGDATA = 0x00010000,
3297 COMIMAGE_FLAGS_32BITPREFERRED = 0x00020000,
3298 COR_VERSION_MAJOR_V2 = 2,
3299 COR_VERSION_MAJOR = COR_VERSION_MAJOR_V2,
3300 COR_VERSION_MINOR = 0,
3301 COR_DELETED_NAME_LENGTH = 8,
3302 COR_VTABLEGAP_NAME_LENGTH = 8,
3303 NATIVE_TYPE_MAX_CB = 1,
3304 COR_ILMETHOD_SECT_SMALL_MAX_DATASIZE = 0xFF,
3305 IMAGE_COR_MIH_METHODRVA = 0x01,
3306 IMAGE_COR_MIH_EHRVA = 0x02,
3307 IMAGE_COR_MIH_BASICBLOCK = 0x08,
3308 COR_VTABLE_32BIT = 0x01,
3309 COR_VTABLE_64BIT = 0x02,
3310 COR_VTABLE_FROM_UNMANAGED = 0x04,
3311 COR_VTABLE_FROM_UNMANAGED_RETAIN_APPDOMAIN = 0x08,
3312 COR_VTABLE_CALL_MOST_DERIVED = 0x10,
3313 IMAGE_COR_EATJ_THUNK_SIZE = 32,
3314 MAX_CLASS_NAME = 1024,
3315 MAX_PACKAGE_NAME = 1024
3316 } ReplacesCorHdrNumericDefines;
3317
3318 typedef struct IMAGE_COR20_HEADER {
3319 DWORD cb;
3320 WORD MajorRuntimeVersion;
3321 WORD MinorRuntimeVersion;
3322 IMAGE_DATA_DIRECTORY MetaData;
3323 DWORD Flags;
3324 _ANONYMOUS_UNION union {
3325 DWORD EntryPointToken;
3326 DWORD EntryPointRVA;
3327 } DUMMYUNIONNAME;
3328 IMAGE_DATA_DIRECTORY Resources;
3329 IMAGE_DATA_DIRECTORY StrongNameSignature;
3330 IMAGE_DATA_DIRECTORY CodeManagerTable;
3331 IMAGE_DATA_DIRECTORY VTableFixups;
3332 IMAGE_DATA_DIRECTORY ExportAddressTableJumps;
3333 IMAGE_DATA_DIRECTORY ManagedNativeHeader;
3334 } IMAGE_COR20_HEADER, *PIMAGE_COR20_HEADER;
3335
3336 #endif /* __IMAGE_COR20_HEADER_DEFINED__ */
3337
3338 typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
3339 DWORD NumberOfSymbols;
3340 DWORD LvaToFirstSymbol;
3341 DWORD NumberOfLinenumbers;
3342 DWORD LvaToFirstLinenumber;
3343 DWORD RvaToFirstByteOfCode;
3344 DWORD RvaToLastByteOfCode;
3345 DWORD RvaToFirstByteOfData;
3346 DWORD RvaToLastByteOfData;
3347 } IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
3348
3349 typedef struct _IMAGE_BASE_RELOCATION {
3350 DWORD VirtualAddress;
3351 DWORD SizeOfBlock;
3352 } IMAGE_BASE_RELOCATION, UNALIGNED *PIMAGE_BASE_RELOCATION;
3353
3354 typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER {
3355 BYTE Name[16];
3356 BYTE Date[12];
3357 BYTE UserID[6];
3358 BYTE GroupID[6];
3359 BYTE Mode[8];
3360 BYTE Size[10];
3361 BYTE EndHeader[2];
3362 } IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
3363
3364 typedef struct _IMAGE_EXPORT_DIRECTORY {
3365 DWORD Characteristics;
3366 DWORD TimeDateStamp;
3367 WORD MajorVersion;
3368 WORD MinorVersion;
3369 DWORD Name;
3370 DWORD Base;
3371 DWORD NumberOfFunctions;
3372 DWORD NumberOfNames;
3373 DWORD AddressOfFunctions;
3374 DWORD AddressOfNames;
3375 DWORD AddressOfNameOrdinals;
3376 } IMAGE_EXPORT_DIRECTORY, *PIMAGE_EXPORT_DIRECTORY;
3377
3378 typedef struct _IMAGE_IMPORT_BY_NAME {
3379 WORD Hint;
3380 BYTE Name[1];
3381 } IMAGE_IMPORT_BY_NAME, *PIMAGE_IMPORT_BY_NAME;
3382
3383 #include <pshpack8.h>
3384 typedef struct _IMAGE_THUNK_DATA64 {
3385 union {
3386 ULONGLONG ForwarderString;
3387 ULONGLONG Function;
3388 ULONGLONG Ordinal;
3389 ULONGLONG AddressOfData;
3390 } u1;
3391 } IMAGE_THUNK_DATA64, *PIMAGE_THUNK_DATA64;
3392 #include <poppack.h>
3393
3394 typedef struct _IMAGE_THUNK_DATA32 {
3395 union {
3396 DWORD ForwarderString;
3397 DWORD Function;
3398 DWORD Ordinal;
3399 DWORD AddressOfData;
3400 } u1;
3401 } IMAGE_THUNK_DATA32, *PIMAGE_THUNK_DATA32;
3402
3403 #define IMAGE_ORDINAL_FLAG64 0x8000000000000000ULL
3404 #define IMAGE_ORDINAL_FLAG32 0x80000000
3405 #define IMAGE_ORDINAL64(Ordinal) (Ordinal & 0xffff)
3406 #define IMAGE_ORDINAL32(Ordinal) (Ordinal & 0xffff)
3407 #define IMAGE_SNAP_BY_ORDINAL64(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG64)!=0)
3408 #define IMAGE_SNAP_BY_ORDINAL32(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG32)!=0)
3409
3410 typedef VOID
3411 (NTAPI *PIMAGE_TLS_CALLBACK)(PVOID DllHandle,DWORD Reason,PVOID Reserved);
3412
3413 typedef struct _IMAGE_TLS_DIRECTORY64 {
3414 ULONGLONG StartAddressOfRawData;
3415 ULONGLONG EndAddressOfRawData;
3416 ULONGLONG AddressOfIndex;
3417 ULONGLONG AddressOfCallBacks;
3418 DWORD SizeOfZeroFill;
3419 DWORD Characteristics;
3420 } IMAGE_TLS_DIRECTORY64, *PIMAGE_TLS_DIRECTORY64;
3421
3422 typedef struct _IMAGE_TLS_DIRECTORY32 {
3423 DWORD StartAddressOfRawData;
3424 DWORD EndAddressOfRawData;
3425 DWORD AddressOfIndex;
3426 DWORD AddressOfCallBacks;
3427 DWORD SizeOfZeroFill;
3428 DWORD Characteristics;
3429 } IMAGE_TLS_DIRECTORY32, *PIMAGE_TLS_DIRECTORY32;
3430
3431 #ifdef _WIN64
3432 #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG64
3433 #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL64(Ordinal)
3434 typedef IMAGE_THUNK_DATA64 IMAGE_THUNK_DATA;
3435 typedef PIMAGE_THUNK_DATA64 PIMAGE_THUNK_DATA;
3436 #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL64(Ordinal)
3437 typedef IMAGE_TLS_DIRECTORY64 IMAGE_TLS_DIRECTORY;
3438 typedef PIMAGE_TLS_DIRECTORY64 PIMAGE_TLS_DIRECTORY;
3439 #else
3440 #define IMAGE_ORDINAL_FLAG IMAGE_ORDINAL_FLAG32
3441 #define IMAGE_ORDINAL(Ordinal) IMAGE_ORDINAL32(Ordinal)
3442 typedef IMAGE_THUNK_DATA32 IMAGE_THUNK_DATA;
3443 typedef PIMAGE_THUNK_DATA32 PIMAGE_THUNK_DATA;
3444 #define IMAGE_SNAP_BY_ORDINAL(Ordinal) IMAGE_SNAP_BY_ORDINAL32(Ordinal)
3445 typedef IMAGE_TLS_DIRECTORY32 IMAGE_TLS_DIRECTORY;
3446 typedef PIMAGE_TLS_DIRECTORY32 PIMAGE_TLS_DIRECTORY;
3447 #endif
3448
3449 typedef struct _IMAGE_IMPORT_DESCRIPTOR {
3450 _ANONYMOUS_UNION union {
3451 DWORD Characteristics;
3452 DWORD OriginalFirstThunk;
3453 } DUMMYUNIONNAME;
3454 DWORD TimeDateStamp;
3455 DWORD ForwarderChain;
3456 DWORD Name;
3457 DWORD FirstThunk;
3458 } IMAGE_IMPORT_DESCRIPTOR, UNALIGNED *PIMAGE_IMPORT_DESCRIPTOR;
3459
3460 typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR {
3461 DWORD TimeDateStamp;
3462 WORD OffsetModuleName;
3463 WORD NumberOfModuleForwarderRefs;
3464 } IMAGE_BOUND_IMPORT_DESCRIPTOR, *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
3465
3466 typedef struct _IMAGE_BOUND_FORWARDER_REF {
3467 DWORD TimeDateStamp;
3468 WORD OffsetModuleName;
3469 WORD Reserved;
3470 } IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
3471
3472 typedef struct _IMAGE_DELAYLOAD_DESCRIPTOR {
3473 union {
3474 DWORD AllAttributes;
3475 struct {
3476 DWORD RvaBased:1;
3477 DWORD ReservedAttributes:31;
3478 };
3479 } Attributes;
3480 DWORD DllNameRVA;
3481 DWORD ModuleHandleRVA;
3482 DWORD ImportAddressTableRVA;
3483 DWORD ImportNameTableRVA;
3484 DWORD BoundImportAddressTableRVA;
3485 DWORD UnloadInformationTableRVA;
3486 DWORD TimeDateStamp;
3487 } IMAGE_DELAYLOAD_DESCRIPTOR, *PIMAGE_DELAYLOAD_DESCRIPTOR;
3488
3489 typedef const IMAGE_DELAYLOAD_DESCRIPTOR *PCIMAGE_DELAYLOAD_DESCRIPTOR;
3490
3491 typedef struct _IMAGE_RESOURCE_DIRECTORY {
3492 DWORD Characteristics;
3493 DWORD TimeDateStamp;
3494 WORD MajorVersion;
3495 WORD MinorVersion;
3496 WORD NumberOfNamedEntries;
3497 WORD NumberOfIdEntries;
3498 } IMAGE_RESOURCE_DIRECTORY, *PIMAGE_RESOURCE_DIRECTORY;
3499
3500 typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
3501 _ANONYMOUS_UNION union {
3502 _ANONYMOUS_STRUCT struct {
3503 DWORD NameOffset:31;
3504 DWORD NameIsString:1;
3505 } DUMMYSTRUCTNAME;
3506 DWORD Name;
3507 WORD Id;
3508 } DUMMYUNIONNAME;
3509 _ANONYMOUS_UNION union {
3510 DWORD OffsetToData;
3511 _ANONYMOUS_STRUCT struct {
3512 DWORD OffsetToDirectory:31;
3513 DWORD DataIsDirectory:1;
3514 } DUMMYSTRUCTNAME2;
3515 } DUMMYUNIONNAME2;
3516 } IMAGE_RESOURCE_DIRECTORY_ENTRY, *PIMAGE_RESOURCE_DIRECTORY_ENTRY;
3517
3518 typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
3519 WORD Length;
3520 CHAR NameString[1];
3521 } IMAGE_RESOURCE_DIRECTORY_STRING, *PIMAGE_RESOURCE_DIRECTORY_STRING;
3522
3523 typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
3524 WORD Length;
3525 WCHAR NameString[1];
3526 } IMAGE_RESOURCE_DIR_STRING_U, *PIMAGE_RESOURCE_DIR_STRING_U;
3527
3528 typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
3529 DWORD OffsetToData;
3530 DWORD Size;
3531 DWORD CodePage;
3532 DWORD Reserved;
3533 } IMAGE_RESOURCE_DATA_ENTRY, *PIMAGE_RESOURCE_DATA_ENTRY;
3534
3535 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY32 {
3536 DWORD Size;
3537 DWORD TimeDateStamp;
3538 WORD MajorVersion;
3539 WORD MinorVersion;
3540 DWORD GlobalFlagsClear;
3541 DWORD GlobalFlagsSet;
3542 DWORD CriticalSectionDefaultTimeout;
3543 DWORD DeCommitFreeBlockThreshold;
3544 DWORD DeCommitTotalFreeThreshold;
3545 DWORD LockPrefixTable;
3546 DWORD MaximumAllocationSize;
3547 DWORD VirtualMemoryThreshold;
3548 DWORD ProcessHeapFlags;
3549 DWORD ProcessAffinityMask;
3550 WORD CSDVersion;
3551 WORD Reserved1;
3552 DWORD EditList;
3553 DWORD SecurityCookie;
3554 DWORD SEHandlerTable;
3555 DWORD SEHandlerCount;
3556 } IMAGE_LOAD_CONFIG_DIRECTORY32, *PIMAGE_LOAD_CONFIG_DIRECTORY32;
3557
3558 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY64 {
3559 DWORD Size;
3560 DWORD TimeDateStamp;
3561 WORD MajorVersion;
3562 WORD MinorVersion;
3563 DWORD GlobalFlagsClear;
3564 DWORD GlobalFlagsSet;
3565 DWORD CriticalSectionDefaultTimeout;
3566 ULONGLONG DeCommitFreeBlockThreshold;
3567 ULONGLONG DeCommitTotalFreeThreshold;
3568 ULONGLONG LockPrefixTable;
3569 ULONGLONG MaximumAllocationSize;
3570 ULONGLONG VirtualMemoryThreshold;
3571 ULONGLONG ProcessAffinityMask;
3572 DWORD ProcessHeapFlags;
3573 WORD CSDVersion;
3574 WORD Reserved1;
3575 ULONGLONG EditList;
3576 ULONGLONG SecurityCookie;
3577 ULONGLONG SEHandlerTable;
3578 ULONGLONG SEHandlerCount;
3579 } IMAGE_LOAD_CONFIG_DIRECTORY64, *PIMAGE_LOAD_CONFIG_DIRECTORY64;
3580
3581 #ifdef _WIN64
3582 typedef IMAGE_LOAD_CONFIG_DIRECTORY64 IMAGE_LOAD_CONFIG_DIRECTORY;
3583 typedef PIMAGE_LOAD_CONFIG_DIRECTORY64 PIMAGE_LOAD_CONFIG_DIRECTORY;
3584 #else
3585 typedef IMAGE_LOAD_CONFIG_DIRECTORY32 IMAGE_LOAD_CONFIG_DIRECTORY;
3586 typedef PIMAGE_LOAD_CONFIG_DIRECTORY32 PIMAGE_LOAD_CONFIG_DIRECTORY;
3587 #endif
3588
3589 typedef struct _IMAGE_RUNTIME_FUNCTION_ENTRY {
3590 DWORD BeginAddress;
3591 DWORD EndAddress;
3592 DWORD UnwindInfoAddress;
3593 } IMAGE_RUNTIME_FUNCTION_ENTRY, *PIMAGE_RUNTIME_FUNCTION_ENTRY;
3594
3595 typedef struct _IMAGE_DEBUG_DIRECTORY {
3596 DWORD Characteristics;
3597 DWORD TimeDateStamp;
3598 WORD MajorVersion;
3599 WORD MinorVersion;
3600 DWORD Type;
3601 DWORD SizeOfData;
3602 DWORD AddressOfRawData;
3603 DWORD PointerToRawData;
3604 } IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
3605
3606 typedef struct _FPO_DATA {
3607 DWORD ulOffStart;
3608 DWORD cbProcSize;
3609 DWORD cdwLocals;
3610 WORD cdwParams;
3611 WORD cbProlog:8;
3612 WORD cbRegs:3;
3613 WORD fHasSEH:1;
3614 WORD fUseBP:1;
3615 WORD reserved:1;
3616 WORD cbFrame:2;
3617 } FPO_DATA, *PFPO_DATA;
3618
3619 typedef struct _IMAGE_DEBUG_MISC {
3620 DWORD DataType;
3621 DWORD Length;
3622 BOOLEAN Unicode;
3623 BYTE Reserved[3];
3624 BYTE Data[1];
3625 } IMAGE_DEBUG_MISC, *PIMAGE_DEBUG_MISC;
3626
3627 typedef struct _IMAGE_FUNCTION_ENTRY {
3628 DWORD StartingAddress;
3629 DWORD EndingAddress;
3630 DWORD EndOfPrologue;
3631 } IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
3632
3633 typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
3634 WORD Signature;
3635 WORD Flags;
3636 WORD Machine;
3637 WORD Characteristics;
3638 DWORD TimeDateStamp;
3639 DWORD CheckSum;
3640 DWORD ImageBase;
3641 DWORD SizeOfImage;
3642 DWORD NumberOfSections;
3643 DWORD ExportedNamesSize;
3644 DWORD DebugDirectorySize;
3645 DWORD SectionAlignment;
3646 DWORD Reserved[2];
3647 } IMAGE_SEPARATE_DEBUG_HEADER, *PIMAGE_SEPARATE_DEBUG_HEADER;
3648
3649 typedef enum _CM_SERVICE_NODE_TYPE {
3650 DriverType = SERVICE_KERNEL_DRIVER,
3651 FileSystemType = SERVICE_FILE_SYSTEM_DRIVER,
3652 Win32ServiceOwnProcess = SERVICE_WIN32_OWN_PROCESS,
3653 Win32ServiceShareProcess = SERVICE_WIN32_SHARE_PROCESS,
3654 AdapterType = SERVICE_ADAPTER,
3655 RecognizerType = SERVICE_RECOGNIZER_DRIVER
3656 } SERVICE_NODE_TYPE;
3657
3658 typedef enum _CM_SERVICE_LOAD_TYPE {
3659 BootLoad = SERVICE_BOOT_START,
3660 SystemLoad = SERVICE_SYSTEM_START,
3661 AutoLoad = SERVICE_AUTO_START,
3662 DemandLoad = SERVICE_DEMAND_START,
3663 DisableLoad = SERVICE_DISABLED
3664 } SERVICE_LOAD_TYPE;
3665
3666 typedef enum _CM_ERROR_CONTROL_TYPE {
3667 IgnoreError = SERVICE_ERROR_IGNORE,
3668 NormalError = SERVICE_ERROR_NORMAL,
3669 SevereError = SERVICE_ERROR_SEVERE,
3670 CriticalError = SERVICE_ERROR_CRITICAL
3671 } SERVICE_ERROR_TYPE;
3672
3673 typedef struct _NT_TIB {
3674 struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList;
3675 PVOID StackBase;
3676 PVOID StackLimit;
3677 PVOID SubSystemTib;
3678 _ANONYMOUS_UNION union {
3679 PVOID FiberData;
3680 DWORD Version;
3681 } DUMMYUNIONNAME;
3682 PVOID ArbitraryUserPointer;
3683 struct _NT_TIB *Self;
3684 } NT_TIB,*PNT_TIB;
3685
3686 typedef struct _NT_TIB32 {
3687 DWORD ExceptionList;
3688 DWORD StackBase;
3689 DWORD StackLimit;
3690 DWORD SubSystemTib;
3691 _ANONYMOUS_UNION union {
3692 DWORD FiberData;
3693 DWORD Version;
3694 } DUMMYUNIONNAME;
3695 DWORD ArbitraryUserPointer;
3696 DWORD Self;
3697 } NT_TIB32,*PNT_TIB32;
3698
3699 typedef struct _NT_TIB64 {
3700 DWORD64 ExceptionList;
3701 DWORD64 StackBase;
3702 DWORD64 StackLimit;
3703 DWORD64 SubSystemTib;
3704 _ANONYMOUS_UNION union {
3705 DWORD64 FiberData;
3706 DWORD Version;
3707 } DUMMYUNIONNAME;
3708 DWORD64 ArbitraryUserPointer;
3709 DWORD64 Self;
3710 } NT_TIB64,*PNT_TIB64;
3711
3712 typedef struct _REPARSE_GUID_DATA_BUFFER {
3713 DWORD ReparseTag;
3714 WORD ReparseDataLength;
3715 WORD Reserved;
3716 GUID ReparseGuid;
3717 struct {
3718 BYTE DataBuffer[1];
3719 } GenericReparseBuffer;
3720 } REPARSE_GUID_DATA_BUFFER, *PREPARSE_GUID_DATA_BUFFER;
3721
3722 typedef struct _REPARSE_POINT_INFORMATION {
3723 WORD ReparseDataLength;
3724 WORD UnparsedNameLength;
3725 } REPARSE_POINT_INFORMATION, *PREPARSE_POINT_INFORMATION;
3726
3727 typedef union _FILE_SEGMENT_ELEMENT {
3728 PVOID64 Buffer;
3729 ULONGLONG Alignment;
3730 } FILE_SEGMENT_ELEMENT, *PFILE_SEGMENT_ELEMENT;
3731
3732 /* JOBOBJECT_BASIC_LIMIT_INFORMATION.LimitFlags constants */
3733 #define JOB_OBJECT_LIMIT_WORKINGSET 0x0001
3734 #define JOB_OBJECT_LIMIT_PROCESS_TIME 0x0002
3735 #define JOB_OBJECT_LIMIT_JOB_TIME 0x0004
3736 #define JOB_OBJECT_LIMIT_ACTIVE_PROCESS 0x0008
3737 #define JOB_OBJECT_LIMIT_AFFINITY 0x0010
3738 #define JOB_OBJECT_LIMIT_PRIORITY_CLASS 0x0020
3739 #define JOB_OBJECT_LIMIT_PRESERVE_JOB_TIME 0x0040
3740 #define JOB_OBJECT_LIMIT_SCHEDULING_CLASS 0x0080
3741 #define JOB_OBJECT_LIMIT_PROCESS_MEMORY 0x0100
3742 #define JOB_OBJECT_LIMIT_JOB_MEMORY 0x0200
3743 #define JOB_OBJECT_LIMIT_DIE_ON_UNHANDLED_EXCEPTION 0x0400
3744 #define JOB_OBJECT_LIMIT_BREAKAWAY_OK 0x0800
3745 #define JOB_OBJECT_LIMIT_SILENT_BREAKAWAY_OK 0x1000
3746 #define JOB_OBJECT_LIMIT_KILL_ON_JOB_CLOSE 0x2000
3747
3748 /* JOBOBJECT_BASIC_UI_RESTRICTIONS.UIRestrictionsClass constants */
3749 #define JOB_OBJECT_UILIMIT_HANDLES 0x0001
3750 #define JOB_OBJECT_UILIMIT_READCLIPBOARD 0x0002
3751 #define JOB_OBJECT_UILIMIT_WRITECLIPBOARD 0x0004
3752 #define JOB_OBJECT_UILIMIT_SYSTEMPARAMETERS 0x0008
3753 #define JOB_OBJECT_UILIMIT_DISPLAYSETTINGS 0x0010
3754 #define JOB_OBJECT_UILIMIT_GLOBALATOMS 0x0020
3755 #define JOB_OBJECT_UILIMIT_DESKTOP 0x0040
3756 #define JOB_OBJECT_UILIMIT_EXITWINDOWS 0x0080
3757
3758 /* JOBOBJECT_SECURITY_LIMIT_INFORMATION.SecurityLimitFlags constants */
3759 #define JOB_OBJECT_SECURITY_NO_ADMIN 0x0001
3760 #define JOB_OBJECT_SECURITY_RESTRICTED_TOKEN 0x0002
3761 #define JOB_OBJECT_SECURITY_ONLY_TOKEN 0x0004
3762 #define JOB_OBJECT_SECURITY_FILTER_TOKENS 0x0008
3763
3764 /* JOBOBJECT_END_OF_JOB_TIME_INFORMATION.EndOfJobTimeAction constants */
3765 #define JOB_OBJECT_TERMINATE_AT_END_OF_JOB 0
3766 #define JOB_OBJECT_POST_AT_END_OF_JOB 1
3767
3768 #define JOB_OBJECT_MSG_END_OF_JOB_TIME 1
3769 #define JOB_OBJECT_MSG_END_OF_PROCESS_TIME 2
3770 #define JOB_OBJECT_MSG_ACTIVE_PROCESS_LIMIT 3
3771 #define JOB_OBJECT_MSG_ACTIVE_PROCESS_ZERO 4
3772 #define JOB_OBJECT_MSG_NEW_PROCESS 6
3773 #define JOB_OBJECT_MSG_EXIT_PROCESS 7
3774 #define JOB_OBJECT_MSG_ABNORMAL_EXIT_PROCESS 8
3775 #define JOB_OBJECT_MSG_PROCESS_MEMORY_LIMIT 9
3776 #define JOB_OBJECT_MSG_JOB_MEMORY_LIMIT 10
3777
3778 #define JOB_OBJECT_ASSIGN_PROCESS 1
3779 #define JOB_OBJECT_SET_ATTRIBUTES 2
3780 #define JOB_OBJECT_QUERY 4
3781 #define JOB_OBJECT_TERMINATE 8
3782 #define JOB_OBJECT_SET_SECURITY_ATTRIBUTES 16
3783 #define JOB_OBJECT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|31)
3784
3785 typedef enum _JOBOBJECTINFOCLASS {
3786 JobObjectBasicAccountingInformation = 1,
3787 JobObjectBasicLimitInformation,
3788 JobObjectBasicProcessIdList,
3789 JobObjectBasicUIRestrictions,
3790 JobObjectSecurityLimitInformation,
3791 JobObjectEndOfJobTimeInformation,
3792 JobObjectAssociateCompletionPortInformation,
3793 JobObjectBasicAndIoAccountingInformation,
3794 JobObjectExtendedLimitInformation,
3795 JobObjectJobSetInformation,
3796 JobObjectGroupInformation,
3797 MaxJobObjectInfoClass
3798 } JOBOBJECTINFOCLASS;
3799
3800 typedef struct _JOB_SET_ARRAY {
3801 HANDLE JobHandle;
3802 DWORD MemberLevel;
3803 DWORD Flags;
3804 } JOB_SET_ARRAY, *PJOB_SET_ARRAY;
3805
3806 typedef struct _JOBOBJECT_BASIC_ACCOUNTING_INFORMATION {
3807 LARGE_INTEGER TotalUserTime;
3808 LARGE_INTEGER TotalKernelTime;
3809 LARGE_INTEGER ThisPeriodTotalUserTime;
3810 LARGE_INTEGER ThisPeriodTotalKernelTime;
3811 DWORD TotalPageFaultCount;
3812 DWORD TotalProcesses;
3813 DWORD ActiveProcesses;
3814 DWORD TotalTerminatedProcesses;
3815 } JOBOBJECT_BASIC_ACCOUNTING_INFORMATION,*PJOBOBJECT_BASIC_ACCOUNTING_INFORMATION;
3816
3817 typedef struct _JOBOBJECT_BASIC_LIMIT_INFORMATION {
3818 LARGE_INTEGER PerProcessUserTimeLimit;
3819 LARGE_INTEGER PerJobUserTimeLimit;
3820 DWORD LimitFlags;
3821 SIZE_T MinimumWorkingSetSize;
3822 SIZE_T MaximumWorkingSetSize;
3823 DWORD ActiveProcessLimit;
3824 ULONG_PTR Affinity;
3825 DWORD PriorityClass;
3826 DWORD SchedulingClass;
3827 } JOBOBJECT_BASIC_LIMIT_INFORMATION,*PJOBOBJECT_BASIC_LIMIT_INFORMATION;
3828
3829 typedef struct _JOBOBJECT_BASIC_PROCESS_ID_LIST {
3830 DWORD NumberOfAssignedProcesses;
3831 DWORD NumberOfProcessIdsInList;
3832 ULONG_PTR ProcessIdList[1];
3833 } JOBOBJECT_BASIC_PROCESS_ID_LIST, *PJOBOBJECT_BASIC_PROCESS_ID_LIST;
3834
3835 typedef struct _JOBOBJECT_BASIC_UI_RESTRICTIONS {
3836 DWORD UIRestrictionsClass;
3837 } JOBOBJECT_BASIC_UI_RESTRICTIONS,*PJOBOBJECT_BASIC_UI_RESTRICTIONS;
3838
3839 typedef struct _JOBOBJECT_SECURITY_LIMIT_INFORMATION {
3840 DWORD SecurityLimitFlags;
3841 HANDLE JobToken;
3842 PTOKEN_GROUPS SidsToDisable;
3843 PTOKEN_PRIVILEGES PrivilegesToDelete;
3844 PTOKEN_GROUPS RestrictedSids;
3845 } JOBOBJECT_SECURITY_LIMIT_INFORMATION,*PJOBOBJECT_SECURITY_LIMIT_INFORMATION;
3846
3847 typedef struct _JOBOBJECT_END_OF_JOB_TIME_INFORMATION {
3848 DWORD EndOfJobTimeAction;
3849 } JOBOBJECT_END_OF_JOB_TIME_INFORMATION,*PJOBOBJECT_END_OF_JOB_TIME_INFORMATION;
3850
3851 typedef struct _JOBOBJECT_ASSOCIATE_COMPLETION_PORT {
3852 PVOID CompletionKey;
3853 HANDLE CompletionPort;
3854 } JOBOBJECT_ASSOCIATE_COMPLETION_PORT,*PJOBOBJECT_ASSOCIATE_COMPLETION_PORT;
3855
3856 typedef struct _JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION {
3857 JOBOBJECT_BASIC_ACCOUNTING_INFORMATION BasicInfo;
3858 IO_COUNTERS IoInfo;
3859 } JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION,*PJOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION;
3860
3861 typedef struct _JOBOBJECT_EXTENDED_LIMIT_INFORMATION {
3862 JOBOBJECT_BASIC_LIMIT_INFORMATION BasicLimitInformation;
3863 IO_COUNTERS IoInfo;
3864 SIZE_T ProcessMemoryLimit;
3865 SIZE_T JobMemoryLimit;
3866 SIZE_T PeakProcessMemoryUsed;
3867 SIZE_T PeakJobMemoryUsed;
3868 } JOBOBJECT_EXTENDED_LIMIT_INFORMATION,*PJOBOBJECT_EXTENDED_LIMIT_INFORMATION;
3869
3870 typedef struct _JOBOBJECT_JOBSET_INFORMATION {
3871 DWORD MemberLevel;
3872 } JOBOBJECT_JOBSET_INFORMATION,*PJOBOBJECT_JOBSET_INFORMATION;
3873
3874 /* Fixme: Making these defines conditional on WINVER will break ddk includes */
3875 #if 1 /* (WINVER >= 0x0500) */
3876
3877 #define ES_SYSTEM_REQUIRED 0x00000001
3878 #define ES_DISPLAY_REQUIRED 0x00000002
3879 #define ES_USER_PRESENT 0x00000004
3880 #define ES_CONTINUOUS 0x80000000
3881
3882 typedef enum _LATENCY_TIME {
3883 LT_DONT_CARE,
3884 LT_LOWEST_LATENCY
3885 } LATENCY_TIME, *PLATENCY_TIME;
3886
3887 typedef enum _SYSTEM_POWER_STATE {
3888 PowerSystemUnspecified = 0,
3889 PowerSystemWorking,
3890 PowerSystemSleeping1,
3891 PowerSystemSleeping2,
3892 PowerSystemSleeping3,
3893 PowerSystemHibernate,
3894 PowerSystemShutdown,
3895 PowerSystemMaximum
3896 } SYSTEM_POWER_STATE, *PSYSTEM_POWER_STATE;
3897
3898 #define POWER_SYSTEM_MAXIMUM PowerSystemMaximum
3899
3900 typedef enum {
3901 PowerActionNone = 0,
3902 PowerActionReserved,
3903 PowerActionSleep,
3904 PowerActionHibernate,
3905 PowerActionShutdown,
3906 PowerActionShutdownReset,
3907 PowerActionShutdownOff,
3908 PowerActionWarmEject
3909 } POWER_ACTION, *PPOWER_ACTION;
3910
3911 typedef enum _DEVICE_POWER_STATE {
3912 PowerDeviceUnspecified = 0,
3913 PowerDeviceD0,
3914 PowerDeviceD1,
3915 PowerDeviceD2,
3916 PowerDeviceD3,
3917 PowerDeviceMaximum
3918 } DEVICE_POWER_STATE, *PDEVICE_POWER_STATE;
3919
3920 #if (NTDDI_VERSION >= NTDDI_WINXP) || !defined(_BATCLASS_)
3921 typedef struct {
3922 DWORD Granularity;
3923 DWORD Capacity;
3924 } BATTERY_REPORTING_SCALE, *PBATTERY_REPORTING_SCALE;
3925 #endif
3926
3927 typedef struct _POWER_ACTION_POLICY {
3928 POWER_ACTION Action;
3929 DWORD Flags;
3930 DWORD EventCode;
3931 } POWER_ACTION_POLICY, *PPOWER_ACTION_POLICY;
3932
3933 /* POWER_ACTION_POLICY.Flags constants */
3934 #define POWER_ACTION_QUERY_ALLOWED 0x00000001
3935 #define POWER_ACTION_UI_ALLOWED 0x00000002
3936 #define POWER_ACTION_OVERRIDE_APPS 0x00000004
3937 #define POWER_ACTION_LIGHTEST_FIRST 0x10000000
3938 #define POWER_ACTION_LOCK_CONSOLE 0x20000000
3939 #define POWER_ACTION_DISABLE_WAKES 0x40000000
3940 #define POWER_ACTION_CRITICAL 0x80000000
3941
3942 /* POWER_ACTION_POLICY.EventCode constants */
3943 #define POWER_LEVEL_USER_NOTIFY_TEXT 0x00000001
3944 #define POWER_LEVEL_USER_NOTIFY_SOUND 0x00000002
3945 #define POWER_LEVEL_USER_NOTIFY_EXEC 0x00000004
3946 #define POWER_USER_NOTIFY_BUTTON 0x00000008
3947 #define POWER_USER_NOTIFY_SHUTDOWN 0x00000010
3948 #define POWER_FORCE_TRIGGER_RESET 0x80000000
3949
3950 #define DISCHARGE_POLICY_CRITICAL 0
3951 #define DISCHARGE_POLICY_LOW 1
3952 #define NUM_DISCHARGE_POLICIES 4
3953
3954 #define PO_THROTTLE_NONE 0
3955 #define PO_THROTTLE_CONSTANT 1
3956 #define PO_THROTTLE_DEGRADE 2
3957 #define PO_THROTTLE_ADAPTIVE 3
3958 #define PO_THROTTLE_MAXIMUM 4
3959
3960 typedef struct _SYSTEM_POWER_LEVEL {
3961 BOOLEAN Enable;
3962 BYTE Spare[3];
3963 DWORD BatteryLevel;
3964 POWER_ACTION_POLICY PowerPolicy;
3965 SYSTEM_POWER_STATE MinSystemState;
3966 } SYSTEM_POWER_LEVEL, *PSYSTEM_POWER_LEVEL;
3967
3968 typedef struct _SYSTEM_POWER_POLICY {
3969 DWORD Revision;
3970 POWER_ACTION_POLICY PowerButton;
3971 POWER_ACTION_POLICY SleepButton;
3972 POWER_ACTION_POLICY LidClose;
3973 SYSTEM_POWER_STATE LidOpenWake;
3974 DWORD Reserved;
3975 POWER_ACTION_POLICY Idle;
3976 DWORD IdleTimeout;
3977 BYTE IdleSensitivity;
3978 BYTE DynamicThrottle;
3979 BYTE Spare2[2];
3980 SYSTEM_POWER_STATE MinSleep;
3981 SYSTEM_POWER_STATE MaxSleep;
3982 SYSTEM_POWER_STATE ReducedLatencySleep;
3983 DWORD WinLogonFlags;
3984 DWORD Spare3;
3985 DWORD DozeS4Timeout;
3986 DWORD BroadcastCapacityResolution;
3987 SYSTEM_POWER_LEVEL DischargePolicy[NUM_DISCHARGE_POLICIES];
3988 DWORD VideoTimeout;
3989 BOOLEAN VideoDimDisplay;
3990 DWORD VideoReserved[3];
3991 DWORD SpindownTimeout;
3992 BOOLEAN OptimizeForPower;
3993 BYTE FanThrottleTolerance;
3994 BYTE ForcedThrottle;
3995 BYTE MinThrottle;
3996 POWER_ACTION_POLICY OverThrottled;
3997 } SYSTEM_POWER_POLICY, *PSYSTEM_POWER_POLICY;
3998
3999 typedef struct _SYSTEM_POWER_CAPABILITIES {
4000 BOOLEAN PowerButtonPresent;
4001 BOOLEAN SleepButtonPresent;
4002 BOOLEAN LidPresent;
4003 BOOLEAN SystemS1;
4004 BOOLEAN SystemS2;
4005 BOOLEAN SystemS3;
4006 BOOLEAN SystemS4;
4007 BOOLEAN SystemS5;
4008 BOOLEAN HiberFilePresent;
4009 BOOLEAN FullWake;
4010 BOOLEAN VideoDimPresent;
4011 BOOLEAN ApmPresent;
4012 BOOLEAN UpsPresent;
4013 BOOLEAN ThermalControl;
4014 BOOLEAN ProcessorThrottle;
4015 BYTE ProcessorMinThrottle;
4016 #if (NTDDI_VERSION < NTDDI_WINXP)
4017 BYTE ProcessorThrottleScale;
4018 BYTE spare2[4];
4019 #else
4020 BYTE ProcessorMaxThrottle;
4021 BOOLEAN FastSystemS4;
4022 BYTE spare2[3];
4023 #endif /* (NTDDI_VERSION < NTDDI_WINXP) */
4024 BOOLEAN DiskSpinDown;
4025 BYTE spare3[8];
4026 BOOLEAN SystemBatteriesPresent;
4027 BOOLEAN BatteriesAreShortTerm;
4028 BATTERY_REPORTING_SCALE BatteryScale[3];
4029 SYSTEM_POWER_STATE AcOnLineWake;
4030 SYSTEM_POWER_STATE SoftLidWake;
4031 SYSTEM_POWER_STATE RtcWake;
4032 SYSTEM_POWER_STATE MinDeviceWakeState;
4033 SYSTEM_POWER_STATE DefaultLowLatencyWake;
4034 } SYSTEM_POWER_CAPABILITIES, *PSYSTEM_POWER_CAPABILITIES;
4035
4036 typedef struct _SYSTEM_BATTERY_STATE {
4037 BOOLEAN AcOnLine;
4038 BOOLEAN BatteryPresent;
4039 BOOLEAN Charging;
4040 BOOLEAN Discharging;
4041 BOOLEAN Spare1[4];
4042 DWORD MaxCapacity;
4043 DWORD RemainingCapacity;
4044 DWORD Rate;
4045 DWORD EstimatedTime;
4046 DWORD DefaultAlert1;
4047 DWORD DefaultAlert2;
4048 } SYSTEM_BATTERY_STATE, *PSYSTEM_BATTERY_STATE;
4049
4050 // FIXME: This should not be here!
4051 typedef struct _PROCESSOR_POWER_INFORMATION {
4052 ULONG Number;
4053 ULONG MaxMhz;
4054 ULONG CurrentMhz;
4055 ULONG MhzLimit;
4056 ULONG MaxIdleState;
4057 ULONG CurrentIdleState;
4058 } PROCESSOR_POWER_INFORMATION, *PPROCESSOR_POWER_INFORMATION;
4059
4060 typedef DWORD EXECUTION_STATE, *PEXECUTION_STATE;
4061
4062 typedef enum _POWER_INFORMATION_LEVEL {
4063 SystemPowerPolicyAc,
4064 SystemPowerPolicyDc,
4065 VerifySystemPolicyAc,
4066 VerifySystemPolicyDc,
4067 SystemPowerCapabilities,
4068 SystemBatteryState,
4069 SystemPowerStateHandler,
4070 ProcessorStateHandler,
4071 SystemPowerPolicyCurrent,
4072 AdministratorPowerPolicy,
4073 SystemReserveHiberFile,
4074 ProcessorInformation,
4075 SystemPowerInformation,
4076 ProcessorStateHandler2,
4077 LastWakeTime,
4078 LastSleepTime,
4079 SystemExecutionState,
4080 SystemPowerStateNotifyHandler,
4081 ProcessorPowerPolicyAc,
4082 ProcessorPowerPolicyDc,
4083 VerifyProcessorPowerPolicyAc,
4084 VerifyProcessorPowerPolicyDc,
4085 ProcessorPowerPolicyCurrent,
4086 SystemPowerStateLogging,
4087 SystemPowerLoggingEntry,
4088 SetPowerSettingValue,
4089 NotifyUserPowerSetting,
4090 PowerInformationLevelUnused0,
4091 PowerInformationLevelUnused1,
4092 SystemVideoState,
4093 TraceApplicationPowerMessage,
4094 TraceApplicationPowerMessageEnd,
4095 ProcessorPerfStates,
4096 ProcessorIdleStates,
4097 ProcessorCap,
4098 SystemWakeSource,
4099 SystemHiberFileInformation,
4100 TraceServicePowerMessage,
4101 ProcessorLoad,
4102 PowerShutdownNotification,
4103 MonitorCapabilities,
4104 SessionPowerInit,
4105 SessionDisplayState,
4106 PowerRequestCreate,
4107 PowerRequestAction,
4108 GetPowerRequestList,
4109 ProcessorInformationEx,
4110 NotifyUserModeLegacyPowerEvent,
4111 GroupPark,
4112 ProcessorIdleDomains,
4113 WakeTimerList,
4114 SystemHiberFileSize,
4115 PowerInformationLevelMaximum
4116 } POWER_INFORMATION_LEVEL;
4117
4118 #if (_WIN32_WINNT >= 0x0501)
4119
4120 typedef enum _ACTIVATION_CONTEXT_INFO_CLASS {
4121 ActivationContextBasicInformation = 1,
4122 ActivationContextDetailedInformation = 2,
4123 AssemblyDetailedInformationInActivationContext = 3,
4124 FileInformationInAssemblyOfAssemblyInActivationContext = 4,
4125 RunlevelInformationInActivationContext = 5,
4126 CompatibilityInformationInActivationContext = 6,
4127 ActivationContextManifestResourceName = 7,
4128 MaxActivationContextInfoClass,
4129 /* For compatibility with the old names */
4130 AssemblyDetailedInformationInActivationContxt = 3,
4131 FileInformationInAssemblyOfAssemblyInActivationContxt = 4
4132 } ACTIVATION_CONTEXT_INFO_CLASS;
4133
4134 typedef struct _ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION {
4135 DWORD ulFlags;
4136 DWORD ulEncodedAssemblyIdentityLength;
4137 DWORD ulManifestPathType;
4138 DWORD ulManifestPathLength;
4139 LARGE_INTEGER liManifestLastWriteTime;
4140 DWORD ulPolicyPathType;
4141 DWORD ulPolicyPathLength;
4142 LARGE_INTEGER liPolicyLastWriteTime;
4143 DWORD ulMetadataSatelliteRosterIndex;
4144 DWORD ulManifestVersionMajor;
4145 DWORD ulManifestVersionMinor;
4146 DWORD ulPolicyVersionMajor;
4147 DWORD ulPolicyVersionMinor;
4148 DWORD ulAssemblyDirectoryNameLength;
4149 PCWSTR lpAssemblyEncodedAssemblyIdentity;
4150 PCWSTR lpAssemblyManifestPath;
4151 PCWSTR lpAssemblyPolicyPath;
4152 PCWSTR lpAssemblyDirectoryName;
4153 DWORD ulFileCount;
4154 } ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION;
4155 typedef const ACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION *PCACTIVATION_CONTEXT_ASSEMBLY_DETAILED_INFORMATION;
4156
4157 typedef struct _ACTIVATION_CONTEXT_DETAILED_INFORMATION {
4158 DWORD dwFlags;
4159 DWORD ulFormatVersion;
4160 DWORD ulAssemblyCount;
4161 DWORD ulRootManifestPathType;
4162 DWORD ulRootManifestPathChars;
4163 DWORD ulRootConfigurationPathType;
4164 DWORD ulRootConfigurationPathChars;
4165 DWORD ulAppDirPathType;
4166 DWORD ulAppDirPathChars;
4167 PCWSTR lpRootManifestPath;
4168 PCWSTR lpRootConfigurationPath;
4169 PCWSTR lpAppDirPath;
4170 } ACTIVATION_CONTEXT_DETAILED_INFORMATION, *PACTIVATION_CONTEXT_DETAILED_INFORMATION;
4171 typedef const ACTIVATION_CONTEXT_DETAILED_INFORMATION *PCACTIVATION_CONTEXT_DETAILED_INFORMATION;
4172
4173 typedef struct _ACTIVATION_CONTEXT_QUERY_INDEX {
4174 DWORD ulAssemblyIndex;
4175 DWORD ulFileIndexInAssembly;
4176 } ACTIVATION_CONTEXT_QUERY_INDEX,*PACTIVATION_CONTEXT_QUERY_INDEX;
4177 typedef const ACTIVATION_CONTEXT_QUERY_INDEX *PCACTIVATION_CONTEXT_QUERY_INDEX;
4178
4179 typedef struct _ASSEMBLY_FILE_DETAILED_INFORMATION {
4180 DWORD ulFlags;
4181 DWORD ulFilenameLength;
4182 DWORD ulPathLength;
4183 PCWSTR lpFileName;
4184 PCWSTR lpFilePath;
4185 } ASSEMBLY_FILE_DETAILED_INFORMATION,*PASSEMBLY_FILE_DETAILED_INFORMATION;
4186 typedef const ASSEMBLY_FILE_DETAILED_INFORMATION *PCASSEMBLY_FILE_DETAILED_INFORMATION;
4187
4188 typedef enum {
4189 ACTCTX_RUN_LEVEL_UNSPECIFIED = 0,
4190 ACTCTX_RUN_LEVEL_AS_INVOKER,
4191 ACTCTX_RUN_LEVEL_HIGHEST_AVAILABLE,
4192 ACTCTX_RUN_LEVEL_REQUIRE_ADMIN,
4193 ACTCTX_RUN_LEVEL_NUMBERS
4194 } ACTCTX_REQUESTED_RUN_LEVEL;
4195
4196 typedef struct _ACTIVATION_CONTEXT_RUN_LEVEL_INFORMATION {
4197 DWORD ulFlags;
4198 ACTCTX_REQUESTED_RUN_LEVEL RunLevel;
4199 DWORD UiAccess;
4200 } ACTIVATION_CONTEXT_RUN_LEVEL_INFORMATION, *PACTIVATION_CONTEXT_RUN_LEVEL_INFORMATION;
4201
4202 typedef enum {
4203 ACTCTX_COMPATIBILITY_ELEMENT_TYPE_UNKNOWN = 0,
4204 ACTCTX_COMPATIBILITY_ELEMENT_TYPE_OS
4205 } ACTCTX_COMPATIBILITY_ELEMENT_TYPE;
4206
4207 typedef struct _COMPATIBILITY_CONTEXT_ELEMENT {
4208 GUID Id;
4209 ACTCTX_COMPATIBILITY_ELEMENT_TYPE Type;
4210 } COMPATIBILITY_CONTEXT_ELEMENT, *PCOMPATIBILITY_CONTEXT_ELEMENT;
4211
4212 typedef struct _ACTIVATION_CONTEXT_COMPATIBILITY_INFORMATION {
4213 DWORD ElementCount;
4214 COMPATIBILITY_CONTEXT_ELEMENT Elements[];
4215 } ACTIVATION_CONTEXT_COMPATIBILITY_INFORMATION, *PACTIVATION_CONTEXT_COMPATIBILITY_INFORMATION;
4216
4217
4218 #define ACTIVATION_CONTEXT_PATH_TYPE_NONE 1
4219 #define ACTIVATION_CONTEXT_PATH_TYPE_WIN32_FILE 2
4220 #define ACTIVATION_CONTEXT_PATH_TYPE_URL 3
4221 #define ACTIVATION_CONTEXT_PATH_TYPE_ASSEMBLYREF 4
4222
4223 #define ACTIVATION_CONTEXT_SECTION_ASSEMBLY_INFORMATION 1
4224 #define ACTIVATION_CONTEXT_SECTION_DLL_REDIRECTION 2
4225 #define ACTIVATION_CONTEXT_SECTION_WINDOW_CLASS_REDIRECTION 3
4226 #define ACTIVATION_CONTEXT_SECTION_COM_SERVER_REDIRECTION 4
4227 #define ACTIVATION_CONTEXT_SECTION_COM_INTERFACE_REDIRECTION 5
4228 #define ACTIVATION_CONTEXT_SECTION_COM_TYPE_LIBRARY_REDIRECTION 6
4229 #define ACTIVATION_CONTEXT_SECTION_COM_PROGID_REDIRECTION 7
4230 #define ACTIVATION_CONTEXT_SECTION_GLOBAL_OBJECT_RENAME_TABLE 8
4231 #define ACTIVATION_CONTEXT_SECTION_CLR_SURROGATES 9
4232
4233 #endif /* (_WIN32_WINNT >= 0x0501) */
4234
4235 typedef struct _PROCESSOR_POWER_POLICY_INFO {
4236 DWORD TimeCheck;
4237 DWORD DemoteLimit;
4238 DWORD PromoteLimit;
4239 BYTE DemotePercent;
4240 BYTE PromotePercent;
4241 BYTE Spare[2];
4242 DWORD AllowDemotion:1;
4243 DWORD AllowPromotion:1;
4244 DWORD Reserved:30;
4245 } PROCESSOR_POWER_POLICY_INFO, *PPROCESSOR_POWER_POLICY_INFO;
4246
4247 typedef struct _PROCESSOR_POWER_POLICY {
4248 DWORD Revision;
4249 BYTE DynamicThrottle;
4250 BYTE Spare[3];
4251 DWORD DisableCStates:1;
4252 DWORD Reserved:31;
4253 DWORD PolicyCount;
4254 PROCESSOR_POWER_POLICY_INFO Policy[3];
4255 } PROCESSOR_POWER_POLICY, *PPROCESSOR_POWER_POLICY;
4256
4257 typedef struct _ADMINISTRATOR_POWER_POLICY {
4258 SYSTEM_POWER_STATE MinSleep;
4259 SYSTEM_POWER_STATE MaxSleep;
4260 DWORD MinVideoTimeout;
4261 DWORD MaxVideoTimeout;
4262 DWORD MinSpindownTimeout;
4263 DWORD MaxSpindownTimeout;
4264 } ADMINISTRATOR_POWER_POLICY, *PADMINISTRATOR_POWER_POLICY;
4265
4266 #endif /* WINVER >= 0x0500 */
4267
4268 typedef VOID (NTAPI *WAITORTIMERCALLBACKFUNC)(PVOID,BOOLEAN);
4269
4270 #ifdef UNICODE
4271 typedef OSVERSIONINFOW OSVERSIONINFO,*POSVERSIONINFO,*LPOSVERSIONINFO;
4272 typedef OSVERSIONINFOEXW OSVERSIONINFOEX,*POSVERSIONINFOEX,*LPOSVERSIONINFOEX;
4273 #else
4274 typedef OSVERSIONINFOA OSVERSIONINFO,*POSVERSIONINFO,*LPOSVERSIONINFO;
4275 typedef OSVERSIONINFOEXA OSVERSIONINFOEX,*POSVERSIONINFOEX,*LPOSVERSIONINFOEX;
4276 #endif
4277
4278 #define VER_SET_CONDITION(lc,t,c) ((lc) = VerSetConditionMask((lc),(t),(c)))
4279
4280 #if (_WIN32_WINNT >= 0x0500)
4281 ULONGLONG WINAPI VerSetConditionMask(_In_ ULONGLONG, _In_ DWORD, _In_ BYTE);
4282 #endif
4283
4284 typedef enum _HEAP_INFORMATION_CLASS {
4285 HeapCompatibilityInformation,
4286 HeapEnableTerminationOnCorruption
4287 } HEAP_INFORMATION_CLASS;
4288
4289 #define CACHE_FULLY_ASSOCIATIVE 0xFF
4290
4291 _Check_return_
4292 NTSYSAPI
4293 SIZE_T
4294 NTAPI
4295 RtlCompareMemory (
4296 _In_ const VOID *Source1,
4297 _In_ const VOID *Source2,
4298 _In_ SIZE_T Length);
4299
4300 #define RtlMoveMemory(Dest,Source,Length) memmove((Dest),(Source),(Length))
4301 #define RtlCopyMemory(Dest,Source,Length) memcpy((Dest),(Source),(Length))
4302 #define RtlFillMemory(Dest,Length,Fill) memset((Dest),(Fill),(Length))
4303 #define RtlZeroMemory(Dest,Length) RtlFillMemory((Dest),(Length),0)
4304 #define RtlEqualMemory(Dest,Source,Length) (!memcmp((Dest),(Source),(Length)))
4305
4306 FORCEINLINE
4307 PVOID
RtlSecureZeroMemory(_Out_writes_bytes_all_ (Length)PVOID Buffer,_In_ SIZE_T Length)4308 RtlSecureZeroMemory(_Out_writes_bytes_all_(Length) PVOID Buffer,
4309 _In_ SIZE_T Length)
4310 {
4311 volatile char *VolatilePointer;
4312
4313 /* Get a volatile pointer to prevent any compiler optimizations */
4314 VolatilePointer = (volatile char *)Buffer;
4315
4316 /* Loop the whole buffer */
4317 while (Length)
4318 {
4319 /* Zero the current byte and move on */
4320 *VolatilePointer++ = 0;
4321 Length--;
4322 }
4323
4324 /* Return the pointer to ensure the compiler won't optimize this away */
4325 return Buffer;
4326 }
4327
4328 #if defined(_M_IX86)
NtCurrentTeb(VOID)4329 FORCEINLINE struct _TEB * NtCurrentTeb(VOID)
4330 {
4331 return (struct _TEB *)__readfsdword(0x18);
4332 }
GetCurrentFiber(VOID)4333 FORCEINLINE PVOID GetCurrentFiber(VOID)
4334 {
4335 return (PVOID)(ULONG_PTR)__readfsdword(0x10);
4336 }
4337 #elif defined (_M_AMD64)
NtCurrentTeb(VOID)4338 FORCEINLINE struct _TEB * NtCurrentTeb(VOID)
4339 {
4340 return (struct _TEB *)__readgsqword(FIELD_OFFSET(NT_TIB, Self));
4341 }
GetCurrentFiber(VOID)4342 FORCEINLINE PVOID GetCurrentFiber(VOID)
4343 {
4344 #ifdef NONAMELESSUNION
4345 return (PVOID)__readgsqword(FIELD_OFFSET(NT_TIB, DUMMYUNIONNAME.FiberData));
4346 #else
4347 return (PVOID)__readgsqword(FIELD_OFFSET(NT_TIB, FiberData));
4348 #endif
4349 }
4350 #elif defined (_M_ARM)
4351 #define CP15_PMSELR 15, 0, 9, 12, 5
4352 #define CP15_PMXEVCNTR 15, 0, 9, 13, 2
4353 #define CP15_TPIDRURW 15, 0, 13, 0, 2
4354 #define CP15_TPIDRURO 15, 0, 13, 0, 3
4355 #define CP15_TPIDRPRW 15, 0, 13, 0, 4
NtCurrentTeb(VOID)4356 FORCEINLINE struct _TEB * NtCurrentTeb(VOID)
4357 {
4358 return (struct _TEB *)(ULONG_PTR)_MoveFromCoprocessor(CP15_TPIDRURW);
4359 }
GetCurrentFiber(VOID)4360 FORCEINLINE PVOID GetCurrentFiber(VOID)
4361 {
4362 #ifdef NONAMELESSUNION
4363 return ((PNT_TIB)(ULONG_PTR)_MoveFromCoprocessor(CP15_TPIDRURW))->DUMMYUNIONNAME.FiberData;
4364 #else
4365 return ((PNT_TIB)(ULONG_PTR)_MoveFromCoprocessor(CP15_TPIDRURW))->FiberData;
4366 #endif
4367 }
4368 #elif defined (_M_ARM64)
NtCurrentTeb(VOID)4369 FORCEINLINE struct _TEB * NtCurrentTeb(VOID)
4370 {
4371 //UNIMPLEMENTED;
4372 return 0;
4373 }
GetCurrentFiber(VOID)4374 FORCEINLINE PVOID GetCurrentFiber(VOID)
4375 {
4376 //UNIMPLEMENTED;
4377 return 0;
4378 }
4379 #elif defined(_M_PPC)
_read_teb_dword(const unsigned long Offset)4380 FORCEINLINE unsigned long _read_teb_dword(const unsigned long Offset)
4381 {
4382 unsigned long result;
4383 __asm__("\tadd 7,13,%1\n"
4384 "\tlwz %0,0(7)\n"
4385 : "=r" (result)
4386 : "r" (Offset)
4387 : "r7");
4388 return result;
4389 }
NtCurrentTeb(VOID)4390 FORCEINLINE struct _TEB * NtCurrentTeb(VOID)
4391 {
4392 return (struct _TEB *)_read_teb_dword(0x18);
4393 }
GetCurrentFiber(VOID)4394 FORCEINLINE PVOID GetCurrentFiber(VOID)
4395 {
4396 return _read_teb_dword(0x10);
4397 }
4398 #else
4399 #error Unknown architecture
4400 #endif
4401
GetFiberData(VOID)4402 FORCEINLINE PVOID GetFiberData(VOID)
4403 {
4404 return *((PVOID *)GetCurrentFiber());
4405 }
4406
4407 /* TODO: Other architectures than X86 */
4408 #if defined(_M_IX86)
4409 #define PF_TEMPORAL_LEVEL_1
4410 #define PF_NON_TEMPORAL_LEVEL_ALL
4411 #define PreFetchCacheLine(l, a)
4412 #elif defined (_M_AMD64)
4413 #define PreFetchCacheLine(l, a)
4414 #elif defined(_M_PPC)
4415 #define PreFetchCacheLine(l, a)
4416 #elif defined(_M_ARM)
4417 #define PreFetchCacheLine(l, a)
4418 #elif defined(_M_ARM64)
4419 #define PreFetchCacheLine(l, a)
4420 #else
4421 #error Unknown architecture
4422 #endif
4423
4424 /* TODO: Other architectures than X86 */
4425 #if defined(_M_IX86)
4426 #if defined(_MSC_VER)
4427 FORCEINLINE
4428 VOID
MemoryBarrier(VOID)4429 MemoryBarrier(VOID)
4430 {
4431 LONG Barrier;
4432 __asm { xchg Barrier, eax }
4433 }
4434 #else
4435 FORCEINLINE
4436 VOID
MemoryBarrier(VOID)4437 MemoryBarrier(VOID)
4438 {
4439 LONG Barrier, *Dummy = &Barrier;
4440 (VOID)Dummy;
4441 __asm__ __volatile__("xchgl %%eax, %[Barrier]" : : [Barrier] "m" (Barrier) : "memory");
4442 }
4443 #endif
4444 #elif defined (_M_AMD64)
4445 #define MemoryBarrier __faststorefence
4446 #elif defined(_M_PPC)
4447 #define MemoryBarrier()
4448 #elif defined(_M_ARM)
4449 #define MemoryBarrier()
4450 #elif defined(_M_ARM64)
4451 #define MemoryBarrier()
4452 #else
4453 #error Unknown architecture
4454 #endif
4455
4456 #if defined(_M_IX86) || defined(_M_AMD64)
4457
4458 #define YieldProcessor _mm_pause
4459
4460 __analysis_noreturn
4461 FORCEINLINE
4462 VOID
DbgRaiseAssertionFailure(VOID)4463 DbgRaiseAssertionFailure(VOID)
4464 {
4465 __int2c();
4466 }
4467
4468 #elif defined(_M_PPC)
4469 #define YieldProcessor() __asm__ __volatile__("nop");
4470 #elif defined(_M_MIPS)
4471 #define YieldProcessor() __asm__ __volatile__("nop");
4472 #elif defined(_M_ARM)
4473 #define YieldProcessor __yield
4474 #elif defined(_M_ARM64)
4475 #define YieldProcessor __yield
4476 #else
4477 #error Unknown architecture
4478 #endif
4479
4480 typedef struct _TP_POOL TP_POOL, *PTP_POOL;
4481 typedef struct _TP_WORK TP_WORK, *PTP_WORK;
4482 typedef struct _TP_CALLBACK_INSTANCE TP_CALLBACK_INSTANCE, *PTP_CALLBACK_INSTANCE;
4483
4484 typedef DWORD TP_VERSION, *PTP_VERSION;
4485
4486 typedef enum _TP_CALLBACK_PRIORITY {
4487 TP_CALLBACK_PRIORITY_HIGH,
4488 TP_CALLBACK_PRIORITY_NORMAL,
4489 TP_CALLBACK_PRIORITY_LOW,
4490 TP_CALLBACK_PRIORITY_INVALID,
4491 TP_CALLBACK_PRIORITY_COUNT = TP_CALLBACK_PRIORITY_INVALID
4492 } TP_CALLBACK_PRIORITY;
4493
4494 typedef VOID
4495 (NTAPI *PTP_WORK_CALLBACK)(
4496 _Inout_ PTP_CALLBACK_INSTANCE Instance,
4497 _Inout_opt_ PVOID Context,
4498 _Inout_ PTP_WORK Work);
4499
4500 typedef struct _TP_CLEANUP_GROUP TP_CLEANUP_GROUP, *PTP_CLEANUP_GROUP;
4501
4502 typedef VOID
4503 (NTAPI *PTP_SIMPLE_CALLBACK)(
4504 _Inout_ PTP_CALLBACK_INSTANCE Instance,
4505 _Inout_opt_ PVOID Context);
4506
4507 typedef VOID
4508 (NTAPI *PTP_CLEANUP_GROUP_CANCEL_CALLBACK)(
4509 _Inout_opt_ PVOID ObjectContext,
4510 _Inout_opt_ PVOID CleanupContext);
4511
4512 #if (_WIN32_WINNT >= _WIN32_WINNT_WIN7)
4513 typedef struct _TP_CALLBACK_ENVIRON_V3 {
4514 TP_VERSION Version;
4515 PTP_POOL Pool;
4516 PTP_CLEANUP_GROUP CleanupGroup;
4517 PTP_CLEANUP_GROUP_CANCEL_CALLBACK CleanupGroupCancelCallback;
4518 PVOID RaceDll;
4519 struct _ACTIVATION_CONTEXT *ActivationContext;
4520 PTP_SIMPLE_CALLBACK FinalizationCallback;
4521 union {
4522 DWORD Flags;
4523 struct {
4524 DWORD LongFunction:1;
4525 DWORD Persistent:1;
4526 DWORD Private:30;
4527 } s;
4528 } u;
4529 TP_CALLBACK_PRIORITY CallbackPriority;
4530 DWORD Size;
4531 } TP_CALLBACK_ENVIRON_V3, TP_CALLBACK_ENVIRON, *PTP_CALLBACK_ENVIRON;
4532 #else
4533 typedef struct _TP_CALLBACK_ENVIRON_V1 {
4534 TP_VERSION Version;
4535 PTP_POOL Pool;
4536 PTP_CLEANUP_GROUP CleanupGroup;
4537 PTP_CLEANUP_GROUP_CANCEL_CALLBACK CleanupGroupCancelCallback;
4538 PVOID RaceDll;
4539 struct _ACTIVATION_CONTEXT *ActivationContext;
4540 PTP_SIMPLE_CALLBACK FinalizationCallback;
4541 union {
4542 DWORD Flags;
4543 struct {
4544 DWORD LongFunction:1;
4545 DWORD Persistent:1;
4546 DWORD Private:30;
4547 } s;
4548 } u;
4549 } TP_CALLBACK_ENVIRON_V1, TP_CALLBACK_ENVIRON, *PTP_CALLBACK_ENVIRON;
4550 #endif /* (_WIN32_WINNT >= _WIN32_WINNT_WIN7) */
4551
4552 #ifdef __WINESRC__
4553 # define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
4554 #endif
4555
4556 #ifdef _MSC_VER
4557 #pragma warning(pop)
4558 #endif
4559
4560 #endif /* RC_INVOKED */
4561