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