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