libemf 1.0.9
winnt.h
1/*
2 * Win32 definitions for Windows NT
3 *
4 * Copyright 1996 Alexandre Julliard
5 */
6
7#ifndef __WINE_WINNT_H
8#define __WINE_WINNT_H
9
10#include "basetsd.h"
11
12#ifndef RC_INVOKED
13#include <ctype.h>
14#include <stddef.h>
15#include <string.h>
16#endif
17
18
19/* On Windows winnt.h depends on a few windef.h types and macros and thus
20 * is not self-contained. Furthermore windef.h includes winnt.h so that it
21 * would be pointless to try to use winnt.h directly.
22 * But for Wine and Winelib I decided to make winnt.h self-contained by
23 * moving these definitions to winnt.h. It makes no difference to Winelib
24 * programs since they are not using winnt.h directly anyway, and it allows
25 * us to use winnt.h and get a minimal set of definitions.
26 */
27
28/**** Some Wine specific definitions *****/
29
30/* Architecture dependent settings. */
31/* These are hardcoded to avoid dependencies on config.h in Winelib apps. */
32#if defined(__i386__)
33# undef WORDS_BIGENDIAN
34# undef BITFIELDS_BIGENDIAN
35# define ALLOW_UNALIGNED_ACCESS
36#elif defined(__x86_64__)
37# undef WORDS_BIGENDIAN
38# undef BITFIELDS_BIGENDIAN
39# define ALLOW_UNALIGNED_ACCESS
40#elif defined(__alpha__)
41# undef WORDS_BIGENDIAN
42# undef BITFIELDS_BIGENDIAN
43# undef ALLOW_UNALIGNED_ACCESS
44#elif defined(__arm__)
45# undef WORDS_BIGENDIAN
46# undef BITFIELDS_BIGENDIAN
47# undef ALLOW_UNALIGNED_ACCESS
48#elif defined(__aarch64__)
49# undef WORDS_BIGENDIAN
50# undef BITFIELDS_BIGENDIAN
51# undef ALLOW_UNALIGNED_ACCESS
52#elif defined(__loongarch64)
53# undef WORDS_BIGENDIAN
54# undef BITFIELDS_BIGENDIAN
55# undef ALLOW_UNALIGNED_ACCESS
56#elif defined(__sparc__)
57# define WORDS_BIGENDIAN
58# define BITFIELDS_BIGENDIAN
59# undef ALLOW_UNALIGNED_ACCESS
60#elif defined(__PPC__)
61# define WORDS_BIGENDIAN
62# define BITFIELDS_BIGENDIAN
63# undef ALLOW_UNALIGNED_ACCESS
64#elif defined(__s390__)
65# define WORDS_BIGENDIAN
66# define BITFIELDS_BIGENDIAN
67# undef ALLOW_UNALIGNED_ACCESS
68#elif defined(__e2k__)
69# undef WORDS_BIGENDIAN
70# undef BITFIELDS_BIGENDIAN
71# undef ALLOW_UNALIGNED_ACCESS
72#elif defined(__MIPSEB__)
73# define WORDS_BIGENDIAN
74# define BITFIELDS_BIGENDIAN
75# undef ALLOW_UNALIGNED_ACCESS
76#elif defined(__riscv) && defined(__riscv_xlen) && __riscv_xlen == 64
77# undef WORDS_BIGENDIAN
78# undef BITFIELDS_BIGENDIAN
79# undef ALLOW_UNALIGNED_ACCESS
80#elif !defined(RC_INVOKED)
81# error Unknown CPU architecture!
82#endif
83
84
85#ifndef DECLSPEC_ALIGN
86# if defined(_MSC_VER) && (_MSC_VER >= 1300) && !defined(MIDL_PASS)
87# define DECLSPEC_ALIGN(x) __declspec(align(x))
88# elif defined(__GNUC__)
89# define DECLSPEC_ALIGN(x) __attribute__((aligned(x)))
90# else
91# define DECLSPEC_ALIGN(x)
92# endif
93#endif
94
95
96/* Calling conventions definitions */
97
98#ifdef __i386__
99# ifndef _X86_
100# define _X86_
101# endif
102# if defined(__GNUC__) && ((__GNUC__ > 2) || ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 7)))
103# define __stdcall __attribute__((__stdcall__))
104# define __cdecl __attribute__((__cdecl__))
105# else
106# error You need gcc >= 2.7 to build Wine on a 386
107# endif /* __GNUC__ */
108#else /* __i386__ */
109# define __stdcall
110# define __cdecl
111#endif /* __i386__ */
112
113#ifndef __WINE__
114#define pascal __stdcall
115#define _pascal __stdcall
116#ifndef _stdcall
117#define _stdcall __stdcall
118#endif
119#ifndef _fastcall
120#define _fastcall __stdcall
121#endif
122#ifndef __fastcall
123#define __fastcall __stdcall
124#endif
125#define __export __stdcall
126#define cdecl __cdecl
127#ifndef _cdecl
128#define _cdecl __cdecl
129#endif
130
131#define near
132#define far
133#define _near
134#define _far
135#define NEAR
136#define FAR
137
138#ifndef _declspec
139#define _declspec(x)
140#endif
141#ifndef __declspec
142#define __declspec(x)
143#endif
144#endif /* __WINE__ */
145
146#define CALLBACK __stdcall
147#if 0
148#define WINAPI __stdcall
149#else
150#define WINAPI __attribute__((visibility("default")))
151#endif
152#define APIPRIVATE __stdcall
153#define PASCAL __stdcall
154#define CDECL __cdecl
155#define _CDECL __cdecl
156#define WINAPIV __cdecl
157#define APIENTRY WINAPI
158#define CONST const
159
160/* Macro for structure packing and more. */
161
162#ifdef __GNUC__
163#define WINE_PACKED __attribute__((packed))
164#define WINE_UNUSED __attribute__((unused))
165#define WINE_NORETURN __attribute__((noreturn))
166#else
167#define WINE_PACKED /* nothing */
168#define WINE_UNUSED /* nothing */
169#define WINE_NORETURN /* nothing */
170#endif
171
172/* Anonymous union/struct handling */
173
174#ifdef __WINE__
175# define NONAMELESSSTRUCT
176# define NONAMELESSUNION
177#else
178#if !defined(__cplusplus)
179/* for c we can keep the anonymous version (to avoid compiler warnings) */
180#define NONAMELESSSTRUCT
181#define NONAMELESSUNION
182#else
183/* Anonymous struct support starts with gcc/g++ 2.96 */
184# if !defined(NONAMELESSSTRUCT) && defined(__GNUC__) && ((__GNUC__ < 2) || ((__GNUC__ == 2) && (__GNUC_MINOR__ < 96)))
185/* && !defined(__cplusplus) */
186# define NONAMELESSSTRUCT
187# endif
188/* Anonymous unions support starts with gcc 2.96/g++ 2.95 */
189# if !defined(NONAMELESSUNION) && defined(__GNUC__) && ((__GNUC__ < 2) || ((__GNUC__ == 2) && ((__GNUC_MINOR__ < 95) || ((__GNUC_MINOR__ == 95) && !defined(__cplusplus)))))
190# define NONAMELESSUNION
191# endif
192#endif
193#endif
194
195#ifndef NONAMELESSSTRUCT
196#define DUMMYSTRUCTNAME
197#define DUMMYSTRUCTNAME1
198#define DUMMYSTRUCTNAME2
199#define DUMMYSTRUCTNAME3
200#define DUMMYSTRUCTNAME4
201#define DUMMYSTRUCTNAME5
202#else /* !defined(NONAMELESSSTRUCT) */
203#define DUMMYSTRUCTNAME s
204#define DUMMYSTRUCTNAME1 s1
205#define DUMMYSTRUCTNAME2 s2
206#define DUMMYSTRUCTNAME3 s3
207#define DUMMYSTRUCTNAME4 s4
208#define DUMMYSTRUCTNAME5 s5
209#endif /* !defined(NONAMELESSSTRUCT) */
210
211#ifndef NONAMELESSUNION
212#define DUMMYUNIONNAME
213#define DUMMYUNIONNAME1
214#define DUMMYUNIONNAME2
215#define DUMMYUNIONNAME3
216#define DUMMYUNIONNAME4
217#define DUMMYUNIONNAME5
218#define DUMMYUNIONNAME6
219#define DUMMYUNIONNAME7
220#define DUMMYUNIONNAME8
221#else /* !defined(NONAMELESSUNION) */
222#define DUMMYUNIONNAME u
223#define DUMMYUNIONNAME1 u1
224#define DUMMYUNIONNAME2 u2
225#define DUMMYUNIONNAME3 u3
226#define DUMMYUNIONNAME4 u4
227#define DUMMYUNIONNAME5 u5
228#define DUMMYUNIONNAME6 u6
229#define DUMMYUNIONNAME7 u7
230#define DUMMYUNIONNAME8 u8
231#endif /* !defined(NONAMELESSUNION) */
232
233
234/**** Parts of windef.h that are needed here *****/
235
236/* Misc. constants. */
237
238#undef NULL
239#ifdef __cplusplus
240#define NULL 0
241#else
242#define NULL ((void*)0)
243#endif
244
245#ifdef FALSE
246#undef FALSE
247#endif
248#define FALSE 0
249
250#ifdef TRUE
251#undef TRUE
252#endif
253#define TRUE 1
254
255#ifndef IN
256#define IN
257#endif
258
259#ifndef OUT
260#define OUT
261#endif
262
263#ifndef OPTIONAL
264#define OPTIONAL
265#endif
266
267/* Standard data types */
268typedef const void *PCVOID, *LPCVOID;
269typedef int BOOL, *PBOOL, *LPBOOL;
270typedef unsigned char BYTE, *PBYTE, *LPBYTE;
271typedef unsigned char UCHAR, *PUCHAR;
272typedef unsigned short USHORT, *PUSHORT, *LPUSHORT;
273typedef unsigned short WORD, *PWORD, *LPWORD;
274typedef int INT, *PINT, *LPINT;
275typedef unsigned int UINT, *PUINT, *LPUINT;
276/* Not sure this is correct. Probably should depend on the compiler, too. */
277#if defined( __LP64__) || defined(__alpha__)
278typedef unsigned int DWORD, *PDWORD, *LPDWORD;
279typedef unsigned int ULONG, *PULONG, *LPULONG;
280#else
281typedef unsigned long DWORD, *PDWORD, *LPDWORD;
282typedef unsigned long ULONG, *PULONG, *LPULONG;
283#endif
284typedef float FLOAT, *PFLOAT, *LPFLOAT;
285typedef double DOUBLE, *PDOUBLE, *LPDOUBLE;
286typedef double DATE;
287
288
289/**** winnt.h proper *****/
290
291/* Microsoft's macros for declaring functions */
292
293#ifdef __cplusplus
294# define EXTERN_C extern "C"
295#else
296# define EXTERN_C extern
297#endif
298
299#ifndef __WINE__
300#define STDMETHODCALLTYPE __stdcall
301#define STDMETHODVCALLTYPE __cdecl
302#define STDAPICALLTYPE __stdcall
303#define STDAPIVCALLTYPE __cdecl
304
305#define STDAPI EXTERN_C HRESULT STDAPICALLTYPE
306#define STDAPI_(type) EXTERN_C type STDAPICALLTYPE
307#define STDMETHODIMP HRESULT STDMETHODCALLTYPE
308#define STDMETHODIMP_(type) type STDMETHODCALLTYPE
309#define STDAPIV EXTERN_C HRESULT STDAPIVCALLTYPE
310#define STDAPIV_(type) EXTERN_C type STDAPIVCALLTYPE
311#define STDMETHODIMPV HRESULT STDMETHODVCALLTYPE
312#define STDMETHODIMPV_(type) type STDMETHODVCALLTYPE
313#endif
314
315/* Define the basic types */
316#ifndef VOID
317#define VOID void
318#endif
319typedef VOID *PVOID, *LPVOID;
320typedef BYTE BOOLEAN, *PBOOLEAN;
321typedef char CHAR, *PCHAR;
322typedef short SHORT, *PSHORT;
323#if defined(__LP64__) || defined(__alpha__)
324typedef int LONG, *PLONG, *LPLONG;
325#else
326typedef long LONG, *PLONG, *LPLONG;
327#endif
328
329/* Some systems might have wchar_t, but we really need 16 bit characters */
330#ifndef WINE_WCHAR_DEFINED
331#ifdef WINE_UNICODE_NATIVE
332typedef wchar_t WCHAR, *PWCHAR;
333#else
334typedef unsigned short WCHAR, *PWCHAR;
335#endif
336#define WINE_WCHAR_DEFINED
337#endif
338
339/* 'Extended/Wide' numerical types */
340#ifndef _ULONGLONG_
341#define _ULONGLONG_
342typedef __int64 LONGLONG, *PLONGLONG;
343typedef __uint64 ULONGLONG, *PULONGLONG;
344#endif
345
346#ifndef _DWORDLONG_
347#define _DWORDLONG_
348typedef ULONGLONG DWORDLONG, *PDWORDLONG;
349#endif
350
351/* ANSI string types */
352typedef CHAR *PCH, *LPCH;
353typedef const CHAR *PCCH, *LPCCH;
354typedef CHAR *PSTR, *LPSTR;
355typedef const CHAR *PCSTR, *LPCSTR;
356
357/* Unicode string types */
358typedef WCHAR *PWCH, *LPWCH;
359typedef const WCHAR *PCWCH, *LPCWCH;
360typedef WCHAR *PWSTR, *LPWSTR;
361typedef const WCHAR *PCWSTR, *LPCWSTR;
362
363/* Neutral character and string types */
364/* These are only defined for Winelib, i.e. _not_ defined for
365 * the emulator. The reason is they depend on the UNICODE
366 * macro which only exists in the user's code.
367 */
368#ifndef __WINE__
369# ifdef WINE_UNICODE_REWRITE
370
371/* Use this if your compiler does not provide a 16bit wchar_t type.
372 * Note that you will need to specify -fwritable-strings or an option
373 * to this effect.
374 * In C++ both WINE_UNICODE_TEXT('c') and WINE_UNICODE_TEXT("str") are
375 * supported, but only the string form can be supported in C.
376 */
377EXTERN_C unsigned short* wine_rewrite_s4tos2(const wchar_t* str4);
378# ifdef __cplusplus
379inline WCHAR* wine_unicode_text(const wchar_t* str4)
380{
381 return (WCHAR*)wine_rewrite_s4tos2(str4);
382}
383inline WCHAR wine_unicode_text(wchar_t chr4)
384{
385 return (WCHAR)chr4;
386}
387# define WINE_UNICODE_TEXT(x) wine_unicode_text(L##x)
388# else /* __cplusplus */
389# define WINE_UNICODE_TEXT(x) ((WCHAR*)wine_rewrite_s4tos2(L##x))
390# endif /* __cplusplus */
391
392# else /* WINE_UNICODE_REWRITE */
393
394/* Define WINE_UNICODE_NATIVE if:
395 * - your compiler provides a 16bit wchar_t type, e.g. gcc >= 2.96 with
396 * -fshort-wchar option
397 * - or if you decide to use the native 32bit Unix wchar_t type. Be aware
398 * though that the Wine APIs only support 16bit WCHAR characters for
399 * binary compatibility reasons.
400 * - or define nothing at all if you don't use Unicode, and blissfully
401 * ignore the issue :-)
402 */
403# define WINE_UNICODE_TEXT(string) L##string
404
405# endif /* WINE_UNICODE_REWRITE */
406
407# ifdef UNICODE
408typedef WCHAR TCHAR, *PTCHAR;
409typedef LPWSTR PTSTR, LPTSTR;
410typedef LPCWSTR PCTSTR, LPCTSTR;
411# define __TEXT(string) WINE_UNICODE_TEXT(string)
412# else /* UNICODE */
413typedef CHAR TCHAR, *PTCHAR;
414typedef LPSTR PTSTR, LPTSTR;
415typedef LPCSTR PCTSTR, LPCTSTR;
416# define __TEXT(string) string
417# endif /* UNICODE */
418# define TEXT(quote) __TEXT(quote)
419#endif /* __WINE__ */
420
421/* Misc common WIN32 types */
422typedef LONG HRESULT;
423typedef DWORD LCID, *PLCID;
424typedef WORD LANGID;
425typedef DWORD EXECUTION_STATE;
426
427/* Handle type */
428
429/* FIXME: Wine does not compile with strict on, therefore strict
430 * handles are presently only usable on machines where sizeof(UINT) ==
431 * sizeof(void*). HANDLEs are supposed to be void* but a large amount
432 * of WINE code operates on HANDLES as if they are UINTs. So to WINE
433 * they exist as UINTs but to the Winelib user who turns on strict,
434 * they exist as void*. If there is a size difference between UINT and
435 * void* then things get ugly.
436 *
437 * Here is the plan to convert Wine to STRICT:
438 *
439 * Types will be converted one at a time by volunteers who will compile
440 * Wine with STRICT turned on. Handles that have not been converted yet
441 * will be declared with DECLARE_OLD_HANDLE. Converted handles are
442 * declared with DECLARE_HANDLE.
443 * See the bug report 90 for more details:
444 * http://wine.codeweavers.com/bugzilla/show_bug.cgi?id=90
445 */
446/*
447 * when compiling Wine we always treat HANDLE as an UINT. Then when
448 * we're ready we'll remove the '!defined(__WINE__)' (the equivalent
449 * of converting it from DECLARE_OLD_HANDLE to DECLARE_HANDLE).
450 */
451#if defined(STRICT) && !defined(__WINE__)
452typedef VOID* HANDLE;
453#define DECLARE_OLD_HANDLE(a) \
454 typedef struct a##__ { int unused; } *a; \
455 typedef a *P##a, *LP##a
456
457#else
458typedef UINT HANDLE;
459#define DECLARE_OLD_HANDLE(a) \
460 typedef HANDLE a; \
461 typedef a *P##a, *LP##a
462#endif
463typedef HANDLE *PHANDLE, *LPHANDLE;
464
465#ifdef STRICT
466#define DECLARE_HANDLE(a) \
467 typedef struct a##__ { int unused; } *a; \
468 typedef a *P##a, *LP##a
469#else /*STRICT*/
470#define DECLARE_HANDLE(a) \
471 typedef HANDLE a; \
472 typedef a *P##a, *LP##a
473#endif /*STRICT*/
474
475/* Defines */
476
477/* Argument 1 passed to the DllEntryProc. */
478#define DLL_PROCESS_DETACH 0 /* detach process (unload library) */
479#define DLL_PROCESS_ATTACH 1 /* attach process (load library) */
480#define DLL_THREAD_ATTACH 2 /* attach new thread */
481#define DLL_THREAD_DETACH 3 /* detach thread */
482
483
484/* u.x.wProcessorArchitecture (NT) */
485#define PROCESSOR_ARCHITECTURE_INTEL 0
486#define PROCESSOR_ARCHITECTURE_MIPS 1
487#define PROCESSOR_ARCHITECTURE_ALPHA 2
488#define PROCESSOR_ARCHITECTURE_PPC 3
489#define PROCESSOR_ARCHITECTURE_SHX 4
490#define PROCESSOR_ARCHITECTURE_ARM 5
491#define PROCESSOR_ARCHITECTURE_UNKNOWN 0xFFFF
492
493/* dwProcessorType */
494#define PROCESSOR_INTEL_386 386
495#define PROCESSOR_INTEL_486 486
496#define PROCESSOR_INTEL_PENTIUM 586
497#define PROCESSOR_INTEL_860 860
498#define PROCESSOR_MIPS_R2000 2000
499#define PROCESSOR_MIPS_R3000 3000
500#define PROCESSOR_MIPS_R4000 4000
501#define PROCESSOR_ALPHA_21064 21064
502#define PROCESSOR_PPC_601 601
503#define PROCESSOR_PPC_603 603
504#define PROCESSOR_PPC_604 604
505#define PROCESSOR_PPC_620 620
506#define PROCESSOR_HITACHI_SH3 10003
507#define PROCESSOR_HITACHI_SH3E 10004
508#define PROCESSOR_HITACHI_SH4 10005
509#define PROCESSOR_MOTOROLA_821 821
510#define PROCESSOR_SHx_SH3 103
511#define PROCESSOR_SHx_SH4 104
512#define PROCESSOR_STRONGARM 2577
513#define PROCESSOR_ARM720 1824 /* 0x720 */
514#define PROCESSOR_ARM820 2080 /* 0x820 */
515#define PROCESSOR_ARM920 2336 /* 0x920 */
516#define PROCESSOR_ARM_7TDMI 70001
517
518typedef struct _MEMORY_BASIC_INFORMATION
519{
520 LPVOID BaseAddress;
521 LPVOID AllocationBase;
522 DWORD AllocationProtect;
523 DWORD RegionSize;
524 DWORD State;
525 DWORD Protect;
526 DWORD Type;
527} MEMORY_BASIC_INFORMATION,*LPMEMORY_BASIC_INFORMATION,*PMEMORY_BASIC_INFORMATION;
528
529#define PAGE_NOACCESS 0x01
530#define PAGE_READONLY 0x02
531#define PAGE_READWRITE 0x04
532#define PAGE_WRITECOPY 0x08
533#define PAGE_EXECUTE 0x10
534#define PAGE_EXECUTE_READ 0x20
535#define PAGE_EXECUTE_READWRITE 0x40
536#define PAGE_EXECUTE_WRITECOPY 0x80
537#define PAGE_GUARD 0x100
538#define PAGE_NOCACHE 0x200
539
540#define MEM_COMMIT 0x00001000
541#define MEM_RESERVE 0x00002000
542#define MEM_DECOMMIT 0x00004000
543#define MEM_RELEASE 0x00008000
544#define MEM_FREE 0x00010000
545#define MEM_PRIVATE 0x00020000
546#define MEM_MAPPED 0x00040000
547#define MEM_RESET 0x00080000
548#define MEM_TOP_DOWN 0x00100000
549#ifdef __WINE__
550#define MEM_SYSTEM 0x80000000
551#endif
552
553#define SEC_FILE 0x00800000
554#define SEC_IMAGE 0x01000000
555#define SEC_RESERVE 0x04000000
556#define SEC_COMMIT 0x08000000
557#define SEC_NOCACHE 0x10000000
558#define MEM_IMAGE SEC_IMAGE
559
560
561#define MINCHAR 0x80
562#define MAXCHAR 0x7f
563#define MINSHORT 0x8000
564#define MAXSHORT 0x7fff
565#define MINLONG 0x80000000
566#define MAXLONG 0x7fffffff
567#define MAXBYTE 0xff
568#define MAXWORD 0xffff
569#define MAXDWORD 0xffffffff
570
571#define FIELD_OFFSET(type, field) \
572 ((LONG)(INT)&(((type *)0)->field))
573
574#define CONTAINING_RECORD(address, type, field) \
575 ((type *)((PCHAR)(address) - (PCHAR)(&((type *)0)->field)))
576
577/* Types */
578
579typedef struct _LIST_ENTRY {
580 struct _LIST_ENTRY *Flink;
581 struct _LIST_ENTRY *Blink;
582} LIST_ENTRY, *PLIST_ENTRY;
583
584typedef struct _SINGLE_LIST_ENTRY {
585 struct _SINGLE_LIST_ENTRY *Next;
586} SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
587
588/* Heap flags */
589
590#define HEAP_NO_SERIALIZE 0x00000001
591#define HEAP_GROWABLE 0x00000002
592#define HEAP_GENERATE_EXCEPTIONS 0x00000004
593#define HEAP_ZERO_MEMORY 0x00000008
594#define HEAP_REALLOC_IN_PLACE_ONLY 0x00000010
595#define HEAP_TAIL_CHECKING_ENABLED 0x00000020
596#define HEAP_FREE_CHECKING_ENABLED 0x00000040
597#define HEAP_DISABLE_COALESCE_ON_FREE 0x00000080
598#define HEAP_CREATE_ALIGN_16 0x00010000
599#define HEAP_CREATE_ENABLE_TRACING 0x00020000
600
601/* This flag allows it to create heaps shared by all processes under win95,
602 FIXME: correct name */
603#define HEAP_SHARED 0x04000000
604
605/* Processor feature flags. */
606#define PF_FLOATING_POINT_PRECISION_ERRATA 0
607#define PF_FLOATING_POINT_EMULATED 1
608#define PF_COMPARE_EXCHANGE_DOUBLE 2
609#define PF_MMX_INSTRUCTIONS_AVAILABLE 3
610#define PF_PPC_MOVEMEM_64BIT_OK 4
611#define PF_ALPHA_BYTE_INSTRUCTIONS 5
612#define PF_XMMI_INSTRUCTIONS_AVAILABLE 6
613#define PF_AMD3D_INSTRUCTIONS_AVAILABLE 7
614#define PF_RDTSC_INSTRUCTION_AVAILABLE 8
615
616
617/* Execution state flags */
618#define ES_SYSTEM_REQUIRED 0x00000001
619#define ES_DISPLAY_REQUIRED 0x00000002
620#define ES_USER_PRESENT 0x00000004
621#define ES_CONTINUOUS 0x80000000
622
623/* The Win32 register context */
624
625/* CONTEXT is the CPU-dependent context; it should be used */
626/* wherever a platform-specific context is needed (e.g. exception */
627/* handling, Win32 register functions). */
628
629/* CONTEXT86 is the i386-specific context; it should be used */
630/* wherever only a 386 context makes sense (e.g. DOS interrupts, */
631/* Win16 register functions), so that this code can be compiled */
632/* on all platforms. */
633
634#define SIZE_OF_80387_REGISTERS 80
635
636typedef struct _FLOATING_SAVE_AREA
637{
638 DWORD ControlWord;
639 DWORD StatusWord;
640 DWORD TagWord;
641 DWORD ErrorOffset;
642 DWORD ErrorSelector;
643 DWORD DataOffset;
644 DWORD DataSelector;
645 BYTE RegisterArea[SIZE_OF_80387_REGISTERS];
646 DWORD Cr0NpxState;
647} FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
648
649#define MAXIMUM_SUPPORTED_EXTENSION 512
650
651typedef struct _CONTEXT86
652{
653 DWORD ContextFlags;
654
655 /* These are selected by CONTEXT_DEBUG_REGISTERS */
656 DWORD Dr0;
657 DWORD Dr1;
658 DWORD Dr2;
659 DWORD Dr3;
660 DWORD Dr6;
661 DWORD Dr7;
662
663 /* These are selected by CONTEXT_FLOATING_POINT */
664 FLOATING_SAVE_AREA FloatSave;
665
666 /* These are selected by CONTEXT_SEGMENTS */
667 DWORD SegGs;
668 DWORD SegFs;
669 DWORD SegEs;
670 DWORD SegDs;
671
672 /* These are selected by CONTEXT_INTEGER */
673 DWORD Edi;
674 DWORD Esi;
675 DWORD Ebx;
676 DWORD Edx;
677 DWORD Ecx;
678 DWORD Eax;
679
680 /* These are selected by CONTEXT_CONTROL */
681 DWORD Ebp;
682 DWORD Eip;
683 DWORD SegCs;
684 DWORD EFlags;
685 DWORD Esp;
686 DWORD SegSs;
687
688 BYTE ExtendedRegisters[MAXIMUM_SUPPORTED_EXTENSION];
689} CONTEXT86;
690
691#define CONTEXT_X86 0x00010000
692#define CONTEXT_i386 CONTEXT_X86
693#define CONTEXT_i486 CONTEXT_X86
694
695#define CONTEXT86_CONTROL (CONTEXT_i386 | 0x0001) /* SS:SP, CS:IP, FLAGS, BP */
696#define CONTEXT86_INTEGER (CONTEXT_i386 | 0x0002) /* AX, BX, CX, DX, SI, DI */
697#define CONTEXT86_SEGMENTS (CONTEXT_i386 | 0x0004) /* DS, ES, FS, GS */
698#define CONTEXT86_FLOATING_POINT (CONTEXT_i386 | 0x0008L) /* 387 state */
699#define CONTEXT86_DEBUG_REGISTERS (CONTEXT_i386 | 0x0010L) /* DB 0-3,6,7 */
700#define CONTEXT86_FULL (CONTEXT86_CONTROL | CONTEXT86_INTEGER | CONTEXT86_SEGMENTS)
701
702/* i386 context definitions */
703#ifdef __i386__
704
705#define CONTEXT_CONTROL CONTEXT86_CONTROL
706#define CONTEXT_INTEGER CONTEXT86_INTEGER
707#define CONTEXT_SEGMENTS CONTEXT86_SEGMENTS
708#define CONTEXT_FLOATING_POINT CONTEXT86_FLOATING_POINT
709#define CONTEXT_DEBUG_REGISTERS CONTEXT86_DEBUG_REGISTERS
710#define CONTEXT_FULL CONTEXT86_FULL
711
712typedef CONTEXT86 CONTEXT;
713
714#endif /* __i386__ */
715
716/* x86-64 context definitions */
717#if defined(__x86_64__)
718
719#define CONTEXT_AMD64 0x00100000
720
721#define CONTEXT_CONTROL (CONTEXT_AMD64 | 0x0001)
722#define CONTEXT_INTEGER (CONTEXT_AMD64 | 0x0002)
723#define CONTEXT_SEGMENTS (CONTEXT_AMD64 | 0x0004)
724#define CONTEXT_FLOATING_POINT (CONTEXT_AMD64 | 0x0008L)
725#define CONTEXT_DEBUG_REGISTERS (CONTEXT_AMD64 | 0x0010L)
726#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_FLOATING_POINT)
727#define CONTEXT_ALL (CONTEXT_CONTROL | CONTEXT_INTEGER | CONTEXT_SEGMENTS | CONTEXT_FLOATING_POINT | CONTEXT_DEBUG_REGISTERS)
728
729#define EXCEPTION_READ_FAULT 0
730#define EXCEPTION_WRITE_FAULT 1
731#define EXCEPTION_EXECUTE_FAULT 8
732
733typedef struct DECLSPEC_ALIGN(16) _M128A {
734 ULONGLONG Low;
735 LONGLONG High;
736} M128A, *PM128A;
737
738typedef struct _XMM_SAVE_AREA32 {
739 WORD ControlWord; /* 000 */
740 WORD StatusWord; /* 002 */
741 BYTE TagWord; /* 004 */
742 BYTE Reserved1; /* 005 */
743 WORD ErrorOpcode; /* 006 */
744 DWORD ErrorOffset; /* 008 */
745 WORD ErrorSelector; /* 00c */
746 WORD Reserved2; /* 00e */
747 DWORD DataOffset; /* 010 */
748 WORD DataSelector; /* 014 */
749 WORD Reserved3; /* 016 */
750 DWORD MxCsr; /* 018 */
751 DWORD MxCsr_Mask; /* 01c */
752 M128A FloatRegisters[8]; /* 020 */
753 M128A XmmRegisters[16]; /* 0a0 */
754 BYTE Reserved4[96]; /* 1a0 */
755} XMM_SAVE_AREA32, *PXMM_SAVE_AREA32;
756
757typedef struct DECLSPEC_ALIGN(16) _CONTEXT {
758 DWORD64 P1Home; /* 000 */
759 DWORD64 P2Home; /* 008 */
760 DWORD64 P3Home; /* 010 */
761 DWORD64 P4Home; /* 018 */
762 DWORD64 P5Home; /* 020 */
763 DWORD64 P6Home; /* 028 */
764
765 /* Control flags */
766 DWORD ContextFlags; /* 030 */
767 DWORD MxCsr; /* 034 */
768
769 /* Segment */
770 WORD SegCs; /* 038 */
771 WORD SegDs; /* 03a */
772 WORD SegEs; /* 03c */
773 WORD SegFs; /* 03e */
774 WORD SegGs; /* 040 */
775 WORD SegSs; /* 042 */
776 DWORD EFlags; /* 044 */
777
778 /* Debug */
779 DWORD64 Dr0; /* 048 */
780 DWORD64 Dr1; /* 050 */
781 DWORD64 Dr2; /* 058 */
782 DWORD64 Dr3; /* 060 */
783 DWORD64 Dr6; /* 068 */
784 DWORD64 Dr7; /* 070 */
785
786 /* Integer */
787 DWORD64 Rax; /* 078 */
788 DWORD64 Rcx; /* 080 */
789 DWORD64 Rdx; /* 088 */
790 DWORD64 Rbx; /* 090 */
791 DWORD64 Rsp; /* 098 */
792 DWORD64 Rbp; /* 0a0 */
793 DWORD64 Rsi; /* 0a8 */
794 DWORD64 Rdi; /* 0b0 */
795 DWORD64 R8; /* 0b8 */
796 DWORD64 R9; /* 0c0 */
797 DWORD64 R10; /* 0c8 */
798 DWORD64 R11; /* 0d0 */
799 DWORD64 R12; /* 0d8 */
800 DWORD64 R13; /* 0e0 */
801 DWORD64 R14; /* 0e8 */
802 DWORD64 R15; /* 0f0 */
803
804 /* Counter */
805 DWORD64 Rip; /* 0f8 */
806
807 /* Floating point */
808 union {
809 XMM_SAVE_AREA32 FltSave; /* 100 */
810 struct {
811 M128A Header[2]; /* 100 */
812 M128A Legacy[8]; /* 120 */
813 M128A Xmm0; /* 1a0 */
814 M128A Xmm1; /* 1b0 */
815 M128A Xmm2; /* 1c0 */
816 M128A Xmm3; /* 1d0 */
817 M128A Xmm4; /* 1e0 */
818 M128A Xmm5; /* 1f0 */
819 M128A Xmm6; /* 200 */
820 M128A Xmm7; /* 210 */
821 M128A Xmm8; /* 220 */
822 M128A Xmm9; /* 230 */
823 M128A Xmm10; /* 240 */
824 M128A Xmm11; /* 250 */
825 M128A Xmm12; /* 260 */
826 M128A Xmm13; /* 270 */
827 M128A Xmm14; /* 280 */
828 M128A Xmm15; /* 290 */
829 } DUMMYSTRUCTNAME;
830 } DUMMYUNIONNAME;
831
832 /* Vector */
833 M128A VectorRegister[26]; /* 300 */
834 DWORD64 VectorControl; /* 4a0 */
835
836 /* Debug control */
837 DWORD64 DebugControl; /* 4a8 */
838 DWORD64 LastBranchToRip; /* 4b0 */
839 DWORD64 LastBranchFromRip; /* 4b8 */
840 DWORD64 LastExceptionToRip; /* 4c0 */
841 DWORD64 LastExceptionFromRip; /* 4c8 */
842} CONTEXT;
843
844typedef struct _RUNTIME_FUNCTION
845{
846 DWORD BeginAddress;
847 DWORD EndAddress;
848 DWORD UnwindData;
849} RUNTIME_FUNCTION, *PRUNTIME_FUNCTION;
850
851#define UNWIND_HISTORY_TABLE_SIZE 12
852
853typedef struct _UNWIND_HISTORY_TABLE_ENTRY
854{
855 ULONG64 ImageBase;
856 PRUNTIME_FUNCTION FunctionEntry;
857} UNWIND_HISTORY_TABLE_ENTRY, *PUNWIND_HISTORY_TABLE_ENTRY;
858
859#define UNWIND_HISTORY_TABLE_NONE 0
860#define UNWIND_HISTORY_TABLE_GLOBAL 1
861#define UNWIND_HISTORY_TABLE_LOCAL 2
862
863typedef struct _UNWIND_HISTORY_TABLE
864{
865 ULONG Count;
866 UCHAR Search;
867 ULONG64 LowAddress;
868 ULONG64 HighAddress;
869 UNWIND_HISTORY_TABLE_ENTRY Entry[UNWIND_HISTORY_TABLE_SIZE];
870} UNWIND_HISTORY_TABLE, *PUNWIND_HISTORY_TABLE;
871
872typedef struct _KNONVOLATILE_CONTEXT_POINTERS
873{
874 union
875 {
876 PM128A FloatingContext[16];
877 struct
878 {
879 PM128A Xmm0;
880 PM128A Xmm1;
881 PM128A Xmm2;
882 PM128A Xmm3;
883 PM128A Xmm4;
884 PM128A Xmm5;
885 PM128A Xmm6;
886 PM128A Xmm7;
887 PM128A Xmm8;
888 PM128A Xmm9;
889 PM128A Xmm10;
890 PM128A Xmm11;
891 PM128A Xmm12;
892 PM128A Xmm13;
893 PM128A Xmm14;
894 PM128A Xmm15;
895 } DUMMYSTRUCTNAME1;
896 } DUMMYUNIONNAME1;
897
898 union
899 {
900 PULONG64 IntegerContext[16];
901 struct
902 {
903 PULONG64 Rax;
904 PULONG64 Rcx;
905 PULONG64 Rdx;
906 PULONG64 Rbx;
907 PULONG64 Rsp;
908 PULONG64 Rbp;
909 PULONG64 Rsi;
910 PULONG64 Rdi;
911 PULONG64 R8;
912 PULONG64 R9;
913 PULONG64 R10;
914 PULONG64 R11;
915 PULONG64 R12;
916 PULONG64 R13;
917 PULONG64 R14;
918 PULONG64 R15;
919 } DUMMYSTRUCTNAME2;
920 } DUMMYUNIONNAME2;
921} KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS;
922
923BOOLEAN CDECL RtlAddFunctionTable(RUNTIME_FUNCTION*,DWORD,DWORD64);
924BOOLEAN CDECL RtlDeleteFunctionTable(RUNTIME_FUNCTION*);
925PRUNTIME_FUNCTION WINAPI RtlLookupFunctionEntry(DWORD64,DWORD64*,UNWIND_HISTORY_TABLE*);
926PVOID WINAPI RtlVirtualUnwind(ULONG,ULONG64,ULONG64,RUNTIME_FUNCTION*,CONTEXT*,PVOID*,ULONG64*,KNONVOLATILE_CONTEXT_POINTERS*);
927
928#define UNW_FLAG_NHANDLER 0
929#define UNW_FLAG_EHANDLER 1
930#define UNW_FLAG_UHANDLER 2
931#define UNW_FLAG_CHAININFO 4
932
933#endif /* __x86_64__ */
934
935/* Alpha context definitions */
936#if defined(__alpha__)
937
938#define CONTEXT_ALPHA 0x00020000
939
940#define CONTEXT_CONTROL (CONTEXT_ALPHA | 0x00000001L)
941#define CONTEXT_FLOATING_POINT (CONTEXT_ALPHA | 0x00000002L)
942#define CONTEXT_INTEGER (CONTEXT_ALPHA | 0x00000004L)
943#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
944
945typedef struct _CONTEXT
946{
947 /* selected by CONTEXT_FLOATING_POINT */
948 ULONGLONG FltF0;
949 ULONGLONG FltF1;
950 ULONGLONG FltF2;
951 ULONGLONG FltF3;
952 ULONGLONG FltF4;
953 ULONGLONG FltF5;
954 ULONGLONG FltF6;
955 ULONGLONG FltF7;
956 ULONGLONG FltF8;
957 ULONGLONG FltF9;
958 ULONGLONG FltF10;
959 ULONGLONG FltF11;
960 ULONGLONG FltF12;
961 ULONGLONG FltF13;
962 ULONGLONG FltF14;
963 ULONGLONG FltF15;
964 ULONGLONG FltF16;
965 ULONGLONG FltF17;
966 ULONGLONG FltF18;
967 ULONGLONG FltF19;
968 ULONGLONG FltF20;
969 ULONGLONG FltF21;
970 ULONGLONG FltF22;
971 ULONGLONG FltF23;
972 ULONGLONG FltF24;
973 ULONGLONG FltF25;
974 ULONGLONG FltF26;
975 ULONGLONG FltF27;
976 ULONGLONG FltF28;
977 ULONGLONG FltF29;
978 ULONGLONG FltF30;
979 ULONGLONG FltF31;
980
981 /* selected by CONTEXT_INTEGER */
982 ULONGLONG IntV0;
983 ULONGLONG IntT0;
984 ULONGLONG IntT1;
985 ULONGLONG IntT2;
986 ULONGLONG IntT3;
987 ULONGLONG IntT4;
988 ULONGLONG IntT5;
989 ULONGLONG IntT6;
990 ULONGLONG IntT7;
991 ULONGLONG IntS0;
992 ULONGLONG IntS1;
993 ULONGLONG IntS2;
994 ULONGLONG IntS3;
995 ULONGLONG IntS4;
996 ULONGLONG IntS5;
997 ULONGLONG IntFp;
998 ULONGLONG IntA0;
999 ULONGLONG IntA1;
1000 ULONGLONG IntA2;
1001 ULONGLONG IntA3;
1002 ULONGLONG IntA4;
1003 ULONGLONG IntA5;
1004 ULONGLONG IntT8;
1005 ULONGLONG IntT9;
1006 ULONGLONG IntT10;
1007 ULONGLONG IntT11;
1008 ULONGLONG IntRa;
1009 ULONGLONG IntT12;
1010 ULONGLONG IntAt;
1011 ULONGLONG IntGp;
1012 ULONGLONG IntSp;
1013 ULONGLONG IntZero;
1014
1015 /* selected by CONTEXT_FLOATING_POINT */
1016 ULONGLONG Fpcr;
1017 ULONGLONG SoftFpcr;
1018
1019 /* selected by CONTEXT_CONTROL */
1020 ULONGLONG Fir;
1021 DWORD Psr;
1022 DWORD ContextFlags;
1023 DWORD Fill[4];
1024} CONTEXT;
1025
1026#define _QUAD_PSR_OFFSET HighSoftFpcr
1027#define _QUAD_FLAGS_OFFSET HighFir
1028
1029#endif /* _ALPHA_ */
1030
1031#ifdef __loongarch64
1032/*
1033 * FIXME:
1034 *
1035 * There is not yet an official CONTEXT structure defined for the
1036 * loongarch64 architecture (64-bit LE), so I just made one up.
1037 *
1038 */
1039
1040#define CONTEXT_LOONGARCH64 0x4000000
1041#define CONTEXT_CONTROL (CONTEXT_LOONGARCH64 | 0x00000001)
1042#define CONTEXT_INTEGER (CONTEXT_LOONGARCH64 | 0x00000002)
1043#define CONTEXT_FLOATING_POINT (CONTEXT_LOONGARCH64 | 0x00000004)
1044#define CONTEXT_DEBUG_REGISTERS (CONTEXT_LOONGARCH64 | 0x00000008)
1045
1046#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1047
1048#define EXCEPTION_READ_FAULT 0
1049#define EXCEPTION_WRITE_FAULT 1
1050#define EXCEPTION_EXECUTE_FAULT 8
1051
1052typedef struct _CONTEXT {
1053 ULONG ContextFlags;
1054
1055 /* This section is specified/returned if the ContextFlags word contains
1056 the flag CONTEXT_INTEGER. */
1057 ULONGLONG X0;
1058 ULONGLONG X1;
1059 ULONGLONG X2;
1060 ULONGLONG X3;
1061 ULONGLONG X4;
1062 ULONGLONG X5;
1063 ULONGLONG X6;
1064 ULONGLONG X7;
1065 ULONGLONG X8;
1066 ULONGLONG X9;
1067 ULONGLONG X10;
1068 ULONGLONG X11;
1069 ULONGLONG X12;
1070 ULONGLONG X13;
1071 ULONGLONG X14;
1072 ULONGLONG X15;
1073 ULONGLONG X16;
1074 ULONGLONG X17;
1075 ULONGLONG X18;
1076 ULONGLONG X19;
1077 ULONGLONG X20;
1078 ULONGLONG X21;
1079 ULONGLONG X22;
1080 ULONGLONG X23;
1081 ULONGLONG X24;
1082 ULONGLONG X25;
1083 ULONGLONG X26;
1084 ULONGLONG X27;
1085 ULONGLONG X28;
1086 ULONGLONG X29;
1087 ULONGLONG X30;
1088 ULONGLONG X31;
1089
1090 /* These are selected by CONTEXT_CONTROL */
1091 ULONGLONG Sp;
1092 ULONGLONG Pc;
1093 ULONGLONG PState;
1094
1095 /* These are selected by CONTEXT_FLOATING_POINT */
1096 /* FIXME */
1097} CONTEXT;
1098
1099#endif /* __loongarch64 */
1100
1101/* Mips context definitions */
1102#if defined(_MIPS_) || defined(__MIPS__) || defined(__mips__)
1103
1104#define CONTEXT_R4000 0x00010000
1105
1106#define CONTEXT_CONTROL (CONTEXT_R4000 | 0x00000001)
1107#define CONTEXT_FLOATING_POINT (CONTEXT_R4000 | 0x00000002)
1108#define CONTEXT_INTEGER (CONTEXT_R4000 | 0x00000004)
1109
1110#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1111
1112typedef struct _CONTEXT
1113{
1114 DWORD Argument[4];
1115 /* These are selected by CONTEXT_FLOATING_POINT */
1116 DWORD FltF0;
1117 DWORD FltF1;
1118 DWORD FltF2;
1119 DWORD FltF3;
1120 DWORD FltF4;
1121 DWORD FltF5;
1122 DWORD FltF6;
1123 DWORD FltF7;
1124 DWORD FltF8;
1125 DWORD FltF9;
1126 DWORD FltF10;
1127 DWORD FltF11;
1128 DWORD FltF12;
1129 DWORD FltF13;
1130 DWORD FltF14;
1131 DWORD FltF15;
1132 DWORD FltF16;
1133 DWORD FltF17;
1134 DWORD FltF18;
1135 DWORD FltF19;
1136 DWORD FltF20;
1137 DWORD FltF21;
1138 DWORD FltF22;
1139 DWORD FltF23;
1140 DWORD FltF24;
1141 DWORD FltF25;
1142 DWORD FltF26;
1143 DWORD FltF27;
1144 DWORD FltF28;
1145 DWORD FltF29;
1146 DWORD FltF30;
1147 DWORD FltF31;
1148
1149 /* These are selected by CONTEXT_INTEGER */
1150 DWORD IntZero;
1151 DWORD IntAt;
1152 DWORD IntV0;
1153 DWORD IntV1;
1154 DWORD IntA0;
1155 DWORD IntA1;
1156 DWORD IntA2;
1157 DWORD IntA3;
1158 DWORD IntT0;
1159 DWORD IntT1;
1160 DWORD IntT2;
1161 DWORD IntT3;
1162 DWORD IntT4;
1163 DWORD IntT5;
1164 DWORD IntT6;
1165 DWORD IntT7;
1166 DWORD IntS0;
1167 DWORD IntS1;
1168 DWORD IntS2;
1169 DWORD IntS3;
1170 DWORD IntS4;
1171 DWORD IntS5;
1172 DWORD IntS6;
1173 DWORD IntS7;
1174 DWORD IntT8;
1175 DWORD IntT9;
1176 DWORD IntK0;
1177 DWORD IntK1;
1178 DWORD IntGp;
1179 DWORD IntSp;
1180 DWORD IntS8;
1181 DWORD IntRa;
1182 DWORD IntLo;
1183 DWORD IntHi;
1184
1185 /* These are selected by CONTEXT_FLOATING_POINT */
1186 DWORD Fsr;
1187
1188 /* These are selected by CONTEXT_CONTROL */
1189 DWORD Fir;
1190 DWORD Psr;
1191
1192 DWORD ContextFlags;
1193 DWORD Fill[2];
1194} CONTEXT;
1195
1196#endif /* _MIPS_ */
1197
1198/* PowerPC context definitions */
1199#ifdef __PPC__
1200
1201#define CONTEXT_CONTROL 0x0001
1202#define CONTEXT_FLOATING_POINT 0x0002
1203#define CONTEXT_INTEGER 0x0004
1204#define CONTEXT_DEBUG_REGISTERS 0x0008
1205#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1206
1207typedef struct
1208{
1209 /* These are selected by CONTEXT_FLOATING_POINT */
1210 double Fpr0;
1211 double Fpr1;
1212 double Fpr2;
1213 double Fpr3;
1214 double Fpr4;
1215 double Fpr5;
1216 double Fpr6;
1217 double Fpr7;
1218 double Fpr8;
1219 double Fpr9;
1220 double Fpr10;
1221 double Fpr11;
1222 double Fpr12;
1223 double Fpr13;
1224 double Fpr14;
1225 double Fpr15;
1226 double Fpr16;
1227 double Fpr17;
1228 double Fpr18;
1229 double Fpr19;
1230 double Fpr20;
1231 double Fpr21;
1232 double Fpr22;
1233 double Fpr23;
1234 double Fpr24;
1235 double Fpr25;
1236 double Fpr26;
1237 double Fpr27;
1238 double Fpr28;
1239 double Fpr29;
1240 double Fpr30;
1241 double Fpr31;
1242 double Fpscr;
1243
1244 /* These are selected by CONTEXT_INTEGER */
1245 DWORD Gpr0;
1246 DWORD Gpr1;
1247 DWORD Gpr2;
1248 DWORD Gpr3;
1249 DWORD Gpr4;
1250 DWORD Gpr5;
1251 DWORD Gpr6;
1252 DWORD Gpr7;
1253 DWORD Gpr8;
1254 DWORD Gpr9;
1255 DWORD Gpr10;
1256 DWORD Gpr11;
1257 DWORD Gpr12;
1258 DWORD Gpr13;
1259 DWORD Gpr14;
1260 DWORD Gpr15;
1261 DWORD Gpr16;
1262 DWORD Gpr17;
1263 DWORD Gpr18;
1264 DWORD Gpr19;
1265 DWORD Gpr20;
1266 DWORD Gpr21;
1267 DWORD Gpr22;
1268 DWORD Gpr23;
1269 DWORD Gpr24;
1270 DWORD Gpr25;
1271 DWORD Gpr26;
1272 DWORD Gpr27;
1273 DWORD Gpr28;
1274 DWORD Gpr29;
1275 DWORD Gpr30;
1276 DWORD Gpr31;
1277
1278 DWORD Cr;
1279 DWORD Xer;
1280
1281 /* These are selected by CONTEXT_CONTROL */
1282 DWORD Msr;
1283 DWORD Iar;
1284 DWORD Lr;
1285 DWORD Ctr;
1286
1287 DWORD ContextFlags;
1288 DWORD Fill[3];
1289
1290 /* These are selected by CONTEXT_DEBUG_REGISTERS */
1291 DWORD Dr0;
1292 DWORD Dr1;
1293 DWORD Dr2;
1294 DWORD Dr3;
1295 DWORD Dr4;
1296 DWORD Dr5;
1297 DWORD Dr6;
1298 DWORD Dr7;
1299} CONTEXT;
1300
1301typedef struct _STACK_FRAME_HEADER
1302{
1303 DWORD BackChain;
1304 DWORD GlueSaved1;
1305 DWORD GlueSaved2;
1306 DWORD Reserved1;
1307 DWORD Spare1;
1308 DWORD Spare2;
1309
1310 DWORD Parameter0;
1311 DWORD Parameter1;
1312 DWORD Parameter2;
1313 DWORD Parameter3;
1314 DWORD Parameter4;
1315 DWORD Parameter5;
1316 DWORD Parameter6;
1317 DWORD Parameter7;
1318} STACK_FRAME_HEADER,*PSTACK_FRAME_HEADER;
1319
1320#endif /* __PPC__ */
1321
1322#ifdef __sparc__
1323
1324/*
1325 * FIXME:
1326 *
1327 * There is no official CONTEXT structure defined for the SPARC
1328 * architecture, so I just made one up.
1329 *
1330 * This structure is valid only for 32-bit SPARC architectures,
1331 * not for 64-bit SPARC.
1332 *
1333 * Note that this structure contains only the 'top-level' registers;
1334 * the rest of the register window chain is not visible.
1335 *
1336 * The layout follows the Solaris 'prgregset_t' structure.
1337 *
1338 */
1339
1340#define CONTEXT_SPARC 0x10000000
1341
1342#define CONTEXT_CONTROL (CONTEXT_SPARC | 0x00000001)
1343#define CONTEXT_FLOATING_POINT (CONTEXT_SPARC | 0x00000002)
1344#define CONTEXT_INTEGER (CONTEXT_SPARC | 0x00000004)
1345
1346#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1347
1348typedef struct _CONTEXT
1349{
1350 DWORD ContextFlags;
1351
1352 /* These are selected by CONTEXT_INTEGER */
1353 DWORD g0;
1354 DWORD g1;
1355 DWORD g2;
1356 DWORD g3;
1357 DWORD g4;
1358 DWORD g5;
1359 DWORD g6;
1360 DWORD g7;
1361 DWORD o0;
1362 DWORD o1;
1363 DWORD o2;
1364 DWORD o3;
1365 DWORD o4;
1366 DWORD o5;
1367 DWORD o6;
1368 DWORD o7;
1369 DWORD l0;
1370 DWORD l1;
1371 DWORD l2;
1372 DWORD l3;
1373 DWORD l4;
1374 DWORD l5;
1375 DWORD l6;
1376 DWORD l7;
1377 DWORD i0;
1378 DWORD i1;
1379 DWORD i2;
1380 DWORD i3;
1381 DWORD i4;
1382 DWORD i5;
1383 DWORD i6;
1384 DWORD i7;
1385
1386 /* These are selected by CONTEXT_CONTROL */
1387 DWORD psr;
1388 DWORD pc;
1389 DWORD npc;
1390 DWORD y;
1391 DWORD wim;
1392 DWORD tbr;
1393
1394 /* FIXME: floating point registers missing */
1395
1396} CONTEXT;
1397
1398#endif /* __sparc__ */
1399
1400#ifdef __s390__
1401
1402/*
1403 * FIXME:
1404 *
1405 * There is no official CONTEXT structure defined for the S390
1406 * architecture, so I just made one up.
1407 *
1408 * Note that this structure contains only the 'top-level' registers;
1409 * the rest of the register window chain is not visible.
1410 *
1411 * The layout is based on the sparc one.
1412 *
1413 */
1414
1415#define CONTEXT_S390C 0x20000000
1416
1417#define CONTEXT_CONTROL (CONTEXT_S390 | 0x00000001)
1418#define CONTEXT_FLOATING_POINT (CONTEXT_S390 | 0x00000002)
1419#define CONTEXT_INTEGER (CONTEXT_S390 | 0x00000004)
1420
1421#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
1422
1423typedef struct _CONTEXT
1424{
1425 DWORD ContextFlags;
1426
1427 /* These are selected by CONTEXT_INTEGER */
1428 DWORD r0;
1429 DWORD r1;
1430 DWORD r2;
1431 DWORD r3;
1432 DWORD r4;
1433 DWORD r5;
1434 DWORD r6;
1435 DWORD r7;
1436 DWORD r8;
1437 DWORD r9;
1438 DWORD r10;
1439 DWORD r11;
1440 DWORD r12;
1441 DWORD r13;
1442 DWORD r14;
1443 DWORD r15;
1444
1445 /* FIXME: this section is fictional (copied from sparc) */
1446 DWORD psr;
1447 DWORD pc;
1448 DWORD npc;
1449 DWORD y;
1450 DWORD wim;
1451 DWORD tbr;
1452
1453 /* FIXME: floating point registers missing */
1454
1455} CONTEXT;
1456
1457#endif /* __s390__ */
1458
1459#ifdef __arm__
1460
1461/* These definitions are taken directly from wine
1462 * http://source.winehq.org/git/wine.git/blob_plain/HEAD:/include/winnt.h */
1463
1464/* The following flags control the contents of the CONTEXT structure. */
1465
1466#define CONTEXT_ARM 0x0200000
1467#define CONTEXT_CONTROL (CONTEXT_ARM | 0x00000001)
1468#define CONTEXT_INTEGER (CONTEXT_ARM | 0x00000002)
1469#define CONTEXT_FLOATING_POINT (CONTEXT_ARM | 0x00000004)
1470#define CONTEXT_DEBUG_REGISTERS (CONTEXT_ARM | 0x00000008)
1471
1472#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1473
1474#define EXCEPTION_READ_FAULT 0
1475#define EXCEPTION_WRITE_FAULT 1
1476#define EXCEPTION_EXECUTE_FAULT 8
1477
1478typedef struct _CONTEXT {
1479/* The flags values within this flag control the contents of
1480 * a CONTEXT record.
1481 *
1482 * If the context record is used as an input parameter, then
1483 * for each portion of the context record controlled by a flag
1484 * whose value is set, it is assumed that that portion of the
1485 * context record contains valid context. If the context record
1486 * is being used to modify a thread's context, then only that
1487 * portion of the threads context will be modified.
1488 *
1489 * If the context record is used as an IN OUT parameter to capture
1490 * the context of a thread, then only those portions of the thread's
1491 * context corresponding to set flags will be returned.
1492 *
1493 * The context record is never used as an OUT only parameter. */
1494
1495ULONG ContextFlags;
1496
1497/* This section is specified/returned if the ContextFlags word contains
1498 * the flag CONTEXT_INTEGER. */
1499ULONG R0;
1500ULONG R1;
1501ULONG R2;
1502ULONG R3;
1503ULONG R4;
1504ULONG R5;
1505ULONG R6;
1506ULONG R7;
1507ULONG R8;
1508ULONG R9;
1509ULONG R10;
1510ULONG Fp;
1511ULONG Ip;
1512
1513/* These are selected by CONTEXT_CONTROL */
1514ULONG Sp;
1515ULONG Lr;
1516ULONG Pc;
1517ULONG Cpsr;
1518} CONTEXT;
1519
1520#endif /* __arm__ */
1521
1522#ifdef __aarch64__
1523/*
1524 * FIXME:
1525 *
1526 * There is not yet an official CONTEXT structure defined for the AArch64
1527 * architecture, so I just made one up.
1528 *
1529 */
1530
1531/* These definitions are taken directly from wine
1532 * http://source.winehq.org/git/wine.git/blob_plain/HEAD:/include/winnt.h */
1533
1534#define CONTEXT_ARM64 0x2000000
1535#define CONTEXT_CONTROL (CONTEXT_ARM64 | 0x00000001)
1536#define CONTEXT_INTEGER (CONTEXT_ARM64 | 0x00000002)
1537#define CONTEXT_FLOATING_POINT (CONTEXT_ARM64 | 0x00000004)
1538#define CONTEXT_DEBUG_REGISTERS (CONTEXT_ARM64 | 0x00000008)
1539
1540#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1541
1542#define EXCEPTION_READ_FAULT 0
1543#define EXCEPTION_WRITE_FAULT 1
1544#define EXCEPTION_EXECUTE_FAULT 8
1545
1546typedef struct _CONTEXT {
1547 ULONG ContextFlags;
1548
1549 /* This section is specified/returned if the ContextFlags word contains
1550 the flag CONTEXT_INTEGER. */
1551 ULONGLONG X0;
1552 ULONGLONG X1;
1553 ULONGLONG X2;
1554 ULONGLONG X3;
1555 ULONGLONG X4;
1556 ULONGLONG X5;
1557 ULONGLONG X6;
1558 ULONGLONG X7;
1559 ULONGLONG X8;
1560 ULONGLONG X9;
1561 ULONGLONG X10;
1562 ULONGLONG X11;
1563 ULONGLONG X12;
1564 ULONGLONG X13;
1565 ULONGLONG X14;
1566 ULONGLONG X15;
1567 ULONGLONG X16;
1568 ULONGLONG X17;
1569 ULONGLONG X18;
1570 ULONGLONG X19;
1571 ULONGLONG X20;
1572 ULONGLONG X21;
1573 ULONGLONG X22;
1574 ULONGLONG X23;
1575 ULONGLONG X24;
1576 ULONGLONG X25;
1577 ULONGLONG X26;
1578 ULONGLONG X27;
1579 ULONGLONG X28;
1580 ULONGLONG X29;
1581 ULONGLONG X30;
1582
1583 /* These are selected by CONTEXT_CONTROL */
1584 ULONGLONG Sp;
1585 ULONGLONG Pc;
1586 ULONGLONG PState;
1587
1588 /* These are selected by CONTEXT_FLOATING_POINT */
1589 /* FIXME */
1590} CONTEXT;
1591
1592#endif /* __aarch64__ */
1593
1594#ifdef __e2k__
1595/*
1596 * FIXME:
1597 *
1598 * There is not yet an official CONTEXT structure defined for the
1599 * Elbrus 2000 architecture (64-bit LE), so I just made one up.
1600 *
1601 */
1602
1603#define CONTEXT_E2K 0x4000000
1604#define CONTEXT_CONTROL (CONTEXT_E2K | 0x00000001)
1605#define CONTEXT_INTEGER (CONTEXT_E2K | 0x00000002)
1606#define CONTEXT_FLOATING_POINT (CONTEXT_E2K | 0x00000004)
1607#define CONTEXT_DEBUG_REGISTERS (CONTEXT_E2K | 0x00000008)
1608
1609#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1610
1611#define EXCEPTION_READ_FAULT 0
1612#define EXCEPTION_WRITE_FAULT 1
1613#define EXCEPTION_EXECUTE_FAULT 8
1614
1615typedef struct _CONTEXT {
1616 ULONG ContextFlags;
1617
1618 /* This section is specified/returned if the ContextFlags word contains
1619 the flag CONTEXT_INTEGER. */
1620 ULONGLONG X0;
1621 ULONGLONG X1;
1622 ULONGLONG X2;
1623 ULONGLONG X3;
1624 ULONGLONG X4;
1625 ULONGLONG X5;
1626 ULONGLONG X6;
1627 ULONGLONG X7;
1628 ULONGLONG X8;
1629 ULONGLONG X9;
1630 ULONGLONG X10;
1631 ULONGLONG X11;
1632 ULONGLONG X12;
1633 ULONGLONG X13;
1634 ULONGLONG X14;
1635 ULONGLONG X15;
1636 ULONGLONG X16;
1637 ULONGLONG X17;
1638 ULONGLONG X18;
1639 ULONGLONG X19;
1640 ULONGLONG X20;
1641 ULONGLONG X21;
1642 ULONGLONG X22;
1643 ULONGLONG X23;
1644 ULONGLONG X24;
1645 ULONGLONG X25;
1646 ULONGLONG X26;
1647 ULONGLONG X27;
1648 ULONGLONG X28;
1649 ULONGLONG X29;
1650 ULONGLONG X30;
1651
1652 /* These are selected by CONTEXT_CONTROL */
1653 ULONGLONG Sp;
1654 ULONGLONG Pc;
1655 ULONGLONG PState;
1656
1657 /* These are selected by CONTEXT_FLOATING_POINT */
1658 /* FIXME */
1659} CONTEXT;
1660
1661#endif /* __e2k__ */
1662
1663#ifdef __riscv && __riscv_xlen==64
1664/*
1665 * FIXME:
1666 *
1667 * There is not yet an official CONTEXT structure defined for the
1668 * riscv64 architecture (64-bit LE), so I just made one up.
1669 *
1670 */
1671
1672#define CONTEXT_RISCV64 0x4000000
1673#define CONTEXT_CONTROL (CONTEXT_RISCV64 | 0x00000001)
1674#define CONTEXT_INTEGER (CONTEXT_RISCV64 | 0x00000002)
1675#define CONTEXT_FLOATING_POINT (CONTEXT_RISCV64 | 0x00000004)
1676#define CONTEXT_DEBUG_REGISTERS (CONTEXT_RISCV64 | 0x00000008)
1677
1678#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_INTEGER)
1679
1680#define EXCEPTION_READ_FAULT 0
1681#define EXCEPTION_WRITE_FAULT 1
1682#define EXCEPTION_EXECUTE_FAULT 8
1683
1684typedef struct _CONTEXT {
1685 ULONG ContextFlags;
1686
1687 /* This section is specified/returned if the ContextFlags word contains
1688 the flag CONTEXT_INTEGER. */
1689 ULONGLONG X0;
1690 ULONGLONG X1;
1691 ULONGLONG X2;
1692 ULONGLONG X3;
1693 ULONGLONG X4;
1694 ULONGLONG X5;
1695 ULONGLONG X6;
1696 ULONGLONG X7;
1697 ULONGLONG X8;
1698 ULONGLONG X9;
1699 ULONGLONG X10;
1700 ULONGLONG X11;
1701 ULONGLONG X12;
1702 ULONGLONG X13;
1703 ULONGLONG X14;
1704 ULONGLONG X15;
1705 ULONGLONG X16;
1706 ULONGLONG X17;
1707 ULONGLONG X18;
1708 ULONGLONG X19;
1709 ULONGLONG X20;
1710 ULONGLONG X21;
1711 ULONGLONG X22;
1712 ULONGLONG X23;
1713 ULONGLONG X24;
1714 ULONGLONG X25;
1715 ULONGLONG X26;
1716 ULONGLONG X27;
1717 ULONGLONG X28;
1718 ULONGLONG X29;
1719 ULONGLONG X30;
1720 ULONGLONG X31;
1721
1722 /* These are selected by CONTEXT_CONTROL */
1723 ULONGLONG Sp;
1724 ULONGLONG Pc;
1725 ULONGLONG PState;
1726
1727 /* These are selected by CONTEXT_FLOATING_POINT */
1728 /* FIXME */
1729} CONTEXT;
1730
1731#endif /* __riscv64__ */
1732
1733
1734#if !defined(CONTEXT_FULL) && !defined(RC_INVOKED)
1735#error You need to define a CONTEXT for your CPU
1736#endif
1737
1738typedef CONTEXT *PCONTEXT;
1739
1740#ifdef __WINE__
1741
1742/* Macros for easier access to i386 context registers */
1743
1744#define AX_reg(context) (*(WORD*)&(context)->Eax)
1745#define BX_reg(context) (*(WORD*)&(context)->Ebx)
1746#define CX_reg(context) (*(WORD*)&(context)->Ecx)
1747#define DX_reg(context) (*(WORD*)&(context)->Edx)
1748#define SI_reg(context) (*(WORD*)&(context)->Esi)
1749#define DI_reg(context) (*(WORD*)&(context)->Edi)
1750#define BP_reg(context) (*(WORD*)&(context)->Ebp)
1751
1752#define AL_reg(context) (*(BYTE*)&(context)->Eax)
1753#define AH_reg(context) (*((BYTE*)&(context)->Eax + 1))
1754#define BL_reg(context) (*(BYTE*)&(context)->Ebx)
1755#define BH_reg(context) (*((BYTE*)&(context)->Ebx + 1))
1756#define CL_reg(context) (*(BYTE*)&(context)->Ecx)
1757#define CH_reg(context) (*((BYTE*)&(context)->Ecx + 1))
1758#define DL_reg(context) (*(BYTE*)&(context)->Edx)
1759#define DH_reg(context) (*((BYTE*)&(context)->Edx + 1))
1760
1761#define SET_CFLAG(context) ((context)->EFlags |= 0x0001)
1762#define RESET_CFLAG(context) ((context)->EFlags &= ~0x0001)
1763#define SET_ZFLAG(context) ((context)->EFlags |= 0x0040)
1764#define RESET_ZFLAG(context) ((context)->EFlags &= ~0x0040)
1765#define ISV86(context) ((context)->EFlags & 0x00020000)
1766
1767
1768/* Macros to retrieve the current context */
1769
1770#ifdef NEED_UNDERSCORE_PREFIX
1771# define __ASM_NAME(name) "_" name
1772#else
1773# define __ASM_NAME(name) name
1774#endif
1775
1776#ifdef NEED_TYPE_IN_DEF
1777# define __ASM_FUNC(name) ".def " __ASM_NAME(name) "; .scl 2; .type 32; .endef"
1778#else
1779# define __ASM_FUNC(name) ".type " __ASM_NAME(name) ",@function"
1780#endif
1781
1782#ifdef __GNUC__
1783# define __ASM_GLOBAL_FUNC(name,code) \
1784 __asm__( ".align 4\n\t" \
1785 ".globl " __ASM_NAME(#name) "\n\t" \
1786 __ASM_FUNC(#name) "\n" \
1787 __ASM_NAME(#name) ":\n\t" \
1788 code );
1789#else /* __GNUC__ */
1790# define __ASM_GLOBAL_FUNC(name,code) \
1791 void __asm_dummy_##name(void) { \
1792 asm( ".align 4\n\t" \
1793 ".globl " __ASM_NAME(#name) "\n\t" \
1794 __ASM_FUNC(#name) "\n" \
1795 __ASM_NAME(#name) ":\n\t" \
1796 code ); \
1797 }
1798#endif /* __GNUC__ */
1799
1800#ifdef __i386__
1801
1802#define _DEFINE_REGS_ENTRYPOINT( name, fn, args ) \
1803 __ASM_GLOBAL_FUNC( name, \
1804 "call " __ASM_NAME("__wine_call_from_32_regs") "\n\t" \
1805 ".long " __ASM_NAME(#fn) "\n\t" \
1806 ".byte " #args ", " #args )
1807#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
1808 extern void WINAPI name(void); \
1809 _DEFINE_REGS_ENTRYPOINT( name, fn, 0 )
1810#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
1811 extern void WINAPI name( t1 a1 ); \
1812 _DEFINE_REGS_ENTRYPOINT( name, fn, 4 )
1813#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
1814 extern void WINAPI name( t1 a1, t2 a2 ); \
1815 _DEFINE_REGS_ENTRYPOINT( name, fn, 8 )
1816#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
1817 extern void WINAPI name( t1 a1, t2 a2, t3 a3 ); \
1818 _DEFINE_REGS_ENTRYPOINT( name, fn, 12 )
1819#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
1820 extern void WINAPI name( t1 a1, t2 a2, t3 a3, t4 a4 ); \
1821 _DEFINE_REGS_ENTRYPOINT( name, fn, 16 )
1822
1823#endif /* __i386__ */
1824
1825#ifdef __sparc__
1826/* FIXME: use getcontext() to retrieve full context */
1827#define _GET_CONTEXT \
1828 CONTEXT context; \
1829 do { memset(&context, 0, sizeof(CONTEXT)); \
1830 context.ContextFlags = CONTEXT_CONTROL; \
1831 context.pc = (DWORD)__builtin_return_address(0); \
1832 } while (0)
1833
1834#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
1835 void WINAPI name ( void ) \
1836 { _GET_CONTEXT; fn( &context ); }
1837#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
1838 void WINAPI name ( t1 a1 ) \
1839 { _GET_CONTEXT; fn( a1, &context ); }
1840#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
1841 void WINAPI name ( t1 a1, t2 a2 ) \
1842 { _GET_CONTEXT; fn( a1, a2, &context ); }
1843#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
1844 void WINAPI name ( t1 a1, t2 a2, t3 a3 ) \
1845 { _GET_CONTEXT; fn( a1, a2, a3, &context ); }
1846#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
1847 void WINAPI name ( t1 a1, t2 a2, t3 a3, t4 a4 ) \
1848 { _GET_CONTEXT; fn( a1, a2, a3, a4, &context ); }
1849
1850#endif /* __sparc__ */
1851
1852#ifdef __s390__
1853/* FIXME: use getcontext() to retrieve full context */
1854#define _GET_CONTEXT \
1855 CONTEXT context; \
1856 do { memset(&context, 0, sizeof(CONTEXT)); \
1857 context.ContextFlags = CONTEXT_CONTROL; \
1858 context.pc = (DWORD)__builtin_return_address(0); \
1859 } while (0)
1860
1861#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
1862 void WINAPI name ( void ) \
1863 { _GET_CONTEXT; fn( &context ); }
1864#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
1865 void WINAPI name ( t1 a1 ) \
1866 { _GET_CONTEXT; fn( a1, &context ); }
1867#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
1868 void WINAPI name ( t1 a1, t2 a2 ) \
1869 { _GET_CONTEXT; fn( a1, a2, &context ); }
1870#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
1871 void WINAPI name ( t1 a1, t2 a2, t3 a3 ) \
1872 { _GET_CONTEXT; fn( a1, a2, a3, &context ); }
1873#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
1874 void WINAPI name ( t1 a1, t2 a2, t3 a3, t4 a4 ) \
1875 { _GET_CONTEXT; fn( a1, a2, a3, a4, &context ); }
1876
1877#endif /* __s390__ */
1878
1879#ifdef __PPC__
1880
1881/* FIXME: use getcontext() to retrieve full context */
1882#define _GET_CONTEXT \
1883 CONTEXT context; \
1884 do { memset(&context, 0, sizeof(CONTEXT)); \
1885 context.ContextFlags = CONTEXT_CONTROL; \
1886 } while (0)
1887
1888#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
1889 void WINAPI name ( void ) \
1890 { _GET_CONTEXT; fn( &context ); }
1891#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
1892 void WINAPI name ( t1 a1 ) \
1893 { _GET_CONTEXT; fn( a1, &context ); }
1894#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
1895 void WINAPI name ( t1 a1, t2 a2 ) \
1896 { _GET_CONTEXT; fn( a1, a2, &context ); }
1897#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
1898 void WINAPI name ( t1 a1, t2 a2, t3 a3 ) \
1899 { _GET_CONTEXT; fn( a1, a2, a3, &context ); }
1900#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
1901 void WINAPI name ( t1 a1, t2 a2, t3 a3, t4 a4 ) \
1902 { _GET_CONTEXT; fn( a1, a2, a3, a4, &context ); }
1903
1904#endif /* __PPC__ */
1905
1906
1907#ifndef DEFINE_REGS_ENTRYPOINT_0
1908#error You need to define DEFINE_REGS_ENTRYPOINT macros for your CPU
1909#endif
1910
1911/* Constructor functions */
1912
1913#ifdef __GNUC__
1914# define DECL_GLOBAL_CONSTRUCTOR(func) \
1915 static void func(void) __attribute__((constructor)); \
1916 static void func(void)
1917#else /* __GNUC__ */
1918# ifdef __i386__
1919# define DECL_GLOBAL_CONSTRUCTOR(func) \
1920 static void __dummy_init_##func(void) { \
1921 asm(".section .init,\"ax\"\n\t" \
1922 "call " #func "\n\t" \
1923 ".previous"); } \
1924 static void func(void)
1925# else /* __i386__ */
1926# error You must define the DECL_GLOBAL_CONSTRUCTOR macro for your platform
1927# endif
1928#endif /* __GNUC__ */
1929
1930/* Segment register access */
1931
1932#ifdef __i386__
1933# ifdef __GNUC__
1934# define __DEFINE_GET_SEG(seg) \
1935 extern inline unsigned short __get_##seg(void) \
1936 { unsigned short res; __asm__("movw %%" #seg ",%w0" : "=r"(res)); return res; }
1937# define __DEFINE_SET_SEG(seg) \
1938 extern inline void __set_##seg(int val) { __asm__("movw %w0,%%" #seg : : "r" (val)); }
1939# else /* __GNUC__ */
1940# define __DEFINE_GET_SEG(seg) extern unsigned short __get_##seg(void);
1941# define __DEFINE_SET_SEG(seg) extern void __set_##seg(unsigned int);
1942# endif /* __GNUC__ */
1943#else /* __i386__ */
1944# define __DEFINE_GET_SEG(seg) inline static unsigned short __get_##seg(void) { return 0; }
1945# define __DEFINE_SET_SEG(seg) /* nothing */
1946#endif /* __i386__ */
1947
1948__DEFINE_GET_SEG(cs)
1949__DEFINE_GET_SEG(ds)
1950__DEFINE_GET_SEG(es)
1951__DEFINE_GET_SEG(fs)
1952__DEFINE_GET_SEG(gs)
1953__DEFINE_GET_SEG(ss)
1954__DEFINE_SET_SEG(fs)
1955__DEFINE_SET_SEG(gs)
1956#undef __DEFINE_GET_SEG
1957#undef __DEFINE_SET_SEG
1958
1959#endif /* __WINE__ */
1960
1961
1962
1963/*
1964 * Language IDs
1965 */
1966
1967#define MAKELCID(l, s) (MAKELONG(l, s))
1968
1969#define MAKELANGID(p, s) ((((WORD)(s))<<10) | (WORD)(p))
1970#define PRIMARYLANGID(l) ((WORD)(l) & 0x3ff)
1971#define SUBLANGID(l) ((WORD)(l) >> 10)
1972
1973#define LANGIDFROMLCID(lcid) ((WORD)(lcid))
1974#define SORTIDFROMLCID(lcid) ((WORD)((((DWORD)(lcid)) >> 16) & 0x0f))
1975
1976#define LANG_SYSTEM_DEFAULT (MAKELANGID(LANG_NEUTRAL, SUBLANG_SYS_DEFAULT))
1977#define LANG_USER_DEFAULT (MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT))
1978#define LOCALE_SYSTEM_DEFAULT (MAKELCID(LANG_SYSTEM_DEFAULT, SORT_DEFAULT))
1979#define LOCALE_USER_DEFAULT (MAKELCID(LANG_USER_DEFAULT, SORT_DEFAULT))
1980#define LOCALE_NEUTRAL (MAKELCID(MAKELANGID(LANG_NEUTRAL,SUBLANG_NEUTRAL),SORT_DEFAULT))
1981
1982/* FIXME: are the symbolic names correct for LIDs: 0x17, 0x20, 0x28,
1983 * 0x2a, 0x2b, 0x2c, 0x2f, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35,
1984 * 0x37, 0x39, 0x3a, 0x3b, 0x3c, 0x3e, 0x3f, 0x41, 0x43, 0x44,
1985 * 0x45, 0x46, 0x47, 0x48, 0x49, 0x4a, 0x4b, 0x4c, 0x4d, 0x4e,
1986 * 0x4f, 0x57
1987 */
1988#define LANG_NEUTRAL 0x00
1989#define LANG_AFRIKAANS 0x36
1990#define LANG_ALBANIAN 0x1c
1991#define LANG_ARABIC 0x01
1992#define LANG_ARMENIAN 0x2b
1993#define LANG_ASSAMESE 0x4d
1994#define LANG_AZERI 0x2c
1995#define LANG_BASQUE 0x2d
1996#define LANG_BENGALI 0x45
1997#define LANG_BULGARIAN 0x02
1998#define LANG_BYELORUSSIAN 0x23
1999#define LANG_CATALAN 0x03
2000#define LANG_CHINESE 0x04
2001#define LANG_SERBO_CROATIAN 0x1a
2002#define LANG_CROATIAN LANG_SERBO_CROATIAN
2003#define LANG_SERBIAN LANG_SERBO_CROATIAN
2004#define LANG_CZECH 0x05
2005#define LANG_DANISH 0x06
2006#define LANG_DUTCH 0x13
2007#define LANG_ENGLISH 0x09
2008#define LANG_ESTONIAN 0x25
2009#define LANG_FAEROESE 0x38
2010#define LANG_FARSI 0x29
2011#define LANG_FINNISH 0x0b
2012#define LANG_FRENCH 0x0c
2013#define LANG_GAELIC 0x3c
2014#define LANG_GEORGIAN 0x37
2015#define LANG_GERMAN 0x07
2016#define LANG_GREEK 0x08
2017#define LANG_GUJARATI 0x47
2018#define LANG_HEBREW 0x0D
2019#define LANG_HINDI 0x39
2020#define LANG_HUNGARIAN 0x0e
2021#define LANG_ICELANDIC 0x0f
2022#define LANG_INDONESIAN 0x21
2023#define LANG_ITALIAN 0x10
2024#define LANG_JAPANESE 0x11
2025#define LANG_KANNADA 0x4b
2026#define LANG_KAZAKH 0x3f
2027#define LANG_KONKANI 0x57
2028#define LANG_KOREAN 0x12
2029#define LANG_LATVIAN 0x26
2030#define LANG_LITHUANIAN 0x27
2031#define LANG_MACEDONIAN 0x2f
2032#define LANG_MALAY 0x3e
2033#define LANG_MALAYALAM 0x4c
2034#define LANG_MALTESE 0x3a
2035#define LANG_MAORI 0x28
2036#define LANG_MARATHI 0x4e
2037#define LANG_NORWEGIAN 0x14
2038#define LANG_ORIYA 0x48
2039#define LANG_POLISH 0x15
2040#define LANG_PORTUGUESE 0x16
2041#define LANG_PUNJABI 0x46
2042#define LANG_RHAETO_ROMANCE 0x17
2043#define LANG_ROMANIAN 0x18
2044#define LANG_RUSSIAN 0x19
2045#define LANG_SAAMI 0x3b
2046#define LANG_SANSKRIT 0x4f
2047#define LANG_SLOVAK 0x1b
2048#define LANG_SLOVENIAN 0x24
2049#define LANG_SORBIAN 0x2e
2050#define LANG_SPANISH 0x0a
2051#define LANG_SUTU 0x30
2052#define LANG_SWAHILI 0x41
2053#define LANG_SWEDISH 0x1d
2054#define LANG_TAMIL 0x49
2055#define LANG_TATAR 0x44
2056#define LANG_TELUGU 0x4a
2057#define LANG_THAI 0x1e
2058#define LANG_TSONGA 0x31
2059#define LANG_TSWANA 0x32
2060#define LANG_TURKISH 0x1f
2061#define LANG_UKRAINIAN 0x22
2062#define LANG_URDU 0x20
2063#define LANG_UZBEK 0x43
2064#define LANG_VENDA 0x33
2065#define LANG_VIETNAMESE 0x2a
2066#define LANG_XHOSA 0x34
2067#define LANG_ZULU 0x35
2068/* non standard; keep the number high enough (but < 0xff) */
2069#define LANG_ESPERANTO 0x8f
2070#define LANG_WALON 0x90
2071#define LANG_CORNISH 0x91
2072#define LANG_WELSH 0x92
2073#define LANG_BRETON 0x93
2074
2075/* Sublanguage definitions */
2076#define SUBLANG_NEUTRAL 0x00 /* language neutral */
2077#define SUBLANG_DEFAULT 0x01 /* user default */
2078#define SUBLANG_SYS_DEFAULT 0x02 /* system default */
2079
2080#define SUBLANG_ARABIC 0x01
2081#define SUBLANG_ARABIC_SAUDI_ARABIA 0x01
2082#define SUBLANG_ARABIC_IRAQ 0x02
2083#define SUBLANG_ARABIC_EGYPT 0x03
2084#define SUBLANG_ARABIC_LIBYA 0x04
2085#define SUBLANG_ARABIC_ALGERIA 0x05
2086#define SUBLANG_ARABIC_MOROCCO 0x06
2087#define SUBLANG_ARABIC_TUNISIA 0x07
2088#define SUBLANG_ARABIC_OMAN 0x08
2089#define SUBLANG_ARABIC_YEMEN 0x09
2090#define SUBLANG_ARABIC_SYRIA 0x0a
2091#define SUBLANG_ARABIC_JORDAN 0x0b
2092#define SUBLANG_ARABIC_LEBANON 0x0c
2093#define SUBLANG_ARABIC_KUWAIT 0x0d
2094#define SUBLANG_ARABIC_UAE 0x0e
2095#define SUBLANG_ARABIC_BAHRAIN 0x0f
2096#define SUBLANG_ARABIC_QATAR 0x10
2097#define SUBLANG_CHINESE_TRADITIONAL 0x01
2098#define SUBLANG_CHINESE_SIMPLIFIED 0x02
2099#define SUBLANG_CHINESE_HONGKONG 0x03
2100#define SUBLANG_CHINESE_SINGAPORE 0x04
2101#define SUBLANG_CHINESE_MACAU 0x05
2102#define SUBLANG_DUTCH 0x01
2103#define SUBLANG_DUTCH_BELGIAN 0x02
2104#define SUBLANG_DUTCH_SURINAM 0x03
2105#define SUBLANG_ENGLISH_US 0x01
2106#define SUBLANG_ENGLISH_UK 0x02
2107#define SUBLANG_ENGLISH_AUS 0x03
2108#define SUBLANG_ENGLISH_CAN 0x04
2109#define SUBLANG_ENGLISH_NZ 0x05
2110#define SUBLANG_ENGLISH_EIRE 0x06
2111#define SUBLANG_ENGLISH_SAFRICA 0x07
2112#define SUBLANG_ENGLISH_JAMAICA 0x08
2113#define SUBLANG_ENGLISH_CARRIBEAN 0x09
2114#define SUBLANG_ENGLISH_BELIZE 0x0a
2115#define SUBLANG_ENGLISH_TRINIDAD 0x0b
2116#define SUBLANG_ENGLISH_ZIMBABWE 0x0c
2117#define SUBLANG_ENGLISH_PHILIPPINES 0x0d
2118#define SUBLANG_FRENCH 0x01
2119#define SUBLANG_FRENCH_BELGIAN 0x02
2120#define SUBLANG_FRENCH_CANADIAN 0x03
2121#define SUBLANG_FRENCH_SWISS 0x04
2122#define SUBLANG_FRENCH_LUXEMBOURG 0x05
2123#define SUBLANG_FRENCH_MONACO 0x06
2124#define SUBLANG_GERMAN 0x01
2125#define SUBLANG_GERMAN_SWISS 0x02
2126#define SUBLANG_GERMAN_AUSTRIAN 0x03
2127#define SUBLANG_GERMAN_LUXEMBOURG 0x04
2128#define SUBLANG_GERMAN_LIECHTENSTEIN 0x05
2129#define SUBLANG_ITALIAN 0x01
2130#define SUBLANG_ITALIAN_SWISS 0x02
2131#define SUBLANG_KOREAN 0x01
2132#define SUBLANG_KOREAN_JOHAB 0x02
2133#define SUBLANG_NORWEGIAN_BOKMAL 0x01
2134#define SUBLANG_NORWEGIAN_NYNORSK 0x02
2135#define SUBLANG_PORTUGUESE 0x02
2136#define SUBLANG_PORTUGUESE_BRAZILIAN 0x01
2137#define SUBLANG_SPANISH 0x01
2138#define SUBLANG_SPANISH_MEXICAN 0x02
2139#define SUBLANG_SPANISH_MODERN 0x03
2140#define SUBLANG_SPANISH_GUATEMALA 0x04
2141#define SUBLANG_SPANISH_COSTARICA 0x05
2142#define SUBLANG_SPANISH_PANAMA 0x06
2143#define SUBLANG_SPANISH_DOMINICAN 0x07
2144#define SUBLANG_SPANISH_VENEZUELA 0x08
2145#define SUBLANG_SPANISH_COLOMBIA 0x09
2146#define SUBLANG_SPANISH_PERU 0x0a
2147#define SUBLANG_SPANISH_ARGENTINA 0x0b
2148#define SUBLANG_SPANISH_ECUADOR 0x0c
2149#define SUBLANG_SPANISH_CHILE 0x0d
2150#define SUBLANG_SPANISH_URUGUAY 0x0e
2151#define SUBLANG_SPANISH_PARAGUAY 0x0f
2152#define SUBLANG_SPANISH_BOLIVIA 0x10
2153#define SUBLANG_SPANISH_EL_SALVADOR 0x11
2154#define SUBLANG_SPANISH_HONDURAS 0x12
2155#define SUBLANG_SPANISH_NICARAGUA 0x13
2156#define SUBLANG_SPANISH_PUERTO_RICO 0x14
2157/* FIXME: I don't know the symbolic names for those */
2158#define SUBLANG_ROMANIAN 0x01
2159#define SUBLANG_ROMANIAN_MOLDAVIA 0x02
2160#define SUBLANG_RUSSIAN 0x01
2161#define SUBLANG_RUSSIAN_MOLDAVIA 0x02
2162#define SUBLANG_CROATIAN 0x01
2163#define SUBLANG_SERBIAN 0x02
2164#define SUBLANG_SERBIAN_LATIN 0x03
2165#define SUBLANG_SWEDISH 0x01
2166#define SUBLANG_SWEDISH_FINLAND 0x02
2167#define SUBLANG_LITHUANIAN 0x01
2168#define SUBLANG_LITHUANIAN_CLASSIC 0x02
2169#define SUBLANG_AZERI 0x01
2170#define SUBLANG_AZERI_CYRILLIC 0x02
2171#define SUBLANG_GAELIC 0x01
2172#define SUBLANG_GAELIC_SCOTTISH 0x02
2173#define SUBLANG_GAELIC_MANX 0x03
2174#define SUBLANG_MALAY 0x01
2175#define SUBLANG_MALAY_BRUNEI_DARUSSALAM 0x02
2176#define SUBLANG_UZBEK 0x01
2177#define SUBLANG_UZBEK_CYRILLIC 0x02
2178#define SUBLANG_URDU_PAKISTAN 0x01
2179
2180
2181
2182/*
2183 * Sort definitions
2184 */
2185
2186#define SORT_DEFAULT 0x0
2187#define SORT_JAPANESE_XJIS 0x0
2188#define SORT_JAPANESE_UNICODE 0x1
2189#define SORT_CHINESE_BIG5 0x0
2190#define SORT_CHINESE_UNICODE 0x1
2191#define SORT_KOREAN_KSC 0x0
2192#define SORT_KOREAN_UNICODE 0x1
2193
2194
2195
2196/*
2197 * Definitions for IsTextUnicode()
2198 */
2199
2200#define IS_TEXT_UNICODE_ASCII16 0x0001
2201#define IS_TEXT_UNICODE_STATISTICS 0x0002
2202#define IS_TEXT_UNICODE_CONTROLS 0x0004
2203#define IS_TEXT_UNICODE_SIGNATURE 0x0008
2204#define IS_TEXT_UNICODE_UNICODE_MASK 0x000F
2205#define IS_TEXT_UNICODE_REVERSE_ASCII16 0x0010
2206#define IS_TEXT_UNICODE_REVERSE_STATISTICS 0x0020
2207#define IS_TEXT_UNICODE_REVERSE_CONTROLS 0x0040
2208#define IS_TEXT_UNICODE_REVERSE_SIGNATURE 0x0080
2209#define IS_TEXT_UNICODE_REVERSE_MASK 0x00F0
2210#define IS_TEXT_UNICODE_ILLEGAL_CHARS 0x0100
2211#define IS_TEXT_UNICODE_ODD_LENGTH 0x0200
2212#define IS_TEXT_UNICODE_DBCS_LEADBYTE 0x0400
2213#define IS_TEXT_UNICODE_NOT_UNICODE_MASK 0x0F00
2214#define IS_TEXT_UNICODE_NULL_BYTES 0x1000
2215#define IS_TEXT_UNICODE_NOT_ASCII_MASK 0xF000
2216
2217
2218
2219/*
2220 * Exception codes
2221 */
2222
2223#define STATUS_SUCCESS 0x00000000
2224#define STATUS_WAIT_0 0x00000000
2225#define STATUS_ABANDONED_WAIT_0 0x00000080
2226#define STATUS_ABANDONED_WAIT_63 0x000000BF
2227#define STATUS_USER_APC 0x000000C0
2228#define STATUS_ALERTED 0x00000101
2229#define STATUS_TIMEOUT 0x00000102
2230#define STATUS_PENDING 0x00000103
2231#define STATUS_REPARSE 0x00000104
2232#define STATUS_MORE_ENTRIES 0x00000105
2233#define STATUS_NOT_ALL_ASSIGNED 0x00000106
2234#define STATUS_SOME_NOT_MAPPED 0x00000107
2235#define STATUS_OPLOCK_BREAK_IN_PROGRESS 0x00000108
2236#define STATUS_VOLUME_MOUNTED 0x00000109
2237#define STATUS_RXACT_COMMITTED 0x0000010A
2238#define STATUS_NOTIFY_CLEANUP 0x0000010B
2239#define STATUS_NOTIFY_ENUM_DIR 0x0000010C
2240#define STATUS_NO_QUOTAS_FOR_ACCOUNT 0x0000010D
2241#define STATUS_PRIMARY_TRANSPORT_CONNECT_FAILED 0x0000010E
2242#define STATUS_PAGE_FAULT_TRANSITION 0x00000110
2243#define STATUS_PAGE_FAULT_DEMAND_ZERO 0x00000111
2244#define STATUS_PAGE_FAULT_COPY_ON_WRITE 0x00000112
2245#define STATUS_PAGE_FAULT_GUARD_PAGE 0x00000113
2246#define STATUS_PAGE_FAULT_PAGING_FILE 0x00000114
2247#define STATUS_CACHE_PAGE_LOCKED 0x00000115
2248#define STATUS_CRASH_DUMP 0x00000116
2249#define STATUS_BUFFER_ALL_ZEROS 0x00000117
2250#define STATUS_REPARSE_OBJECT 0x00000118
2251
2252#define STATUS_THREAD_WAS_SUSPENDED 0x40000001
2253#define STATUS_WORKING_SET_LIMIT_RANGE 0x40000002
2254#define STATUS_IMAGE_NOT_AT_BASE 0x40000003
2255#define STATUS_RXACT_STATE_CREATED 0x40000004
2256#define STATUS_SEGMENT_NOTIFICATION 0x40000005
2257#define STATUS_LOCAL_USER_SESSION_KEY 0x40000006
2258#define STATUS_BAD_CURRENT_DIRECTORY 0x40000007
2259#define STATUS_SERIAL_MORE_WRITES 0x40000008
2260#define STATUS_REGISTRY_RECOVERED 0x40000009
2261#define STATUS_FT_READ_RECOVERY_FROM_BACKUP 0x4000000A
2262#define STATUS_FT_WRITE_RECOVERY 0x4000000B
2263#define STATUS_SERIAL_COUNTER_TIMEOUT 0x4000000C
2264#define STATUS_NULL_LM_PASSWORD 0x4000000D
2265#define STATUS_IMAGE_MACHINE_TYPE_MISMATCH 0x4000000E
2266#define STATUS_RECEIVE_PARTIAL 0x4000000F
2267#define STATUS_RECEIVE_EXPEDITED 0x40000010
2268#define STATUS_RECEIVE_PARTIAL_EXPEDITED 0x40000011
2269#define STATUS_EVENT_DONE 0x40000012
2270#define STATUS_EVENT_PENDING 0x40000013
2271#define STATUS_CHECKING_FILE_SYSTEM 0x40000014
2272#define STATUS_FATAL_APP_EXIT 0x40000015
2273#define STATUS_PREDEFINED_HANDLE 0x40000016
2274#define STATUS_WAS_UNLOCKED 0x40000017
2275#define STATUS_SERVICE_NOTIFICATION 0x40000018
2276#define STATUS_WAS_LOCKED 0x40000019
2277#define STATUS_LOG_HARD_ERROR 0x4000001A
2278#define STATUS_ALREADY_WIN32 0x4000001B
2279#define STATUS_WX86_UNSIMULATE 0x4000001C
2280#define STATUS_WX86_CONTINUE 0x4000001D
2281#define STATUS_WX86_SINGLE_STEP 0x4000001E
2282#define STATUS_WX86_BREAKPOINT 0x4000001F
2283#define STATUS_WX86_EXCEPTION_CONTINUE 0x40000020
2284#define STATUS_WX86_EXCEPTION_LASTCHANCE 0x40000021
2285#define STATUS_WX86_EXCEPTION_CHAIN 0x40000022
2286#define STATUS_IMAGE_MACHINE_TYPE_MISMATCH_EXE 0x40000023
2287#define STATUS_NO_YIELD_PERFORMED 0x40000024
2288#define STATUS_TIMER_RESUME_IGNORED 0x40000025
2289
2290#define STATUS_GUARD_PAGE_VIOLATION 0x80000001
2291#define STATUS_DATATYPE_MISALIGNMENT 0x80000002
2292#define STATUS_BREAKPOINT 0x80000003
2293#define STATUS_SINGLE_STEP 0x80000004
2294#define STATUS_BUFFER_OVERFLOW 0x80000005
2295#define STATUS_NO_MORE_FILES 0x80000006
2296#define STATUS_WAKE_SYSTEM_DEBUGGER 0x80000007
2297
2298#define STATUS_HANDLES_CLOSED 0x8000000A
2299#define STATUS_NO_INHERITANCE 0x8000000B
2300#define STATUS_GUID_SUBSTITUTION_MADE 0x8000000C
2301#define STATUS_PARTIAL_COPY 0x8000000D
2302#define STATUS_DEVICE_PAPER_EMPTY 0x8000000E
2303#define STATUS_DEVICE_POWERED_OFF 0x8000000F
2304#define STATUS_DEVICE_OFF_LINE 0x80000010
2305#define STATUS_DEVICE_BUSY 0x80000011
2306#define STATUS_NO_MORE_EAS 0x80000012
2307#define STATUS_INVALID_EA_NAME 0x80000013
2308#define STATUS_EA_LIST_INCONSISTENT 0x80000014
2309#define STATUS_INVALID_EA_FLAG 0x80000015
2310#define STATUS_VERIFY_REQUIRED 0x80000016
2311#define STATUS_EXTRANEOUS_INFORMATION 0x80000017
2312#define STATUS_RXACT_COMMIT_NECESSARY 0x80000018
2313#define STATUS_NO_MORE_ENTRIES 0x8000001A
2314#define STATUS_FILEMARK_DETECTED 0x8000001B
2315#define STATUS_MEDIA_CHANGED 0x8000001C
2316#define STATUS_BUS_RESET 0x8000001D
2317#define STATUS_END_OF_MEDIA 0x8000001E
2318#define STATUS_BEGINNING_OF_MEDIA 0x8000001F
2319#define STATUS_MEDIA_CHECK 0x80000020
2320#define STATUS_SETMARK_DETECTED 0x80000021
2321#define STATUS_NO_DATA_DETECTED 0x80000022
2322#define STATUS_REDIRECTOR_HAS_OPEN_HANDLES 0x80000023
2323#define STATUS_SERVER_HAS_OPEN_HANDLES 0x80000024
2324#define STATUS_ALREADY_DISCONNECTED 0x80000025
2325#define STATUS_LONGJUMP 0x80000026
2326
2327#define STATUS_UNSUCCESSFUL 0xC0000001
2328#define STATUS_NOT_IMPLEMENTED 0xC0000002
2329#define STATUS_INVALID_INFO_CLASS 0xC0000003
2330#define STATUS_INFO_LENGTH_MISMATCH 0xC0000004
2331#define STATUS_ACCESS_VIOLATION 0xC0000005
2332#define STATUS_IN_PAGE_ERROR 0xC0000006
2333#define STATUS_PAGEFILE_QUOTA 0xC0000007
2334#define STATUS_INVALID_HANDLE 0xC0000008
2335#define STATUS_BAD_INITIAL_STACK 0xC0000009
2336#define STATUS_BAD_INITIAL_PC 0xC000000A
2337#define STATUS_INVALID_CID 0xC000000B
2338#define STATUS_TIMER_NOT_CANCELED 0xC000000C
2339#define STATUS_INVALID_PARAMETER 0xC000000D
2340#define STATUS_NO_SUCH_DEVICE 0xC000000E
2341#define STATUS_NO_SUCH_FILE 0xC000000F
2342#define STATUS_INVALID_DEVICE_REQUEST 0xC0000010
2343#define STATUS_END_OF_FILE 0xC0000011
2344#define STATUS_WRONG_VOLUME 0xC0000012
2345#define STATUS_NO_MEDIA_IN_DEVICE 0xC0000013
2346#define STATUS_UNRECOGNIZED_MEDIA 0xC0000014
2347#define STATUS_NONEXISTENT_SECTOR 0xC0000015
2348#define STATUS_MORE_PROCESSING_REQUIRED 0xC0000016
2349#define STATUS_NO_MEMORY 0xC0000017
2350#define STATUS_CONFLICTING_ADDRESSES 0xC0000018
2351#define STATUS_NOT_MAPPED_VIEW 0xC0000019
2352#define STATUS_UNABLE_TO_FREE_VM 0xC000001A
2353#define STATUS_UNABLE_TO_DELETE_SECTION 0xC000001B
2354#define STATUS_INVALID_SYSTEM_SERVICE 0xC000001C
2355#define STATUS_ILLEGAL_INSTRUCTION 0xC000001D
2356#define STATUS_INVALID_LOCK_SEQUENCE 0xC000001E
2357#define STATUS_INVALID_VIEW_SIZE 0xC000001F
2358#define STATUS_INVALID_FILE_FOR_SECTION 0xC0000020
2359#define STATUS_ALREADY_COMMITTED 0xC0000021
2360#define STATUS_ACCESS_DENIED 0xC0000022
2361#define STATUS_BUFFER_TOO_SMALL 0xC0000023
2362#define STATUS_OBJECT_TYPE_MISMATCH 0xC0000024
2363#define STATUS_NONCONTINUABLE_EXCEPTION 0xC0000025
2364#define STATUS_INVALID_DISPOSITION 0xC0000026
2365#define STATUS_UNWIND 0xC0000027
2366#define STATUS_BAD_STACK 0xC0000028
2367#define STATUS_INVALID_UNWIND_TARGET 0xC0000029
2368#define STATUS_NOT_LOCKED 0xC000002A
2369#define STATUS_PARITY_ERROR 0xC000002B
2370#define STATUS_UNABLE_TO_DECOMMIT_VM 0xC000002C
2371#define STATUS_NOT_COMMITTED 0xC000002D
2372#define STATUS_INVALID_PORT_ATTRIBUTES 0xC000002E
2373#define STATUS_PORT_MESSAGE_TOO_LONG 0xC000002F
2374#define STATUS_INVALID_PARAMETER_MIX 0xC0000030
2375#define STATUS_INVALID_QUOTA_LOWER 0xC0000031
2376#define STATUS_DISK_CORRUPT_ERROR 0xC0000032
2377#define STATUS_OBJECT_NAME_INVALID 0xC0000033
2378#define STATUS_OBJECT_NAME_NOT_FOUND 0xC0000034
2379#define STATUS_OBJECT_NAME_COLLISION 0xC0000035
2380#define STATUS_PORT_DISCONNECTED 0xC0000037
2381#define STATUS_DEVICE_ALREADY_ATTACHED 0xC0000038
2382#define STATUS_OBJECT_PATH_INVALID 0xC0000039
2383#define STATUS_OBJECT_PATH_NOT_FOUND 0xC000003A
2384#define STATUS_PATH_SYNTAX_BAD 0xC000003B
2385#define STATUS_DATA_OVERRUN 0xC000003C
2386#define STATUS_DATA_LATE_ERROR 0xC000003D
2387#define STATUS_DATA_ERROR 0xC000003E
2388#define STATUS_CRC_ERROR 0xC000003F
2389#define STATUS_SECTION_TOO_BIG 0xC0000040
2390#define STATUS_PORT_CONNECTION_REFUSED 0xC0000041
2391#define STATUS_INVALID_PORT_HANDLE 0xC0000042
2392#define STATUS_SHARING_VIOLATION 0xC0000043
2393#define STATUS_QUOTA_EXCEEDED 0xC0000044
2394#define STATUS_INVALID_PAGE_PROTECTION 0xC0000045
2395#define STATUS_MUTANT_NOT_OWNED 0xC0000046
2396#define STATUS_SEMAPHORE_LIMIT_EXCEEDED 0xC0000047
2397#define STATUS_PORT_ALREADY_SET 0xC0000048
2398#define STATUS_SECTION_NOT_IMAGE 0xC0000049
2399#define STATUS_SUSPEND_COUNT_EXCEEDED 0xC000004A
2400#define STATUS_THREAD_IS_TERMINATING 0xC000004B
2401#define STATUS_BAD_WORKING_SET_LIMIT 0xC000004C
2402#define STATUS_INCOMPATIBLE_FILE_MAP 0xC000004D
2403#define STATUS_SECTION_PROTECTION 0xC000004E
2404#define STATUS_EAS_NOT_SUPPORTED 0xC000004F
2405#define STATUS_EA_TOO_LARGE 0xC0000050
2406#define STATUS_NONEXISTENT_EA_ENTRY 0xC0000051
2407#define STATUS_NO_EAS_ON_FILE 0xC0000052
2408#define STATUS_EA_CORRUPT_ERROR 0xC0000053
2409#define STATUS_LOCK_NOT_GRANTED 0xC0000054 /* FIXME: not sure */
2410#define STATUS_FILE_LOCK_CONFLICT 0xC0000055 /* FIXME: not sure */
2411#define STATUS_DELETE_PENDING 0xC0000056
2412#define STATUS_CTL_FILE_NOT_SUPPORTED 0xC0000057
2413#define STATUS_UNKNOWN_REVISION 0xC0000058
2414#define STATUS_REVISION_MISMATCH 0xC0000059
2415#define STATUS_INVALID_OWNER 0xC000005A
2416#define STATUS_INVALID_PRIMARY_GROUP 0xC000005B
2417#define STATUS_NO_IMPERSONATION_TOKEN 0xC000005C
2418#define STATUS_CANT_DISABLE_MANDATORY 0xC000005D
2419#define STATUS_NO_LOGON_SERVERS 0xC000005E
2420#define STATUS_NO_SUCH_LOGON_SESSION 0xC000005F
2421#define STATUS_NO_SUCH_PRIVILEGE 0xC0000060
2422#define STATUS_PRIVILEGE_NOT_HELD 0xC0000061
2423#define STATUS_INVALID_ACCOUNT_NAME 0xC0000062
2424#define STATUS_USER_EXISTS 0xC0000063
2425#define STATUS_NO_SUCH_USER 0xC0000064
2426#define STATUS_GROUP_EXISTS 0xC0000065
2427#define STATUS_NO_SUCH_GROUP 0xC0000066
2428#define STATUS_MEMBER_IN_GROUP 0xC0000067
2429#define STATUS_MEMBER_NOT_IN_GROUP 0xC0000068
2430#define STATUS_LAST_ADMIN 0xC0000069
2431#define STATUS_WRONG_PASSWORD 0xC000006A
2432#define STATUS_ILL_FORMED_PASSWORD 0xC000006B
2433#define STATUS_PASSWORD_RESTRICTION 0xC000006C
2434#define STATUS_LOGON_FAILURE 0xC000006D
2435#define STATUS_ACCOUNT_RESTRICTION 0xC000006E
2436#define STATUS_INVALID_LOGON_HOURS 0xC000006F
2437#define STATUS_INVALID_WORKSTATION 0xC0000070
2438#define STATUS_PASSWORD_EXPIRED 0xC0000071
2439#define STATUS_ACCOUNT_DISABLED 0xC0000072
2440#define STATUS_NONE_MAPPED 0xC0000073
2441#define STATUS_TOO_MANY_LUIDS_REQUESTED 0xC0000074
2442#define STATUS_LUIDS_EXHAUSTED 0xC0000075
2443#define STATUS_INVALID_SUB_AUTHORITY 0xC0000076
2444#define STATUS_INVALID_ACL 0xC0000077
2445#define STATUS_INVALID_SID 0xC0000078
2446#define STATUS_INVALID_SECURITY_DESCR 0xC0000079
2447#define STATUS_PROCEDURE_NOT_FOUND 0xC000007A
2448#define STATUS_INVALID_IMAGE_FORMAT 0xC000007B
2449#define STATUS_NO_TOKEN 0xC000007C
2450#define STATUS_BAD_INHERITANCE_ACL 0xC000007D
2451#define STATUS_RANGE_NOT_LOCKED 0xC000007E
2452#define STATUS_DISK_FULL 0xC000007F
2453#define STATUS_SERVER_DISABLED 0xC0000080
2454#define STATUS_SERVER_NOT_DISABLED 0xC0000081
2455#define STATUS_TOO_MANY_GUIDS_REQUESTED 0xC0000082
2456#define STATUS_GUIDS_EXHAUSTED 0xC0000083
2457#define STATUS_INVALID_ID_AUTHORITY 0xC0000084
2458#define STATUS_AGENTS_EXHAUSTED 0xC0000085
2459#define STATUS_INVALID_VOLUME_LABEL 0xC0000086
2460#define STATUS_SECTION_NOT_EXTENDED 0xC0000087
2461#define STATUS_NOT_MAPPED_DATA 0xC0000088
2462#define STATUS_RESOURCE_DATA_NOT_FOUND 0xC0000089
2463#define STATUS_RESOURCE_TYPE_NOT_FOUND 0xC000008A
2464#define STATUS_RESOURCE_NAME_NOT_FOUND 0xC000008B
2465#define STATUS_ARRAY_BOUNDS_EXCEEDED 0xC000008C
2466#define STATUS_FLOAT_DENORMAL_OPERAND 0xC000008D
2467#define STATUS_FLOAT_DIVIDE_BY_ZERO 0xC000008E
2468#define STATUS_FLOAT_INEXACT_RESULT 0xC000008F
2469#define STATUS_FLOAT_INVALID_OPERATION 0xC0000090
2470#define STATUS_FLOAT_OVERFLOW 0xC0000091
2471#define STATUS_FLOAT_STACK_CHECK 0xC0000092
2472#define STATUS_FLOAT_UNDERFLOW 0xC0000093
2473#define STATUS_INTEGER_DIVIDE_BY_ZERO 0xC0000094
2474#define STATUS_INTEGER_OVERFLOW 0xC0000095
2475#define STATUS_PRIVILEGED_INSTRUCTION 0xC0000096
2476#define STATUS_TOO_MANY_PAGING_FILES 0xC0000097
2477#define STATUS_FILE_INVALID 0xC0000098
2478#define STATUS_ALLOTTED_SPACE_EXCEEDED 0xC0000099
2479#define STATUS_INSUFFICIENT_RESOURCES 0xC000009A
2480#define STATUS_DFS_EXIT_PATH_FOUND 0xC000009B
2481#define STATUS_DEVICE_DATA_ERROR 0xC000009C
2482#define STATUS_DEVICE_NOT_CONNECTED 0xC000009D
2483#define STATUS_DEVICE_POWER_FAILURE 0xC000009E
2484#define STATUS_FREE_VM_NOT_AT_BASE 0xC000009F
2485#define STATUS_MEMORY_NOT_ALLOCATED 0xC00000A0
2486#define STATUS_WORKING_SET_QUOTA 0xC00000A1
2487#define STATUS_MEDIA_WRITE_PROTECTED 0xC00000A2
2488#define STATUS_DEVICE_NOT_READY 0xC00000A3
2489#define STATUS_INVALID_GROUP_ATTRIBUTES 0xC00000A4
2490#define STATUS_BAD_IMPERSONATION_LEVEL 0xC00000A5
2491#define STATUS_CANT_OPEN_ANONYMOUS 0xC00000A6
2492#define STATUS_BAD_VALIDATION_CLASS 0xC00000A7
2493#define STATUS_BAD_TOKEN_TYPE 0xC00000A8
2494#define STATUS_BAD_MASTER_BOOT_RECORD 0xC00000A9
2495#define STATUS_INSTRUCTION_MISALIGNMENT 0xC00000AA
2496#define STATUS_INSTANCE_NOT_AVAILABLE 0xC00000AB
2497#define STATUS_PIPE_NOT_AVAILABLE 0xC00000AC
2498#define STATUS_INVALID_PIPE_STATE 0xC00000AD
2499#define STATUS_PIPE_BUSY 0xC00000AE
2500#define STATUS_ILLEGAL_FUNCTION 0xC00000AF
2501#define STATUS_PIPE_DISCONNECTED 0xC00000B0
2502#define STATUS_PIPE_CLOSING 0xC00000B1
2503#define STATUS_PIPE_CONNECTED 0xC00000B2
2504#define STATUS_PIPE_LISTENING 0xC00000B3
2505#define STATUS_INVALID_READ_MODE 0xC00000B4
2506#define STATUS_IO_TIMEOUT 0xC00000B5
2507#define STATUS_FILE_FORCED_CLOSED 0xC00000B6
2508#define STATUS_PROFILING_NOT_STARTED 0xC00000B7
2509#define STATUS_PROFILING_NOT_STOPPED 0xC00000B8
2510#define STATUS_COULD_NOT_INTERPRET 0xC00000B9
2511#define STATUS_FILE_IS_A_DIRECTORY 0xC00000BA
2512#define STATUS_NOT_SUPPORTED 0xC00000BB
2513#define STATUS_REMOTE_NOT_LISTENING 0xC00000BC
2514#define STATUS_DUPLICATE_NAME 0xC00000BD
2515#define STATUS_BAD_NETWORK_PATH 0xC00000BE
2516#define STATUS_NETWORK_BUSY 0xC00000BF
2517#define STATUS_DEVICE_DOES_NOT_EXIST 0xC00000C0
2518#define STATUS_TOO_MANY_COMMANDS 0xC00000C1
2519#define STATUS_ADAPTER_HARDWARE_ERROR 0xC00000C2
2520#define STATUS_INVALID_NETWORK_RESPONSE 0xC00000C3
2521#define STATUS_UNEXPECTED_NETWORK_ERROR 0xC00000C4
2522#define STATUS_BAD_REMOTE_ADAPTER 0xC00000C5
2523#define STATUS_PRINT_QUEUE_FULL 0xC00000C6
2524#define STATUS_NO_SPOOL_SPACE 0xC00000C7
2525#define STATUS_PRINT_CANCELLED 0xC00000C8
2526#define STATUS_NETWORK_NAME_DELETED 0xC00000C9
2527#define STATUS_NETWORK_ACCESS_DENIED 0xC00000CA
2528#define STATUS_BAD_DEVICE_TYPE 0xC00000CB
2529#define STATUS_BAD_NETWORK_NAME 0xC00000CC
2530#define STATUS_TOO_MANY_NAMES 0xC00000CD
2531#define STATUS_TOO_MANY_SESSIONS 0xC00000CE
2532#define STATUS_SHARING_PAUSED 0xC00000CF
2533#define STATUS_REQUEST_NOT_ACCEPTED 0xC00000D0
2534#define STATUS_REDIRECTOR_PAUSED 0xC00000D1
2535#define STATUS_NET_WRITE_FAULT 0xC00000D2
2536#define STATUS_PROFILING_AT_LIMIT 0xC00000D3
2537#define STATUS_NOT_SAME_DEVICE 0xC00000D4
2538#define STATUS_FILE_RENAMED 0xC00000D5
2539#define STATUS_VIRTUAL_CIRCUIT_CLOSED 0xC00000D6
2540#define STATUS_NO_SECURITY_ON_OBJECT 0xC00000D7
2541#define STATUS_CANT_WAIT 0xC00000D8
2542#define STATUS_PIPE_EMPTY 0xC00000D9
2543#define STATUS_CANT_ACCESS_DOMAIN_INFO 0xC00000DA
2544#define STATUS_CANT_TERMINATE_SELF 0xC00000DB
2545#define STATUS_INVALID_SERVER_STATE 0xC00000DC
2546#define STATUS_INVALID_DOMAIN_STATE 0xC00000DD
2547#define STATUS_INVALID_DOMAIN_ROLE 0xC00000DE
2548#define STATUS_NO_SUCH_DOMAIN 0xC00000DF
2549#define STATUS_DOMAIN_EXISTS 0xC00000E0
2550#define STATUS_DOMAIN_LIMIT_EXCEEDED 0xC00000E1
2551#define STATUS_OPLOCK_NOT_GRANTED 0xC00000E2
2552#define STATUS_INVALID_OPLOCK_PROTOCOL 0xC00000E3
2553#define STATUS_INTERNAL_DB_CORRUPTION 0xC00000E4
2554#define STATUS_INTERNAL_ERROR 0xC00000E5
2555#define STATUS_GENERIC_NOT_MAPPED 0xC00000E6
2556#define STATUS_BAD_DESCRIPTOR_FORMAT 0xC00000E7
2557#define STATUS_INVALID_USER_BUFFER 0xC00000E8
2558#define STATUS_UNEXPECTED_IO_ERROR 0xC00000E9
2559#define STATUS_UNEXPECTED_MM_CREATE_ERR 0xC00000EA
2560#define STATUS_UNEXPECTED_MM_MAP_ERROR 0xC00000EB
2561#define STATUS_UNEXPECTED_MM_EXTEND_ERR 0xC00000EC
2562#define STATUS_NOT_LOGON_PROCESS 0xC00000ED
2563#define STATUS_LOGON_SESSION_EXISTS 0xC00000EE
2564#define STATUS_INVALID_PARAMETER_1 0xC00000EF
2565#define STATUS_INVALID_PARAMETER_2 0xC00000F0
2566#define STATUS_INVALID_PARAMETER_3 0xC00000F1
2567#define STATUS_INVALID_PARAMETER_4 0xC00000F2
2568#define STATUS_INVALID_PARAMETER_5 0xC00000F3
2569#define STATUS_INVALID_PARAMETER_6 0xC00000F4
2570#define STATUS_INVALID_PARAMETER_7 0xC00000F5
2571#define STATUS_INVALID_PARAMETER_8 0xC00000F6
2572#define STATUS_INVALID_PARAMETER_9 0xC00000F7
2573#define STATUS_INVALID_PARAMETER_10 0xC00000F8
2574#define STATUS_INVALID_PARAMETER_11 0xC00000F9
2575#define STATUS_INVALID_PARAMETER_12 0xC00000FA
2576#define STATUS_REDIRECTOR_NOT_STARTED 0xC00000FB
2577#define STATUS_REDIRECTOR_STARTED 0xC00000FC
2578#define STATUS_STACK_OVERFLOW 0xC00000FD
2579#define STATUS_BAD_FUNCTION_TABLE 0xC00000FF
2580#define STATUS_VARIABLE_NOT_FOUND 0xC0000100
2581#define STATUS_DIRECTORY_NOT_EMPTY 0xC0000101
2582#define STATUS_FILE_CORRUPT_ERROR 0xC0000102
2583#define STATUS_NOT_A_DIRECTORY 0xC0000103
2584#define STATUS_BAD_LOGON_SESSION_STATE 0xC0000104
2585#define STATUS_LOGON_SESSION_COLLISION 0xC0000105
2586#define STATUS_NAME_TOO_LONG 0xC0000106
2587#define STATUS_FILES_OPEN 0xC0000107
2588#define STATUS_CONNECTION_IN_USE 0xC0000108
2589#define STATUS_MESSAGE_NOT_FOUND 0xC0000109
2590#define STATUS_PROCESS_IS_TERMINATING 0xC000010A
2591#define STATUS_INVALID_LOGON_TYPE 0xC000010B
2592#define STATUS_NO_GUID_TRANSLATION 0xC000010C
2593#define STATUS_CANNOT_IMPERSONATE 0xC000010D
2594#define STATUS_IMAGE_ALREADY_LOADED 0xC000010E
2595#define STATUS_ABIOS_NOT_PRESENT 0xC000010F
2596#define STATUS_ABIOS_LID_NOT_EXIST 0xC0000110
2597#define STATUS_ABIOS_LID_ALREADY_OWNED 0xC0000111
2598#define STATUS_ABIOS_NOT_LID_OWNER 0xC0000112
2599#define STATUS_ABIOS_INVALID_COMMAND 0xC0000113
2600#define STATUS_ABIOS_INVALID_LID 0xC0000114
2601#define STATUS_ABIOS_SELECTOR_NOT_AVAILABLE 0xC0000115
2602#define STATUS_ABIOS_INVALID_SELECTOR 0xC0000116
2603#define STATUS_NO_LDT 0xC0000117
2604#define STATUS_INVALID_LDT_SIZE 0xC0000118
2605#define STATUS_INVALID_LDT_OFFSET 0xC0000119
2606#define STATUS_INVALID_LDT_DESCRIPTOR 0xC000011A
2607#define STATUS_INVALID_IMAGE_NE_FORMAT 0xC000011B
2608#define STATUS_RXACT_INVALID_STATE 0xC000011C
2609#define STATUS_RXACT_COMMIT_FAILURE 0xC000011D
2610#define STATUS_MAPPED_FILE_SIZE_ZERO 0xC000011E
2611#define STATUS_TOO_MANY_OPENED_FILES 0xC000011F
2612#define STATUS_CANCELLED 0xC0000120
2613#define STATUS_CANNOT_DELETE 0xC0000121
2614#define STATUS_INVALID_COMPUTER_NAME 0xC0000122
2615#define STATUS_FILE_DELETED 0xC0000123
2616#define STATUS_SPECIAL_ACCOUNT 0xC0000124
2617#define STATUS_SPECIAL_GROUP 0xC0000125
2618#define STATUS_SPECIAL_USER 0xC0000126
2619#define STATUS_MEMBERS_PRIMARY_GROUP 0xC0000127
2620#define STATUS_FILE_CLOSED 0xC0000128
2621#define STATUS_TOO_MANY_THREADS 0xC0000129
2622#define STATUS_THREAD_NOT_IN_PROCESS 0xC000012A
2623#define STATUS_TOKEN_ALREADY_IN_USE 0xC000012B
2624#define STATUS_PAGEFILE_QUOTA_EXCEEDED 0xC000012C
2625#define STATUS_COMMITMENT_LIMIT 0xC000012D
2626#define STATUS_INVALID_IMAGE_LE_FORMAT 0xC000012E
2627#define STATUS_INVALID_IMAGE_NOT_MZ 0xC000012F
2628#define STATUS_INVALID_IMAGE_PROTECT 0xC0000130
2629#define STATUS_INVALID_IMAGE_WIN_16 0xC0000131
2630#define STATUS_LOGON_SERVER_CONFLICT 0xC0000132
2631#define STATUS_TIME_DIFFERENCE_AT_DC 0xC0000133
2632#define STATUS_SYNCHRONIZATION_REQUIRED 0xC0000134
2633#define STATUS_DLL_NOT_FOUND 0xC0000135
2634#define STATUS_OPEN_FAILED 0xC0000136
2635#define STATUS_IO_PRIVILEGE_FAILED 0xC0000137
2636#define STATUS_ORDINAL_NOT_FOUND 0xC0000138
2637#define STATUS_ENTRYPOINT_NOT_FOUND 0xC0000139
2638#define STATUS_CONTROL_C_EXIT 0xC000013A
2639#define STATUS_LOCAL_DISCONNECT 0xC000013B
2640#define STATUS_REMOTE_DISCONNECT 0xC000013C
2641#define STATUS_REMOTE_RESOURCES 0xC000013D
2642#define STATUS_LINK_FAILED 0xC000013E
2643#define STATUS_LINK_TIMEOUT 0xC000013F
2644#define STATUS_INVALID_CONNECTION 0xC0000140
2645#define STATUS_INVALID_ADDRESS 0xC0000141
2646#define STATUS_DLL_INIT_FAILED 0xC0000142
2647#define STATUS_MISSING_SYSTEMFILE 0xC0000143
2648#define STATUS_UNHANDLED_EXCEPTION 0xC0000144
2649#define STATUS_APP_INIT_FAILURE 0xC0000145
2650#define STATUS_PAGEFILE_CREATE_FAILED 0xC0000146
2651#define STATUS_NO_PAGEFILE 0xC0000147
2652#define STATUS_INVALID_LEVEL 0xC0000148
2653#define STATUS_WRONG_PASSWORD_CORE 0xC0000149
2654#define STATUS_ILLEGAL_FLOAT_CONTEXT 0xC000014A
2655#define STATUS_PIPE_BROKEN 0xC000014B
2656#define STATUS_REGISTRY_CORRUPT 0xC000014C
2657#define STATUS_REGISTRY_IO_FAILED 0xC000014D
2658#define STATUS_NO_EVENT_PAIR 0xC000014E
2659#define STATUS_UNRECOGNIZED_VOLUME 0xC000014F
2660#define STATUS_SERIAL_NO_DEVICE_INITED 0xC0000150
2661#define STATUS_NO_SUCH_ALIAS 0xC0000151
2662#define STATUS_MEMBER_NOT_IN_ALIAS 0xC0000152
2663#define STATUS_MEMBER_IN_ALIAS 0xC0000153
2664#define STATUS_ALIAS_EXISTS 0xC0000154
2665#define STATUS_LOGON_NOT_GRANTED 0xC0000155
2666#define STATUS_TOO_MANY_SECRETS 0xC0000156
2667#define STATUS_SECRET_TOO_LONG 0xC0000157
2668#define STATUS_INTERNAL_DB_ERROR 0xC0000158
2669#define STATUS_FULLSCREEN_MODE 0xC0000159
2670#define STATUS_TOO_MANY_CONTEXT_IDS 0xC000015A
2671#define STATUS_LOGON_TYPE_NOT_GRANTED 0xC000015B
2672#define STATUS_NOT_REGISTRY_FILE 0xC000015C
2673#define STATUS_NT_CROSS_ENCRYPTION_REQUIRED 0xC000015D
2674#define STATUS_DOMAIN_CTRLR_CONFIG_ERROR 0xC000015E
2675#define STATUS_FT_MISSING_MEMBER 0xC000015F
2676#define STATUS_ILL_FORMED_SERVICE_ENTRY 0xC0000160
2677#define STATUS_ILLEGAL_CHARACTER 0xC0000161
2678#define STATUS_UNMAPPABLE_CHARACTER 0xC0000162
2679#define STATUS_UNDEFINED_CHARACTER 0xC0000163
2680#define STATUS_FLOPPY_VOLUME 0xC0000164
2681#define STATUS_FLOPPY_ID_MARK_NOT_FOUND 0xC0000165
2682#define STATUS_FLOPPY_WRONG_CYLINDER 0xC0000166
2683#define STATUS_FLOPPY_UNKNOWN_ERROR 0xC0000167
2684#define STATUS_FLOPPY_BAD_REGISTERS 0xC0000168
2685#define STATUS_DISK_RECALIBRATE_FAILED 0xC0000169
2686#define STATUS_DISK_OPERATION_FAILED 0xC000016A
2687#define STATUS_DISK_RESET_FAILED 0xC000016B
2688#define STATUS_SHARED_IRQ_BUSY 0xC000016C
2689#define STATUS_FT_ORPHANING 0xC000016D
2690#define STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT 0xC000016E
2691
2692#define STATUS_PARTITION_FAILURE 0xC0000172
2693#define STATUS_INVALID_BLOCK_LENGTH 0xC0000173
2694#define STATUS_DEVICE_NOT_PARTITIONED 0xC0000174
2695#define STATUS_UNABLE_TO_LOCK_MEDIA 0xC0000175
2696#define STATUS_UNABLE_TO_UNLOAD_MEDIA 0xC0000176
2697#define STATUS_EOM_OVERFLOW 0xC0000177
2698#define STATUS_NO_MEDIA 0xC0000178
2699#define STATUS_NO_SUCH_MEMBER 0xC000017A
2700#define STATUS_INVALID_MEMBER 0xC000017B
2701#define STATUS_KEY_DELETED 0xC000017C
2702#define STATUS_NO_LOG_SPACE 0xC000017D
2703#define STATUS_TOO_MANY_SIDS 0xC000017E
2704#define STATUS_LM_CROSS_ENCRYPTION_REQUIRED 0xC000017F
2705#define STATUS_KEY_HAS_CHILDREN 0xC0000180
2706#define STATUS_CHILD_MUST_BE_VOLATILE 0xC0000181
2707#define STATUS_DEVICE_CONFIGURATION_ERROR 0xC0000182
2708#define STATUS_DRIVER_INTERNAL_ERROR 0xC0000183
2709#define STATUS_INVALID_DEVICE_STATE 0xC0000184
2710#define STATUS_IO_DEVICE_ERROR 0xC0000185
2711#define STATUS_DEVICE_PROTOCOL_ERROR 0xC0000186
2712#define STATUS_BACKUP_CONTROLLER 0xC0000187
2713#define STATUS_LOG_FILE_FULL 0xC0000188
2714#define STATUS_TOO_LATE 0xC0000189
2715#define STATUS_NO_TRUST_LSA_SECRET 0xC000018A
2716#define STATUS_NO_TRUST_SAM_ACCOUNT 0xC000018B
2717#define STATUS_TRUSTED_DOMAIN_FAILURE 0xC000018C
2718#define STATUS_TRUSTED_RELATIONSHIP_FAILURE 0xC000018D
2719#define STATUS_EVENTLOG_FILE_CORRUPT 0xC000018E
2720#define STATUS_EVENTLOG_CANT_START 0xC000018F
2721#define STATUS_TRUST_FAILURE 0xC0000190
2722#define STATUS_MUTANT_LIMIT_EXCEEDED 0xC0000191
2723#define STATUS_NETLOGON_NOT_STARTED 0xC0000192
2724#define STATUS_ACCOUNT_EXPIRED 0xC0000193
2725#define STATUS_POSSIBLE_DEADLOCK 0xC0000194
2726#define STATUS_NETWORK_CREDENTIAL_CONFLICT 0xC0000195
2727#define STATUS_REMOTE_SESSION_LIMIT 0xC0000196
2728#define STATUS_EVENTLOG_FILE_CHANGED 0xC0000197
2729#define STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT 0xC0000198
2730#define STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT 0xC0000199
2731#define STATUS_NOLOGON_SERVER_TRUST_ACCOUNT 0xC000019A
2732#define STATUS_DOMAIN_TRUST_INCONSISTENT 0xC000019B
2733#define STATUS_FS_DRIVER_REQUIRED 0xC000019C
2734
2735#define STATUS_NO_USER_SESSION_KEY 0xC0000202
2736#define STATUS_USER_SESSION_DELETED 0xC0000203
2737#define STATUS_RESOURCE_LANG_NOT_FOUND 0xC0000204
2738#define STATUS_INSUFF_SERVER_RESOURCES 0xC0000205
2739#define STATUS_INVALID_BUFFER_SIZE 0xC0000206
2740#define STATUS_INVALID_ADDRESS_COMPONENT 0xC0000207
2741#define STATUS_INVALID_ADDRESS_WILDCARD 0xC0000208
2742#define STATUS_TOO_MANY_ADDRESSES 0xC0000209
2743#define STATUS_ADDRESS_ALREADY_EXISTS 0xC000020A
2744#define STATUS_ADDRESS_CLOSED 0xC000020B
2745#define STATUS_CONNECTION_DISCONNECTED 0xC000020C
2746#define STATUS_CONNECTION_RESET 0xC000020D
2747#define STATUS_TOO_MANY_NODES 0xC000020E
2748#define STATUS_TRANSACTION_ABORTED 0xC000020F
2749#define STATUS_TRANSACTION_TIMED_OUT 0xC0000210
2750#define STATUS_TRANSACTION_NO_RELEASE 0xC0000211
2751#define STATUS_TRANSACTION_NO_MATCH 0xC0000212
2752#define STATUS_TRANSACTION_RESPONDED 0xC0000213
2753#define STATUS_TRANSACTION_INVALID_ID 0xC0000214
2754#define STATUS_TRANSACTION_INVALID_TYPE 0xC0000215
2755#define STATUS_NOT_SERVER_SESSION 0xC0000216
2756#define STATUS_NOT_CLIENT_SESSION 0xC0000217
2757#define STATUS_CANNOT_LOAD_REGISTRY_FILE 0xC0000218
2758#define STATUS_DEBUG_ATTACH_FAILED 0xC0000219
2759#define STATUS_SYSTEM_PROCESS_TERMINATED 0xC000021A
2760#define STATUS_DATA_NOT_ACCEPTED 0xC000021B
2761#define STATUS_NO_BROWSER_SERVERS_FOUND 0xC000021C
2762#define STATUS_VDM_HARD_ERROR 0xC000021D
2763#define STATUS_DRIVER_CANCEL_TIMEOUT 0xC000021E
2764#define STATUS_REPLY_MESSAGE_MISMATCH 0xC000021F
2765#define STATUS_MAPPED_ALIGNMENT 0xC0000220
2766#define STATUS_IMAGE_CHECKSUM_MISMATCH 0xC0000221
2767#define STATUS_LOST_WRITEBEHIND_DATA 0xC0000222
2768#define STATUS_CLIENT_SERVER_PARAMETERS_INVALID 0xC0000223
2769#define STATUS_PASSWORD_MUST_CHANGE 0xC0000224
2770#define STATUS_NOT_FOUND 0xC0000225
2771#define STATUS_NOT_TINY_STREAM 0xC0000226
2772#define STATUS_RECOVERY_FAILURE 0xC0000227
2773#define STATUS_STACK_OVERFLOW_READ 0xC0000228
2774#define STATUS_FAIL_CHECK 0xC0000229
2775#define STATUS_DUPLICATE_OBJECTID 0xC000022A
2776#define STATUS_OBJECTID_EXISTS 0xC000022B
2777#define STATUS_CONVERT_TO_LARGE 0xC000022C
2778#define STATUS_RETRY 0xC000022D
2779#define STATUS_FOUND_OUT_OF_SCOPE 0xC000022E
2780#define STATUS_ALLOCATE_BUCKET 0xC000022F
2781#define STATUS_PROPSET_NOT_FOUND 0xC0000230
2782#define STATUS_MARSHALL_OVERFLOW 0xC0000231
2783#define STATUS_INVALID_VARIANT 0xC0000232
2784#define STATUS_DOMAIN_CONTROLLER_NOT_FOUND 0xC0000233
2785#define STATUS_ACCOUNT_LOCKED_OUT 0xC0000234
2786#define STATUS_HANDLE_NOT_CLOSABLE 0xC0000235
2787#define STATUS_CONNECTION_REFUSED 0xC0000236
2788#define STATUS_GRACEFUL_DISCONNECT 0xC0000237
2789#define STATUS_ADDRESS_ALREADY_ASSOCIATED 0xC0000238
2790#define STATUS_ADDRESS_NOT_ASSOCIATED 0xC0000239
2791#define STATUS_CONNECTION_INVALID 0xC000023A
2792#define STATUS_CONNECTION_ACTIVE 0xC000023B
2793#define STATUS_NETWORK_UNREACHABLE 0xC000023C
2794#define STATUS_HOST_UNREACHABLE 0xC000023D
2795#define STATUS_PROTOCOL_UNREACHABLE 0xC000023E
2796#define STATUS_PORT_UNREACHABLE 0xC000023F
2797#define STATUS_REQUEST_ABORTED 0xC0000240
2798#define STATUS_CONNECTION_ABORTED 0xC0000241
2799#define STATUS_BAD_COMPRESSION_BUFFER 0xC0000242
2800#define STATUS_USER_MAPPED_FILE 0xC0000243
2801#define STATUS_AUDIT_FAILED 0xC0000244
2802#define STATUS_TIMER_RESOLUTION_NOT_SET 0xC0000245
2803#define STATUS_CONNECTION_COUNT_LIMIT 0xC0000246
2804#define STATUS_LOGIN_TIME_RESTRICTION 0xC0000247
2805#define STATUS_LOGIN_WKSTA_RESTRICTION 0xC0000248
2806#define STATUS_IMAGE_MP_UP_MISMATCH 0xC0000249
2807#define STATUS_INSUFFICIENT_LOGON_INFO 0xC0000250
2808#define STATUS_BAD_DLL_ENTRYPOINT 0xC0000251
2809#define STATUS_BAD_SERVICE_ENTRYPOINT 0xC0000252
2810#define STATUS_LPC_REPLY_LOST 0xC0000253
2811#define STATUS_IP_ADDRESS_CONFLICT1 0xC0000254
2812#define STATUS_IP_ADDRESS_CONFLICT2 0xC0000255
2813#define STATUS_REGISTRY_QUOTA_LIMIT 0xC0000256
2814#define STATUS_PATH_NOT_COVERED 0xC0000257
2815#define STATUS_NO_CALLBACK_ACTIVE 0xC0000258
2816#define STATUS_LICENSE_QUOTA_EXCEEDED 0xC0000259
2817#define STATUS_PWD_TOO_SHORT 0xC000025A
2818#define STATUS_PWD_TOO_RECENT 0xC000025B
2819#define STATUS_PWD_HISTORY_CONFLICT 0xC000025C
2820#define STATUS_PLUGPLAY_NO_DEVICE 0xC000025E
2821#define STATUS_UNSUPPORTED_COMPRESSION 0xC000025F
2822#define STATUS_INVALID_HW_PROFILE 0xC0000260
2823#define STATUS_INVALID_PLUGPLAY_DEVICE_PATH 0xC0000261
2824#define STATUS_DRIVER_ORDINAL_NOT_FOUND 0xC0000262
2825#define STATUS_DRIVER_ENTRYPOINT_NOT_FOUND 0xC0000263
2826#define STATUS_RESOURCE_NOT_OWNED 0xC0000264
2827#define STATUS_TOO_MANY_LINKS 0xC0000265
2828#define STATUS_QUOTA_LIST_INCONSISTENT 0xC0000266
2829#define STATUS_FILE_IS_OFFLINE 0xC0000267
2830#define STATUS_EVALUATION_EXPIRATION 0xC0000268
2831#define STATUS_ILLEGAL_DLL_RELOCATION 0xC0000269
2832#define STATUS_LICENSE_VIOLATION 0xC000026A
2833#define STATUS_DLL_INIT_FAILED_LOGOFF 0xC000026B
2834#define STATUS_DRIVER_UNABLE_TO_LOAD 0xC000026C
2835#define STATUS_DFS_UNAVAILABLE 0xC000026D
2836#define STATUS_VOLUME_DISMOUNTED 0xC000026E
2837#define STATUS_WX86_INTERNAL_ERROR 0xC000026F
2838#define STATUS_WX86_FLOAT_STACK_CHECK 0xC0000270
2839#define STATUS_WOW_ASSERTION 0xC0009898
2840#define RPC_NT_INVALID_STRING_BINDING 0xC0020001
2841#define RPC_NT_WRONG_KIND_OF_BINDING 0xC0020002
2842#define RPC_NT_INVALID_BINDING 0xC0020003
2843#define RPC_NT_PROTSEQ_NOT_SUPPORTED 0xC0020004
2844#define RPC_NT_INVALID_RPC_PROTSEQ 0xC0020005
2845#define RPC_NT_INVALID_STRING_UUID 0xC0020006
2846#define RPC_NT_INVALID_ENDPOINT_FORMAT 0xC0020007
2847#define RPC_NT_INVALID_NET_ADDR 0xC0020008
2848#define RPC_NT_NO_ENDPOINT_FOUND 0xC0020009
2849#define RPC_NT_INVALID_TIMEOUT 0xC002000A
2850#define RPC_NT_OBJECT_NOT_FOUND 0xC002000B
2851#define RPC_NT_ALREADY_REGISTERED 0xC002000C
2852#define RPC_NT_TYPE_ALREADY_REGISTERED 0xC002000D
2853#define RPC_NT_ALREADY_LISTENING 0xC002000E
2854#define RPC_NT_NO_PROTSEQS_REGISTERED 0xC002000F
2855#define RPC_NT_NOT_LISTENING 0xC0020010
2856#define RPC_NT_UNKNOWN_MGR_TYPE 0xC0020011
2857#define RPC_NT_UNKNOWN_IF 0xC0020012
2858#define RPC_NT_NO_BINDINGS 0xC0020013
2859#define RPC_NT_NO_PROTSEQS 0xC0020014
2860#define RPC_NT_CANT_CREATE_ENDPOINT 0xC0020015
2861#define RPC_NT_OUT_OF_RESOURCES 0xC0020016
2862#define RPC_NT_SERVER_UNAVAILABLE 0xC0020017
2863#define RPC_NT_SERVER_TOO_BUSY 0xC0020018
2864#define RPC_NT_INVALID_NETWORK_OPTIONS 0xC0020019
2865#define RPC_NT_NO_CALL_ACTIVE 0xC002001A
2866#define RPC_NT_CALL_FAILED 0xC002001B
2867#define RPC_NT_CALL_FAILED_DNE 0xC002001C
2868#define RPC_NT_PROTOCOL_ERROR 0xC002001D
2869#define RPC_NT_UNSUPPORTED_TRANS_SYN 0xC002001F
2870#define RPC_NT_UNSUPPORTED_TYPE 0xC0020021
2871#define RPC_NT_INVALID_TAG 0xC0020022
2872#define RPC_NT_INVALID_BOUND 0xC0020023
2873#define RPC_NT_NO_ENTRY_NAME 0xC0020024
2874#define RPC_NT_INVALID_NAME_SYNTAX 0xC0020025
2875#define RPC_NT_UNSUPPORTED_NAME_SYNTAX 0xC0020026
2876#define RPC_NT_UUID_NO_ADDRESS 0xC0020028
2877#define RPC_NT_DUPLICATE_ENDPOINT 0xC0020029
2878#define RPC_NT_UNKNOWN_AUTHN_TYPE 0xC002002A
2879#define RPC_NT_MAX_CALLS_TOO_SMALL 0xC002002B
2880#define RPC_NT_STRING_TOO_LONG 0xC002002C
2881#define RPC_NT_PROTSEQ_NOT_FOUND 0xC002002D
2882#define RPC_NT_PROCNUM_OUT_OF_RANGE 0xC002002E
2883#define RPC_NT_BINDING_HAS_NO_AUTH 0xC002002F
2884#define RPC_NT_UNKNOWN_AUTHN_SERVICE 0xC0020030
2885#define RPC_NT_UNKNOWN_AUTHN_LEVEL 0xC0020031
2886#define RPC_NT_INVALID_AUTH_IDENTITY 0xC0020032
2887#define RPC_NT_UNKNOWN_AUTHZ_SERVICE 0xC0020033
2888#define EPT_NT_INVALID_ENTRY 0xC0020034
2889#define EPT_NT_CANT_PERFORM_OP 0xC0020035
2890#define EPT_NT_NOT_REGISTERED 0xC0020036
2891#define RPC_NT_NOTHING_TO_EXPORT 0xC0020037
2892#define RPC_NT_INCOMPLETE_NAME 0xC0020038
2893#define RPC_NT_INVALID_VERS_OPTION 0xC0020039
2894#define RPC_NT_NO_MORE_MEMBERS 0xC002003A
2895#define RPC_NT_NOT_ALL_OBJS_UNEXPORTED 0xC002003B
2896#define RPC_NT_INTERFACE_NOT_FOUND 0xC002003C
2897#define RPC_NT_ENTRY_ALREADY_EXISTS 0xC002003D
2898#define RPC_NT_ENTRY_NOT_FOUND 0xC002003E
2899#define RPC_NT_NAME_SERVICE_UNAVAILABLE 0xC002003F
2900#define RPC_NT_INVALID_NAF_ID 0xC0020040
2901#define RPC_NT_CANNOT_SUPPORT 0xC0020041
2902#define RPC_NT_NO_CONTEXT_AVAILABLE 0xC0020042
2903#define RPC_NT_INTERNAL_ERROR 0xC0020043
2904#define RPC_NT_ZERO_DIVIDE 0xC0020044
2905#define RPC_NT_ADDRESS_ERROR 0xC0020045
2906#define RPC_NT_FP_DIV_ZERO 0xC0020046
2907#define RPC_NT_FP_UNDERFLOW 0xC0020047
2908#define RPC_NT_FP_OVERFLOW 0xC0020048
2909#define RPC_NT_NO_MORE_ENTRIES 0xC0030001
2910#define RPC_NT_SS_CHAR_TRANS_OPEN_FAIL 0xC0030002
2911#define RPC_NT_SS_CHAR_TRANS_SHORT_FILE 0xC0030003
2912#define RPC_NT_SS_IN_NULL_CONTEXT 0xC0030004
2913#define RPC_NT_SS_CONTEXT_MISMATCH 0xC0030005
2914#define RPC_NT_SS_CONTEXT_DAMAGED 0xC0030006
2915#define RPC_NT_SS_HANDLES_MISMATCH 0xC0030007
2916#define RPC_NT_SS_CANNOT_GET_CALL_HANDLE 0xC0030008
2917#define RPC_NT_NULL_REF_POINTER 0xC0030009
2918#define RPC_NT_ENUM_VALUE_OUT_OF_RANGE 0xC003000A
2919#define RPC_NT_BYTE_COUNT_TOO_SMALL 0xC003000B
2920#define RPC_NT_BAD_STUB_DATA 0xC003000C
2921#define RPC_NT_CALL_IN_PROGRESS 0xC0020049
2922#define RPC_NT_NO_MORE_BINDINGS 0xC002004A
2923#define RPC_NT_GROUP_MEMBER_NOT_FOUND 0xC002004B
2924#define EPT_NT_CANT_CREATE 0xC002004C
2925#define RPC_NT_INVALID_OBJECT 0xC002004D
2926#define RPC_NT_NO_INTERFACES 0xC002004F
2927#define RPC_NT_CALL_CANCELLED 0xC0020050
2928#define RPC_NT_BINDING_INCOMPLETE 0xC0020051
2929#define RPC_NT_COMM_FAILURE 0xC0020052
2930#define RPC_NT_UNSUPPORTED_AUTHN_LEVEL 0xC0020053
2931#define RPC_NT_NO_PRINC_NAME 0xC0020054
2932#define RPC_NT_NOT_RPC_ERROR 0xC0020055
2933#define RPC_NT_UUID_LOCAL_ONLY 0x40020056
2934#define RPC_NT_SEC_PKG_ERROR 0xC0020057
2935#define RPC_NT_NOT_CANCELLED 0xC0020058
2936#define RPC_NT_INVALID_ES_ACTION 0xC0030059
2937#define RPC_NT_WRONG_ES_VERSION 0xC003005A
2938#define RPC_NT_WRONG_STUB_VERSION 0xC003005B
2939#define RPC_NT_INVALID_PIPE_OBJECT 0xC003005C
2940#define RPC_NT_INVALID_PIPE_OPERATION 0xC003005D
2941#define RPC_NT_WRONG_PIPE_VERSION 0xC003005E
2942#define RPC_NT_SEND_INCOMPLETE 0x400200AF
2943
2944#define MAXIMUM_WAIT_OBJECTS 64
2945#define MAXIMUM_SUSPEND_COUNT 127
2946
2947
2948/*
2949 * Return values from the actual exception handlers
2950 */
2951
2952#define ExceptionContinueExecution 0
2953#define ExceptionContinueSearch 1
2954#define ExceptionNestedException 2
2955#define ExceptionCollidedUnwind 3
2956
2957/*
2958 * Return values from filters in except() and from UnhandledExceptionFilter
2959 */
2960
2961#define EXCEPTION_EXECUTE_HANDLER 1
2962#define EXCEPTION_CONTINUE_SEARCH 0
2963#define EXCEPTION_CONTINUE_EXECUTION -1
2964
2965/*
2966 * From OS/2 2.0 exception handling
2967 * Win32 seems to use the same flags as ExceptionFlags in an EXCEPTION_RECORD
2968 */
2969
2970#define EH_NONCONTINUABLE 0x01
2971#define EH_UNWINDING 0x02
2972#define EH_EXIT_UNWIND 0x04
2973#define EH_STACK_INVALID 0x08
2974#define EH_NESTED_CALL 0x10
2975
2976#define EXCEPTION_CONTINUABLE 0
2977#define EXCEPTION_NONCONTINUABLE EH_NONCONTINUABLE
2978
2979/*
2980 * The exception record used by Win32 to give additional information
2981 * about exception to exception handlers.
2982 */
2983
2984#define EXCEPTION_MAXIMUM_PARAMETERS 15
2985
2986typedef struct __EXCEPTION_RECORD
2987{
2988 DWORD ExceptionCode;
2989 DWORD ExceptionFlags;
2990 struct __EXCEPTION_RECORD *ExceptionRecord;
2991
2992 LPVOID ExceptionAddress;
2993 DWORD NumberParameters;
2994 DWORD ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
2995} EXCEPTION_RECORD, *PEXCEPTION_RECORD;
2996
2997/*
2998 * The exception pointers structure passed to exception filters
2999 * in except() and the UnhandledExceptionFilter().
3000 */
3001
3002typedef struct _EXCEPTION_POINTERS
3003{
3004 PEXCEPTION_RECORD ExceptionRecord;
3005 PCONTEXT ContextRecord;
3006} EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
3007
3008
3009/*
3010 * The exception frame, used for registering exception handlers
3011 * Win32 cares only about this, but compilers generally emit
3012 * larger exception frames for their own use.
3013 */
3014
3015struct __EXCEPTION_FRAME;
3016
3017typedef DWORD (*PEXCEPTION_HANDLER)(PEXCEPTION_RECORD,struct __EXCEPTION_FRAME*,
3018 PCONTEXT,struct __EXCEPTION_FRAME **);
3019
3020typedef struct __EXCEPTION_FRAME
3021{
3022 struct __EXCEPTION_FRAME *Prev;
3023 PEXCEPTION_HANDLER Handler;
3024} EXCEPTION_FRAME, *PEXCEPTION_FRAME;
3025
3026/*
3027 * function pointer to a exception filter
3028 */
3029
3030typedef LONG CALLBACK (*PTOP_LEVEL_EXCEPTION_FILTER)(PEXCEPTION_POINTERS ExceptionInfo);
3031typedef PTOP_LEVEL_EXCEPTION_FILTER LPTOP_LEVEL_EXCEPTION_FILTER;
3032
3033DWORD WINAPI UnhandledExceptionFilter( PEXCEPTION_POINTERS epointers );
3034LPTOP_LEVEL_EXCEPTION_FILTER
3035WINAPI SetUnhandledExceptionFilter( LPTOP_LEVEL_EXCEPTION_FILTER filter );
3036
3037/* status values for ContinueDebugEvent */
3038#define DBG_CONTINUE 0x00010002
3039#define DBG_TERMINATE_THREAD 0x40010003
3040#define DBG_TERMINATE_PROCESS 0x40010004
3041#define DBG_CONTROL_C 0x40010005
3042#define DBG_CONTROL_BREAK 0x40010008
3043#define DBG_EXCEPTION_NOT_HANDLED 0x80010001
3044
3045typedef struct _NT_TIB
3046{
3047 struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList;
3048 PVOID StackBase;
3049 PVOID StackLimit;
3050 PVOID SubSystemTib;
3051 union {
3052 PVOID FiberData;
3053 DWORD Version;
3054 } DUMMYUNIONNAME;
3055 PVOID ArbitraryUserPointer;
3056 struct _NT_TIB *Self;
3057} NT_TIB, *PNT_TIB;
3058
3059struct _TEB;
3060
3061#if defined(__i386__) && defined(__GNUC__) && !defined(__CHECKER__)
3062extern inline struct _TEB WINAPI *NtCurrentTeb(void);
3063extern inline struct _TEB WINAPI *NtCurrentTeb(void)
3064{
3065 struct _TEB *teb;
3066 __asm__(".byte 0x64\n\tmovl (0x18),%0" : "=r" (teb));
3067 return teb;
3068}
3069#else
3070extern struct _TEB WINAPI *NtCurrentTeb(void);
3071#endif
3072
3073
3074/*
3075 * File formats definitions
3076 */
3077
3078typedef struct _IMAGE_DOS_HEADER {
3079 WORD e_magic; /* 00: MZ Header signature */
3080 WORD e_cblp; /* 02: Bytes on last page of file */
3081 WORD e_cp; /* 04: Pages in file */
3082 WORD e_crlc; /* 06: Relocations */
3083 WORD e_cparhdr; /* 08: Size of header in paragraphs */
3084 WORD e_minalloc; /* 0a: Minimum extra paragraphs needed */
3085 WORD e_maxalloc; /* 0c: Maximum extra paragraphs needed */
3086 WORD e_ss; /* 0e: Initial (relative) SS value */
3087 WORD e_sp; /* 10: Initial SP value */
3088 WORD e_csum; /* 12: Checksum */
3089 WORD e_ip; /* 14: Initial IP value */
3090 WORD e_cs; /* 16: Initial (relative) CS value */
3091 WORD e_lfarlc; /* 18: File address of relocation table */
3092 WORD e_ovno; /* 1a: Overlay number */
3093 WORD e_res[4]; /* 1c: Reserved words */
3094 WORD e_oemid; /* 24: OEM identifier (for e_oeminfo) */
3095 WORD e_oeminfo; /* 26: OEM information; e_oemid specific */
3096 WORD e_res2[10]; /* 28: Reserved words */
3097 DWORD e_lfanew; /* 3c: Offset to extended header */
3098} IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
3099
3100#define IMAGE_DOS_SIGNATURE 0x5A4D /* MZ */
3101#define IMAGE_OS2_SIGNATURE 0x454E /* NE */
3102#define IMAGE_OS2_SIGNATURE_LE 0x454C /* LE */
3103#define IMAGE_OS2_SIGNATURE_LX 0x584C /* LX */
3104#define IMAGE_VXD_SIGNATURE 0x454C /* LE */
3105#define IMAGE_NT_SIGNATURE 0x00004550 /* PE00 */
3106
3107/*
3108 * This is the Windows executable (NE) header.
3109 * the name IMAGE_OS2_HEADER is misleading, but in the SDK this way.
3110 */
3111typedef struct
3112{
3113 WORD ne_magic; /* 00 NE signature 'NE' */
3114 BYTE ne_ver; /* 02 Linker version number */
3115 BYTE ne_rev; /* 03 Linker revision number */
3116 WORD ne_enttab; /* 04 Offset to entry table relative to NE */
3117 WORD ne_cbenttab; /* 06 Length of entry table in bytes */
3118 LONG ne_crc; /* 08 Checksum */
3119 WORD ne_flags; /* 0c Flags about segments in this file */
3120 WORD ne_autodata; /* 0e Automatic data segment number */
3121 WORD ne_heap; /* 10 Initial size of local heap */
3122 WORD ne_stack; /* 12 Initial size of stack */
3123 DWORD ne_csip; /* 14 Initial CS:IP */
3124 DWORD ne_sssp; /* 18 Initial SS:SP */
3125 WORD ne_cseg; /* 1c # of entries in segment table */
3126 WORD ne_cmod; /* 1e # of entries in module reference tab. */
3127 WORD ne_cbnrestab; /* 20 Length of nonresident-name table */
3128 WORD ne_segtab; /* 22 Offset to segment table */
3129 WORD ne_rsrctab; /* 24 Offset to resource table */
3130 WORD ne_restab; /* 26 Offset to resident-name table */
3131 WORD ne_modtab; /* 28 Offset to module reference table */
3132 WORD ne_imptab; /* 2a Offset to imported name table */
3133 DWORD ne_nrestab; /* 2c Offset to nonresident-name table */
3134 WORD ne_cmovent; /* 30 # of movable entry points */
3135 WORD ne_align; /* 32 Logical sector alignment shift count */
3136 WORD ne_cres; /* 34 # of resource segments */
3137 BYTE ne_exetyp; /* 36 Flags indicating target OS */
3138 BYTE ne_flagsothers; /* 37 Additional information flags */
3139 WORD fastload_offset; /* 38 Offset to fast load area (should be ne_pretthunks)*/
3140 WORD fastload_length; /* 3a Length of fast load area (should be ne_psegrefbytes) */
3141 WORD ne_swaparea; /* 3c Reserved by Microsoft */
3142 WORD ne_expver; /* 3e Expected Windows version number */
3143} IMAGE_OS2_HEADER,*PIMAGE_OS2_HEADER;
3144
3145typedef struct _IMAGE_VXD_HEADER {
3146 WORD e32_magic;
3147 BYTE e32_border;
3148 BYTE e32_worder;
3149 DWORD e32_level;
3150 WORD e32_cpu;
3151 WORD e32_os;
3152 DWORD e32_ver;
3153 DWORD e32_mflags;
3154 DWORD e32_mpages;
3155 DWORD e32_startobj;
3156 DWORD e32_eip;
3157 DWORD e32_stackobj;
3158 DWORD e32_esp;
3159 DWORD e32_pagesize;
3160 DWORD e32_lastpagesize;
3161 DWORD e32_fixupsize;
3162 DWORD e32_fixupsum;
3163 DWORD e32_ldrsize;
3164 DWORD e32_ldrsum;
3165 DWORD e32_objtab;
3166 DWORD e32_objcnt;
3167 DWORD e32_objmap;
3168 DWORD e32_itermap;
3169 DWORD e32_rsrctab;
3170 DWORD e32_rsrccnt;
3171 DWORD e32_restab;
3172 DWORD e32_enttab;
3173 DWORD e32_dirtab;
3174 DWORD e32_dircnt;
3175 DWORD e32_fpagetab;
3176 DWORD e32_frectab;
3177 DWORD e32_impmod;
3178 DWORD e32_impmodcnt;
3179 DWORD e32_impproc;
3180 DWORD e32_pagesum;
3181 DWORD e32_datapage;
3182 DWORD e32_preload;
3183 DWORD e32_nrestab;
3184 DWORD e32_cbnrestab;
3185 DWORD e32_nressum;
3186 DWORD e32_autodata;
3187 DWORD e32_debuginfo;
3188 DWORD e32_debuglen;
3189 DWORD e32_instpreload;
3190 DWORD e32_instdemand;
3191 DWORD e32_heapsize;
3192 BYTE e32_res3[12];
3193 DWORD e32_winresoff;
3194 DWORD e32_winreslen;
3195 WORD e32_devid;
3196 WORD e32_ddkver;
3197} IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
3198
3199
3200/* These defines describe the meanings of the bits in the Characteristics
3201 field */
3202
3203#define IMAGE_FILE_RELOCS_STRIPPED 0x0001 /* No relocation info */
3204#define IMAGE_FILE_EXECUTABLE_IMAGE 0x0002
3205#define IMAGE_FILE_LINE_NUMS_STRIPPED 0x0004
3206#define IMAGE_FILE_LOCAL_SYMS_STRIPPED 0x0008
3207#define IMAGE_FILE_16BIT_MACHINE 0x0040
3208#define IMAGE_FILE_BYTES_REVERSED_LO 0x0080
3209#define IMAGE_FILE_32BIT_MACHINE 0x0100
3210#define IMAGE_FILE_DEBUG_STRIPPED 0x0200
3211#define IMAGE_FILE_SYSTEM 0x1000
3212#define IMAGE_FILE_DLL 0x2000
3213#define IMAGE_FILE_BYTES_REVERSED_HI 0x8000
3214
3215/* These are the settings of the Machine field. */
3216#define IMAGE_FILE_MACHINE_UNKNOWN 0
3217#define IMAGE_FILE_MACHINE_I860 0x14d
3218#define IMAGE_FILE_MACHINE_I386 0x14c
3219#define IMAGE_FILE_MACHINE_R3000 0x162
3220#define IMAGE_FILE_MACHINE_R4000 0x166
3221#define IMAGE_FILE_MACHINE_R10000 0x168
3222#define IMAGE_FILE_MACHINE_ALPHA 0x184
3223#define IMAGE_FILE_MACHINE_POWERPC 0x1F0
3224
3225#define IMAGE_SIZEOF_FILE_HEADER 20
3226
3227/* Possible Magic values */
3228#define IMAGE_NT_OPTIONAL_HDR_MAGIC 0x10b
3229#define IMAGE_ROM_OPTIONAL_HDR_MAGIC 0x107
3230
3231/* These are indexes into the DataDirectory array */
3232#define IMAGE_FILE_EXPORT_DIRECTORY 0
3233#define IMAGE_FILE_IMPORT_DIRECTORY 1
3234#define IMAGE_FILE_RESOURCE_DIRECTORY 2
3235#define IMAGE_FILE_EXCEPTION_DIRECTORY 3
3236#define IMAGE_FILE_SECURITY_DIRECTORY 4
3237#define IMAGE_FILE_BASE_RELOCATION_TABLE 5
3238#define IMAGE_FILE_DEBUG_DIRECTORY 6
3239#define IMAGE_FILE_DESCRIPTION_STRING 7
3240#define IMAGE_FILE_MACHINE_VALUE 8 /* Mips */
3241#define IMAGE_FILE_THREAD_LOCAL_STORAGE 9
3242#define IMAGE_FILE_CALLBACK_DIRECTORY 10
3243
3244/* Directory Entries, indices into the DataDirectory array */
3245
3246#define IMAGE_DIRECTORY_ENTRY_EXPORT 0
3247#define IMAGE_DIRECTORY_ENTRY_IMPORT 1
3248#define IMAGE_DIRECTORY_ENTRY_RESOURCE 2
3249#define IMAGE_DIRECTORY_ENTRY_EXCEPTION 3
3250#define IMAGE_DIRECTORY_ENTRY_SECURITY 4
3251#define IMAGE_DIRECTORY_ENTRY_BASERELOC 5
3252#define IMAGE_DIRECTORY_ENTRY_DEBUG 6
3253#define IMAGE_DIRECTORY_ENTRY_COPYRIGHT 7
3254#define IMAGE_DIRECTORY_ENTRY_GLOBALPTR 8 /* (MIPS GP) */
3255#define IMAGE_DIRECTORY_ENTRY_TLS 9
3256#define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG 10
3257#define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT 11
3258#define IMAGE_DIRECTORY_ENTRY_IAT 12 /* Import Address Table */
3259#define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT 13
3260#define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR 14
3261
3262/* Subsystem Values */
3263
3264#define IMAGE_SUBSYSTEM_UNKNOWN 0
3265#define IMAGE_SUBSYSTEM_NATIVE 1
3266#define IMAGE_SUBSYSTEM_WINDOWS_GUI 2 /* Windows GUI subsystem */
3267#define IMAGE_SUBSYSTEM_WINDOWS_CUI 3 /* Windows character subsystem*/
3268#define IMAGE_SUBSYSTEM_OS2_CUI 5
3269#define IMAGE_SUBSYSTEM_POSIX_CUI 7
3270
3271typedef struct _IMAGE_FILE_HEADER {
3272 WORD Machine;
3273 WORD NumberOfSections;
3274 DWORD TimeDateStamp;
3275 DWORD PointerToSymbolTable;
3276 DWORD NumberOfSymbols;
3277 WORD SizeOfOptionalHeader;
3278 WORD Characteristics;
3279} IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
3280
3281typedef struct _IMAGE_DATA_DIRECTORY {
3282 DWORD VirtualAddress;
3283 DWORD Size;
3284} IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
3285
3286#define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
3287
3288typedef struct _IMAGE_OPTIONAL_HEADER {
3289
3290 /* Standard fields */
3291
3292 WORD Magic; /* 0x10b or 0x107 */ /* 0x00 */
3293 BYTE MajorLinkerVersion;
3294 BYTE MinorLinkerVersion;
3295 DWORD SizeOfCode;
3296 DWORD SizeOfInitializedData;
3297 DWORD SizeOfUninitializedData;
3298 DWORD AddressOfEntryPoint; /* 0x10 */
3299 DWORD BaseOfCode;
3300 DWORD BaseOfData;
3301
3302 /* NT additional fields */
3303
3304 DWORD ImageBase;
3305 DWORD SectionAlignment; /* 0x20 */
3306 DWORD FileAlignment;
3307 WORD MajorOperatingSystemVersion;
3308 WORD MinorOperatingSystemVersion;
3309 WORD MajorImageVersion;
3310 WORD MinorImageVersion;
3311 WORD MajorSubsystemVersion; /* 0x30 */
3312 WORD MinorSubsystemVersion;
3313 DWORD Win32VersionValue;
3314 DWORD SizeOfImage;
3315 DWORD SizeOfHeaders;
3316 DWORD CheckSum; /* 0x40 */
3317 WORD Subsystem;
3318 WORD DllCharacteristics;
3319 DWORD SizeOfStackReserve;
3320 DWORD SizeOfStackCommit;
3321 DWORD SizeOfHeapReserve; /* 0x50 */
3322 DWORD SizeOfHeapCommit;
3323 DWORD LoaderFlags;
3324 DWORD NumberOfRvaAndSizes;
3325 IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES]; /* 0x60 */
3326} IMAGE_OPTIONAL_HEADER, *PIMAGE_OPTIONAL_HEADER;
3327
3328typedef struct _IMAGE_NT_HEADERS {
3329 DWORD Signature; /* "PE"\0\0 */
3330 IMAGE_FILE_HEADER FileHeader;
3331 IMAGE_OPTIONAL_HEADER OptionalHeader;
3332} IMAGE_NT_HEADERS, *PIMAGE_NT_HEADERS;
3333
3334#define IMAGE_SIZEOF_SHORT_NAME 8
3335
3336typedef struct _IMAGE_SECTION_HEADER {
3337 BYTE Name[IMAGE_SIZEOF_SHORT_NAME];
3338 union {
3339 DWORD PhysicalAddress;
3340 DWORD VirtualSize;
3341 } Misc;
3342 DWORD VirtualAddress;
3343 DWORD SizeOfRawData;
3344 DWORD PointerToRawData;
3345 DWORD PointerToRelocations;
3346 DWORD PointerToLinenumbers;
3347 WORD NumberOfRelocations;
3348 WORD NumberOfLinenumbers;
3349 DWORD Characteristics;
3350} IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
3351
3352#define IMAGE_SIZEOF_SECTION_HEADER 40
3353
3354#define IMAGE_FIRST_SECTION(ntheader) \
3355 ((PIMAGE_SECTION_HEADER)((LPBYTE)&((PIMAGE_NT_HEADERS)(ntheader))->OptionalHeader + \
3356 ((PIMAGE_NT_HEADERS)(ntheader))->FileHeader.SizeOfOptionalHeader))
3357
3358/* These defines are for the Characteristics bitfield. */
3359/* #define IMAGE_SCN_TYPE_REG 0x00000000 - Reserved */
3360/* #define IMAGE_SCN_TYPE_DSECT 0x00000001 - Reserved */
3361/* #define IMAGE_SCN_TYPE_NOLOAD 0x00000002 - Reserved */
3362/* #define IMAGE_SCN_TYPE_GROUP 0x00000004 - Reserved */
3363/* #define IMAGE_SCN_TYPE_NO_PAD 0x00000008 - Reserved */
3364/* #define IMAGE_SCN_TYPE_COPY 0x00000010 - Reserved */
3365
3366#define IMAGE_SCN_CNT_CODE 0x00000020
3367#define IMAGE_SCN_CNT_INITIALIZED_DATA 0x00000040
3368#define IMAGE_SCN_CNT_UNINITIALIZED_DATA 0x00000080
3369
3370#define IMAGE_SCN_LNK_OTHER 0x00000100
3371#define IMAGE_SCN_LNK_INFO 0x00000200
3372/* #define IMAGE_SCN_TYPE_OVER 0x00000400 - Reserved */
3373#define IMAGE_SCN_LNK_REMOVE 0x00000800
3374#define IMAGE_SCN_LNK_COMDAT 0x00001000
3375
3376/* 0x00002000 - Reserved */
3377/* #define IMAGE_SCN_MEM_PROTECTED 0x00004000 - Obsolete */
3378#define IMAGE_SCN_MEM_FARDATA 0x00008000
3379
3380/* #define IMAGE_SCN_MEM_SYSHEAP 0x00010000 - Obsolete */
3381#define IMAGE_SCN_MEM_PURGEABLE 0x00020000
3382#define IMAGE_SCN_MEM_16BIT 0x00020000
3383#define IMAGE_SCN_MEM_LOCKED 0x00040000
3384#define IMAGE_SCN_MEM_PRELOAD 0x00080000
3385
3386#define IMAGE_SCN_ALIGN_1BYTES 0x00100000
3387#define IMAGE_SCN_ALIGN_2BYTES 0x00200000
3388#define IMAGE_SCN_ALIGN_4BYTES 0x00300000
3389#define IMAGE_SCN_ALIGN_8BYTES 0x00400000
3390#define IMAGE_SCN_ALIGN_16BYTES 0x00500000 /* Default */
3391#define IMAGE_SCN_ALIGN_32BYTES 0x00600000
3392#define IMAGE_SCN_ALIGN_64BYTES 0x00700000
3393/* 0x00800000 - Unused */
3394
3395#define IMAGE_SCN_LNK_NRELOC_OVFL 0x01000000
3396
3397
3398#define IMAGE_SCN_MEM_DISCARDABLE 0x02000000
3399#define IMAGE_SCN_MEM_NOT_CACHED 0x04000000
3400#define IMAGE_SCN_MEM_NOT_PAGED 0x08000000
3401#define IMAGE_SCN_MEM_SHARED 0x10000000
3402#define IMAGE_SCN_MEM_EXECUTE 0x20000000
3403#define IMAGE_SCN_MEM_READ 0x40000000
3404#define IMAGE_SCN_MEM_WRITE 0x80000000
3405
3406#include "pshpack2.h"
3407
3408typedef struct _IMAGE_SYMBOL {
3409 union {
3410 BYTE ShortName[8];
3411 struct {
3412 DWORD Short;
3413 DWORD Long;
3414 } Name;
3415 DWORD LongName[2];
3416 } N;
3417 DWORD Value;
3418 SHORT SectionNumber;
3419 WORD Type;
3420 BYTE StorageClass;
3421 BYTE NumberOfAuxSymbols;
3422} IMAGE_SYMBOL;
3423typedef IMAGE_SYMBOL *PIMAGE_SYMBOL;
3424
3425#define IMAGE_SIZEOF_SYMBOL 18
3426
3427typedef struct _IMAGE_LINENUMBER {
3428 union {
3429 DWORD SymbolTableIndex;
3430 DWORD VirtualAddress;
3431 } Type;
3432 WORD Linenumber;
3433} IMAGE_LINENUMBER;
3434typedef IMAGE_LINENUMBER *PIMAGE_LINENUMBER;
3435
3436#define IMAGE_SIZEOF_LINENUMBER 6
3437
3438typedef union _IMAGE_AUX_SYMBOL {
3439 struct {
3440 DWORD TagIndex;
3441 union {
3442 struct {
3443 WORD Linenumber;
3444 WORD Size;
3445 } LnSz;
3446 DWORD TotalSize;
3447 } Misc;
3448 union {
3449 struct {
3450 DWORD PointerToLinenumber;
3451 DWORD PointerToNextFunction;
3452 } Function;
3453 struct {
3454 WORD Dimension[4];
3455 } Array;
3456 } FcnAry;
3457 WORD TvIndex;
3458 } Sym;
3459 struct {
3460 BYTE Name[IMAGE_SIZEOF_SYMBOL];
3461 } File;
3462 struct {
3463 DWORD Length;
3464 WORD NumberOfRelocations;
3465 WORD NumberOfLinenumbers;
3466 DWORD CheckSum;
3467 SHORT Number;
3468 BYTE Selection;
3469 } Section;
3470} IMAGE_AUX_SYMBOL;
3471typedef IMAGE_AUX_SYMBOL *PIMAGE_AUX_SYMBOL;
3472
3473#define IMAGE_SIZEOF_AUX_SYMBOL 18
3474
3475#include "poppack.h"
3476
3477#define IMAGE_SYM_UNDEFINED (SHORT)0
3478#define IMAGE_SYM_ABSOLUTE (SHORT)-1
3479#define IMAGE_SYM_DEBUG (SHORT)-2
3480
3481#define IMAGE_SYM_TYPE_NULL 0x0000
3482#define IMAGE_SYM_TYPE_VOID 0x0001
3483#define IMAGE_SYM_TYPE_CHAR 0x0002
3484#define IMAGE_SYM_TYPE_SHORT 0x0003
3485#define IMAGE_SYM_TYPE_INT 0x0004
3486#define IMAGE_SYM_TYPE_LONG 0x0005
3487#define IMAGE_SYM_TYPE_FLOAT 0x0006
3488#define IMAGE_SYM_TYPE_DOUBLE 0x0007
3489#define IMAGE_SYM_TYPE_STRUCT 0x0008
3490#define IMAGE_SYM_TYPE_UNION 0x0009
3491#define IMAGE_SYM_TYPE_ENUM 0x000A
3492#define IMAGE_SYM_TYPE_MOE 0x000B
3493#define IMAGE_SYM_TYPE_BYTE 0x000C
3494#define IMAGE_SYM_TYPE_WORD 0x000D
3495#define IMAGE_SYM_TYPE_UINT 0x000E
3496#define IMAGE_SYM_TYPE_DWORD 0x000F
3497#define IMAGE_SYM_TYPE_PCODE 0x8000
3498
3499#define IMAGE_SYM_DTYPE_NULL 0
3500#define IMAGE_SYM_DTYPE_POINTER 1
3501#define IMAGE_SYM_DTYPE_FUNCTION 2
3502#define IMAGE_SYM_DTYPE_ARRAY 3
3503
3504#define IMAGE_SYM_CLASS_END_OF_FUNCTION (BYTE )-1
3505#define IMAGE_SYM_CLASS_NULL 0x0000
3506#define IMAGE_SYM_CLASS_AUTOMATIC 0x0001
3507#define IMAGE_SYM_CLASS_EXTERNAL 0x0002
3508#define IMAGE_SYM_CLASS_STATIC 0x0003
3509#define IMAGE_SYM_CLASS_REGISTER 0x0004
3510#define IMAGE_SYM_CLASS_EXTERNAL_DEF 0x0005
3511#define IMAGE_SYM_CLASS_LABEL 0x0006
3512#define IMAGE_SYM_CLASS_UNDEFINED_LABEL 0x0007
3513#define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT 0x0008
3514#define IMAGE_SYM_CLASS_ARGUMENT 0x0009
3515#define IMAGE_SYM_CLASS_STRUCT_TAG 0x000A
3516#define IMAGE_SYM_CLASS_MEMBER_OF_UNION 0x000B
3517#define IMAGE_SYM_CLASS_UNION_TAG 0x000C
3518#define IMAGE_SYM_CLASS_TYPE_DEFINITION 0x000D
3519#define IMAGE_SYM_CLASS_UNDEFINED_STATIC 0x000E
3520#define IMAGE_SYM_CLASS_ENUM_TAG 0x000F
3521#define IMAGE_SYM_CLASS_MEMBER_OF_ENUM 0x0010
3522#define IMAGE_SYM_CLASS_REGISTER_PARAM 0x0011
3523#define IMAGE_SYM_CLASS_BIT_FIELD 0x0012
3524
3525#define IMAGE_SYM_CLASS_FAR_EXTERNAL 0x0044
3526#define IMAGE_SYM_CLASS_BLOCK 0x0064
3527#define IMAGE_SYM_CLASS_FUNCTION 0x0065
3528#define IMAGE_SYM_CLASS_END_OF_STRUCT 0x0066
3529#define IMAGE_SYM_CLASS_FILE 0x0067
3530#define IMAGE_SYM_CLASS_SECTION 0x0068
3531#define IMAGE_SYM_CLASS_WEAK_EXTERNAL 0x0069
3532
3533#define N_BTMASK 0x000F
3534#define N_TMASK 0x0030
3535#define N_TMASK1 0x00C0
3536#define N_TMASK2 0x00F0
3537#define N_BTSHFT 4
3538#define N_TSHIFT 2
3539
3540#define BTYPE(x) ((x) & N_BTMASK)
3541
3542#ifndef ISPTR
3543#define ISPTR(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_POINTER << N_BTSHFT))
3544#endif
3545
3546#ifndef ISFCN
3547#define ISFCN(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_FUNCTION << N_BTSHFT))
3548#endif
3549
3550#ifndef ISARY
3551#define ISARY(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_ARRAY << N_BTSHFT))
3552#endif
3553
3554#ifndef ISTAG
3555#define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG || (x)==IMAGE_SYM_CLASS_UNION_TAG || (x)==IMAGE_SYM_CLASS_ENUM_TAG)
3556#endif
3557
3558#ifndef INCREF
3559#define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
3560#endif
3561#ifndef DECREF
3562#define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
3563#endif
3564
3565#define IMAGE_COMDAT_SELECT_NODUPLICATES 1
3566#define IMAGE_COMDAT_SELECT_ANY 2
3567#define IMAGE_COMDAT_SELECT_SAME_SIZE 3
3568#define IMAGE_COMDAT_SELECT_EXACT_MATCH 4
3569#define IMAGE_COMDAT_SELECT_ASSOCIATIVE 5
3570#define IMAGE_COMDAT_SELECT_LARGEST 6
3571#define IMAGE_COMDAT_SELECT_NEWEST 7
3572
3573#define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY 1
3574#define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY 2
3575#define IMAGE_WEAK_EXTERN_SEARCH_ALIAS 3
3576
3577/* Export module directory */
3578
3579typedef struct _IMAGE_EXPORT_DIRECTORY {
3580 DWORD Characteristics;
3581 DWORD TimeDateStamp;
3582 WORD MajorVersion;
3583 WORD MinorVersion;
3584 DWORD Name;
3585 DWORD Base;
3586 DWORD NumberOfFunctions;
3587 DWORD NumberOfNames;
3588 DWORD AddressOfFunctions;
3589 DWORD AddressOfNames;
3590 DWORD AddressOfNameOrdinals;
3591} IMAGE_EXPORT_DIRECTORY,*PIMAGE_EXPORT_DIRECTORY;
3592
3593/* Import name entry */
3594typedef struct _IMAGE_IMPORT_BY_NAME {
3595 WORD Hint;
3596 BYTE Name[1];
3597} IMAGE_IMPORT_BY_NAME,*PIMAGE_IMPORT_BY_NAME;
3598
3599/* Import thunk */
3600typedef struct _IMAGE_THUNK_DATA {
3601 union {
3602 LPBYTE ForwarderString;
3603 PDWORD Function;
3604 DWORD Ordinal;
3605 PIMAGE_IMPORT_BY_NAME AddressOfData;
3606 } u1;
3607} IMAGE_THUNK_DATA,*PIMAGE_THUNK_DATA;
3608
3609/* Import module directory */
3610
3611typedef struct _IMAGE_IMPORT_DESCRIPTOR {
3612 union {
3613 DWORD Characteristics; /* 0 for terminating null import descriptor */
3614 PIMAGE_THUNK_DATA OriginalFirstThunk; /* RVA to original unbound IAT */
3615 } u;
3616 DWORD TimeDateStamp; /* 0 if not bound,
3617 * -1 if bound, and real date\time stamp
3618 * in IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT
3619 * (new BIND)
3620 * otherwise date/time stamp of DLL bound to
3621 * (Old BIND)
3622 */
3623 DWORD ForwarderChain; /* -1 if no forwarders */
3624 DWORD Name;
3625 /* RVA to IAT (if bound this IAT has actual addresses) */
3626 PIMAGE_THUNK_DATA FirstThunk;
3627} IMAGE_IMPORT_DESCRIPTOR,*PIMAGE_IMPORT_DESCRIPTOR;
3628
3629#define IMAGE_ORDINAL_FLAG 0x80000000
3630#define IMAGE_SNAP_BY_ORDINAL(Ordinal) ((Ordinal & IMAGE_ORDINAL_FLAG) != 0)
3631#define IMAGE_ORDINAL(Ordinal) (Ordinal & 0xffff)
3632
3633typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR
3634{
3635 DWORD TimeDateStamp;
3636 WORD OffsetModuleName;
3637 WORD NumberOfModuleForwarderRefs;
3638/* Array of zero or more IMAGE_BOUND_FORWARDER_REF follows */
3639} IMAGE_BOUND_IMPORT_DESCRIPTOR, *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
3640
3641typedef struct _IMAGE_BOUND_FORWARDER_REF
3642{
3643 DWORD TimeDateStamp;
3644 WORD OffsetModuleName;
3645 WORD Reserved;
3646} IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
3647
3648#include "pshpack2.h"
3649
3650typedef struct _IMAGE_BASE_RELOCATION
3651{
3652 DWORD VirtualAddress;
3653 DWORD SizeOfBlock;
3654 /* WORD TypeOffset[1]; */
3655} IMAGE_BASE_RELOCATION,*PIMAGE_BASE_RELOCATION;
3656
3657typedef struct _IMAGE_RELOCATION
3658{
3659 union {
3660 DWORD VirtualAddress;
3661 DWORD RelocCount;
3662 } u;
3663 DWORD SymbolTableIndex;
3664 WORD Type;
3665} IMAGE_RELOCATION;
3666typedef IMAGE_RELOCATION *PIMAGE_RELOCATION;
3667
3668#include "poppack.h"
3669
3670#define IMAGE_SIZEOF_RELOCATION 10
3671
3672/* generic relocation types */
3673#define IMAGE_REL_BASED_ABSOLUTE 0
3674#define IMAGE_REL_BASED_HIGH 1
3675#define IMAGE_REL_BASED_LOW 2
3676#define IMAGE_REL_BASED_HIGHLOW 3
3677#define IMAGE_REL_BASED_HIGHADJ 4
3678#define IMAGE_REL_BASED_MIPS_JMPADDR 5
3679#define IMAGE_REL_BASED_SECTION 6
3680#define IMAGE_REL_BASED_REL 7
3681#define IMAGE_REL_BASED_MIPS_JMPADDR16 9
3682#define IMAGE_REL_BASED_IA64_IMM64 9 /* yes, 9 too */
3683#define IMAGE_REL_BASED_DIR64 10
3684#define IMAGE_REL_BASED_HIGH3ADJ 11
3685
3686/* I386 relocation types */
3687#define IMAGE_REL_I386_ABSOLUTE 0
3688#define IMAGE_REL_I386_DIR16 1
3689#define IMAGE_REL_I386_REL16 2
3690#define IMAGE_REL_I386_DIR32 6
3691#define IMAGE_REL_I386_DIR32NB 7
3692#define IMAGE_REL_I386_SEG12 9
3693#define IMAGE_REL_I386_SECTION 10
3694#define IMAGE_REL_I386_SECREL 11
3695#define IMAGE_REL_I386_REL32 20
3696
3697/* MIPS relocation types */
3698#define IMAGE_REL_MIPS_ABSOLUTE 0x0000
3699#define IMAGE_REL_MIPS_REFHALF 0x0001
3700#define IMAGE_REL_MIPS_REFWORD 0x0002
3701#define IMAGE_REL_MIPS_JMPADDR 0x0003
3702#define IMAGE_REL_MIPS_REFHI 0x0004
3703#define IMAGE_REL_MIPS_REFLO 0x0005
3704#define IMAGE_REL_MIPS_GPREL 0x0006
3705#define IMAGE_REL_MIPS_LITERAL 0x0007
3706#define IMAGE_REL_MIPS_SECTION 0x000A
3707#define IMAGE_REL_MIPS_SECREL 0x000B
3708#define IMAGE_REL_MIPS_SECRELLO 0x000C
3709#define IMAGE_REL_MIPS_SECRELHI 0x000D
3710#define IMAGE_REL_MIPS_JMPADDR16 0x0010
3711#define IMAGE_REL_MIPS_REFWORDNB 0x0022
3712#define IMAGE_REL_MIPS_PAIR 0x0025
3713
3714/* ALPHA relocation types */
3715#define IMAGE_REL_ALPHA_ABSOLUTE 0x0000
3716#define IMAGE_REL_ALPHA_REFLONG 0x0001
3717#define IMAGE_REL_ALPHA_REFQUAD 0x0002
3718#define IMAGE_REL_ALPHA_GPREL 0x0003
3719#define IMAGE_REL_ALPHA_LITERAL 0x0004
3720#define IMAGE_REL_ALPHA_LITUSE 0x0005
3721#define IMAGE_REL_ALPHA_GPDISP 0x0006
3722#define IMAGE_REL_ALPHA_BRADDR 0x0007
3723#define IMAGE_REL_ALPHA_HINT 0x0008
3724#define IMAGE_REL_ALPHA_INLINE_REFLONG 0x0009
3725#define IMAGE_REL_ALPHA_REFHI 0x000A
3726#define IMAGE_REL_ALPHA_REFLO 0x000B
3727#define IMAGE_REL_ALPHA_PAIR 0x000C
3728#define IMAGE_REL_ALPHA_MATCH 0x000D
3729#define IMAGE_REL_ALPHA_SECTION 0x000E
3730#define IMAGE_REL_ALPHA_SECREL 0x000F
3731#define IMAGE_REL_ALPHA_REFLONGNB 0x0010
3732#define IMAGE_REL_ALPHA_SECRELLO 0x0011
3733#define IMAGE_REL_ALPHA_SECRELHI 0x0012
3734#define IMAGE_REL_ALPHA_REFQ3 0x0013
3735#define IMAGE_REL_ALPHA_REFQ2 0x0014
3736#define IMAGE_REL_ALPHA_REFQ1 0x0015
3737#define IMAGE_REL_ALPHA_GPRELLO 0x0016
3738#define IMAGE_REL_ALPHA_GPRELHI 0x0017
3739
3740/* PowerPC relocation types */
3741#define IMAGE_REL_PPC_ABSOLUTE 0x0000
3742#define IMAGE_REL_PPC_ADDR64 0x0001
3743#define IMAGE_REL_PPC_ADDR 0x0002
3744#define IMAGE_REL_PPC_ADDR24 0x0003
3745#define IMAGE_REL_PPC_ADDR16 0x0004
3746#define IMAGE_REL_PPC_ADDR14 0x0005
3747#define IMAGE_REL_PPC_REL24 0x0006
3748#define IMAGE_REL_PPC_REL14 0x0007
3749#define IMAGE_REL_PPC_TOCREL16 0x0008
3750#define IMAGE_REL_PPC_TOCREL14 0x0009
3751#define IMAGE_REL_PPC_ADDR32NB 0x000A
3752#define IMAGE_REL_PPC_SECREL 0x000B
3753#define IMAGE_REL_PPC_SECTION 0x000C
3754#define IMAGE_REL_PPC_IFGLUE 0x000D
3755#define IMAGE_REL_PPC_IMGLUE 0x000E
3756#define IMAGE_REL_PPC_SECREL16 0x000F
3757#define IMAGE_REL_PPC_REFHI 0x0010
3758#define IMAGE_REL_PPC_REFLO 0x0011
3759#define IMAGE_REL_PPC_PAIR 0x0012
3760#define IMAGE_REL_PPC_SECRELLO 0x0013
3761#define IMAGE_REL_PPC_SECRELHI 0x0014
3762#define IMAGE_REL_PPC_GPREL 0x0015
3763#define IMAGE_REL_PPC_TYPEMASK 0x00FF
3764/* modifier bits */
3765#define IMAGE_REL_PPC_NEG 0x0100
3766#define IMAGE_REL_PPC_BRTAKEN 0x0200
3767#define IMAGE_REL_PPC_BRNTAKEN 0x0400
3768#define IMAGE_REL_PPC_TOCDEFN 0x0800
3769
3770/* SH3 ? relocation type */
3771#define IMAGE_REL_SH3_ABSOLUTE 0x0000
3772#define IMAGE_REL_SH3_DIRECT16 0x0001
3773#define IMAGE_REL_SH3_DIRECT 0x0002
3774#define IMAGE_REL_SH3_DIRECT8 0x0003
3775#define IMAGE_REL_SH3_DIRECT8_WORD 0x0004
3776#define IMAGE_REL_SH3_DIRECT8_LONG 0x0005
3777#define IMAGE_REL_SH3_DIRECT4 0x0006
3778#define IMAGE_REL_SH3_DIRECT4_WORD 0x0007
3779#define IMAGE_REL_SH3_DIRECT4_LONG 0x0008
3780#define IMAGE_REL_SH3_PCREL8_WORD 0x0009
3781#define IMAGE_REL_SH3_PCREL8_LONG 0x000A
3782#define IMAGE_REL_SH3_PCREL12_WORD 0x000B
3783#define IMAGE_REL_SH3_STARTOF_SECTION 0x000C
3784#define IMAGE_REL_SH3_SIZEOF_SECTION 0x000D
3785#define IMAGE_REL_SH3_SECTION 0x000E
3786#define IMAGE_REL_SH3_SECREL 0x000F
3787#define IMAGE_REL_SH3_DIRECT32_NB 0x0010
3788
3789/* ARM (Archimedes?) relocation types */
3790#define IMAGE_REL_ARM_ABSOLUTE 0x0000
3791#define IMAGE_REL_ARM_ADDR 0x0001
3792#define IMAGE_REL_ARM_ADDR32NB 0x0002
3793#define IMAGE_REL_ARM_BRANCH24 0x0003
3794#define IMAGE_REL_ARM_BRANCH11 0x0004
3795#define IMAGE_REL_ARM_SECTION 0x000E
3796#define IMAGE_REL_ARM_SECREL 0x000F
3797
3798/* IA64 relocation types */
3799#define IMAGE_REL_IA64_ABSOLUTE 0x0000
3800#define IMAGE_REL_IA64_IMM14 0x0001
3801#define IMAGE_REL_IA64_IMM22 0x0002
3802#define IMAGE_REL_IA64_IMM64 0x0003
3803#define IMAGE_REL_IA64_DIR 0x0004
3804#define IMAGE_REL_IA64_DIR64 0x0005
3805#define IMAGE_REL_IA64_PCREL21B 0x0006
3806#define IMAGE_REL_IA64_PCREL21M 0x0007
3807#define IMAGE_REL_IA64_PCREL21F 0x0008
3808#define IMAGE_REL_IA64_GPREL22 0x0009
3809#define IMAGE_REL_IA64_LTOFF22 0x000A
3810#define IMAGE_REL_IA64_SECTION 0x000B
3811#define IMAGE_REL_IA64_SECREL22 0x000C
3812#define IMAGE_REL_IA64_SECREL64I 0x000D
3813#define IMAGE_REL_IA64_SECREL 0x000E
3814#define IMAGE_REL_IA64_LTOFF64 0x000F
3815#define IMAGE_REL_IA64_DIR32NB 0x0010
3816#define IMAGE_REL_IA64_RESERVED_11 0x0011
3817#define IMAGE_REL_IA64_RESERVED_12 0x0012
3818#define IMAGE_REL_IA64_RESERVED_13 0x0013
3819#define IMAGE_REL_IA64_RESERVED_14 0x0014
3820#define IMAGE_REL_IA64_RESERVED_15 0x0015
3821#define IMAGE_REL_IA64_RESERVED_16 0x0016
3822#define IMAGE_REL_IA64_ADDEND 0x001F
3823
3824/* archive format */
3825
3826#define IMAGE_ARCHIVE_START_SIZE 8
3827#define IMAGE_ARCHIVE_START "!<arch>\n"
3828#define IMAGE_ARCHIVE_END "`\n"
3829#define IMAGE_ARCHIVE_PAD "\n"
3830#define IMAGE_ARCHIVE_LINKER_MEMBER "/ "
3831#define IMAGE_ARCHIVE_LONGNAMES_MEMBER "// "
3832
3833typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER
3834{
3835 BYTE Name[16];
3836 BYTE Date[12];
3837 BYTE UserID[6];
3838 BYTE GroupID[6];
3839 BYTE Mode[8];
3840 BYTE Size[10];
3841 BYTE EndHeader[2];
3842} IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
3843
3844#define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
3845
3846/*
3847 * Resource directory stuff
3848 */
3849typedef struct _IMAGE_RESOURCE_DIRECTORY {
3850 DWORD Characteristics;
3851 DWORD TimeDateStamp;
3852 WORD MajorVersion;
3853 WORD MinorVersion;
3854 WORD NumberOfNamedEntries;
3855 WORD NumberOfIdEntries;
3856 /* IMAGE_RESOURCE_DIRECTORY_ENTRY DirectoryEntries[]; */
3857} IMAGE_RESOURCE_DIRECTORY,*PIMAGE_RESOURCE_DIRECTORY;
3858
3859#define IMAGE_RESOURCE_NAME_IS_STRING 0x80000000
3860#define IMAGE_RESOURCE_DATA_IS_DIRECTORY 0x80000000
3861
3862typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
3863 union u1 {
3864 struct fleegle {
3865#ifdef BITFIELDS_BIGENDIAN
3866 unsigned NameIsString:1;
3867 unsigned NameOffset:31;
3868#else
3869 unsigned NameOffset:31;
3870 unsigned NameIsString:1;
3871#endif
3872 } DUMMYSTRUCTNAME1;
3873 DWORD Name;
3874 struct sneegle {
3875#ifdef WORDS_BIGENDIAN
3876 WORD __pad;
3877 WORD Id;
3878#else
3879 WORD Id;
3880 WORD __pad;
3881#endif
3882 } DUMMYSTRUCTNAME2;
3883 } DUMMYUNIONNAME1;
3884 union u2 {
3885 DWORD OffsetToData;
3886 struct drooper {
3887#ifdef BITFIELDS_BIGENDIAN
3888 unsigned DataIsDirectory:1;
3889 unsigned OffsetToDirectory:31;
3890#else
3891 unsigned OffsetToDirectory:31;
3892 unsigned DataIsDirectory:1;
3893#endif
3894 } DUMMYSTRUCTNAME3;
3895 } DUMMYUNIONNAME2;
3896} IMAGE_RESOURCE_DIRECTORY_ENTRY,*PIMAGE_RESOURCE_DIRECTORY_ENTRY;
3897
3898
3899typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
3900 WORD Length;
3901 CHAR NameString[ 1 ];
3902} IMAGE_RESOURCE_DIRECTORY_STRING,*PIMAGE_RESOURCE_DIRECTORY_STRING;
3903
3904typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
3905 WORD Length;
3906 WCHAR NameString[ 1 ];
3907} IMAGE_RESOURCE_DIR_STRING_U,*PIMAGE_RESOURCE_DIR_STRING_U;
3908
3909typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
3910 DWORD OffsetToData;
3911 DWORD Size;
3912 DWORD CodePage;
3913 DWORD ResourceHandle;
3914} IMAGE_RESOURCE_DATA_ENTRY,*PIMAGE_RESOURCE_DATA_ENTRY;
3915
3916
3917typedef VOID CALLBACK (*PIMAGE_TLS_CALLBACK)(
3918 LPVOID DllHandle,DWORD Reason,LPVOID Reserved
3919);
3920
3921typedef struct _IMAGE_TLS_DIRECTORY {
3922 DWORD StartAddressOfRawData;
3923 DWORD EndAddressOfRawData;
3924 LPDWORD AddressOfIndex;
3925 PIMAGE_TLS_CALLBACK *AddressOfCallBacks;
3926 DWORD SizeOfZeroFill;
3927 DWORD Characteristics;
3928} IMAGE_TLS_DIRECTORY,*PIMAGE_TLS_DIRECTORY;
3929
3930typedef struct _IMAGE_DEBUG_DIRECTORY {
3931 DWORD Characteristics;
3932 DWORD TimeDateStamp;
3933 WORD MajorVersion;
3934 WORD MinorVersion;
3935 DWORD Type;
3936 DWORD SizeOfData;
3937 DWORD AddressOfRawData;
3938 DWORD PointerToRawData;
3939} IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
3940
3941#define IMAGE_DEBUG_TYPE_UNKNOWN 0
3942#define IMAGE_DEBUG_TYPE_COFF 1
3943#define IMAGE_DEBUG_TYPE_CODEVIEW 2
3944#define IMAGE_DEBUG_TYPE_FPO 3
3945#define IMAGE_DEBUG_TYPE_MISC 4
3946#define IMAGE_DEBUG_TYPE_EXCEPTION 5
3947#define IMAGE_DEBUG_TYPE_FIXUP 6
3948#define IMAGE_DEBUG_TYPE_OMAP_TO_SRC 7
3949#define IMAGE_DEBUG_TYPE_OMAP_FROM_SRC 8
3950#define IMAGE_DEBUG_TYPE_BORLAND 9
3951#define IMAGE_DEBUG_TYPE_RESERVED10 10
3952
3953typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
3954 DWORD NumberOfSymbols;
3955 DWORD LvaToFirstSymbol;
3956 DWORD NumberOfLinenumbers;
3957 DWORD LvaToFirstLinenumber;
3958 DWORD RvaToFirstByteOfCode;
3959 DWORD RvaToLastByteOfCode;
3960 DWORD RvaToFirstByteOfData;
3961 DWORD RvaToLastByteOfData;
3962} IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
3963
3964#define FRAME_FPO 0
3965#define FRAME_TRAP 1
3966#define FRAME_TSS 2
3967#define FRAME_NONFPO 3
3968
3969typedef struct _FPO_DATA {
3970 DWORD ulOffStart;
3971 DWORD cbProcSize;
3972 DWORD cdwLocals;
3973 WORD cdwParams;
3974 unsigned cbProlog : 8;
3975 unsigned cbRegs : 3;
3976 unsigned fHasSEH : 1;
3977 unsigned fUseBP : 1;
3978 unsigned reserved : 1;
3979 unsigned cbFrame : 2;
3980} FPO_DATA, *PFPO_DATA;
3981
3982typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY {
3983 DWORD Characteristics;
3984 DWORD TimeDateStamp;
3985 WORD MajorVersion;
3986 WORD MinorVersion;
3987 DWORD GlobalFlagsClear;
3988 DWORD GlobalFlagsSet;
3989 DWORD CriticalSectionDefaultTimeout;
3990 DWORD DeCommitFreeBlockThreshold;
3991 DWORD DeCommitTotalFreeThreshold;
3992 PVOID LockPrefixTable;
3993 DWORD MaximumAllocationSize;
3994 DWORD VirtualMemoryThreshold;
3995 DWORD ProcessHeapFlags;
3996 DWORD ProcessAffinityMask;
3997 WORD CSDVersion;
3998 WORD Reserved1;
3999 PVOID EditList;
4000 DWORD Reserved[1];
4001} IMAGE_LOAD_CONFIG_DIRECTORY, *PIMAGE_LOAD_CONFIG_DIRECTORY;
4002
4003typedef struct _IMAGE_FUNCTION_ENTRY {
4004 DWORD StartingAddress;
4005 DWORD EndingAddress;
4006 DWORD EndOfPrologue;
4007} IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
4008
4009#define IMAGE_DEBUG_MISC_EXENAME 1
4010
4011typedef struct _IMAGE_DEBUG_MISC {
4012 DWORD DataType;
4013 DWORD Length;
4014 BYTE Unicode;
4015 BYTE Reserved[ 3 ];
4016 BYTE Data[ 1 ];
4017} IMAGE_DEBUG_MISC, *PIMAGE_DEBUG_MISC;
4018
4019/* This is the structure that appears at the very start of a .DBG file. */
4020
4021typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
4022 WORD Signature;
4023 WORD Flags;
4024 WORD Machine;
4025 WORD Characteristics;
4026 DWORD TimeDateStamp;
4027 DWORD CheckSum;
4028 DWORD ImageBase;
4029 DWORD SizeOfImage;
4030 DWORD NumberOfSections;
4031 DWORD ExportedNamesSize;
4032 DWORD DebugDirectorySize;
4033 DWORD SectionAlignment;
4034 DWORD Reserved[ 2 ];
4035} IMAGE_SEPARATE_DEBUG_HEADER,*PIMAGE_SEPARATE_DEBUG_HEADER;
4036
4037#define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
4038
4039
4040typedef struct tagMESSAGE_RESOURCE_ENTRY {
4041 WORD Length;
4042 WORD Flags;
4043 BYTE Text[1];
4044} MESSAGE_RESOURCE_ENTRY,*PMESSAGE_RESOURCE_ENTRY;
4045#define MESSAGE_RESOURCE_UNICODE 0x0001
4046
4047typedef struct tagMESSAGE_RESOURCE_BLOCK {
4048 DWORD LowId;
4049 DWORD HighId;
4050 DWORD OffsetToEntries;
4051} MESSAGE_RESOURCE_BLOCK,*PMESSAGE_RESOURCE_BLOCK;
4052
4053typedef struct tagMESSAGE_RESOURCE_DATA {
4054 DWORD NumberOfBlocks;
4055 MESSAGE_RESOURCE_BLOCK Blocks[ 1 ];
4056} MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA;
4057
4058/*
4059 * Here follows typedefs for security and tokens.
4060 */
4061
4062/*
4063 * First a constant for the following typdefs.
4064 */
4065
4066#define ANYSIZE_ARRAY 1
4067
4068/* FIXME: Orphan. What does it point to? */
4069typedef PVOID PACCESS_TOKEN;
4070
4071/*
4072 * TOKEN_INFORMATION_CLASS
4073 */
4074
4075typedef enum _TOKEN_INFORMATION_CLASS {
4076 TokenUser = 1,
4077 TokenGroups,
4078 TokenPrivileges,
4079 TokenOwner,
4080 TokenPrimaryGroup,
4081 TokenDefaultDacl,
4082 TokenSource,
4083 TokenType,
4084 TokenImpersonationLevel,
4085 TokenStatistics
4086} TOKEN_INFORMATION_CLASS;
4087
4088#define TOKEN_TOKEN_ADJUST_DEFAULT 0x0080
4089#define TOKEN_ADJUST_GROUPS 0x0040
4090#define TOKEN_ADJUST_PRIVILEGES 0x0020
4091#define TOKEN_ADJUST_SESSIONID 0x0100
4092#define TOKEN_ASSIGN_PRIMARY 0x0001
4093#define TOKEN_DUPLICATE 0x0002
4094#define TOKEN_EXECUTE STANDARD_RIGHTS_EXECUTE
4095#define TOKEN_IMPERSONATE 0x0004
4096#define TOKEN_QUERY 0x0008
4097#define TOKEN_QUERY_SOURCE 0x0010
4098#define TOKEN_ADJUST_DEFAULT 0x0080
4099#define TOKEN_READ (STANDARD_RIGHTS_READ|TOKEN_QUERY)
4100#define TOKEN_WRITE (STANDARD_RIGHTS_WRITE | \
4101 TOKEN_ADJUST_PRIVILEGES | \
4102 TOKEN_ADJUST_GROUPS | \
4103 TOKEN_ADJUST_DEFAULT )
4104#define TOKEN_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | \
4105 TOKEN_ASSIGN_PRIMARY | \
4106 TOKEN_DUPLICATE | \
4107 TOKEN_IMPERSONATE | \
4108 TOKEN_QUERY | \
4109 TOKEN_QUERY_SOURCE | \
4110 TOKEN_ADJUST_PRIVILEGES | \
4111 TOKEN_ADJUST_GROUPS | \
4112 TOKEN_ADJUST_SESSIONID | \
4113 TOKEN_ADJUST_DEFAULT )
4114
4115#ifndef _SECURITY_DEFINED
4116#define _SECURITY_DEFINED
4117
4118
4119typedef DWORD ACCESS_MASK, *PACCESS_MASK;
4120
4121typedef struct _GENERIC_MAPPING {
4122 ACCESS_MASK GenericRead;
4123 ACCESS_MASK GenericWrite;
4124 ACCESS_MASK GenericExecute;
4125 ACCESS_MASK GenericAll;
4126} GENERIC_MAPPING, *PGENERIC_MAPPING;
4127
4128#ifndef SID_IDENTIFIER_AUTHORITY_DEFINED
4129#define SID_IDENTIFIER_AUTHORITY_DEFINED
4130typedef struct {
4131 BYTE Value[6];
4132} SID_IDENTIFIER_AUTHORITY,*PSID_IDENTIFIER_AUTHORITY,*LPSID_IDENTIFIER_AUTHORITY;
4133#endif /* !defined(SID_IDENTIFIER_AUTHORITY_DEFINED) */
4134
4135#ifndef SID_DEFINED
4136#define SID_DEFINED
4137typedef struct _SID {
4138 BYTE Revision;
4139 BYTE SubAuthorityCount;
4140 SID_IDENTIFIER_AUTHORITY IdentifierAuthority;
4141 DWORD SubAuthority[1];
4142} SID,*PSID;
4143#endif /* !defined(SID_DEFINED) */
4144
4145#define SID_REVISION (1) /* Current revision */
4146#define SID_MAX_SUB_AUTHORITIES (15) /* current max subauths */
4147#define SID_RECOMMENDED_SUB_AUTHORITIES (1) /* recommended subauths */
4148
4149
4150/*
4151 * ACL
4152 */
4153
4154#define ACL_REVISION1 1
4155#define ACL_REVISION2 2
4156#define ACL_REVISION3 3
4157#define ACL_REVISION4 4
4158
4159#define MIN_ACL_REVISION ACL_REVISION2
4160#define MAX_ACL_REVISION ACL_REVISION4
4161
4162typedef struct _ACL {
4163 BYTE AclRevision;
4164 BYTE Sbz1;
4165 WORD AclSize;
4166 WORD AceCount;
4167 WORD Sbz2;
4168} ACL, *PACL;
4169
4170/* SECURITY_DESCRIPTOR */
4171#define SECURITY_DESCRIPTOR_REVISION 1
4172#define SECURITY_DESCRIPTOR_REVISION1 1
4173
4174
4175#define SE_OWNER_DEFAULTED 0x0001
4176#define SE_GROUP_DEFAULTED 0x0002
4177#define SE_DACL_PRESENT 0x0004
4178#define SE_DACL_DEFAULTED 0x0008
4179#define SE_SACL_PRESENT 0x0010
4180#define SE_SACL_DEFAULTED 0x0020
4181#define SE_SELF_RELATIVE 0x8000
4182
4183typedef DWORD SECURITY_INFORMATION, *PSECURITY_INFORMATION;
4184typedef WORD SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL;
4185
4186/* The security descriptor structure */
4187typedef struct {
4188 BYTE Revision;
4189 BYTE Sbz1;
4190 SECURITY_DESCRIPTOR_CONTROL Control;
4191 DWORD Owner;
4192 DWORD Group;
4193 DWORD Sacl;
4194 DWORD Dacl;
4195} SECURITY_DESCRIPTOR_RELATIVE, *PISECURITY_DESCRIPTOR_RELATIVE;
4196
4197typedef struct {
4198 BYTE Revision;
4199 BYTE Sbz1;
4200 SECURITY_DESCRIPTOR_CONTROL Control;
4201 PSID Owner;
4202 PSID Group;
4203 PACL Sacl;
4204 PACL Dacl;
4205} SECURITY_DESCRIPTOR, *PSECURITY_DESCRIPTOR;
4206
4207#define SECURITY_DESCRIPTOR_MIN_LENGTH (sizeof(SECURITY_DESCRIPTOR))
4208
4209#endif /* _SECURITY_DEFINED */
4210
4211/*
4212 * SID_AND_ATTRIBUTES
4213 */
4214
4215typedef struct _SID_AND_ATTRIBUTES {
4216 PSID Sid;
4217 DWORD Attributes;
4218} SID_AND_ATTRIBUTES ;
4219
4220/* security entities */
4221#define SECURITY_NULL_RID (0x00000000L)
4222#define SECURITY_WORLD_RID (0x00000000L)
4223#define SECURITY_LOCAL_RID (0X00000000L)
4224
4225#define SECURITY_NULL_SID_AUTHORITY {0,0,0,0,0,0}
4226
4227/* S-1-1 */
4228#define SECURITY_WORLD_SID_AUTHORITY {0,0,0,0,0,1}
4229
4230/* S-1-2 */
4231#define SECURITY_LOCAL_SID_AUTHORITY {0,0,0,0,0,2}
4232
4233/* S-1-3 */
4234#define SECURITY_CREATOR_SID_AUTHORITY {0,0,0,0,0,3}
4235#define SECURITY_CREATOR_OWNER_RID (0x00000000L)
4236#define SECURITY_CREATOR_GROUP_RID (0x00000001L)
4237#define SECURITY_CREATOR_OWNER_SERVER_RID (0x00000002L)
4238#define SECURITY_CREATOR_GROUP_SERVER_RID (0x00000003L)
4239
4240/* S-1-4 */
4241#define SECURITY_NON_UNIQUE_AUTHORITY {0,0,0,0,0,4}
4242
4243/* S-1-5 */
4244#define SECURITY_NT_AUTHORITY {0,0,0,0,0,5}
4245#define SECURITY_DIALUP_RID 0x00000001L
4246#define SECURITY_NETWORK_RID 0x00000002L
4247#define SECURITY_BATCH_RID 0x00000003L
4248#define SECURITY_INTERACTIVE_RID 0x00000004L
4249#define SECURITY_LOGON_IDS_RID 0x00000005L
4250#define SECURITY_SERVICE_RID 0x00000006L
4251#define SECURITY_ANONYMOUS_LOGON_RID 0x00000007L
4252#define SECURITY_PROXY_RID 0x00000008L
4253#define SECURITY_ENTERPRISE_CONTROLLERS_RID 0x00000009L
4254#define SECURITY_PRINCIPAL_SELF_RID 0x0000000AL
4255#define SECURITY_AUTHENTICATED_USER_RID 0x0000000BL
4256#define SECURITY_RESTRICTED_CODE_RID 0x0000000CL
4257#define SECURITY_TERMINAL_SERVER_RID 0x0000000DL
4258#define SECURITY_LOCAL_SYSTEM_RID 0x00000012L
4259#define SECURITY_NT_NON_UNIQUE 0x00000015L
4260#define SECURITY_BUILTIN_DOMAIN_RID 0x00000020L
4261
4262#define DOMAIN_GROUP_RID_ADMINS 0x00000200L
4263#define DOMAIN_GROUP_RID_USERS 0x00000201L
4264#define DOMAIN_GROUP_RID_GUESTS 0x00000202L
4265
4266#define DOMAIN_ALIAS_RID_ADMINS 0x00000220L
4267#define DOMAIN_ALIAS_RID_USERS 0x00000221L
4268#define DOMAIN_ALIAS_RID_GUESTS 0x00000222L
4269
4270#define SECURITY_SERVER_LOGON_RID SECURITY_ENTERPRISE_CONTROLLERS_RID
4271
4272#define SECURITY_LOGON_IDS_RID_COUNT (3L)
4273
4274/*
4275 * TOKEN_USER
4276 */
4277
4278typedef struct _TOKEN_USER {
4279 SID_AND_ATTRIBUTES User;
4280} TOKEN_USER;
4281
4282/*
4283 * TOKEN_GROUPS
4284 */
4285
4286typedef struct _TOKEN_GROUPS {
4287 DWORD GroupCount;
4288 SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY];
4289} TOKEN_GROUPS;
4290
4291/*
4292 * LUID_AND_ATTRIBUTES
4293 */
4294
4295typedef union _LARGE_INTEGER {
4296 struct dorp {
4297 DWORD LowPart;
4298 LONG HighPart;
4299 } DUMMYSTRUCTNAME;
4300 LONGLONG QuadPart;
4301} LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
4302
4303typedef union _ULARGE_INTEGER {
4304 struct banana {
4305 DWORD LowPart;
4306 DWORD HighPart;
4307 } DUMMYSTRUCTNAME;
4308 ULONGLONG QuadPart;
4309} ULARGE_INTEGER, *LPULARGE_INTEGER, *PULARGE_INTEGER;
4310
4311/*
4312 * Locally Unique Identifier
4313 */
4314
4315typedef struct _LUID {
4316 DWORD LowPart;
4317 LONG HighPart;
4318} LUID, *PLUID;
4319
4320#include "pshpack4.h"
4321typedef struct _LUID_AND_ATTRIBUTES {
4322 LUID Luid;
4323 DWORD Attributes;
4324} LUID_AND_ATTRIBUTES;
4325#include "poppack.h"
4326
4327/*
4328 * PRIVILEGE_SET
4329 */
4330
4331typedef struct _PRIVILEGE_SET {
4332 DWORD PrivilegeCount;
4333 DWORD Control;
4334 LUID_AND_ATTRIBUTES Privilege[ANYSIZE_ARRAY];
4335} PRIVILEGE_SET, *PPRIVILEGE_SET;
4336
4337/*
4338 * TOKEN_PRIVILEGES
4339 */
4340
4341typedef struct _TOKEN_PRIVILEGES {
4342 DWORD PrivilegeCount;
4343 LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
4344} TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES;
4345
4346/*
4347 * TOKEN_OWNER
4348 */
4349
4350typedef struct _TOKEN_OWNER {
4351 PSID Owner;
4352} TOKEN_OWNER;
4353
4354/*
4355 * TOKEN_PRIMARY_GROUP
4356 */
4357
4358typedef struct _TOKEN_PRIMARY_GROUP {
4359 PSID PrimaryGroup;
4360} TOKEN_PRIMARY_GROUP;
4361
4362
4363/*
4364 * TOKEN_DEFAULT_DACL
4365 */
4366
4367typedef struct _TOKEN_DEFAULT_DACL {
4368 PACL DefaultDacl;
4369} TOKEN_DEFAULT_DACL;
4370
4371/*
4372 * TOKEN_SOURCEL
4373 */
4374
4375typedef struct _TOKEN_SOURCE {
4376 char Sourcename[8];
4377 LUID SourceIdentifier;
4378} TOKEN_SOURCE;
4379
4380/*
4381 * TOKEN_TYPE
4382 */
4383
4384typedef enum tagTOKEN_TYPE {
4385 TokenPrimary = 1,
4386 TokenImpersonation
4387} TOKEN_TYPE;
4388
4389/*
4390 * SECURITY_IMPERSONATION_LEVEL
4391 */
4392
4393typedef enum _SECURITY_IMPERSONATION_LEVEL {
4394 SecurityAnonymous,
4395 SecurityIdentification,
4396 SecurityImpersonation,
4397 SecurityDelegation
4398} SECURITY_IMPERSONATION_LEVEL, *PSECURITY_IMPERSONATION_LEVEL;
4399
4400
4401typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,
4402 * PSECURITY_CONTEXT_TRACKING_MODE;
4403/*
4404 * Quality of Service
4405 */
4406
4407typedef struct _SECURITY_QUALITY_OF_SERVICE {
4408 DWORD Length;
4409 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
4410 SECURITY_CONTEXT_TRACKING_MODE ContextTrackingMode;
4411 BOOLEAN EffectiveOnly;
4412} SECURITY_QUALITY_OF_SERVICE, *PSECURITY_QUALITY_OF_SERVICE;
4413
4414/*
4415 * TOKEN_STATISTICS
4416 */
4417
4418typedef struct _TOKEN_STATISTICS {
4419 LUID TokenId;
4420 LUID AuthenticationId;
4421 LARGE_INTEGER ExpirationTime;
4422 TOKEN_TYPE TokenType;
4423 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
4424 DWORD DynamicCharged;
4425 DWORD DynamicAvailable;
4426 DWORD GroupCount;
4427 DWORD PrivilegeCount;
4428 LUID ModifiedId;
4429} TOKEN_STATISTICS;
4430
4431/*
4432 * ACLs of NT
4433 */
4434
4435#define ACL_REVISION 2
4436
4437#define ACL_REVISION1 1
4438#define ACL_REVISION2 2
4439
4440/* ACEs, directly starting after an ACL */
4441typedef struct _ACE_HEADER {
4442 BYTE AceType;
4443 BYTE AceFlags;
4444 WORD AceSize;
4445} ACE_HEADER,*PACE_HEADER;
4446
4447/* AceType */
4448#define ACCESS_ALLOWED_ACE_TYPE 0
4449#define ACCESS_DENIED_ACE_TYPE 1
4450#define SYSTEM_AUDIT_ACE_TYPE 2
4451#define SYSTEM_ALARM_ACE_TYPE 3
4452
4453/* inherit AceFlags */
4454#define OBJECT_INHERIT_ACE 0x01
4455#define CONTAINER_INHERIT_ACE 0x02
4456#define NO_PROPAGATE_INHERIT_ACE 0x04
4457#define INHERIT_ONLY_ACE 0x08
4458#define VALID_INHERIT_FLAGS 0x0F
4459
4460/* AceFlags mask for what events we (should) audit */
4461#define SUCCESSFUL_ACCESS_ACE_FLAG 0x40
4462#define FAILED_ACCESS_ACE_FLAG 0x80
4463
4464/* different ACEs depending on AceType
4465 * SidStart marks the begin of a SID
4466 * so the thing finally looks like this:
4467 * 0: ACE_HEADER
4468 * 4: ACCESS_MASK
4469 * 8... : SID
4470 */
4471typedef struct _ACCESS_ALLOWED_ACE {
4472 ACE_HEADER Header;
4473 DWORD Mask;
4474 DWORD SidStart;
4475} ACCESS_ALLOWED_ACE,*PACCESS_ALLOWED_ACE;
4476
4477typedef struct _ACCESS_DENIED_ACE {
4478 ACE_HEADER Header;
4479 DWORD Mask;
4480 DWORD SidStart;
4481} ACCESS_DENIED_ACE,*PACCESS_DENIED_ACE;
4482
4483typedef struct _SYSTEM_AUDIT_ACE {
4484 ACE_HEADER Header;
4485 DWORD Mask;
4486 DWORD SidStart;
4487} SYSTEM_AUDIT_ACE,*PSYSTEM_AUDIT_ACE;
4488
4489typedef struct _SYSTEM_ALARM_ACE {
4490 ACE_HEADER Header;
4491 DWORD Mask;
4492 DWORD SidStart;
4493} SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
4494
4495typedef enum tagSID_NAME_USE {
4496 SidTypeUser = 1,
4497 SidTypeGroup,
4498 SidTypeDomain,
4499 SidTypeAlias,
4500 SidTypeWellKnownGroup,
4501 SidTypeDeletedAccount,
4502 SidTypeInvalid,
4503 SidTypeUnknown
4504} SID_NAME_USE,*PSID_NAME_USE;
4505
4506/* Access rights */
4507
4508/* DELETE may be already defined via /usr/include/arpa/nameser_compat.h */
4509#undef DELETE
4510#define DELETE 0x00010000
4511#define READ_CONTROL 0x00020000
4512#define WRITE_DAC 0x00040000
4513#define WRITE_OWNER 0x00080000
4514#define SYNCHRONIZE 0x00100000
4515#define STANDARD_RIGHTS_REQUIRED 0x000f0000
4516
4517#define STANDARD_RIGHTS_READ READ_CONTROL
4518#define STANDARD_RIGHTS_WRITE READ_CONTROL
4519#define STANDARD_RIGHTS_EXECUTE READ_CONTROL
4520
4521#define STANDARD_RIGHTS_ALL 0x001f0000
4522
4523#define SPECIFIC_RIGHTS_ALL 0x0000ffff
4524
4525#define GENERIC_READ 0x80000000
4526#define GENERIC_WRITE 0x40000000
4527#define GENERIC_EXECUTE 0x20000000
4528#define GENERIC_ALL 0x10000000
4529
4530#define MAXIMUM_ALLOWED 0x02000000
4531#define ACCESS_SYSTEM_SECURITY 0x01000000
4532
4533#define EVENT_MODIFY_STATE 0x0002
4534#define EVENT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4535
4536#define SEMAPHORE_MODIFY_STATE 0x0002
4537#define SEMAPHORE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4538
4539#define MUTEX_MODIFY_STATE 0x0001
4540#define MUTEX_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1)
4541
4542#define TIMER_QUERY_STATE 0x0001
4543#define TIMER_MODIFY_STATE 0x0002
4544#define TIMER_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
4545
4546#define PROCESS_TERMINATE 0x0001
4547#define PROCESS_CREATE_THREAD 0x0002
4548#define PROCESS_VM_OPERATION 0x0008
4549#define PROCESS_VM_READ 0x0010
4550#define PROCESS_VM_WRITE 0x0020
4551#define PROCESS_DUP_HANDLE 0x0040
4552#define PROCESS_CREATE_PROCESS 0x0080
4553#define PROCESS_SET_QUOTA 0x0100
4554#define PROCESS_SET_INFORMATION 0x0200
4555#define PROCESS_QUERY_INFORMATION 0x0400
4556#define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xfff)
4557
4558#define THREAD_TERMINATE 0x0001
4559#define THREAD_SUSPEND_RESUME 0x0002
4560#define THREAD_GET_CONTEXT 0x0008
4561#define THREAD_SET_CONTEXT 0x0010
4562#define THREAD_SET_INFORMATION 0x0020
4563#define THREAD_QUERY_INFORMATION 0x0040
4564#define THREAD_SET_THREAD_TOKEN 0x0080
4565#define THREAD_IMPERSONATE 0x0100
4566#define THREAD_DIRECT_IMPERSONATION 0x0200
4567#define THREAD_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3ff)
4568
4569#define THREAD_BASE_PRIORITY_LOWRT 15
4570#define THREAD_BASE_PRIORITY_MAX 2
4571#define THREAD_BASE_PRIORITY_MIN -2
4572#define THREAD_BASE_PRIORITY_IDLE -15
4573
4574#define FILE_READ_DATA 0x0001 /* file & pipe */
4575#define FILE_LIST_DIRECTORY 0x0001 /* directory */
4576#define FILE_WRITE_DATA 0x0002 /* file & pipe */
4577#define FILE_ADD_FILE 0x0002 /* directory */
4578#define FILE_APPEND_DATA 0x0004 /* file */
4579#define FILE_ADD_SUBDIRECTORY 0x0004 /* directory */
4580#define FILE_CREATE_PIPE_INSTANCE 0x0004 /* named pipe */
4581#define FILE_READ_EA 0x0008 /* file & directory */
4582#define FILE_READ_PROPERTIES FILE_READ_EA
4583#define FILE_WRITE_EA 0x0010 /* file & directory */
4584#define FILE_WRITE_PROPERTIES FILE_WRITE_EA
4585#define FILE_EXECUTE 0x0020 /* file */
4586#define FILE_TRAVERSE 0x0020 /* directory */
4587#define FILE_DELETE_CHILD 0x0040 /* directory */
4588#define FILE_READ_ATTRIBUTES 0x0080 /* all */
4589#define FILE_WRITE_ATTRIBUTES 0x0100 /* all */
4590#define FILE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1ff)
4591
4592#define FILE_GENERIC_READ (STANDARD_RIGHTS_READ | FILE_READ_DATA | \
4593 FILE_READ_ATTRIBUTES | FILE_READ_EA | \
4594 SYNCHRONIZE)
4595#define FILE_GENERIC_WRITE (STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA | \
4596 FILE_WRITE_ATTRIBUTES | FILE_WRITE_EA | \
4597 FILE_APPEND_DATA | SYNCHRONIZE)
4598#define FILE_GENERIC_EXECUTE (STANDARD_RIGHTS_EXECUTE | FILE_EXECUTE | \
4599 FILE_READ_ATTRIBUTES | SYNCHRONIZE)
4600
4601
4602/* File attribute flags */
4603#define FILE_SHARE_READ 0x00000001L
4604#define FILE_SHARE_WRITE 0x00000002L
4605#define FILE_SHARE_DELETE 0x00000004L
4606#define FILE_ATTRIBUTE_READONLY 0x00000001L
4607#define FILE_ATTRIBUTE_HIDDEN 0x00000002L
4608#define FILE_ATTRIBUTE_SYSTEM 0x00000004L
4609#define FILE_ATTRIBUTE_LABEL 0x00000008L /* Not in Windows API */
4610#define FILE_ATTRIBUTE_DIRECTORY 0x00000010L
4611#define FILE_ATTRIBUTE_ARCHIVE 0x00000020L
4612#define FILE_ATTRIBUTE_NORMAL 0x00000080L
4613#define FILE_ATTRIBUTE_TEMPORARY 0x00000100L
4614#define FILE_ATTRIBUTE_ATOMIC_WRITE 0x00000200L
4615#define FILE_ATTRIBUTE_XACTION_WRITE 0x00000400L
4616#define FILE_ATTRIBUTE_COMPRESSED 0x00000800L
4617#define FILE_ATTRIBUTE_OFFLINE 0x00001000L
4618#define FILE_ATTRIBUTE_SYMLINK 0x80000000L /* Not in Windows API */
4619
4620/* File notification flags */
4621#define FILE_NOTIFY_CHANGE_FILE_NAME 0x00000001
4622#define FILE_NOTIFY_CHANGE_DIR_NAME 0x00000002
4623#define FILE_NOTIFY_CHANGE_ATTRIBUTES 0x00000004
4624#define FILE_NOTIFY_CHANGE_SIZE 0x00000008
4625#define FILE_NOTIFY_CHANGE_LAST_WRITE 0x00000010
4626#define FILE_NOTIFY_CHANGE_LAST_ACCESS 0x00000020
4627#define FILE_NOTIFY_CHANGE_CREATION 0x00000040
4628#define FILE_NOTIFY_CHANGE_SECURITY 0x00000100
4629
4630#define FILE_ACTION_ADDED 0x00000001
4631#define FILE_ACTION_REMOVED 0x00000002
4632#define FILE_ACTION_MODIFIED 0x00000003
4633#define FILE_ACTION_RENAMED_OLD_NAME 0x00000004
4634#define FILE_ACTION_RENAMED_NEW_NAME 0x00000005
4635
4636
4637#define FILE_CASE_SENSITIVE_SEARCH 0x00000001
4638#define FILE_CASE_PRESERVED_NAMES 0x00000002
4639#define FILE_UNICODE_ON_DISK 0x00000004
4640#define FILE_PERSISTENT_ACLS 0x00000008
4641#define FILE_FILE_COMPRESSION 0x00000010
4642#define FILE_VOLUME_IS_COMPRESSED 0x00008000
4643
4644/* File alignments (NT) */
4645#define FILE_BYTE_ALIGNMENT 0x00000000
4646#define FILE_WORD_ALIGNMENT 0x00000001
4647#define FILE_LONG_ALIGNMENT 0x00000003
4648#define FILE_QUAD_ALIGNMENT 0x00000007
4649#define FILE_OCTA_ALIGNMENT 0x0000000f
4650#define FILE_32_BYTE_ALIGNMENT 0x0000001f
4651#define FILE_64_BYTE_ALIGNMENT 0x0000003f
4652#define FILE_128_BYTE_ALIGNMENT 0x0000007f
4653#define FILE_256_BYTE_ALIGNMENT 0x000000ff
4654#define FILE_512_BYTE_ALIGNMENT 0x000001ff
4655
4656#define REG_NONE 0 /* no type */
4657#define REG_SZ 1 /* string type (ASCII) */
4658#define REG_EXPAND_SZ 2 /* string, includes %ENVVAR% (expanded by caller) (ASCII) */
4659#define REG_BINARY 3 /* binary format, callerspecific */
4660/* YES, REG_DWORD == REG_DWORD_LITTLE_ENDIAN */
4661#define REG_DWORD 4 /* DWORD in little endian format */
4662#define REG_DWORD_LITTLE_ENDIAN 4 /* DWORD in little endian format */
4663#define REG_DWORD_BIG_ENDIAN 5 /* DWORD in big endian format */
4664#define REG_LINK 6 /* symbolic link (UNICODE) */
4665#define REG_MULTI_SZ 7 /* multiple strings, delimited by \0, terminated by \0\0 (ASCII) */
4666#define REG_RESOURCE_LIST 8 /* resource list? huh? */
4667#define REG_FULL_RESOURCE_DESCRIPTOR 9 /* full resource descriptor? huh? */
4668#define REG_RESOURCE_REQUIREMENTS_LIST 10
4669
4670/* ----------------------------- begin registry ----------------------------- */
4671
4672/* Registry security values */
4673#define OWNER_SECURITY_INFORMATION 0x00000001
4674#define GROUP_SECURITY_INFORMATION 0x00000002
4675#define DACL_SECURITY_INFORMATION 0x00000004
4676#define SACL_SECURITY_INFORMATION 0x00000008
4677
4678#define REG_OPTION_RESERVED 0x00000000
4679#define REG_OPTION_NON_VOLATILE 0x00000000
4680#define REG_OPTION_VOLATILE 0x00000001
4681#define REG_OPTION_CREATE_LINK 0x00000002
4682#define REG_OPTION_BACKUP_RESTORE 0x00000004 /* FIXME */
4683#define REG_OPTION_OPEN_LINK 0x00000008
4684#define REG_LEGAL_OPTION (REG_OPTION_RESERVED| \
4685 REG_OPTION_NON_VOLATILE| \
4686 REG_OPTION_VOLATILE| \
4687 REG_OPTION_CREATE_LINK| \
4688 REG_OPTION_BACKUP_RESTORE| \
4689 REG_OPTION_OPEN_LINK)
4690
4691
4692#define REG_CREATED_NEW_KEY 0x00000001
4693#define REG_OPENED_EXISTING_KEY 0x00000002
4694
4695/* For RegNotifyChangeKeyValue */
4696#define REG_NOTIFY_CHANGE_NAME 0x1
4697
4698#define KEY_QUERY_VALUE 0x00000001
4699#define KEY_SET_VALUE 0x00000002
4700#define KEY_CREATE_SUB_KEY 0x00000004
4701#define KEY_ENUMERATE_SUB_KEYS 0x00000008
4702#define KEY_NOTIFY 0x00000010
4703#define KEY_CREATE_LINK 0x00000020
4704
4705#define KEY_READ ((STANDARD_RIGHTS_READ| \
4706 KEY_QUERY_VALUE| \
4707 KEY_ENUMERATE_SUB_KEYS| \
4708 KEY_NOTIFY) \
4709 & (~SYNCHRONIZE) \
4710 )
4711#define KEY_WRITE ((STANDARD_RIGHTS_WRITE| \
4712 KEY_SET_VALUE| \
4713 KEY_CREATE_SUB_KEY) \
4714 & (~SYNCHRONIZE) \
4715 )
4716#define KEY_EXECUTE ((KEY_READ) \
4717 & (~SYNCHRONIZE)) \
4718 )
4719#define KEY_ALL_ACCESS ((STANDARD_RIGHTS_ALL| \
4720 KEY_QUERY_VALUE| \
4721 KEY_SET_VALUE| \
4722 KEY_CREATE_SUB_KEY| \
4723 KEY_ENUMERATE_SUB_KEYS| \
4724 KEY_NOTIFY| \
4725 KEY_CREATE_LINK) \
4726 & (~SYNCHRONIZE) \
4727 )
4728/* ------------------------------ end registry ------------------------------ */
4729
4730
4731#define EVENTLOG_SUCCESS 0x0000
4732#define EVENTLOG_ERROR_TYPE 0x0001
4733#define EVENTLOG_WARNING_TYPE 0x0002
4734#define EVENTLOG_INFORMATION_TYPE 0x0004
4735#define EVENTLOG_AUDIT_SUCCESS 0x0008
4736#define EVENTLOG_AUDIT_FAILURE 0x0010
4737
4738#define SERVICE_BOOT_START 0x00000000
4739#define SERVICE_SYSTEM_START 0x00000001
4740#define SERVICE_AUTO_START 0x00000002
4741#define SERVICE_DEMAND_START 0x00000003
4742#define SERVICE_DISABLED 0x00000004
4743
4744#define SERVICE_ERROR_IGNORE 0x00000000
4745#define SERVICE_ERROR_NORMAL 0x00000001
4746#define SERVICE_ERROR_SEVERE 0x00000002
4747#define SERVICE_ERROR_CRITICAL 0x00000003
4748
4749/* Service types */
4750#define SERVICE_KERNEL_DRIVER 0x00000001
4751#define SERVICE_FILE_SYSTEM_DRIVER 0x00000002
4752#define SERVICE_ADAPTER 0x00000004
4753#define SERVICE_RECOGNIZER_DRIVER 0x00000008
4754
4755#define SERVICE_DRIVER ( SERVICE_KERNEL_DRIVER | SERVICE_FILE_SYSTEM_DRIVER | \
4756 SERVICE_RECOGNIZER_DRIVER )
4757
4758#define SERVICE_WIN32_OWN_PROCESS 0x00000010
4759#define SERVICE_WIN32_SHARE_PROCESS 0x00000020
4760#define SERVICE_WIN32 (SERVICE_WIN32_OWN_PROCESS | SERVICE_WIN32_SHARE_PROCESS)
4761
4762#define SERVICE_INTERACTIVE_PROCESS 0x00000100
4763
4764#define SERVICE_TYPE_ALL ( SERVICE_WIN32 | SERVICE_ADAPTER | \
4765 SERVICE_DRIVER | SERVICE_INTERACTIVE_PROCESS )
4766
4767
4768typedef enum _CM_SERVICE_NODE_TYPE
4769{
4770 DriverType = SERVICE_KERNEL_DRIVER,
4771 FileSystemType = SERVICE_FILE_SYSTEM_DRIVER,
4772 Win32ServiceOwnProcess = SERVICE_WIN32_OWN_PROCESS,
4773 Win32ServiceShareProcess = SERVICE_WIN32_SHARE_PROCESS,
4774 AdapterType = SERVICE_ADAPTER,
4775 RecognizerType = SERVICE_RECOGNIZER_DRIVER
4776} SERVICE_NODE_TYPE;
4777
4778typedef enum _CM_SERVICE_LOAD_TYPE
4779{
4780 BootLoad = SERVICE_BOOT_START,
4781 SystemLoad = SERVICE_SYSTEM_START,
4782 AutoLoad = SERVICE_AUTO_START,
4783 DemandLoad = SERVICE_DEMAND_START,
4784 DisableLoad = SERVICE_DISABLED
4785} SERVICE_LOAD_TYPE;
4786
4787typedef enum _CM_ERROR_CONTROL_TYPE
4788{
4789 IgnoreError = SERVICE_ERROR_IGNORE,
4790 NormalError = SERVICE_ERROR_NORMAL,
4791 SevereError = SERVICE_ERROR_SEVERE,
4792 CriticalError = SERVICE_ERROR_CRITICAL
4793} SERVICE_ERROR_TYPE;
4794
4795
4796
4797#define RtlEqualMemory(Destination, Source, Length) (!memcmp((Destination),(Source),(Length)))
4798#define RtlMoveMemory(Destination, Source, Length) memmove((Destination),(Source),(Length))
4799#define RtlCopyMemory(Destination, Source, Length) memcpy((Destination),(Source),(Length))
4800#define RtlFillMemory(Destination, Length, Fill) memset((Destination),(Fill),(Length))
4801#define RtlZeroMemory(Destination, Length) memset((Destination),0,(Length))
4802
4803#include "guiddef.h"
4804
4805typedef struct _RTL_CRITICAL_SECTION_DEBUG
4806{
4807 WORD Type;
4808 WORD CreatorBackTraceIndex;
4809 struct _RTL_CRITICAL_SECTION *CriticalSection;
4810 LIST_ENTRY ProcessLocksList;
4811 DWORD EntryCount;
4812 DWORD ContentionCount;
4813 DWORD Spare[ 2 ];
4814} RTL_CRITICAL_SECTION_DEBUG, *PRTL_CRITICAL_SECTION_DEBUG, RTL_RESOURCE_DEBUG, *PRTL_RESOURCE_DEBUG;
4815
4816typedef struct _RTL_CRITICAL_SECTION {
4817 PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
4818 LONG LockCount;
4819 LONG RecursionCount;
4820 HANDLE OwningThread;
4821 HANDLE LockSemaphore;
4822 ULONG_PTR SpinCount;
4823} RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;
4824
4825#endif /* __WINE_WINNT_H */