Implemented a bunch of large integer functions in ntdll.
[wine] / include / 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 #include "windef.h"
12
13 #ifndef RC_INVOKED
14 #include <string.h>
15 #endif
16
17 #include "pshpack1.h"
18 /* Defines */
19
20 /* Argument 1 passed to the DllEntryProc. */
21 #define DLL_PROCESS_DETACH      0       /* detach process (unload library) */
22 #define DLL_PROCESS_ATTACH      1       /* attach process (load library) */
23 #define DLL_THREAD_ATTACH       2       /* attach new thread */
24 #define DLL_THREAD_DETACH       3       /* detach thread */
25
26
27 /* u.x.wProcessorArchitecture (NT) */
28 #define PROCESSOR_ARCHITECTURE_INTEL    0
29 #define PROCESSOR_ARCHITECTURE_MIPS     1
30 #define PROCESSOR_ARCHITECTURE_ALPHA    2
31 #define PROCESSOR_ARCHITECTURE_PPC      3
32 #define PROCESSOR_ARCHITECTURE_SHX      4
33 #define PROCESSOR_ARCHITECTURE_ARM      5
34 #define PROCESSOR_ARCHITECTURE_UNKNOWN  0xFFFF
35
36 /* dwProcessorType */
37 #define PROCESSOR_INTEL_386      386
38 #define PROCESSOR_INTEL_486      486
39 #define PROCESSOR_INTEL_PENTIUM  586
40 #define PROCESSOR_INTEL_860      860
41 #define PROCESSOR_MIPS_R2000     2000
42 #define PROCESSOR_MIPS_R3000     3000
43 #define PROCESSOR_MIPS_R4000     4000
44 #define PROCESSOR_ALPHA_21064    21064
45 #define PROCESSOR_PPC_601        601
46 #define PROCESSOR_PPC_603        603
47 #define PROCESSOR_PPC_604        604
48 #define PROCESSOR_PPC_620        620
49 #define PROCESSOR_HITACHI_SH3    10003
50 #define PROCESSOR_HITACHI_SH3E   10004
51 #define PROCESSOR_HITACHI_SH4    10005
52 #define PROCESSOR_MOTOROLA_821   821
53 #define PROCESSOR_SHx_SH3        103
54 #define PROCESSOR_SHx_SH4        104
55 #define PROCESSOR_STRONGARM      2577
56 #define PROCESSOR_ARM720         1824    /* 0x720 */
57 #define PROCESSOR_ARM820         2080    /* 0x820 */
58 #define PROCESSOR_ARM920         2336    /* 0x920 */
59 #define PROCESSOR_ARM_7TDMI      70001
60
61 typedef struct _MEMORY_BASIC_INFORMATION
62 {
63     LPVOID   BaseAddress;
64     LPVOID   AllocationBase;
65     DWORD    AllocationProtect;
66     DWORD    RegionSize;
67     DWORD    State;
68     DWORD    Protect;
69     DWORD    Type;
70 } MEMORY_BASIC_INFORMATION,*LPMEMORY_BASIC_INFORMATION,*PMEMORY_BASIC_INFORMATION;
71
72 #define PAGE_NOACCESS           0x01
73 #define PAGE_READONLY           0x02
74 #define PAGE_READWRITE          0x04
75 #define PAGE_WRITECOPY          0x08
76 #define PAGE_EXECUTE            0x10
77 #define PAGE_EXECUTE_READ       0x20
78 #define PAGE_EXECUTE_READWRITE  0x40
79 #define PAGE_EXECUTE_WRITECOPY  0x80
80 #define PAGE_GUARD              0x100
81 #define PAGE_NOCACHE            0x200
82
83 #define MEM_COMMIT              0x00001000
84 #define MEM_RESERVE             0x00002000
85 #define MEM_DECOMMIT            0x00004000
86 #define MEM_RELEASE             0x00008000
87 #define MEM_FREE                0x00010000
88 #define MEM_PRIVATE             0x00020000
89 #define MEM_MAPPED              0x00040000
90 #define MEM_RESET               0x00080000
91 #define MEM_TOP_DOWN            0x00100000
92 #ifdef __WINE__
93 #define MEM_SYSTEM              0x80000000
94 #endif
95
96 #define SEC_FILE                0x00800000
97 #define SEC_IMAGE               0x01000000
98 #define SEC_RESERVE             0x04000000
99 #define SEC_COMMIT              0x08000000
100 #define SEC_NOCACHE             0x10000000
101 #define MEM_IMAGE               SEC_IMAGE
102
103
104 #define ANYSIZE_ARRAY 1
105
106 #define MINCHAR       0x80
107 #define MAXCHAR       0x7f
108 #define MINSHORT      0x8000
109 #define MAXSHORT      0x7fff
110 #define MINLONG       0x80000000
111 #define MAXLONG       0x7fffffff
112 #define MAXBYTE       0xff
113 #define MAXWORD       0xffff
114 #define MAXDWORD      0xffffffff
115
116 #define FIELD_OFFSET(type, field) \
117   ((LONG)(INT)&(((type *)0)->field))
118
119 #define CONTAINING_RECORD(address, type, field) \
120   ((type *)((PCHAR)(address) - (PCHAR)(&((type *)0)->field)))
121
122 /* Types */
123
124 /* TCHAR data types definitions for Winelib. */
125 /* These types are _not_ defined for the emulator, because they */
126 /* depend on the UNICODE macro that only exists in user's code. */
127
128 #ifndef __WINE__
129 # ifdef UNICODE
130 typedef WCHAR TCHAR, *PTCHAR;
131 typedef LPWSTR PTSTR, LPTSTR;
132 typedef LPCWSTR PCTSTR, LPCTSTR;
133 #define __TEXT(string) L##string /*probably wrong */
134 # else  /* UNICODE */
135 typedef char TCHAR, *PTCHAR;
136 typedef LPSTR PTSTR, LPTSTR;
137 typedef LPCSTR PCTSTR, LPCTSTR;
138 #define __TEXT(string) string
139 # endif /* UNICODE */
140 #endif   /* __WINE__ */
141 #define TEXT(quote) __TEXT(quote)
142
143 typedef BYTE     BOOLEAN;
144 typedef BOOLEAN *PBOOLEAN;
145
146 #ifndef _DWORDLONG_
147 #define _DWORDLONG_
148 typedef __uint64 DWORDLONG, *PDWORDLONG;
149 #endif
150
151 #ifndef _ULONGLONG_
152 #define _ULONGLONG_
153 typedef __int64 LONGLONG, *PLONGLONG;
154 typedef __uint64 ULONGLONG, *PULONGLONG;
155 #endif
156
157 typedef struct _LIST_ENTRY {
158   struct _LIST_ENTRY *Flink;
159   struct _LIST_ENTRY *Blink;
160 } LIST_ENTRY, *PLIST_ENTRY;
161
162 typedef struct _SINGLE_LIST_ENTRY {
163   struct _SINGLE_LIST_ENTRY *Next;
164 } SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
165
166 /* Heap flags */
167
168 #define HEAP_NO_SERIALIZE               0x00000001
169 #define HEAP_GROWABLE                   0x00000002
170 #define HEAP_GENERATE_EXCEPTIONS        0x00000004
171 #define HEAP_ZERO_MEMORY                0x00000008
172 #define HEAP_REALLOC_IN_PLACE_ONLY      0x00000010
173 #define HEAP_TAIL_CHECKING_ENABLED      0x00000020
174 #define HEAP_FREE_CHECKING_ENABLED      0x00000040
175 #define HEAP_DISABLE_COALESCE_ON_FREE   0x00000080
176 #define HEAP_CREATE_ALIGN_16            0x00010000
177 #define HEAP_CREATE_ENABLE_TRACING      0x00020000
178
179 /* This flag allows it to create heaps shared by all processes under win95,
180    FIXME: correct name */
181 #define HEAP_SHARED                     0x04000000  
182
183 #define HEAP_WINE_SEGPTR                0x10000000  /* Not a Win32 flag */
184 #define HEAP_WINE_CODESEG               0x20000000  /* Not a Win32 flag */
185 #define HEAP_WINE_CODE16SEG             0x40000000  /* Not a Win32 flag */
186
187 /* Processor feature flags.  */
188 #define PF_FLOATING_POINT_PRECISION_ERRATA      0
189 #define PF_FLOATING_POINT_EMULATED              1
190 #define PF_COMPARE_EXCHANGE_DOUBLE              2
191 #define PF_MMX_INSTRUCTIONS_AVAILABLE           3
192 #define PF_PPC_MOVEMEM_64BIT_OK                 4
193 #define PF_ALPHA_BYTE_INSTRUCTIONS              5
194
195
196 /* The Win32 register context */
197
198 /* CONTEXT is the CPU-dependent context; it should be used        */
199 /* wherever a platform-specific context is needed (e.g. exception */
200 /* handling, Win32 register functions). */
201
202 /* CONTEXT86 is the i386-specific context; it should be used     */
203 /* wherever only a 386 context makes sense (e.g. DOS interrupts, */
204 /* Win16 register functions), so that this code can be compiled  */
205 /* on all platforms. */
206
207 #define SIZE_OF_80387_REGISTERS      80
208
209 typedef struct _FLOATING_SAVE_AREA
210 {
211     DWORD   ControlWord;
212     DWORD   StatusWord;
213     DWORD   TagWord;    
214     DWORD   ErrorOffset;
215     DWORD   ErrorSelector;
216     DWORD   DataOffset;
217     DWORD   DataSelector;    
218     BYTE    RegisterArea[SIZE_OF_80387_REGISTERS];
219     DWORD   Cr0NpxState;
220 } FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
221
222 typedef struct _CONTEXT86
223 {
224     DWORD   ContextFlags;
225
226     /* These are selected by CONTEXT_DEBUG_REGISTERS */
227     DWORD   Dr0;
228     DWORD   Dr1;
229     DWORD   Dr2;
230     DWORD   Dr3;
231     DWORD   Dr6;
232     DWORD   Dr7;
233
234     /* These are selected by CONTEXT_FLOATING_POINT */
235     FLOATING_SAVE_AREA FloatSave;
236
237     /* These are selected by CONTEXT_SEGMENTS */
238     DWORD   SegGs;
239     DWORD   SegFs;
240     DWORD   SegEs;
241     DWORD   SegDs;    
242
243     /* These are selected by CONTEXT_INTEGER */
244     DWORD   Edi;
245     DWORD   Esi;
246     DWORD   Ebx;
247     DWORD   Edx;    
248     DWORD   Ecx;
249     DWORD   Eax;
250
251     /* These are selected by CONTEXT_CONTROL */
252     DWORD   Ebp;    
253     DWORD   Eip;
254     DWORD   SegCs;
255     DWORD   EFlags;
256     DWORD   Esp;
257     DWORD   SegSs;
258 } CONTEXT86;
259
260 #define CONTEXT_X86       0x00010000
261 #define CONTEXT_i386      CONTEXT_X86
262 #define CONTEXT_i486      CONTEXT_X86
263
264 #define CONTEXT86_CONTROL   (CONTEXT_i386 | 0x0001) /* SS:SP, CS:IP, FLAGS, BP */
265 #define CONTEXT86_INTEGER   (CONTEXT_i386 | 0x0002) /* AX, BX, CX, DX, SI, DI */
266 #define CONTEXT86_SEGMENTS  (CONTEXT_i386 | 0x0004) /* DS, ES, FS, GS */
267 #define CONTEXT86_FLOATING_POINT  (CONTEXT_i386 | 0x0008L) /* 387 state */
268 #define CONTEXT86_DEBUG_REGISTERS (CONTEXT_i386 | 0x0010L) /* DB 0-3,6,7 */
269 #define CONTEXT86_FULL (CONTEXT86_CONTROL | CONTEXT86_INTEGER | CONTEXT86_SEGMENTS)
270
271 /* i386 context definitions */
272 #ifdef __i386__
273
274 #define CONTEXT_CONTROL         CONTEXT86_CONTROL
275 #define CONTEXT_INTEGER         CONTEXT86_INTEGER
276 #define CONTEXT_SEGMENTS        CONTEXT86_SEGMENTS
277 #define CONTEXT_FLOATING_POINT  CONTEXT86_FLOATING_POINT
278 #define CONTEXT_DEBUG_REGISTERS CONTEXT86_DEBUG_REGISTERS
279 #define CONTEXT_FULL            CONTEXT86_FULL
280
281 typedef CONTEXT86 CONTEXT;
282
283 #endif  /* __i386__ */
284
285 /* Alpha context definitions */
286 #ifdef _ALPHA_
287
288 #define CONTEXT_ALPHA   0x00020000
289  
290 #define CONTEXT_CONTROL         (CONTEXT_ALPHA | 0x00000001L)
291 #define CONTEXT_FLOATING_POINT  (CONTEXT_ALPHA | 0x00000002L)
292 #define CONTEXT_INTEGER         (CONTEXT_ALPHA | 0x00000004L)
293 #define CONTEXT_FULL  (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
294
295 typedef struct _CONTEXT
296 {
297     /* selected by CONTEXT_FLOATING_POINT */
298     ULONGLONG FltF0;
299     ULONGLONG FltF1;
300     ULONGLONG FltF2;
301     ULONGLONG FltF3;
302     ULONGLONG FltF4;
303     ULONGLONG FltF5;
304     ULONGLONG FltF6;
305     ULONGLONG FltF7;
306     ULONGLONG FltF8;
307     ULONGLONG FltF9;
308     ULONGLONG FltF10;
309     ULONGLONG FltF11;
310     ULONGLONG FltF12;
311     ULONGLONG FltF13;
312     ULONGLONG FltF14;
313     ULONGLONG FltF15;
314     ULONGLONG FltF16;
315     ULONGLONG FltF17;
316     ULONGLONG FltF18;
317     ULONGLONG FltF19;
318     ULONGLONG FltF20;
319     ULONGLONG FltF21;
320     ULONGLONG FltF22;
321     ULONGLONG FltF23;
322     ULONGLONG FltF24;
323     ULONGLONG FltF25;
324     ULONGLONG FltF26;
325     ULONGLONG FltF27;
326     ULONGLONG FltF28;
327     ULONGLONG FltF29;
328     ULONGLONG FltF30;
329     ULONGLONG FltF31;
330
331     /* selected by CONTEXT_INTEGER */
332     ULONGLONG IntV0;
333     ULONGLONG IntT0;
334     ULONGLONG IntT1;
335     ULONGLONG IntT2;
336     ULONGLONG IntT3;
337     ULONGLONG IntT4;
338     ULONGLONG IntT5;
339     ULONGLONG IntT6;
340     ULONGLONG IntT7;
341     ULONGLONG IntS0;
342     ULONGLONG IntS1;
343     ULONGLONG IntS2;
344     ULONGLONG IntS3;
345     ULONGLONG IntS4;
346     ULONGLONG IntS5;
347     ULONGLONG IntFp;
348     ULONGLONG IntA0;
349     ULONGLONG IntA1;
350     ULONGLONG IntA2;
351     ULONGLONG IntA3;
352     ULONGLONG IntA4;
353     ULONGLONG IntA5;
354     ULONGLONG IntT8;
355     ULONGLONG IntT9;
356     ULONGLONG IntT10;
357     ULONGLONG IntT11;
358     ULONGLONG IntRa;
359     ULONGLONG IntT12;
360     ULONGLONG IntAt;
361     ULONGLONG IntGp;
362     ULONGLONG IntSp;
363     ULONGLONG IntZero;
364
365     /* selected by CONTEXT_FLOATING_POINT */
366     ULONGLONG Fpcr;
367     ULONGLONG SoftFpcr;
368
369     /* selected by CONTEXT_CONTROL */
370     ULONGLONG Fir;
371     DWORD Psr;
372     DWORD ContextFlags;
373     DWORD Fill[4];
374 } CONTEXT;
375
376 #define _QUAD_PSR_OFFSET   HighSoftFpcr
377 #define _QUAD_FLAGS_OFFSET HighFir
378
379 #endif  /* _ALPHA_ */
380
381 /* Mips context definitions */
382 #ifdef _MIPS_
383
384 #define CONTEXT_R4000   0x00010000
385
386 #define CONTEXT_CONTROL         (CONTEXT_R4000 | 0x00000001)
387 #define CONTEXT_FLOATING_POINT  (CONTEXT_R4000 | 0x00000002)
388 #define CONTEXT_INTEGER         (CONTEXT_R4000 | 0x00000004)
389
390 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
391
392 typedef struct _CONTEXT
393 {
394     DWORD Argument[4];
395     /* These are selected by CONTEXT_FLOATING_POINT */
396     DWORD FltF0;
397     DWORD FltF1;
398     DWORD FltF2;
399     DWORD FltF3;
400     DWORD FltF4;
401     DWORD FltF5;
402     DWORD FltF6;
403     DWORD FltF7;
404     DWORD FltF8;
405     DWORD FltF9;
406     DWORD FltF10;
407     DWORD FltF11;
408     DWORD FltF12;
409     DWORD FltF13;
410     DWORD FltF14;
411     DWORD FltF15;
412     DWORD FltF16;
413     DWORD FltF17;
414     DWORD FltF18;
415     DWORD FltF19;
416     DWORD FltF20;
417     DWORD FltF21;
418     DWORD FltF22;
419     DWORD FltF23;
420     DWORD FltF24;
421     DWORD FltF25;
422     DWORD FltF26;
423     DWORD FltF27;
424     DWORD FltF28;
425     DWORD FltF29;
426     DWORD FltF30;
427     DWORD FltF31;
428
429     /* These are selected by CONTEXT_INTEGER */
430     DWORD IntZero;
431     DWORD IntAt;
432     DWORD IntV0;
433     DWORD IntV1;
434     DWORD IntA0;
435     DWORD IntA1;
436     DWORD IntA2;
437     DWORD IntA3;
438     DWORD IntT0;
439     DWORD IntT1;
440     DWORD IntT2;
441     DWORD IntT3;
442     DWORD IntT4;
443     DWORD IntT5;
444     DWORD IntT6;
445     DWORD IntT7;
446     DWORD IntS0;
447     DWORD IntS1;
448     DWORD IntS2;
449     DWORD IntS3;
450     DWORD IntS4;
451     DWORD IntS5;
452     DWORD IntS6;
453     DWORD IntS7;
454     DWORD IntT8;
455     DWORD IntT9;
456     DWORD IntK0;
457     DWORD IntK1;
458     DWORD IntGp;
459     DWORD IntSp;
460     DWORD IntS8;
461     DWORD IntRa;
462     DWORD IntLo;
463     DWORD IntHi;
464
465     /* These are selected by CONTEXT_FLOATING_POINT */
466     DWORD Fsr;
467
468     /* These are selected by CONTEXT_CONTROL */
469     DWORD Fir;
470     DWORD Psr;
471
472     DWORD ContextFlags;
473     DWORD Fill[2];
474 } CONTEXT;
475
476 #endif  /* _MIPS_ */
477
478 /* PowerPC context definitions */
479 #ifdef __PPC__
480
481 #define CONTEXT_CONTROL         0x0001
482 #define CONTEXT_FLOATING_POINT  0x0002
483 #define CONTEXT_INTEGER         0x0004
484 #define CONTEXT_DEBUG_REGISTERS 0x0008
485 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
486
487 typedef struct
488 {
489     /* These are selected by CONTEXT_FLOATING_POINT */
490     double Fpr0;
491     double Fpr1;
492     double Fpr2;
493     double Fpr3;
494     double Fpr4;
495     double Fpr5;
496     double Fpr6;
497     double Fpr7;
498     double Fpr8;
499     double Fpr9;
500     double Fpr10;
501     double Fpr11;
502     double Fpr12;
503     double Fpr13;
504     double Fpr14;
505     double Fpr15;
506     double Fpr16;
507     double Fpr17;
508     double Fpr18;
509     double Fpr19;
510     double Fpr20;
511     double Fpr21;
512     double Fpr22;
513     double Fpr23;
514     double Fpr24;
515     double Fpr25;
516     double Fpr26;
517     double Fpr27;
518     double Fpr28;
519     double Fpr29;
520     double Fpr30;
521     double Fpr31;
522     double Fpscr;
523
524     /* These are selected by CONTEXT_INTEGER */
525     DWORD Gpr0;
526     DWORD Gpr1;
527     DWORD Gpr2;
528     DWORD Gpr3;
529     DWORD Gpr4;
530     DWORD Gpr5;
531     DWORD Gpr6;
532     DWORD Gpr7;
533     DWORD Gpr8;
534     DWORD Gpr9;
535     DWORD Gpr10;
536     DWORD Gpr11;
537     DWORD Gpr12;
538     DWORD Gpr13;
539     DWORD Gpr14;
540     DWORD Gpr15;
541     DWORD Gpr16;
542     DWORD Gpr17;
543     DWORD Gpr18;
544     DWORD Gpr19;
545     DWORD Gpr20;
546     DWORD Gpr21;
547     DWORD Gpr22;
548     DWORD Gpr23;
549     DWORD Gpr24;
550     DWORD Gpr25;
551     DWORD Gpr26;
552     DWORD Gpr27;
553     DWORD Gpr28;
554     DWORD Gpr29;
555     DWORD Gpr30;
556     DWORD Gpr31;
557
558     DWORD Cr;
559     DWORD Xer;
560
561     /* These are selected by CONTEXT_CONTROL */
562     DWORD Msr;
563     DWORD Iar;
564     DWORD Lr;
565     DWORD Ctr;
566
567     DWORD ContextFlags;
568     DWORD Fill[3];
569
570     /* These are selected by CONTEXT_DEBUG_REGISTERS */
571     DWORD Dr0;
572     DWORD Dr1;
573     DWORD Dr2;
574     DWORD Dr3;
575     DWORD Dr4;
576     DWORD Dr5;
577     DWORD Dr6;
578     DWORD Dr7;
579 } CONTEXT;
580
581 typedef struct _STACK_FRAME_HEADER
582 {
583     DWORD BackChain;
584     DWORD GlueSaved1;
585     DWORD GlueSaved2;
586     DWORD Reserved1;
587     DWORD Spare1;
588     DWORD Spare2;
589
590     DWORD Parameter0;
591     DWORD Parameter1;
592     DWORD Parameter2;
593     DWORD Parameter3;
594     DWORD Parameter4;
595     DWORD Parameter5;
596     DWORD Parameter6;
597     DWORD Parameter7;
598 } STACK_FRAME_HEADER,*PSTACK_FRAME_HEADER;
599
600 #endif  /* __PPC__ */
601
602 #ifdef __sparc__
603
604 /* 
605  * FIXME:  
606  *
607  * There is no official CONTEXT structure defined for the SPARC 
608  * architecture, so I just made one up.
609  *
610  * This structure is valid only for 32-bit SPARC architectures,
611  * not for 64-bit SPARC.
612  *
613  * Note that this structure contains only the 'top-level' registers;
614  * the rest of the register window chain is not visible.
615  *
616  * The layout follows the Solaris 'prgregset_t' structure.
617  * 
618  */ 
619
620 #define CONTEXT_SPARC            0x10000000
621
622 #define CONTEXT_CONTROL         (CONTEXT_SPARC | 0x00000001)
623 #define CONTEXT_FLOATING_POINT  (CONTEXT_SPARC | 0x00000002)
624 #define CONTEXT_INTEGER         (CONTEXT_SPARC | 0x00000004)
625
626 #define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
627
628 typedef struct _CONTEXT
629 {
630     DWORD ContextFlags;
631
632     /* These are selected by CONTEXT_INTEGER */
633     DWORD g0;
634     DWORD g1;
635     DWORD g2;
636     DWORD g3;
637     DWORD g4;
638     DWORD g5;
639     DWORD g6;
640     DWORD g7;
641     DWORD o0;
642     DWORD o1;
643     DWORD o2;
644     DWORD o3;
645     DWORD o4;
646     DWORD o5;
647     DWORD o6;
648     DWORD o7;
649     DWORD l0;
650     DWORD l1;
651     DWORD l2;
652     DWORD l3;
653     DWORD l4;
654     DWORD l5;
655     DWORD l6;
656     DWORD l7;
657     DWORD i0;
658     DWORD i1;
659     DWORD i2;
660     DWORD i3;
661     DWORD i4;
662     DWORD i5;
663     DWORD i6;
664     DWORD i7;
665
666     /* These are selected by CONTEXT_CONTROL */
667     DWORD psr;
668     DWORD pc;
669     DWORD npc;
670     DWORD y;
671     DWORD wim;
672     DWORD tbr;
673
674     /* FIXME: floating point registers missing */
675
676 } CONTEXT;
677
678 #endif  /* __sparc__ */
679
680 #if !defined(CONTEXT_FULL) && !defined(RC_INVOKED)
681 #error You need to define a CONTEXT for your CPU
682 #endif
683
684 typedef CONTEXT *PCONTEXT;
685 typedef HANDLE *PHANDLE;
686
687 #ifdef __WINE__
688
689 /* Macros for easier access to i386 context registers */
690
691 #define AX_reg(context)      (*(WORD*)&(context)->Eax)
692 #define BX_reg(context)      (*(WORD*)&(context)->Ebx)
693 #define CX_reg(context)      (*(WORD*)&(context)->Ecx)
694 #define DX_reg(context)      (*(WORD*)&(context)->Edx)
695 #define SI_reg(context)      (*(WORD*)&(context)->Esi)
696 #define DI_reg(context)      (*(WORD*)&(context)->Edi)
697 #define BP_reg(context)      (*(WORD*)&(context)->Ebp)
698
699 #define AL_reg(context)      (*(BYTE*)&(context)->Eax)
700 #define AH_reg(context)      (*((BYTE*)&(context)->Eax + 1))
701 #define BL_reg(context)      (*(BYTE*)&(context)->Ebx)
702 #define BH_reg(context)      (*((BYTE*)&(context)->Ebx + 1))
703 #define CL_reg(context)      (*(BYTE*)&(context)->Ecx)
704 #define CH_reg(context)      (*((BYTE*)&(context)->Ecx + 1))
705 #define DL_reg(context)      (*(BYTE*)&(context)->Edx)
706 #define DH_reg(context)      (*((BYTE*)&(context)->Edx + 1))
707
708 #define SET_CFLAG(context)   ((context)->EFlags |= 0x0001)
709 #define RESET_CFLAG(context) ((context)->EFlags &= ~0x0001)
710 #define SET_ZFLAG(context)   ((context)->EFlags |= 0x0040)
711 #define RESET_ZFLAG(context) ((context)->EFlags &= ~0x0040)
712 #define ISV86(context)       ((context)->EFlags & 0x00020000)
713
714
715 /* Macros to retrieve the current context */
716
717 #ifdef __i386__
718
719 #ifdef NEED_UNDERSCORE_PREFIX
720 # define __ASM_NAME(name) "_" name
721 #else
722 # define __ASM_NAME(name) name
723 #endif
724
725 #ifdef __GNUC__
726 # define __ASM_GLOBAL_FUNC(name,code) \
727       __asm__( ".align 4\n\t" \
728                ".globl " __ASM_NAME(#name) "\n\t" \
729                ".type " __ASM_NAME(#name) ",@function\n" \
730                __ASM_NAME(#name) ":\n\t" \
731                code );
732 #else  /* __GNUC__ */
733 # define __ASM_GLOBAL_FUNC(name,code) \
734       void __asm_dummy_##name(void) { \
735           asm( ".align 4\n\t" \
736                ".globl " __ASM_NAME(#name) "\n\t" \
737                ".type " __ASM_NAME(#name) ",@function\n" \
738                __ASM_NAME(#name) ":\n\t" \
739                code ); \
740       }
741 #endif  /* __GNUC__ */
742
743 #define _DEFINE_REGS_ENTRYPOINT( name, fn, args ) \
744     __ASM_GLOBAL_FUNC( name, \
745                        "call " __ASM_NAME("CALL32_Regs") "\n\t" \
746                        ".long " __ASM_NAME(#fn) "\n\t" \
747                        ".byte " #args ", " #args )
748 #define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
749   extern void WINAPI name(void); \
750   _DEFINE_REGS_ENTRYPOINT( name, fn, 0 )
751 #define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
752   extern void WINAPI name( t1 a1 ); \
753   _DEFINE_REGS_ENTRYPOINT( name, fn, 4 )
754 #define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
755   extern void WINAPI name( t1 a1, t2 a2 ); \
756   _DEFINE_REGS_ENTRYPOINT( name, fn, 8 )
757 #define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
758   extern void WINAPI name( t1 a1, t2 a2, t3 a3 ); \
759   _DEFINE_REGS_ENTRYPOINT( name, fn, 12 )
760 #define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
761   extern void WINAPI name( t1 a1, t2 a2, t3 a3, t4 a4 ); \
762   _DEFINE_REGS_ENTRYPOINT( name, fn, 16 )
763
764 #endif  /* __i386__ */
765
766 #ifdef __sparc__
767 /* FIXME: use getcontext() to retrieve full context */
768 #define _GET_CONTEXT \
769     CONTEXT context;   \
770     do { memset(&context, 0, sizeof(CONTEXT));            \
771          context.ContextFlags = CONTEXT_CONTROL;          \
772          context.pc = (DWORD)__builtin_return_address(0); \
773        } while (0)
774
775 #define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
776   void WINAPI name ( void ) \
777   { _GET_CONTEXT; fn( &context ); }
778 #define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
779   void WINAPI name ( t1 a1 ) \
780   { _GET_CONTEXT; fn( a1, &context ); }
781 #define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
782   void WINAPI name ( t1 a1, t2 a2 ) \
783   { _GET_CONTEXT; fn( a1, a2, &context ); }
784 #define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
785   void WINAPI name ( t1 a1, t2 a2, t3 a3 ) \
786   { _GET_CONTEXT; fn( a1, a2, a3, &context ); }
787 #define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
788   void WINAPI name ( t1 a1, t2 a2, t3 a3, t4 a4 ) \
789   { _GET_CONTEXT; fn( a1, a2, a3, a4, &context ); }
790
791 #endif /* __sparc__ */
792
793 #ifndef DEFINE_REGS_ENTRYPOINT_0
794 #error You need to define DEFINE_REGS_ENTRYPOINT macros for your CPU
795 #endif
796
797 #ifdef __i386__
798 # define GET_IP(context) ((LPVOID)(context)->Eip)
799 #endif
800 #ifdef __sparc__
801 # define GET_IP(context) ((LPVOID)(context)->pc)
802 #endif
803  
804 #if !defined(GET_IP) && !defined(RC_INVOKED)
805 # error You must define GET_IP for this CPU
806 #endif
807
808 /* Constructor functions */
809
810 #ifdef __GNUC__
811 # define DECL_GLOBAL_CONSTRUCTOR(func) \
812     static void func(void) __attribute__((constructor)); \
813     static void func(void)
814 #else  /* __GNUC__ */
815 # ifdef __i386__
816 #  define DECL_GLOBAL_CONSTRUCTOR(func) \
817     static void __dummy_init_##func(void) { \
818         asm(".section .init,\"ax\"\n\t" \
819             "call " #func "\n\t" \
820             ".previous"); } \
821     static void func(void)
822 # else  /* __i386__ */
823 #  error You must define the DECL_GLOBAL_CONSTRUCTOR macro for your platform
824 # endif
825 #endif  /* __GNUC__ */
826
827 #endif  /* __WINE__ */
828
829 /*
830  * Exception codes
831  */
832
833 #define STATUS_SUCCESS                   0x00000000
834 #define STATUS_WAIT_0                    0x00000000
835 #define STATUS_ABANDONED_WAIT_0          0x00000080
836 #define STATUS_USER_APC                  0x000000C0
837 #define STATUS_TIMEOUT                   0x00000102
838 #define STATUS_PENDING                   0x00000103
839
840 #define STATUS_GUARD_PAGE_VIOLATION      0x80000001    
841 #define STATUS_DATATYPE_MISALIGNMENT     0x80000002
842 #define STATUS_BREAKPOINT                0x80000003
843 #define STATUS_SINGLE_STEP               0x80000004
844 #define STATUS_BUFFER_OVERFLOW           0x80000005
845 #define STATUS_NO_MORE_FILES             0x80000006
846 #define STATUS_WAKE_SYSTEM_DEBUGGER      0x80000007
847
848 #define STATUS_HANDLES_CLOSED            0x8000000A
849 #define STATUS_NO_INHERITANCE            0x8000000B
850 #define STATUS_GUID_SUBSTITUTION_MADE    0x8000000C
851 #define STATUS_PARTIAL_COPY              0x8000000D
852 #define STATUS_DEVICE_PAPER_EMPTY        0x8000000E
853 #define STATUS_DEVICE_POWERED_OFF        0x8000000F
854 #define STATUS_DEVICE_OFF_LINE           0x80000010
855 #define STATUS_DEVICE_BUSY               0x80000011
856 #define STATUS_NO_MORE_EAS               0x80000012
857 #define STATUS_INVALID_EA_NAME           0x80000013
858 #define STATUS_EA_LIST_INCONSISTENT      0x80000014
859 #define STATUS_INVALID_EA_FLAG           0x80000015
860 #define STATUS_VERIFY_REQUIRED           0x80000016
861 #define STATUS_EXTRANEOUS_INFORMATION    0x80000017
862 #define STATUS_RXACT_COMMIT_NECESSARY    0x80000018
863 #define STATUS_NO_MORE_ENTRIES           0x8000001A
864 #define STATUS_FILEMARK_DETECTED         0x8000001B
865 #define STATUS_MEDIA_CHANGED             0x8000001C
866 #define STATUS_BUS_RESET                 0x8000001D
867 #define STATUS_END_OF_MEDIA              0x8000001E
868 #define STATUS_BEGINNING_OF_MEDIA        0x8000001F
869 #define STATUS_MEDIA_CHECK               0x80000020
870 #define STATUS_SETMARK_DETECTED          0x80000021
871 #define STATUS_NO_DATA_DETECTED          0x80000022
872 #define STATUS_REDIRECTOR_HAS_OPEN_HANDLES 0x80000023
873 #define STATUS_SERVER_HAS_OPEN_HANDLES   0x80000024
874 #define STATUS_ALREADY_DISCONNECTED      0x80000025
875 #define STATUS_LONGJUMP                  0x80000026
876
877 #define STATUS_UNSUCCESSFUL              0xC0000001
878 #define STATUS_NOT_IMPLEMENTED           0xC0000002
879 #define STATUS_INVALID_INFO_CLASS        0xC0000003
880 #define STATUS_INFO_LENGTH_MISMATCH      0xC0000004
881 #define STATUS_ACCESS_VIOLATION          0xC0000005
882 #define STATUS_IN_PAGE_ERROR             0xC0000006
883 #define STATUS_PAGEFILE_QUOTA            0xC0000007
884 #define STATUS_INVALID_HANDLE            0xC0000008
885 #define STATUS_BAD_INITIAL_STACK         0xC0000009
886 #define STATUS_BAD_INITIAL_PC            0xC000000A
887 #define STATUS_INVALID_CID               0xC000000B
888 #define STATUS_TIMER_NOT_CANCELED        0xC000000C
889 #define STATUS_INVALID_PARAMETER         0xC000000D
890 #define STATUS_NO_SUCH_DEVICE            0xC000000E
891 #define STATUS_NO_SUCH_FILE              0xC000000F
892 #define STATUS_INVALID_DEVICE_REQUEST    0xC0000010
893 #define STATUS_END_OF_FILE               0xC0000011
894 #define STATUS_WRONG_VOLUME              0xC0000012
895 #define STATUS_NO_MEDIA_IN_DEVICE        0xC0000013
896 #define STATUS_UNRECOGNIZED_MEDIA        0xC0000014
897 #define STATUS_NONEXISTENT_SECTOR        0xC0000015
898 #define STATUS_MORE_PROCESSING_REQUIRED  0xC0000016
899 #define STATUS_NO_MEMORY                 0xC0000017
900 #define STATUS_CONFLICTING_ADDRESSES     0xC0000018
901 #define STATUS_NOT_MAPPED_VIEW           0xC0000019
902 #define STATUS_UNABLE_TO_FREE_VM         0xC000001A
903 #define STATUS_UNABLE_TO_DELETE_SECTION  0xC000001B
904 #define STATUS_INVALID_SYSTEM_SERVICE    0xC000001C
905 #define STATUS_ILLEGAL_INSTRUCTION       0xC000001D
906 #define STATUS_INVALID_LOCK_SEQUENCE     0xC000001E
907 #define STATUS_INVALID_VIEW_SIZE         0xC000001F
908 #define STATUS_INVALID_FILE_FOR_SECTION  0xC0000020
909 #define STATUS_ALREADY_COMMITTED         0xC0000021
910 #define STATUS_ACCESS_DENIED             0xC0000022
911 #define STATUS_BUFFER_TOO_SMALL          0xC0000023
912 #define STATUS_OBJECT_TYPE_MISMATCH      0xC0000024
913 #define STATUS_NONCONTINUABLE_EXCEPTION  0xC0000025
914 #define STATUS_INVALID_DISPOSITION       0xC0000026
915 #define STATUS_UNWIND                    0xC0000027
916 #define STATUS_BAD_STACK                 0xC0000028
917 #define STATUS_INVALID_UNWIND_TARGET     0xC0000029
918 #define STATUS_NOT_LOCKED                0xC000002A
919 #define STATUS_PARITY_ERROR              0xC000002B
920 #define STATUS_UNABLE_TO_DECOMMIT_VM     0xC000002C
921 #define STATUS_NOT_COMMITTED             0xC000002D
922 #define STATUS_INVALID_PORT_ATTRIBUTES   0xC000002E
923 #define STATUS_PORT_MESSAGE_TOO_LONG     0xC000002F
924 #define STATUS_INVALID_PARAMETER_MIX     0xC0000030
925 #define STATUS_INVALID_QUOTA_LOWER       0xC0000031
926 #define STATUS_DISK_CORRUPT_ERROR        0xC0000032
927 #define STATUS_OBJECT_NAME_INVALID       0xC0000033
928 #define STATUS_OBJECT_NAME_NOT_FOUND     0xC0000034
929 #define STATUS_OBJECT_NAME_COLLISION     0xC0000035
930 #define STATUS_PORT_DISCONNECTED         0xC0000037
931 #define STATUS_DEVICE_ALREADY_ATTACHED   0xC0000038
932 #define STATUS_OBJECT_PATH_INVALID       0xC0000039
933 #define STATUS_OBJECT_PATH_NOT_FOUND     0xC000003A
934 #define STATUS_PATH_SYNTAX_BAD           0xC000003B
935 #define STATUS_DATA_OVERRUN              0xC000003C
936 #define STATUS_DATA_LATE_ERROR           0xC000003D
937 #define STATUS_DATA_ERROR                0xC000003E
938 #define STATUS_CRC_ERROR                 0xC000003F
939 #define STATUS_SECTION_TOO_BIG           0xC0000040
940 #define STATUS_PORT_CONNECTION_REFUSED   0xC0000041
941 #define STATUS_INVALID_PORT_HANDLE       0xC0000042
942 #define STATUS_SHARING_VIOLATION         0xC0000043
943 #define STATUS_QUOTA_EXCEEDED            0xC0000044
944 #define STATUS_INVALID_PAGE_PROTECTION   0xC0000045
945 #define STATUS_MUTANT_NOT_OWNED          0xC0000046
946 #define STATUS_SEMAPHORE_LIMIT_EXCEEDED  0xC0000047
947 #define STATUS_PORT_ALREADY_SET          0xC0000048
948 #define STATUS_SUSPEND_COUNT_EXCEEDED    0xC000004A
949 #define STATUS_LOCK_NOT_GRANTED          0xC0000054  /* FIXME: not sure */
950 #define STATUS_FILE_LOCK_CONFLICT        0xC0000055  /* FIXME: not sure */
951 #define STATUS_UNKNOWN_REVISION          0xC0000058
952 #define STATUS_INVALID_SECURITY_DESCR    0xC0000079
953 #define STATUS_DISK_FULL                 0xC000007F 
954 #define STATUS_SECTION_NOT_EXTENDED      0xC0000087
955 #define STATUS_ARRAY_BOUNDS_EXCEEDED     0xC000008C
956 #define STATUS_FLOAT_DENORMAL_OPERAND    0xC000008D
957 #define STATUS_FLOAT_DIVIDE_BY_ZERO      0xC000008E
958 #define STATUS_FLOAT_INEXACT_RESULT      0xC000008F
959 #define STATUS_FLOAT_INVALID_OPERATION   0xC0000090
960 #define STATUS_FLOAT_OVERFLOW            0xC0000091
961 #define STATUS_FLOAT_STACK_CHECK         0xC0000092
962 #define STATUS_FLOAT_UNDERFLOW           0xC0000093
963 #define STATUS_INTEGER_DIVIDE_BY_ZERO    0xC0000094
964 #define STATUS_INTEGER_OVERFLOW          0xC0000095
965 #define STATUS_PRIVILEGED_INSTRUCTION    0xC0000096
966 #define STATUS_MEDIA_WRITE_PROTECTED     0XC00000A2
967 #define STATUS_INVALID_PARAMETER_2       0xC00000F0
968 #define STATUS_STACK_OVERFLOW            0xC00000FD
969 #define STATUS_DIRECTORY_NOT_EMPTY       0xC0000101
970 #define STATUS_TOO_MANY_OPENED_FILES     0xC000011F
971 #define STATUS_CONTROL_C_EXIT            0xC000013A
972 #define STATUS_PIPE_BROKEN               0xC000014B
973 #define STATUS_NOT_REGISTRY_FILE         0xC000015C
974 #define STATUS_PARTITION_FAILURE         0xC0000172
975 #define STATUS_INVALID_BLOCK_LENGTH      0xC0000173
976 #define STATUS_DEVICE_NOT_PARTITIONED    0xC0000174
977 #define STATUS_UNABLE_TO_LOCK_MEDIA      0xC0000175
978 #define STATUS_UNABLE_TO_UNLOAD_MEDIA    0xC0000176
979 #define STATUS_EOM_OVERFLOW              0xC0000177
980 #define STATUS_NO_MEDIA                  0xC0000178
981 #define STATUS_NO_SUCH_MEMBER            0xC000017A
982 #define STATUS_INVALID_MEMBER            0xC000017B
983 #define STATUS_KEY_DELETED               0xC000017C
984 #define STATUS_NO_LOG_SPACE              0xC000017D
985 #define STATUS_TOO_MANY_SIDS             0xC000017E
986 #define STATUS_LM_CROSS_ENCRYPTION_REQUIRED 0xC000017F
987 #define STATUS_KEY_HAS_CHILDREN          0xC0000180
988 #define STATUS_CHILD_MUST_BE_VOLATILE    0xC0000181
989 #define STATUS_DEVICE_CONFIGURATION_ERROR0xC0000182
990 #define STATUS_DRIVER_INTERNAL_ERROR     0xC0000183
991 #define STATUS_INVALID_DEVICE_STATE      0xC0000184
992 #define STATUS_IO_DEVICE_ERROR           0xC0000185
993 #define STATUS_DEVICE_PROTOCOL_ERROR     0xC0000186
994 #define STATUS_BACKUP_CONTROLLER         0xC0000187
995 #define STATUS_LOG_FILE_FULL             0xC0000188
996 #define STATUS_TOO_LATE                  0xC0000189
997 #define STATUS_NO_TRUST_LSA_SECRET       0xC000018A
998 #define STATUS_NO_TRUST_SAM_ACCOUNT      0xC000018B
999 #define STATUS_TRUSTED_DOMAIN_FAILURE    0xC000018C
1000 #define STATUS_TRUSTED_RELATIONSHIP_FAILURE 0xC000018D
1001 #define STATUS_EVENTLOG_FILE_CORRUPT     0xC000018E
1002 #define STATUS_EVENTLOG_CANT_START       0xC000018F
1003 #define STATUS_TRUST_FAILURE             0xC0000190
1004 #define STATUS_MUTANT_LIMIT_EXCEEDED     0xC0000191
1005 #define STATUS_NETLOGON_NOT_STARTED      0xC0000192
1006 #define STATUS_ACCOUNT_EXPIRED           0xC0000193
1007 #define STATUS_POSSIBLE_DEADLOCK         0xC0000194
1008 #define STATUS_NETWORK_CREDENTIAL_CONFLICT 0xC0000195
1009 #define STATUS_REMOTE_SESSION_LIMIT      0xC0000196
1010 #define STATUS_EVENTLOG_FILE_CHANGED     0xC0000197
1011 #define STATUS_NOLOGON_INTERDOMAIN_TRUST_ACCOUNT 0xC0000198
1012 #define STATUS_NOLOGON_WORKSTATION_TRUST_ACCOUNT 0xC0000199
1013 #define STATUS_NOLOGON_SERVER_TRUST_ACCOUNT 0xC000019A
1014 #define STATUS_DOMAIN_TRUST_INCONSISTENT 0xC000019B
1015 #define STATUS_FS_DRIVER_REQUIRED        0xC000019C
1016
1017 #define STATUS_RESOURCE_LANG_NOT_FOUND   0xC0000204
1018
1019 #define MAXIMUM_WAIT_OBJECTS 64
1020 #define MAXIMUM_SUSPEND_COUNT 127
1021
1022
1023 /*
1024  * Return values from the actual exception handlers
1025  */
1026
1027 #define ExceptionContinueExecution 0
1028 #define ExceptionContinueSearch    1
1029 #define ExceptionNestedException   2
1030 #define ExceptionCollidedUnwind    3
1031  
1032 /*
1033  * Return values from filters in except() and from UnhandledExceptionFilter
1034  */
1035  
1036 #define EXCEPTION_EXECUTE_HANDLER        1
1037 #define EXCEPTION_CONTINUE_SEARCH        0
1038 #define EXCEPTION_CONTINUE_EXECUTION    -1
1039
1040 /*
1041  * From OS/2 2.0 exception handling
1042  * Win32 seems to use the same flags as ExceptionFlags in an EXCEPTION_RECORD
1043  */
1044
1045 #define EH_NONCONTINUABLE   0x01
1046 #define EH_UNWINDING        0x02
1047 #define EH_EXIT_UNWIND      0x04
1048 #define EH_STACK_INVALID    0x08
1049 #define EH_NESTED_CALL      0x10
1050
1051 #define EXCEPTION_CONTINUABLE        0
1052 #define EXCEPTION_NONCONTINUABLE     EH_NONCONTINUABLE
1053  
1054 /*
1055  * The exception record used by Win32 to give additional information 
1056  * about exception to exception handlers.
1057  */
1058
1059 #define EXCEPTION_MAXIMUM_PARAMETERS 15
1060
1061 typedef struct __EXCEPTION_RECORD
1062 {
1063     DWORD    ExceptionCode;
1064     DWORD    ExceptionFlags;
1065     struct __EXCEPTION_RECORD *ExceptionRecord;
1066
1067     LPVOID   ExceptionAddress;
1068     DWORD    NumberParameters;
1069     DWORD    ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
1070 } EXCEPTION_RECORD, *PEXCEPTION_RECORD;
1071
1072 /*
1073  * The exception pointers structure passed to exception filters
1074  * in except() and the UnhandledExceptionFilter().
1075  */
1076  
1077 typedef struct _EXCEPTION_POINTERS 
1078 {
1079   PEXCEPTION_RECORD  ExceptionRecord;
1080   PCONTEXT           ContextRecord;
1081 } EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
1082
1083
1084 /*
1085  * The exception frame, used for registering exception handlers 
1086  * Win32 cares only about this, but compilers generally emit 
1087  * larger exception frames for their own use.
1088  */
1089
1090 struct __EXCEPTION_FRAME;
1091
1092 typedef DWORD (*PEXCEPTION_HANDLER)(PEXCEPTION_RECORD,struct __EXCEPTION_FRAME*,
1093                                     PCONTEXT,struct __EXCEPTION_FRAME **);
1094
1095 typedef struct __EXCEPTION_FRAME
1096 {
1097   struct __EXCEPTION_FRAME *Prev;
1098   PEXCEPTION_HANDLER       Handler;
1099 } EXCEPTION_FRAME, *PEXCEPTION_FRAME;
1100
1101 #include "poppack.h"
1102
1103 /*
1104  * function pointer to a exception filter
1105  */
1106
1107 typedef LONG CALLBACK (*PTOP_LEVEL_EXCEPTION_FILTER)(PEXCEPTION_POINTERS ExceptionInfo);
1108 typedef PTOP_LEVEL_EXCEPTION_FILTER LPTOP_LEVEL_EXCEPTION_FILTER;
1109
1110 DWORD WINAPI UnhandledExceptionFilter( PEXCEPTION_POINTERS epointers );
1111 LPTOP_LEVEL_EXCEPTION_FILTER
1112 WINAPI SetUnhandledExceptionFilter( LPTOP_LEVEL_EXCEPTION_FILTER filter );
1113
1114 /* status values for ContinueDebugEvent */
1115 #define DBG_CONTINUE                0x00010002
1116 #define DBG_TERMINATE_THREAD        0x40010003
1117 #define DBG_TERMINATE_PROCESS       0x40010004
1118 #define DBG_CONTROL_C               0x40010005
1119 #define DBG_CONTROL_BREAK           0x40010008
1120 #define DBG_EXCEPTION_NOT_HANDLED   0x80010001
1121
1122 typedef struct _NT_TIB 
1123 {
1124         struct _EXCEPTION_REGISTRATION_RECORD *ExceptionList;
1125         PVOID StackBase;
1126         PVOID StackLimit;
1127         PVOID SubSystemTib;
1128         union {
1129           PVOID FiberData;
1130           DWORD Version;
1131         } DUMMYUNIONNAME;
1132         PVOID ArbitraryUserPointer;
1133         struct _NT_TIB *Self;
1134 } NT_TIB, *PNT_TIB;
1135
1136 struct _TEB;
1137
1138 #if defined(__i386__) && defined(__GNUC__)
1139 extern inline struct _TEB WINAPI *NtCurrentTeb(void);
1140 extern inline struct _TEB WINAPI *NtCurrentTeb(void)
1141 {
1142     struct _TEB *teb;
1143     __asm__(".byte 0x64\n\tmovl (0x18),%0" : "=r" (teb));
1144     return teb;
1145 }
1146 #else
1147 extern struct _TEB WINAPI *NtCurrentTeb(void);
1148 #endif
1149
1150
1151 /*
1152  * File formats definitions
1153  */
1154
1155 typedef struct _IMAGE_DOS_HEADER {
1156     WORD  e_magic;      /* 00: MZ Header signature */
1157     WORD  e_cblp;       /* 02: Bytes on last page of file */
1158     WORD  e_cp;         /* 04: Pages in file */
1159     WORD  e_crlc;       /* 06: Relocations */
1160     WORD  e_cparhdr;    /* 08: Size of header in paragraphs */
1161     WORD  e_minalloc;   /* 0a: Minimum extra paragraphs needed */
1162     WORD  e_maxalloc;   /* 0c: Maximum extra paragraphs needed */
1163     WORD  e_ss;         /* 0e: Initial (relative) SS value */
1164     WORD  e_sp;         /* 10: Initial SP value */
1165     WORD  e_csum;       /* 12: Checksum */
1166     WORD  e_ip;         /* 14: Initial IP value */
1167     WORD  e_cs;         /* 16: Initial (relative) CS value */
1168     WORD  e_lfarlc;     /* 18: File address of relocation table */
1169     WORD  e_ovno;       /* 1a: Overlay number */
1170     WORD  e_res[4];     /* 1c: Reserved words */
1171     WORD  e_oemid;      /* 24: OEM identifier (for e_oeminfo) */
1172     WORD  e_oeminfo;    /* 26: OEM information; e_oemid specific */
1173     WORD  e_res2[10];   /* 28: Reserved words */
1174     DWORD e_lfanew;     /* 3c: Offset to extended header */
1175 } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
1176
1177 #define IMAGE_DOS_SIGNATURE    0x5A4D     /* MZ   */
1178 #define IMAGE_OS2_SIGNATURE    0x454E     /* NE   */
1179 #define IMAGE_OS2_SIGNATURE_LE 0x454C     /* LE   */
1180 #define IMAGE_OS2_SIGNATURE_LX 0x584C     /* LX */
1181 #define IMAGE_VXD_SIGNATURE    0x454C     /* LE   */
1182 #define IMAGE_NT_SIGNATURE     0x00004550 /* PE00 */
1183
1184 /*
1185  * This is the Windows executable (NE) header.
1186  * the name IMAGE_OS2_HEADER is misleading, but in the SDK this way.
1187  */
1188 typedef struct 
1189 {
1190     WORD  ne_magic;             /* 00 NE signature 'NE' */
1191     BYTE  ne_ver;               /* 02 Linker version number */
1192     BYTE  ne_rev;               /* 03 Linker revision number */
1193     WORD  ne_enttab;            /* 04 Offset to entry table relative to NE */
1194     WORD  ne_cbenttab;          /* 06 Length of entry table in bytes */
1195     LONG  ne_crc;               /* 08 Checksum */
1196     WORD  ne_flags;             /* 0c Flags about segments in this file */
1197     WORD  ne_autodata;          /* 0e Automatic data segment number */
1198     WORD  ne_heap;              /* 10 Initial size of local heap */
1199     WORD  ne_stack;             /* 12 Initial size of stack */
1200     DWORD ne_csip;              /* 14 Initial CS:IP */
1201     DWORD ne_sssp;              /* 18 Initial SS:SP */
1202     WORD  ne_cseg;              /* 1c # of entries in segment table */
1203     WORD  ne_cmod;              /* 1e # of entries in module reference tab. */
1204     WORD  ne_cbnrestab;         /* 20 Length of nonresident-name table     */
1205     WORD  ne_segtab;            /* 22 Offset to segment table */
1206     WORD  ne_rsrctab;           /* 24 Offset to resource table */
1207     WORD  ne_restab;            /* 26 Offset to resident-name table */
1208     WORD  ne_modtab;            /* 28 Offset to module reference table */
1209     WORD  ne_imptab;            /* 2a Offset to imported name table */
1210     DWORD ne_nrestab;           /* 2c Offset to nonresident-name table */
1211     WORD  ne_cmovent;           /* 30 # of movable entry points */
1212     WORD  ne_align;             /* 32 Logical sector alignment shift count */
1213     WORD  ne_cres;              /* 34 # of resource segments */
1214     BYTE  ne_exetyp;            /* 36 Flags indicating target OS */
1215     BYTE  ne_flagsothers;       /* 37 Additional information flags */
1216     WORD  fastload_offset;      /* 38 Offset to fast load area (should be ne_pretthunks)*/
1217     WORD  fastload_length;      /* 3a Length of fast load area (should be ne_psegrefbytes) */
1218     WORD  ne_swaparea;          /* 3c Reserved by Microsoft */
1219     WORD  ne_expver;            /* 3e Expected Windows version number */
1220 } IMAGE_OS2_HEADER,*PIMAGE_OS2_HEADER;
1221
1222 typedef struct _IMAGE_VXD_HEADER {
1223   WORD  e32_magic;
1224   BYTE  e32_border;
1225   BYTE  e32_worder;
1226   DWORD e32_level;
1227   WORD  e32_cpu;
1228   WORD  e32_os;
1229   DWORD e32_ver;
1230   DWORD e32_mflags;
1231   DWORD e32_mpages;
1232   DWORD e32_startobj;
1233   DWORD e32_eip;
1234   DWORD e32_stackobj;
1235   DWORD e32_esp;
1236   DWORD e32_pagesize;
1237   DWORD e32_lastpagesize;
1238   DWORD e32_fixupsize;
1239   DWORD e32_fixupsum;
1240   DWORD e32_ldrsize;
1241   DWORD e32_ldrsum;
1242   DWORD e32_objtab;
1243   DWORD e32_objcnt;
1244   DWORD e32_objmap;
1245   DWORD e32_itermap;
1246   DWORD e32_rsrctab;
1247   DWORD e32_rsrccnt;
1248   DWORD e32_restab;
1249   DWORD e32_enttab;
1250   DWORD e32_dirtab;
1251   DWORD e32_dircnt;
1252   DWORD e32_fpagetab;
1253   DWORD e32_frectab;
1254   DWORD e32_impmod;
1255   DWORD e32_impmodcnt;
1256   DWORD e32_impproc;
1257   DWORD e32_pagesum;
1258   DWORD e32_datapage;
1259   DWORD e32_preload;
1260   DWORD e32_nrestab;
1261   DWORD e32_cbnrestab;
1262   DWORD e32_nressum;
1263   DWORD e32_autodata;
1264   DWORD e32_debuginfo;
1265   DWORD e32_debuglen;
1266   DWORD e32_instpreload;
1267   DWORD e32_instdemand;
1268   DWORD e32_heapsize;
1269   BYTE   e32_res3[12];
1270   DWORD e32_winresoff;
1271   DWORD e32_winreslen;
1272   WORD  e32_devid;
1273   WORD  e32_ddkver;
1274 } IMAGE_VXD_HEADER, *PIMAGE_VXD_HEADER;
1275
1276
1277 /* These defines describe the meanings of the bits in the Characteristics
1278    field */
1279
1280 #define IMAGE_FILE_RELOCS_STRIPPED      0x0001 /* No relocation info */
1281 #define IMAGE_FILE_EXECUTABLE_IMAGE     0x0002
1282 #define IMAGE_FILE_LINE_NUMS_STRIPPED   0x0004
1283 #define IMAGE_FILE_LOCAL_SYMS_STRIPPED  0x0008
1284 #define IMAGE_FILE_16BIT_MACHINE        0x0040
1285 #define IMAGE_FILE_BYTES_REVERSED_LO    0x0080
1286 #define IMAGE_FILE_32BIT_MACHINE        0x0100
1287 #define IMAGE_FILE_DEBUG_STRIPPED       0x0200
1288 #define IMAGE_FILE_SYSTEM               0x1000
1289 #define IMAGE_FILE_DLL                  0x2000
1290 #define IMAGE_FILE_BYTES_REVERSED_HI    0x8000
1291
1292 /* These are the settings of the Machine field. */
1293 #define IMAGE_FILE_MACHINE_UNKNOWN      0
1294 #define IMAGE_FILE_MACHINE_I860         0x14d
1295 #define IMAGE_FILE_MACHINE_I386         0x14c
1296 #define IMAGE_FILE_MACHINE_R3000        0x162
1297 #define IMAGE_FILE_MACHINE_R4000        0x166
1298 #define IMAGE_FILE_MACHINE_R10000       0x168
1299 #define IMAGE_FILE_MACHINE_ALPHA        0x184
1300 #define IMAGE_FILE_MACHINE_POWERPC      0x1F0  
1301
1302 #define IMAGE_SIZEOF_FILE_HEADER        20
1303
1304 /* Possible Magic values */
1305 #define IMAGE_NT_OPTIONAL_HDR_MAGIC        0x10b
1306 #define IMAGE_ROM_OPTIONAL_HDR_MAGIC       0x107
1307
1308 /* These are indexes into the DataDirectory array */
1309 #define IMAGE_FILE_EXPORT_DIRECTORY             0
1310 #define IMAGE_FILE_IMPORT_DIRECTORY             1
1311 #define IMAGE_FILE_RESOURCE_DIRECTORY           2
1312 #define IMAGE_FILE_EXCEPTION_DIRECTORY          3
1313 #define IMAGE_FILE_SECURITY_DIRECTORY           4
1314 #define IMAGE_FILE_BASE_RELOCATION_TABLE        5
1315 #define IMAGE_FILE_DEBUG_DIRECTORY              6
1316 #define IMAGE_FILE_DESCRIPTION_STRING           7
1317 #define IMAGE_FILE_MACHINE_VALUE                8  /* Mips */
1318 #define IMAGE_FILE_THREAD_LOCAL_STORAGE         9
1319 #define IMAGE_FILE_CALLBACK_DIRECTORY           10
1320
1321 /* Directory Entries, indices into the DataDirectory array */
1322
1323 #define IMAGE_DIRECTORY_ENTRY_EXPORT            0
1324 #define IMAGE_DIRECTORY_ENTRY_IMPORT            1
1325 #define IMAGE_DIRECTORY_ENTRY_RESOURCE          2
1326 #define IMAGE_DIRECTORY_ENTRY_EXCEPTION         3
1327 #define IMAGE_DIRECTORY_ENTRY_SECURITY          4
1328 #define IMAGE_DIRECTORY_ENTRY_BASERELOC         5
1329 #define IMAGE_DIRECTORY_ENTRY_DEBUG             6
1330 #define IMAGE_DIRECTORY_ENTRY_COPYRIGHT         7
1331 #define IMAGE_DIRECTORY_ENTRY_GLOBALPTR         8   /* (MIPS GP) */
1332 #define IMAGE_DIRECTORY_ENTRY_TLS               9
1333 #define IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG       10
1334 #define IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT      11
1335 #define IMAGE_DIRECTORY_ENTRY_IAT               12  /* Import Address Table */
1336 #define IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT      13
1337 #define IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR    14
1338
1339 /* Subsystem Values */
1340
1341 #define IMAGE_SUBSYSTEM_UNKNOWN         0
1342 #define IMAGE_SUBSYSTEM_NATIVE          1
1343 #define IMAGE_SUBSYSTEM_WINDOWS_GUI     2       /* Windows GUI subsystem */
1344 #define IMAGE_SUBSYSTEM_WINDOWS_CUI     3       /* Windows character subsystem*/
1345 #define IMAGE_SUBSYSTEM_OS2_CUI         5
1346 #define IMAGE_SUBSYSTEM_POSIX_CUI       7
1347
1348 typedef struct _IMAGE_FILE_HEADER {
1349   WORD  Machine;
1350   WORD  NumberOfSections;
1351   DWORD TimeDateStamp;
1352   DWORD PointerToSymbolTable;
1353   DWORD NumberOfSymbols;
1354   WORD  SizeOfOptionalHeader;
1355   WORD  Characteristics;
1356 } IMAGE_FILE_HEADER, *PIMAGE_FILE_HEADER;
1357
1358 typedef struct _IMAGE_DATA_DIRECTORY {
1359   DWORD VirtualAddress;
1360   DWORD Size;
1361 } IMAGE_DATA_DIRECTORY, *PIMAGE_DATA_DIRECTORY;
1362
1363 #define IMAGE_NUMBEROF_DIRECTORY_ENTRIES 16
1364
1365 typedef struct _IMAGE_OPTIONAL_HEADER {
1366
1367   /* Standard fields */
1368
1369   WORD  Magic;
1370   BYTE  MajorLinkerVersion;
1371   BYTE  MinorLinkerVersion;
1372   DWORD SizeOfCode;
1373   DWORD SizeOfInitializedData;
1374   DWORD SizeOfUninitializedData;
1375   DWORD AddressOfEntryPoint;
1376   DWORD BaseOfCode;
1377   DWORD BaseOfData;
1378
1379   /* NT additional fields */
1380
1381   DWORD ImageBase;
1382   DWORD SectionAlignment;
1383   DWORD FileAlignment;
1384   WORD  MajorOperatingSystemVersion;
1385   WORD  MinorOperatingSystemVersion;
1386   WORD  MajorImageVersion;
1387   WORD  MinorImageVersion;
1388   WORD  MajorSubsystemVersion;
1389   WORD  MinorSubsystemVersion;
1390   DWORD Win32VersionValue;
1391   DWORD SizeOfImage;
1392   DWORD SizeOfHeaders;
1393   DWORD CheckSum;
1394   WORD  Subsystem;
1395   WORD  DllCharacteristics;
1396   DWORD SizeOfStackReserve;
1397   DWORD SizeOfStackCommit;
1398   DWORD SizeOfHeapReserve;
1399   DWORD SizeOfHeapCommit;
1400   DWORD LoaderFlags;
1401   DWORD NumberOfRvaAndSizes;
1402   IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
1403 } IMAGE_OPTIONAL_HEADER, *PIMAGE_OPTIONAL_HEADER;
1404
1405 typedef struct _IMAGE_NT_HEADERS {
1406   DWORD Signature;
1407   IMAGE_FILE_HEADER FileHeader;
1408   IMAGE_OPTIONAL_HEADER OptionalHeader;
1409 } IMAGE_NT_HEADERS, *PIMAGE_NT_HEADERS;
1410
1411 #define IMAGE_SIZEOF_SHORT_NAME 8
1412
1413 typedef struct _IMAGE_SECTION_HEADER {
1414   BYTE  Name[IMAGE_SIZEOF_SHORT_NAME];
1415   union {
1416     DWORD PhysicalAddress;
1417     DWORD VirtualSize;
1418   } Misc;
1419   DWORD VirtualAddress;
1420   DWORD SizeOfRawData;
1421   DWORD PointerToRawData;
1422   DWORD PointerToRelocations;
1423   DWORD PointerToLinenumbers;
1424   WORD  NumberOfRelocations;
1425   WORD  NumberOfLinenumbers;
1426   DWORD Characteristics;
1427 } IMAGE_SECTION_HEADER, *PIMAGE_SECTION_HEADER;
1428
1429 #define IMAGE_SIZEOF_SECTION_HEADER 40
1430
1431 #define IMAGE_FIRST_SECTION(ntheader) \
1432   ((PIMAGE_SECTION_HEADER)((LPBYTE)&((PIMAGE_NT_HEADERS)(ntheader))->OptionalHeader + \
1433                            ((PIMAGE_NT_HEADERS)(ntheader))->FileHeader.SizeOfOptionalHeader))
1434
1435 /* These defines are for the Characteristics bitfield. */
1436 /* #define IMAGE_SCN_TYPE_REG                   0x00000000 - Reserved */
1437 /* #define IMAGE_SCN_TYPE_DSECT                 0x00000001 - Reserved */
1438 /* #define IMAGE_SCN_TYPE_NOLOAD                0x00000002 - Reserved */
1439 /* #define IMAGE_SCN_TYPE_GROUP                 0x00000004 - Reserved */
1440 /* #define IMAGE_SCN_TYPE_NO_PAD                0x00000008 - Reserved */
1441 /* #define IMAGE_SCN_TYPE_COPY                  0x00000010 - Reserved */
1442
1443 #define IMAGE_SCN_CNT_CODE                      0x00000020
1444 #define IMAGE_SCN_CNT_INITIALIZED_DATA          0x00000040
1445 #define IMAGE_SCN_CNT_UNINITIALIZED_DATA        0x00000080
1446
1447 #define IMAGE_SCN_LNK_OTHER                     0x00000100 
1448 #define IMAGE_SCN_LNK_INFO                      0x00000200  
1449 /* #define      IMAGE_SCN_TYPE_OVER             0x00000400 - Reserved */
1450 #define IMAGE_SCN_LNK_REMOVE                    0x00000800
1451 #define IMAGE_SCN_LNK_COMDAT                    0x00001000
1452
1453 /*                                              0x00002000 - Reserved */
1454 /* #define IMAGE_SCN_MEM_PROTECTED              0x00004000 - Obsolete */
1455 #define IMAGE_SCN_MEM_FARDATA                   0x00008000
1456
1457 /* #define IMAGE_SCN_MEM_SYSHEAP                0x00010000 - Obsolete */
1458 #define IMAGE_SCN_MEM_PURGEABLE                 0x00020000
1459 #define IMAGE_SCN_MEM_16BIT                     0x00020000
1460 #define IMAGE_SCN_MEM_LOCKED                    0x00040000
1461 #define IMAGE_SCN_MEM_PRELOAD                   0x00080000
1462
1463 #define IMAGE_SCN_ALIGN_1BYTES                  0x00100000
1464 #define IMAGE_SCN_ALIGN_2BYTES                  0x00200000
1465 #define IMAGE_SCN_ALIGN_4BYTES                  0x00300000
1466 #define IMAGE_SCN_ALIGN_8BYTES                  0x00400000
1467 #define IMAGE_SCN_ALIGN_16BYTES                 0x00500000  /* Default */
1468 #define IMAGE_SCN_ALIGN_32BYTES                 0x00600000
1469 #define IMAGE_SCN_ALIGN_64BYTES                 0x00700000
1470 /*                                              0x00800000 - Unused */
1471
1472 #define IMAGE_SCN_LNK_NRELOC_OVFL               0x01000000
1473
1474
1475 #define IMAGE_SCN_MEM_DISCARDABLE               0x02000000
1476 #define IMAGE_SCN_MEM_NOT_CACHED                0x04000000
1477 #define IMAGE_SCN_MEM_NOT_PAGED                 0x08000000
1478 #define IMAGE_SCN_MEM_SHARED                    0x10000000
1479 #define IMAGE_SCN_MEM_EXECUTE                   0x20000000
1480 #define IMAGE_SCN_MEM_READ                      0x40000000
1481 #define IMAGE_SCN_MEM_WRITE                     0x80000000
1482
1483 #include "pshpack2.h"
1484
1485 typedef struct _IMAGE_SYMBOL {
1486     union {
1487         BYTE    ShortName[8];
1488         struct {
1489             DWORD   Short;
1490             DWORD   Long;
1491         } Name;
1492         DWORD   LongName[2];
1493     } N;
1494     DWORD   Value;
1495     SHORT   SectionNumber;
1496     WORD    Type;
1497     BYTE    StorageClass;
1498     BYTE    NumberOfAuxSymbols;
1499 } IMAGE_SYMBOL;
1500 typedef IMAGE_SYMBOL *PIMAGE_SYMBOL;
1501
1502 #define IMAGE_SIZEOF_SYMBOL 18
1503
1504 typedef struct _IMAGE_LINENUMBER {
1505     union {
1506         DWORD   SymbolTableIndex;
1507         DWORD   VirtualAddress;
1508     } Type;
1509     WORD    Linenumber;
1510 } IMAGE_LINENUMBER;
1511 typedef IMAGE_LINENUMBER *PIMAGE_LINENUMBER;
1512
1513 #define IMAGE_SIZEOF_LINENUMBER  6
1514
1515 typedef union _IMAGE_AUX_SYMBOL {
1516     struct {
1517         DWORD    TagIndex;
1518         union {
1519             struct {
1520                 WORD    Linenumber;
1521                 WORD    Size;
1522             } LnSz;
1523            DWORD    TotalSize;
1524         } Misc;
1525         union {
1526             struct {
1527                 DWORD    PointerToLinenumber;
1528                 DWORD    PointerToNextFunction;
1529             } Function;
1530             struct {
1531                 WORD     Dimension[4];
1532             } Array;
1533         } FcnAry;
1534         WORD    TvIndex;
1535     } Sym;
1536     struct {
1537         BYTE    Name[IMAGE_SIZEOF_SYMBOL];
1538     } File;
1539     struct {
1540         DWORD   Length;
1541         WORD    NumberOfRelocations;
1542         WORD    NumberOfLinenumbers;
1543         DWORD   CheckSum;
1544         SHORT   Number;
1545         BYTE    Selection;
1546     } Section;
1547 } IMAGE_AUX_SYMBOL;
1548 typedef IMAGE_AUX_SYMBOL *PIMAGE_AUX_SYMBOL;
1549
1550 #define IMAGE_SIZEOF_AUX_SYMBOL 18
1551
1552 #include "poppack.h"
1553
1554 #define IMAGE_SYM_UNDEFINED           (SHORT)0
1555 #define IMAGE_SYM_ABSOLUTE            (SHORT)-1
1556 #define IMAGE_SYM_DEBUG               (SHORT)-2
1557
1558 #define IMAGE_SYM_TYPE_NULL                 0x0000
1559 #define IMAGE_SYM_TYPE_VOID                 0x0001
1560 #define IMAGE_SYM_TYPE_CHAR                 0x0002
1561 #define IMAGE_SYM_TYPE_SHORT                0x0003
1562 #define IMAGE_SYM_TYPE_INT                  0x0004
1563 #define IMAGE_SYM_TYPE_LONG                 0x0005
1564 #define IMAGE_SYM_TYPE_FLOAT                0x0006
1565 #define IMAGE_SYM_TYPE_DOUBLE               0x0007
1566 #define IMAGE_SYM_TYPE_STRUCT               0x0008
1567 #define IMAGE_SYM_TYPE_UNION                0x0009
1568 #define IMAGE_SYM_TYPE_ENUM                 0x000A
1569 #define IMAGE_SYM_TYPE_MOE                  0x000B
1570 #define IMAGE_SYM_TYPE_BYTE                 0x000C
1571 #define IMAGE_SYM_TYPE_WORD                 0x000D
1572 #define IMAGE_SYM_TYPE_UINT                 0x000E
1573 #define IMAGE_SYM_TYPE_DWORD                0x000F
1574 #define IMAGE_SYM_TYPE_PCODE                0x8000
1575
1576 #define IMAGE_SYM_DTYPE_NULL                0
1577 #define IMAGE_SYM_DTYPE_POINTER             1
1578 #define IMAGE_SYM_DTYPE_FUNCTION            2
1579 #define IMAGE_SYM_DTYPE_ARRAY               3
1580
1581 #define IMAGE_SYM_CLASS_END_OF_FUNCTION     (BYTE )-1
1582 #define IMAGE_SYM_CLASS_NULL                0x0000
1583 #define IMAGE_SYM_CLASS_AUTOMATIC           0x0001
1584 #define IMAGE_SYM_CLASS_EXTERNAL            0x0002
1585 #define IMAGE_SYM_CLASS_STATIC              0x0003
1586 #define IMAGE_SYM_CLASS_REGISTER            0x0004
1587 #define IMAGE_SYM_CLASS_EXTERNAL_DEF        0x0005
1588 #define IMAGE_SYM_CLASS_LABEL               0x0006
1589 #define IMAGE_SYM_CLASS_UNDEFINED_LABEL     0x0007
1590 #define IMAGE_SYM_CLASS_MEMBER_OF_STRUCT    0x0008
1591 #define IMAGE_SYM_CLASS_ARGUMENT            0x0009
1592 #define IMAGE_SYM_CLASS_STRUCT_TAG          0x000A
1593 #define IMAGE_SYM_CLASS_MEMBER_OF_UNION     0x000B
1594 #define IMAGE_SYM_CLASS_UNION_TAG           0x000C
1595 #define IMAGE_SYM_CLASS_TYPE_DEFINITION     0x000D
1596 #define IMAGE_SYM_CLASS_UNDEFINED_STATIC    0x000E
1597 #define IMAGE_SYM_CLASS_ENUM_TAG            0x000F
1598 #define IMAGE_SYM_CLASS_MEMBER_OF_ENUM      0x0010
1599 #define IMAGE_SYM_CLASS_REGISTER_PARAM      0x0011
1600 #define IMAGE_SYM_CLASS_BIT_FIELD           0x0012
1601
1602 #define IMAGE_SYM_CLASS_FAR_EXTERNAL        0x0044
1603 #define IMAGE_SYM_CLASS_BLOCK               0x0064
1604 #define IMAGE_SYM_CLASS_FUNCTION            0x0065
1605 #define IMAGE_SYM_CLASS_END_OF_STRUCT       0x0066
1606 #define IMAGE_SYM_CLASS_FILE                0x0067
1607 #define IMAGE_SYM_CLASS_SECTION             0x0068
1608 #define IMAGE_SYM_CLASS_WEAK_EXTERNAL       0x0069
1609
1610 #define N_BTMASK                            0x000F
1611 #define N_TMASK                             0x0030
1612 #define N_TMASK1                            0x00C0
1613 #define N_TMASK2                            0x00F0
1614 #define N_BTSHFT                            4
1615 #define N_TSHIFT                            2
1616
1617 #define BTYPE(x) ((x) & N_BTMASK)
1618
1619 #ifndef ISPTR
1620 #define ISPTR(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_POINTER << N_BTSHFT))
1621 #endif
1622
1623 #ifndef ISFCN
1624 #define ISFCN(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_FUNCTION << N_BTSHFT))
1625 #endif
1626
1627 #ifndef ISARY
1628 #define ISARY(x) (((x) & N_TMASK) == (IMAGE_SYM_DTYPE_ARRAY << N_BTSHFT))
1629 #endif
1630
1631 #ifndef ISTAG
1632 #define ISTAG(x) ((x)==IMAGE_SYM_CLASS_STRUCT_TAG || (x)==IMAGE_SYM_CLASS_UNION_TAG || (x)==IMAGE_SYM_CLASS_ENUM_TAG)
1633 #endif
1634
1635 #ifndef INCREF
1636 #define INCREF(x) ((((x)&~N_BTMASK)<<N_TSHIFT)|(IMAGE_SYM_DTYPE_POINTER<<N_BTSHFT)|((x)&N_BTMASK))
1637 #endif
1638 #ifndef DECREF
1639 #define DECREF(x) ((((x)>>N_TSHIFT)&~N_BTMASK)|((x)&N_BTMASK))
1640 #endif
1641
1642 #define IMAGE_COMDAT_SELECT_NODUPLICATES    1
1643 #define IMAGE_COMDAT_SELECT_ANY             2
1644 #define IMAGE_COMDAT_SELECT_SAME_SIZE       3
1645 #define IMAGE_COMDAT_SELECT_EXACT_MATCH     4
1646 #define IMAGE_COMDAT_SELECT_ASSOCIATIVE     5
1647 #define IMAGE_COMDAT_SELECT_LARGEST         6
1648 #define IMAGE_COMDAT_SELECT_NEWEST          7
1649
1650 #define IMAGE_WEAK_EXTERN_SEARCH_NOLIBRARY  1
1651 #define IMAGE_WEAK_EXTERN_SEARCH_LIBRARY    2
1652 #define IMAGE_WEAK_EXTERN_SEARCH_ALIAS      3
1653
1654 /* Export module directory */
1655
1656 typedef struct _IMAGE_EXPORT_DIRECTORY {
1657         DWORD   Characteristics;
1658         DWORD   TimeDateStamp;
1659         WORD    MajorVersion;
1660         WORD    MinorVersion;
1661         DWORD   Name;
1662         DWORD   Base;
1663         DWORD   NumberOfFunctions;
1664         DWORD   NumberOfNames;
1665         DWORD   AddressOfFunctions;
1666         DWORD   AddressOfNames;
1667         DWORD   AddressOfNameOrdinals;
1668 } IMAGE_EXPORT_DIRECTORY,*PIMAGE_EXPORT_DIRECTORY;
1669
1670 /* Import name entry */
1671 typedef struct _IMAGE_IMPORT_BY_NAME {
1672         WORD    Hint;
1673         BYTE    Name[1];
1674 } IMAGE_IMPORT_BY_NAME,*PIMAGE_IMPORT_BY_NAME;
1675
1676 /* Import thunk */
1677 typedef struct _IMAGE_THUNK_DATA {
1678         union {
1679                 LPBYTE    ForwarderString;
1680                 FARPROC Function;
1681                 DWORD     Ordinal;
1682                 PIMAGE_IMPORT_BY_NAME   AddressOfData;
1683         } u1;
1684 } IMAGE_THUNK_DATA,*PIMAGE_THUNK_DATA;
1685
1686 /* Import module directory */
1687
1688 typedef struct _IMAGE_IMPORT_DESCRIPTOR {
1689         union {
1690                 DWORD   Characteristics; /* 0 for terminating null import descriptor  */
1691                 PIMAGE_THUNK_DATA OriginalFirstThunk;   /* RVA to original unbound IAT */
1692         } u;
1693         DWORD   TimeDateStamp;  /* 0 if not bound,
1694                                  * -1 if bound, and real date\time stamp
1695                                  *    in IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT
1696                                  * (new BIND)
1697                                  * otherwise date/time stamp of DLL bound to
1698                                  * (Old BIND)
1699                                  */
1700         DWORD   ForwarderChain; /* -1 if no forwarders */
1701         DWORD   Name;
1702         /* RVA to IAT (if bound this IAT has actual addresses) */
1703         PIMAGE_THUNK_DATA FirstThunk;   
1704 } IMAGE_IMPORT_DESCRIPTOR,*PIMAGE_IMPORT_DESCRIPTOR;
1705
1706 #define IMAGE_ORDINAL_FLAG              0x80000000
1707 #define IMAGE_SNAP_BY_ORDINAL(Ordinal)  ((Ordinal & IMAGE_ORDINAL_FLAG) != 0)
1708 #define IMAGE_ORDINAL(Ordinal)          (Ordinal & 0xffff)
1709
1710 typedef struct _IMAGE_BOUND_IMPORT_DESCRIPTOR
1711 {
1712     DWORD   TimeDateStamp;
1713     WORD    OffsetModuleName;
1714     WORD    NumberOfModuleForwarderRefs;
1715 /* Array of zero or more IMAGE_BOUND_FORWARDER_REF follows */
1716 } IMAGE_BOUND_IMPORT_DESCRIPTOR,  *PIMAGE_BOUND_IMPORT_DESCRIPTOR;
1717
1718 typedef struct _IMAGE_BOUND_FORWARDER_REF
1719 {
1720     DWORD   TimeDateStamp;
1721     WORD    OffsetModuleName;
1722     WORD    Reserved;
1723 } IMAGE_BOUND_FORWARDER_REF, *PIMAGE_BOUND_FORWARDER_REF;
1724
1725 typedef struct _IMAGE_BASE_RELOCATION
1726 {
1727         DWORD   VirtualAddress;
1728         DWORD   SizeOfBlock;
1729         WORD    TypeOffset[1];
1730 } IMAGE_BASE_RELOCATION,*PIMAGE_BASE_RELOCATION;
1731
1732 typedef struct _IMAGE_RELOCATION
1733 {
1734     union {
1735         DWORD   VirtualAddress;
1736         DWORD   RelocCount;
1737     } u;
1738     DWORD   SymbolTableIndex;
1739     WORD    Type;
1740 } IMAGE_RELOCATION;
1741 typedef IMAGE_RELOCATION *PIMAGE_RELOCATION;
1742
1743 #define IMAGE_SIZEOF_RELOCATION 10
1744
1745 /* generic relocation types */
1746 #define IMAGE_REL_BASED_ABSOLUTE                0
1747 #define IMAGE_REL_BASED_HIGH                    1
1748 #define IMAGE_REL_BASED_LOW                     2
1749 #define IMAGE_REL_BASED_HIGHLOW                 3
1750 #define IMAGE_REL_BASED_HIGHADJ                 4
1751 #define IMAGE_REL_BASED_MIPS_JMPADDR            5
1752 #define IMAGE_REL_BASED_SECTION                 6
1753 #define IMAGE_REL_BASED_REL                     7
1754 #define IMAGE_REL_BASED_MIPS_JMPADDR16          9
1755 #define IMAGE_REL_BASED_IA64_IMM64              9 /* yes, 9 too */
1756 #define IMAGE_REL_BASED_DIR64                   10
1757 #define IMAGE_REL_BASED_HIGH3ADJ                11
1758
1759 /* I386 relocation types */
1760 #define IMAGE_REL_I386_ABSOLUTE                 0
1761 #define IMAGE_REL_I386_DIR16                    1
1762 #define IMAGE_REL_I386_REL16                    2
1763 #define IMAGE_REL_I386_DIR32                    6
1764 #define IMAGE_REL_I386_DIR32NB                  7
1765 #define IMAGE_REL_I386_SEG12                    9
1766 #define IMAGE_REL_I386_SECTION                  10
1767 #define IMAGE_REL_I386_SECREL                   11
1768 #define IMAGE_REL_I386_REL32                    20
1769
1770 /* MIPS relocation types */
1771 #define IMAGE_REL_MIPS_ABSOLUTE         0x0000
1772 #define IMAGE_REL_MIPS_REFHALF          0x0001
1773 #define IMAGE_REL_MIPS_REFWORD          0x0002
1774 #define IMAGE_REL_MIPS_JMPADDR          0x0003
1775 #define IMAGE_REL_MIPS_REFHI            0x0004
1776 #define IMAGE_REL_MIPS_REFLO            0x0005
1777 #define IMAGE_REL_MIPS_GPREL            0x0006
1778 #define IMAGE_REL_MIPS_LITERAL          0x0007
1779 #define IMAGE_REL_MIPS_SECTION          0x000A
1780 #define IMAGE_REL_MIPS_SECREL           0x000B
1781 #define IMAGE_REL_MIPS_SECRELLO         0x000C
1782 #define IMAGE_REL_MIPS_SECRELHI         0x000D
1783 #define IMAGE_REL_MIPS_JMPADDR16        0x0010
1784 #define IMAGE_REL_MIPS_REFWORDNB        0x0022
1785 #define IMAGE_REL_MIPS_PAIR             0x0025
1786
1787 /* ALPHA relocation types */
1788 #define IMAGE_REL_ALPHA_ABSOLUTE        0x0000
1789 #define IMAGE_REL_ALPHA_REFLONG         0x0001
1790 #define IMAGE_REL_ALPHA_REFQUAD         0x0002
1791 #define IMAGE_REL_ALPHA_GPREL           0x0003
1792 #define IMAGE_REL_ALPHA_LITERAL         0x0004
1793 #define IMAGE_REL_ALPHA_LITUSE          0x0005
1794 #define IMAGE_REL_ALPHA_GPDISP          0x0006
1795 #define IMAGE_REL_ALPHA_BRADDR          0x0007
1796 #define IMAGE_REL_ALPHA_HINT            0x0008
1797 #define IMAGE_REL_ALPHA_INLINE_REFLONG  0x0009
1798 #define IMAGE_REL_ALPHA_REFHI           0x000A
1799 #define IMAGE_REL_ALPHA_REFLO           0x000B
1800 #define IMAGE_REL_ALPHA_PAIR            0x000C
1801 #define IMAGE_REL_ALPHA_MATCH           0x000D
1802 #define IMAGE_REL_ALPHA_SECTION         0x000E
1803 #define IMAGE_REL_ALPHA_SECREL          0x000F
1804 #define IMAGE_REL_ALPHA_REFLONGNB       0x0010
1805 #define IMAGE_REL_ALPHA_SECRELLO        0x0011
1806 #define IMAGE_REL_ALPHA_SECRELHI        0x0012
1807 #define IMAGE_REL_ALPHA_REFQ3           0x0013
1808 #define IMAGE_REL_ALPHA_REFQ2           0x0014
1809 #define IMAGE_REL_ALPHA_REFQ1           0x0015
1810 #define IMAGE_REL_ALPHA_GPRELLO         0x0016
1811 #define IMAGE_REL_ALPHA_GPRELHI         0x0017
1812
1813 /* PowerPC relocation types */
1814 #define IMAGE_REL_PPC_ABSOLUTE          0x0000
1815 #define IMAGE_REL_PPC_ADDR64            0x0001
1816 #define IMAGE_REL_PPC_ADDR            0x0002
1817 #define IMAGE_REL_PPC_ADDR24            0x0003
1818 #define IMAGE_REL_PPC_ADDR16            0x0004
1819 #define IMAGE_REL_PPC_ADDR14            0x0005
1820 #define IMAGE_REL_PPC_REL24             0x0006
1821 #define IMAGE_REL_PPC_REL14             0x0007
1822 #define IMAGE_REL_PPC_TOCREL16          0x0008
1823 #define IMAGE_REL_PPC_TOCREL14          0x0009
1824 #define IMAGE_REL_PPC_ADDR32NB          0x000A
1825 #define IMAGE_REL_PPC_SECREL            0x000B
1826 #define IMAGE_REL_PPC_SECTION           0x000C
1827 #define IMAGE_REL_PPC_IFGLUE            0x000D
1828 #define IMAGE_REL_PPC_IMGLUE            0x000E
1829 #define IMAGE_REL_PPC_SECREL16          0x000F
1830 #define IMAGE_REL_PPC_REFHI             0x0010
1831 #define IMAGE_REL_PPC_REFLO             0x0011
1832 #define IMAGE_REL_PPC_PAIR              0x0012
1833 #define IMAGE_REL_PPC_SECRELLO          0x0013
1834 #define IMAGE_REL_PPC_SECRELHI          0x0014
1835 #define IMAGE_REL_PPC_GPREL             0x0015
1836 #define IMAGE_REL_PPC_TYPEMASK          0x00FF
1837 /* modifier bits */
1838 #define IMAGE_REL_PPC_NEG               0x0100
1839 #define IMAGE_REL_PPC_BRTAKEN           0x0200
1840 #define IMAGE_REL_PPC_BRNTAKEN          0x0400
1841 #define IMAGE_REL_PPC_TOCDEFN           0x0800
1842
1843 /* SH3 ? relocation type */
1844 #define IMAGE_REL_SH3_ABSOLUTE          0x0000
1845 #define IMAGE_REL_SH3_DIRECT16          0x0001
1846 #define IMAGE_REL_SH3_DIRECT          0x0002
1847 #define IMAGE_REL_SH3_DIRECT8           0x0003
1848 #define IMAGE_REL_SH3_DIRECT8_WORD      0x0004
1849 #define IMAGE_REL_SH3_DIRECT8_LONG      0x0005
1850 #define IMAGE_REL_SH3_DIRECT4           0x0006
1851 #define IMAGE_REL_SH3_DIRECT4_WORD      0x0007
1852 #define IMAGE_REL_SH3_DIRECT4_LONG      0x0008
1853 #define IMAGE_REL_SH3_PCREL8_WORD       0x0009
1854 #define IMAGE_REL_SH3_PCREL8_LONG       0x000A
1855 #define IMAGE_REL_SH3_PCREL12_WORD      0x000B
1856 #define IMAGE_REL_SH3_STARTOF_SECTION   0x000C
1857 #define IMAGE_REL_SH3_SIZEOF_SECTION    0x000D
1858 #define IMAGE_REL_SH3_SECTION           0x000E
1859 #define IMAGE_REL_SH3_SECREL            0x000F
1860 #define IMAGE_REL_SH3_DIRECT32_NB       0x0010
1861
1862 /* ARM (Archimedes?) relocation types */
1863 #define IMAGE_REL_ARM_ABSOLUTE          0x0000
1864 #define IMAGE_REL_ARM_ADDR              0x0001
1865 #define IMAGE_REL_ARM_ADDR32NB          0x0002
1866 #define IMAGE_REL_ARM_BRANCH24          0x0003
1867 #define IMAGE_REL_ARM_BRANCH11          0x0004
1868 #define IMAGE_REL_ARM_SECTION           0x000E
1869 #define IMAGE_REL_ARM_SECREL            0x000F
1870
1871 /* IA64 relocation types */
1872 #define IMAGE_REL_IA64_ABSOLUTE         0x0000
1873 #define IMAGE_REL_IA64_IMM14            0x0001
1874 #define IMAGE_REL_IA64_IMM22            0x0002
1875 #define IMAGE_REL_IA64_IMM64            0x0003
1876 #define IMAGE_REL_IA64_DIR              0x0004
1877 #define IMAGE_REL_IA64_DIR64            0x0005
1878 #define IMAGE_REL_IA64_PCREL21B         0x0006
1879 #define IMAGE_REL_IA64_PCREL21M         0x0007
1880 #define IMAGE_REL_IA64_PCREL21F         0x0008
1881 #define IMAGE_REL_IA64_GPREL22          0x0009
1882 #define IMAGE_REL_IA64_LTOFF22          0x000A
1883 #define IMAGE_REL_IA64_SECTION          0x000B
1884 #define IMAGE_REL_IA64_SECREL22         0x000C
1885 #define IMAGE_REL_IA64_SECREL64I        0x000D
1886 #define IMAGE_REL_IA64_SECREL           0x000E
1887 #define IMAGE_REL_IA64_LTOFF64          0x000F
1888 #define IMAGE_REL_IA64_DIR32NB          0x0010
1889 #define IMAGE_REL_IA64_RESERVED_11      0x0011
1890 #define IMAGE_REL_IA64_RESERVED_12      0x0012
1891 #define IMAGE_REL_IA64_RESERVED_13      0x0013
1892 #define IMAGE_REL_IA64_RESERVED_14      0x0014
1893 #define IMAGE_REL_IA64_RESERVED_15      0x0015
1894 #define IMAGE_REL_IA64_RESERVED_16      0x0016
1895 #define IMAGE_REL_IA64_ADDEND           0x001F
1896
1897 /* archive format */
1898
1899 #define IMAGE_ARCHIVE_START_SIZE             8
1900 #define IMAGE_ARCHIVE_START                  "!<arch>\n"
1901 #define IMAGE_ARCHIVE_END                    "`\n"
1902 #define IMAGE_ARCHIVE_PAD                    "\n"
1903 #define IMAGE_ARCHIVE_LINKER_MEMBER          "/               "
1904 #define IMAGE_ARCHIVE_LONGNAMES_MEMBER       "//              "
1905
1906 typedef struct _IMAGE_ARCHIVE_MEMBER_HEADER
1907 {
1908     BYTE     Name[16];
1909     BYTE     Date[12];
1910     BYTE     UserID[6];
1911     BYTE     GroupID[6];
1912     BYTE     Mode[8];
1913     BYTE     Size[10];
1914     BYTE     EndHeader[2];
1915 } IMAGE_ARCHIVE_MEMBER_HEADER, *PIMAGE_ARCHIVE_MEMBER_HEADER;
1916
1917 #define IMAGE_SIZEOF_ARCHIVE_MEMBER_HDR 60
1918
1919 /*
1920  * Resource directory stuff
1921  */
1922 typedef struct _IMAGE_RESOURCE_DIRECTORY {
1923         DWORD   Characteristics;
1924         DWORD   TimeDateStamp;
1925         WORD    MajorVersion;
1926         WORD    MinorVersion;
1927         WORD    NumberOfNamedEntries;
1928         WORD    NumberOfIdEntries;
1929         /*  IMAGE_RESOURCE_DIRECTORY_ENTRY DirectoryEntries[]; */
1930 } IMAGE_RESOURCE_DIRECTORY,*PIMAGE_RESOURCE_DIRECTORY;
1931
1932 #define IMAGE_RESOURCE_NAME_IS_STRING           0x80000000
1933 #define IMAGE_RESOURCE_DATA_IS_DIRECTORY        0x80000000
1934
1935 typedef struct _IMAGE_RESOURCE_DIRECTORY_ENTRY {
1936         union {
1937                 struct {
1938                         unsigned NameOffset:31;
1939                         unsigned NameIsString:1;
1940                 } s;
1941                 DWORD   Name;
1942                 WORD    Id;
1943         } u1;
1944         union {
1945                 DWORD   OffsetToData;
1946                 struct {
1947                         unsigned OffsetToDirectory:31;
1948                         unsigned DataIsDirectory:1;
1949                 } s;
1950         } u2;
1951 } IMAGE_RESOURCE_DIRECTORY_ENTRY,*PIMAGE_RESOURCE_DIRECTORY_ENTRY;
1952
1953
1954 typedef struct _IMAGE_RESOURCE_DIRECTORY_STRING {
1955         WORD    Length;
1956         CHAR    NameString[ 1 ];
1957 } IMAGE_RESOURCE_DIRECTORY_STRING,*PIMAGE_RESOURCE_DIRECTORY_STRING;
1958
1959 typedef struct _IMAGE_RESOURCE_DIR_STRING_U {
1960         WORD    Length;
1961         WCHAR   NameString[ 1 ];
1962 } IMAGE_RESOURCE_DIR_STRING_U,*PIMAGE_RESOURCE_DIR_STRING_U;
1963
1964 typedef struct _IMAGE_RESOURCE_DATA_ENTRY {
1965         DWORD   OffsetToData;
1966         DWORD   Size;
1967         DWORD   CodePage;
1968         DWORD   ResourceHandle;
1969 } IMAGE_RESOURCE_DATA_ENTRY,*PIMAGE_RESOURCE_DATA_ENTRY;
1970
1971
1972 typedef VOID CALLBACK (*PIMAGE_TLS_CALLBACK)(
1973         LPVOID DllHandle,DWORD Reason,LPVOID Reserved
1974 );
1975
1976 typedef struct _IMAGE_TLS_DIRECTORY {
1977         DWORD   StartAddressOfRawData;
1978         DWORD   EndAddressOfRawData;
1979         LPDWORD AddressOfIndex;
1980         PIMAGE_TLS_CALLBACK *AddressOfCallBacks;
1981         DWORD   SizeOfZeroFill;
1982         DWORD   Characteristics;
1983 } IMAGE_TLS_DIRECTORY,*PIMAGE_TLS_DIRECTORY;
1984
1985 typedef struct _IMAGE_DEBUG_DIRECTORY {
1986   DWORD Characteristics;
1987   DWORD TimeDateStamp;
1988   WORD  MajorVersion;
1989   WORD  MinorVersion;
1990   DWORD Type;
1991   DWORD SizeOfData;
1992   DWORD AddressOfRawData;
1993   DWORD PointerToRawData;
1994 } IMAGE_DEBUG_DIRECTORY, *PIMAGE_DEBUG_DIRECTORY;
1995
1996 #define IMAGE_DEBUG_TYPE_UNKNOWN        0
1997 #define IMAGE_DEBUG_TYPE_COFF           1
1998 #define IMAGE_DEBUG_TYPE_CODEVIEW       2
1999 #define IMAGE_DEBUG_TYPE_FPO            3
2000 #define IMAGE_DEBUG_TYPE_MISC           4
2001 #define IMAGE_DEBUG_TYPE_EXCEPTION      5
2002 #define IMAGE_DEBUG_TYPE_FIXUP          6
2003 #define IMAGE_DEBUG_TYPE_OMAP_TO_SRC    7
2004 #define IMAGE_DEBUG_TYPE_OMAP_FROM_SRC  8
2005 #define IMAGE_DEBUG_TYPE_BORLAND        9
2006 #define IMAGE_DEBUG_TYPE_RESERVED10    10
2007
2008 typedef struct _IMAGE_COFF_SYMBOLS_HEADER {
2009   DWORD NumberOfSymbols;
2010   DWORD LvaToFirstSymbol;
2011   DWORD NumberOfLinenumbers;
2012   DWORD LvaToFirstLinenumber;
2013   DWORD RvaToFirstByteOfCode;
2014   DWORD RvaToLastByteOfCode;
2015   DWORD RvaToFirstByteOfData;
2016   DWORD RvaToLastByteOfData;
2017 } IMAGE_COFF_SYMBOLS_HEADER, *PIMAGE_COFF_SYMBOLS_HEADER;
2018
2019 #define FRAME_FPO       0
2020 #define FRAME_TRAP      1
2021 #define FRAME_TSS       2
2022 #define FRAME_NONFPO    3
2023
2024 typedef struct _FPO_DATA {
2025   DWORD ulOffStart;
2026   DWORD cbProcSize;
2027   DWORD cdwLocals;
2028   WORD  cdwParams;
2029   unsigned cbProlog : 8;
2030   unsigned cbRegs   : 3;
2031   unsigned fHasSEH  : 1;
2032   unsigned fUseBP   : 1;
2033   unsigned reserved : 1;
2034   unsigned cbFrame  : 2;
2035 } FPO_DATA, *PFPO_DATA;
2036
2037 typedef struct _IMAGE_LOAD_CONFIG_DIRECTORY {
2038   DWORD Characteristics;
2039   DWORD TimeDateStamp;
2040   WORD  MajorVersion;
2041   WORD  MinorVersion;
2042   DWORD GlobalFlagsClear;
2043   DWORD GlobalFlagsSet;
2044   DWORD CriticalSectionDefaultTimeout;
2045   DWORD DeCommitFreeBlockThreshold;
2046   DWORD DeCommitTotalFreeThreshold;
2047   PVOID LockPrefixTable;
2048   DWORD MaximumAllocationSize;
2049   DWORD VirtualMemoryThreshold;
2050   DWORD ProcessHeapFlags;
2051   DWORD ProcessAffinityMask;
2052   WORD  CSDVersion;
2053   WORD  Reserved1;
2054   PVOID EditList;
2055   DWORD Reserved[1];
2056 } IMAGE_LOAD_CONFIG_DIRECTORY, *PIMAGE_LOAD_CONFIG_DIRECTORY;
2057
2058 typedef struct _IMAGE_FUNCTION_ENTRY {
2059   DWORD StartingAddress;
2060   DWORD EndingAddress;
2061   DWORD EndOfPrologue;
2062 } IMAGE_FUNCTION_ENTRY, *PIMAGE_FUNCTION_ENTRY;
2063
2064 /* This is the structure that appears at the very start of a .DBG file. */
2065
2066 typedef struct _IMAGE_SEPARATE_DEBUG_HEADER {
2067         WORD    Signature;
2068         WORD    Flags;
2069         WORD    Machine;
2070         WORD    Characteristics;
2071         DWORD   TimeDateStamp;
2072         DWORD   CheckSum;
2073         DWORD   ImageBase;
2074         DWORD   SizeOfImage;
2075         DWORD   NumberOfSections;
2076         DWORD   ExportedNamesSize;
2077         DWORD   DebugDirectorySize;
2078         DWORD   SectionAlignment;
2079         DWORD   Reserved[ 2 ];
2080 } IMAGE_SEPARATE_DEBUG_HEADER,*PIMAGE_SEPARATE_DEBUG_HEADER;
2081
2082 #define IMAGE_SEPARATE_DEBUG_SIGNATURE 0x4944
2083
2084
2085 typedef struct tagMESSAGE_RESOURCE_ENTRY {
2086         WORD    Length;
2087         WORD    Flags;
2088         BYTE    Text[1];
2089 } MESSAGE_RESOURCE_ENTRY,*PMESSAGE_RESOURCE_ENTRY;
2090 #define MESSAGE_RESOURCE_UNICODE        0x0001
2091
2092 typedef struct tagMESSAGE_RESOURCE_BLOCK {
2093         DWORD   LowId;
2094         DWORD   HighId;
2095         DWORD   OffsetToEntries;
2096 } MESSAGE_RESOURCE_BLOCK,*PMESSAGE_RESOURCE_BLOCK;
2097
2098 typedef struct tagMESSAGE_RESOURCE_DATA {
2099         DWORD                   NumberOfBlocks;
2100         MESSAGE_RESOURCE_BLOCK  Blocks[ 1 ];
2101 } MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA;
2102
2103 /*
2104  * Here follows typedefs for security and tokens.
2105  */ 
2106
2107 /*
2108  * First a constant for the following typdefs.
2109  */
2110
2111 #define ANYSIZE_ARRAY   1
2112
2113 /* FIXME:  Orphan.  What does it point to? */
2114 typedef PVOID PACCESS_TOKEN;
2115
2116 /*
2117  * TOKEN_INFORMATION_CLASS
2118  */
2119
2120 typedef enum _TOKEN_INFORMATION_CLASS {
2121   TokenUser = 1, 
2122   TokenGroups, 
2123   TokenPrivileges, 
2124   TokenOwner, 
2125   TokenPrimaryGroup, 
2126   TokenDefaultDacl, 
2127   TokenSource, 
2128   TokenType, 
2129   TokenImpersonationLevel, 
2130   TokenStatistics 
2131 } TOKEN_INFORMATION_CLASS; 
2132
2133 #ifndef _SECURITY_DEFINED
2134 #define _SECURITY_DEFINED
2135
2136 #include "pshpack1.h"
2137
2138 typedef DWORD ACCESS_MASK, *PACCESS_MASK;
2139
2140 typedef struct _GENERIC_MAPPING {
2141     ACCESS_MASK GenericRead;
2142     ACCESS_MASK GenericWrite;
2143     ACCESS_MASK GenericExecute;
2144     ACCESS_MASK GenericAll;
2145 } GENERIC_MAPPING, *PGENERIC_MAPPING;
2146
2147 #ifndef SID_IDENTIFIER_AUTHORITY_DEFINED
2148 #define SID_IDENTIFIER_AUTHORITY_DEFINED
2149 typedef struct {
2150     BYTE Value[6];
2151 } SID_IDENTIFIER_AUTHORITY,*PSID_IDENTIFIER_AUTHORITY,*LPSID_IDENTIFIER_AUTHORITY;
2152 #endif /* !defined(SID_IDENTIFIER_AUTHORITY_DEFINED) */
2153
2154 #ifndef SID_DEFINED
2155 #define SID_DEFINED
2156 typedef struct _SID {
2157     BYTE Revision;
2158     BYTE SubAuthorityCount;
2159     SID_IDENTIFIER_AUTHORITY IdentifierAuthority;
2160     DWORD SubAuthority[1];
2161 } SID,*PSID;
2162 #endif /* !defined(SID_DEFINED) */
2163
2164 #define SID_REVISION                    (1)     /* Current revision */
2165 #define SID_MAX_SUB_AUTHORITIES         (15)    /* current max subauths */
2166 #define SID_RECOMMENDED_SUB_AUTHORITIES (1)     /* recommended subauths */
2167
2168
2169 /* 
2170  * ACL 
2171  */
2172
2173 #define ACL_REVISION1 1
2174 #define ACL_REVISION2 2
2175 #define ACL_REVISION3 3
2176 #define ACL_REVISION4 4
2177
2178 #define MIN_ACL_REVISION ACL_REVISION2
2179 #define MAX_ACL_REVISION ACL_REVISION4
2180
2181 typedef struct _ACL {
2182     BYTE AclRevision;
2183     BYTE Sbz1;
2184     WORD AclSize;
2185     WORD AceCount;
2186     WORD Sbz2;
2187 } ACL, *PACL;
2188
2189 /* SECURITY_DESCRIPTOR */
2190 #define SECURITY_DESCRIPTOR_REVISION    1
2191 #define SECURITY_DESCRIPTOR_REVISION1   1
2192
2193
2194 #define SE_OWNER_DEFAULTED      0x0001
2195 #define SE_GROUP_DEFAULTED      0x0002
2196 #define SE_DACL_PRESENT         0x0004
2197 #define SE_DACL_DEFAULTED       0x0008
2198 #define SE_SACL_PRESENT         0x0010
2199 #define SE_SACL_DEFAULTED       0x0020
2200 #define SE_SELF_RELATIVE        0x8000
2201
2202 typedef DWORD SECURITY_INFORMATION, *PSECURITY_INFORMATION;
2203 typedef WORD SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL;
2204
2205 /* The security descriptor structure */
2206 typedef struct {
2207     BYTE Revision;
2208     BYTE Sbz1;
2209     SECURITY_DESCRIPTOR_CONTROL Control;
2210     DWORD Owner;
2211     DWORD Group;
2212     DWORD Sacl;
2213     DWORD Dacl;
2214 } SECURITY_DESCRIPTOR_RELATIVE, *PISECURITY_DESCRIPTOR_RELATIVE;
2215
2216 typedef struct {
2217     BYTE Revision;
2218     BYTE Sbz1;
2219     SECURITY_DESCRIPTOR_CONTROL Control;
2220     PSID Owner;
2221     PSID Group;
2222     PACL Sacl;
2223     PACL Dacl;
2224 } SECURITY_DESCRIPTOR, *PSECURITY_DESCRIPTOR;
2225
2226 #define SECURITY_DESCRIPTOR_MIN_LENGTH   (sizeof(SECURITY_DESCRIPTOR)) 
2227
2228 #include "poppack.h"
2229
2230 #endif /* _SECURITY_DEFINED */
2231
2232 #include "pshpack1.h"
2233
2234 /* 
2235  * SID_AND_ATTRIBUTES
2236  */
2237
2238 typedef struct _SID_AND_ATTRIBUTES {
2239   PSID  Sid; 
2240   DWORD Attributes; 
2241 } SID_AND_ATTRIBUTES ; 
2242  
2243 /* security entities */
2244 #define SECURITY_NULL_RID                       (0x00000000L)
2245 #define SECURITY_WORLD_RID                      (0x00000000L)
2246 #define SECURITY_LOCAL_RID                      (0X00000000L)
2247
2248 #define SECURITY_NULL_SID_AUTHORITY             {0,0,0,0,0,0}
2249
2250 /* S-1-1 */
2251 #define SECURITY_WORLD_SID_AUTHORITY            {0,0,0,0,0,1}
2252
2253 /* S-1-2 */
2254 #define SECURITY_LOCAL_SID_AUTHORITY            {0,0,0,0,0,2}
2255
2256 /* S-1-3 */
2257 #define SECURITY_CREATOR_SID_AUTHORITY          {0,0,0,0,0,3}
2258 #define SECURITY_CREATOR_OWNER_RID              (0x00000000L) 
2259 #define SECURITY_CREATOR_GROUP_RID              (0x00000001L)
2260 #define SECURITY_CREATOR_OWNER_SERVER_RID       (0x00000002L)
2261 #define SECURITY_CREATOR_GROUP_SERVER_RID       (0x00000003L)
2262
2263 /* S-1-4 */
2264 #define SECURITY_NON_UNIQUE_AUTHORITY           {0,0,0,0,0,4}
2265
2266 /* S-1-5 */
2267 #define SECURITY_NT_AUTHORITY                   {0,0,0,0,0,5} 
2268 #define SECURITY_DIALUP_RID                     0x00000001L
2269 #define SECURITY_NETWORK_RID                    0x00000002L
2270 #define SECURITY_BATCH_RID                      0x00000003L
2271 #define SECURITY_INTERACTIVE_RID                0x00000004L
2272 #define SECURITY_LOGON_IDS_RID                  0x00000005L
2273 #define SECURITY_SERVICE_RID                    0x00000006L
2274 #define SECURITY_ANONYMOUS_LOGON_RID            0x00000007L
2275 #define SECURITY_PROXY_RID                      0x00000008L
2276 #define SECURITY_ENTERPRISE_CONTROLLERS_RID     0x00000009L
2277 #define SECURITY_PRINCIPAL_SELF_RID             0x0000000AL
2278 #define SECURITY_AUTHENTICATED_USER_RID         0x0000000BL
2279 #define SECURITY_RESTRICTED_CODE_RID            0x0000000CL
2280 #define SECURITY_TERMINAL_SERVER_RID            0x0000000DL
2281 #define SECURITY_LOCAL_SYSTEM_RID               0x00000012L
2282 #define SECURITY_NT_NON_UNIQUE                  0x00000015L
2283 #define SECURITY_BUILTIN_DOMAIN_RID             0x00000020L
2284
2285 #define DOMAIN_GROUP_RID_ADMINS                 0x00000200L
2286 #define DOMAIN_GROUP_RID_USERS                  0x00000201L
2287 #define DOMAIN_GROUP_RID_GUESTS                 0x00000202L
2288
2289 #define DOMAIN_ALIAS_RID_ADMINS                 0x00000220L
2290 #define DOMAIN_ALIAS_RID_USERS                  0x00000221L
2291 #define DOMAIN_ALIAS_RID_GUESTS                 0x00000222L
2292
2293 #define SECURITY_SERVER_LOGON_RID               SECURITY_ENTERPRISE_CONTROLLERS_RID
2294
2295 #define SECURITY_LOGON_IDS_RID_COUNT            (3L)
2296
2297 /*
2298  * TOKEN_USER
2299  */
2300
2301 typedef struct _TOKEN_USER {
2302   SID_AND_ATTRIBUTES User; 
2303 } TOKEN_USER; 
2304
2305 /*
2306  * TOKEN_GROUPS
2307  */
2308
2309 typedef struct _TOKEN_GROUPS  {
2310   DWORD GroupCount; 
2311   SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY]; 
2312 } TOKEN_GROUPS; 
2313
2314 /*
2315  * LUID_AND_ATTRIBUTES
2316  */
2317
2318 typedef union _LARGE_INTEGER {
2319     struct {
2320         DWORD    LowPart;
2321         LONG     HighPart;
2322     } DUMMYSTRUCTNAME;
2323     LONGLONG QuadPart;
2324 } LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
2325
2326 typedef union _ULARGE_INTEGER {
2327     struct {
2328         DWORD    LowPart;
2329         DWORD    HighPart;
2330     } DUMMYSTRUCTNAME;
2331     ULONGLONG QuadPart;
2332 } ULARGE_INTEGER, *LPULARGE_INTEGER, *PULARGE_INTEGER;
2333
2334 /*
2335  * Locally Unique Identifier
2336  */
2337
2338 typedef LARGE_INTEGER LUID,*PLUID;
2339
2340 typedef struct _LUID_AND_ATTRIBUTES {
2341   LUID   Luid; 
2342   DWORD  Attributes; 
2343 } LUID_AND_ATTRIBUTES; 
2344
2345 /*
2346  * PRIVILEGE_SET
2347  */
2348
2349 typedef struct _PRIVILEGE_SET {
2350     DWORD PrivilegeCount;
2351     DWORD Control;
2352     LUID_AND_ATTRIBUTES Privilege[ANYSIZE_ARRAY];
2353 } PRIVILEGE_SET, *PPRIVILEGE_SET;
2354
2355 /*
2356  * TOKEN_PRIVILEGES
2357  */
2358
2359 typedef struct _TOKEN_PRIVILEGES {
2360   DWORD PrivilegeCount; 
2361   LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY]; 
2362 } TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES; 
2363
2364 /*
2365  * TOKEN_OWNER
2366  */
2367
2368 typedef struct _TOKEN_OWNER {
2369   PSID Owner; 
2370 } TOKEN_OWNER; 
2371
2372 /*
2373  * TOKEN_PRIMARY_GROUP
2374  */
2375
2376 typedef struct _TOKEN_PRIMARY_GROUP {
2377   PSID PrimaryGroup; 
2378 } TOKEN_PRIMARY_GROUP; 
2379
2380
2381 /*
2382  * TOKEN_DEFAULT_DACL
2383  */
2384
2385 typedef struct _TOKEN_DEFAULT_DACL { 
2386   PACL DefaultDacl; 
2387 } TOKEN_DEFAULT_DACL; 
2388
2389 /*
2390  * TOKEN_SOURCEL
2391  */
2392
2393 typedef struct _TOKEN_SOURCE {
2394   char Sourcename[8]; 
2395   LUID SourceIdentifier; 
2396 } TOKEN_SOURCE; 
2397
2398 /*
2399  * TOKEN_TYPE
2400  */
2401
2402 typedef enum tagTOKEN_TYPE {
2403   TokenPrimary = 1, 
2404   TokenImpersonation 
2405 } TOKEN_TYPE; 
2406
2407 /*
2408  * SECURITY_IMPERSONATION_LEVEL
2409  */
2410
2411 typedef enum _SECURITY_IMPERSONATION_LEVEL {
2412   SecurityAnonymous, 
2413   SecurityIdentification, 
2414   SecurityImpersonation, 
2415   SecurityDelegation 
2416 } SECURITY_IMPERSONATION_LEVEL, *PSECURITY_IMPERSONATION_LEVEL; 
2417
2418
2419 typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,
2420         * PSECURITY_CONTEXT_TRACKING_MODE;
2421 /*
2422  *      Quality of Service
2423  */
2424
2425 typedef struct _SECURITY_QUALITY_OF_SERVICE {
2426   DWORD                         Length;
2427   SECURITY_IMPERSONATION_LEVEL  ImpersonationLevel;
2428   SECURITY_CONTEXT_TRACKING_MODE ContextTrackingMode;
2429   BOOL                          EffectiveOnly;
2430 } SECURITY_QUALITY_OF_SERVICE, *PSECURITY_QUALITY_OF_SERVICE;
2431
2432 /*
2433  * TOKEN_STATISTICS
2434  */
2435
2436 typedef struct _TOKEN_STATISTICS {
2437   LUID  TokenId; 
2438   LUID  AuthenticationId; 
2439   LARGE_INTEGER ExpirationTime; 
2440   TOKEN_TYPE    TokenType; 
2441   SECURITY_IMPERSONATION_LEVEL ImpersonationLevel; 
2442   DWORD DynamicCharged; 
2443   DWORD DynamicAvailable; 
2444   DWORD GroupCount; 
2445   DWORD PrivilegeCount; 
2446   LUID  ModifiedId; 
2447 } TOKEN_STATISTICS; 
2448
2449 /* 
2450  *      ACLs of NT 
2451  */
2452
2453 #define ACL_REVISION    2
2454
2455 #define ACL_REVISION1   1
2456 #define ACL_REVISION2   2
2457
2458 /* ACEs, directly starting after an ACL */
2459 typedef struct _ACE_HEADER {
2460         BYTE    AceType;
2461         BYTE    AceFlags;
2462         WORD    AceSize;
2463 } ACE_HEADER,*PACE_HEADER;
2464
2465 /* AceType */
2466 #define ACCESS_ALLOWED_ACE_TYPE         0
2467 #define ACCESS_DENIED_ACE_TYPE          1
2468 #define SYSTEM_AUDIT_ACE_TYPE           2
2469 #define SYSTEM_ALARM_ACE_TYPE           3
2470
2471 /* inherit AceFlags */
2472 #define OBJECT_INHERIT_ACE              0x01
2473 #define CONTAINER_INHERIT_ACE           0x02
2474 #define NO_PROPAGATE_INHERIT_ACE        0x04
2475 #define INHERIT_ONLY_ACE                0x08
2476 #define VALID_INHERIT_FLAGS             0x0F
2477
2478 /* AceFlags mask for what events we (should) audit */
2479 #define SUCCESSFUL_ACCESS_ACE_FLAG      0x40
2480 #define FAILED_ACCESS_ACE_FLAG          0x80
2481
2482 /* different ACEs depending on AceType 
2483  * SidStart marks the begin of a SID
2484  * so the thing finally looks like this:
2485  * 0: ACE_HEADER
2486  * 4: ACCESS_MASK
2487  * 8... : SID
2488  */
2489 typedef struct _ACCESS_ALLOWED_ACE {
2490         ACE_HEADER      Header;
2491         DWORD           Mask;
2492         DWORD           SidStart;
2493 } ACCESS_ALLOWED_ACE,*PACCESS_ALLOWED_ACE;
2494
2495 typedef struct _ACCESS_DENIED_ACE {
2496         ACE_HEADER      Header;
2497         DWORD           Mask;
2498         DWORD           SidStart;
2499 } ACCESS_DENIED_ACE,*PACCESS_DENIED_ACE;
2500
2501 typedef struct _SYSTEM_AUDIT_ACE {
2502         ACE_HEADER      Header;
2503         DWORD           Mask;
2504         DWORD           SidStart;
2505 } SYSTEM_AUDIT_ACE,*PSYSTEM_AUDIT_ACE;
2506
2507 typedef struct _SYSTEM_ALARM_ACE {
2508         ACE_HEADER      Header;
2509         DWORD           Mask;
2510         DWORD           SidStart;
2511 } SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
2512
2513 typedef enum tagSID_NAME_USE {
2514         SidTypeUser = 1,
2515         SidTypeGroup,
2516         SidTypeDomain,
2517         SidTypeAlias,
2518         SidTypeWellKnownGroup,
2519         SidTypeDeletedAccount,
2520         SidTypeInvalid,
2521         SidTypeUnknown
2522 } SID_NAME_USE,*PSID_NAME_USE;
2523
2524 /* Access rights */
2525
2526 /* DELETE may be already defined via /usr/include/arpa/nameser_compat.h */
2527 #undef  DELETE
2528 #define DELETE                     0x00010000
2529 #define READ_CONTROL               0x00020000
2530 #define WRITE_DAC                  0x00040000
2531 #define WRITE_OWNER                0x00080000
2532 #define SYNCHRONIZE                0x00100000
2533 #define STANDARD_RIGHTS_REQUIRED   0x000f0000
2534
2535 #define STANDARD_RIGHTS_READ       READ_CONTROL
2536 #define STANDARD_RIGHTS_WRITE      READ_CONTROL
2537 #define STANDARD_RIGHTS_EXECUTE    READ_CONTROL
2538
2539 #define STANDARD_RIGHTS_ALL        0x001f0000
2540
2541 #define SPECIFIC_RIGHTS_ALL        0x0000ffff
2542
2543 #define GENERIC_READ               0x80000000
2544 #define GENERIC_WRITE              0x40000000
2545 #define GENERIC_EXECUTE            0x20000000
2546 #define GENERIC_ALL                0x10000000
2547
2548 #define MAXIMUM_ALLOWED            0x02000000
2549 #define ACCESS_SYSTEM_SECURITY     0x01000000
2550
2551 #define EVENT_MODIFY_STATE         0x0002
2552 #define EVENT_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
2553
2554 #define SEMAPHORE_MODIFY_STATE     0x0002
2555 #define SEMAPHORE_ALL_ACCESS       (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
2556
2557 #define MUTEX_MODIFY_STATE         0x0001
2558 #define MUTEX_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1)
2559
2560 #define TIMER_QUERY_STATE          0x0001
2561 #define TIMER_MODIFY_STATE         0x0002
2562 #define TIMER_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
2563
2564 #define PROCESS_TERMINATE          0x0001
2565 #define PROCESS_CREATE_THREAD      0x0002
2566 #define PROCESS_VM_OPERATION       0x0008
2567 #define PROCESS_VM_READ            0x0010
2568 #define PROCESS_VM_WRITE           0x0020
2569 #define PROCESS_DUP_HANDLE         0x0040
2570 #define PROCESS_CREATE_PROCESS     0x0080
2571 #define PROCESS_SET_QUOTA          0x0100
2572 #define PROCESS_SET_INFORMATION    0x0200
2573 #define PROCESS_QUERY_INFORMATION  0x0400
2574 #define PROCESS_ALL_ACCESS         (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xfff)
2575
2576 #define THREAD_TERMINATE           0x0001
2577 #define THREAD_SUSPEND_RESUME      0x0002
2578 #define THREAD_GET_CONTEXT         0x0008
2579 #define THREAD_SET_CONTEXT         0x0010
2580 #define THREAD_SET_INFORMATION     0x0020
2581 #define THREAD_QUERY_INFORMATION   0x0040
2582 #define THREAD_SET_THREAD_TOKEN    0x0080
2583 #define THREAD_IMPERSONATE         0x0100
2584 #define THREAD_DIRECT_IMPERSONATION 0x0200
2585 #define THREAD_ALL_ACCESS          (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3ff)
2586
2587 #define THREAD_BASE_PRIORITY_LOWRT  15 
2588 #define THREAD_BASE_PRIORITY_MAX    2 
2589 #define THREAD_BASE_PRIORITY_MIN   -2
2590 #define THREAD_BASE_PRIORITY_IDLE  -15
2591
2592 #define FILE_READ_DATA            0x0001    /* file & pipe */
2593 #define FILE_LIST_DIRECTORY       0x0001    /* directory */
2594 #define FILE_WRITE_DATA           0x0002    /* file & pipe */
2595 #define FILE_ADD_FILE             0x0002    /* directory */
2596 #define FILE_APPEND_DATA          0x0004    /* file */
2597 #define FILE_ADD_SUBDIRECTORY     0x0004    /* directory */
2598 #define FILE_CREATE_PIPE_INSTANCE 0x0004    /* named pipe */
2599 #define FILE_READ_EA              0x0008    /* file & directory */
2600 #define FILE_READ_PROPERTIES      FILE_READ_EA
2601 #define FILE_WRITE_EA             0x0010    /* file & directory */
2602 #define FILE_WRITE_PROPERTIES     FILE_WRITE_EA
2603 #define FILE_EXECUTE              0x0020    /* file */
2604 #define FILE_TRAVERSE             0x0020    /* directory */
2605 #define FILE_DELETE_CHILD         0x0040    /* directory */
2606 #define FILE_READ_ATTRIBUTES      0x0080    /* all */
2607 #define FILE_WRITE_ATTRIBUTES     0x0100    /* all */
2608 #define FILE_ALL_ACCESS           (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1ff)
2609
2610 #define FILE_GENERIC_READ         (STANDARD_RIGHTS_READ | FILE_READ_DATA | \
2611                                    FILE_READ_ATTRIBUTES | FILE_READ_EA | \
2612                                    SYNCHRONIZE)
2613 #define FILE_GENERIC_WRITE        (STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA | \
2614                                    FILE_WRITE_ATTRIBUTES | FILE_WRITE_EA | \
2615                                    FILE_APPEND_DATA | SYNCHRONIZE)
2616 #define FILE_GENERIC_EXECUTE      (STANDARD_RIGHTS_EXECUTE | FILE_EXECUTE | \
2617                                    FILE_READ_ATTRIBUTES | SYNCHRONIZE)
2618
2619
2620 /* File attribute flags */
2621 #define FILE_SHARE_READ                 0x00000001L
2622 #define FILE_SHARE_WRITE                0x00000002L
2623 #define FILE_SHARE_DELETE               0x00000004L
2624 #define FILE_ATTRIBUTE_READONLY         0x00000001L
2625 #define FILE_ATTRIBUTE_HIDDEN           0x00000002L
2626 #define FILE_ATTRIBUTE_SYSTEM           0x00000004L
2627 #define FILE_ATTRIBUTE_LABEL            0x00000008L  /* Not in Windows API */
2628 #define FILE_ATTRIBUTE_DIRECTORY        0x00000010L
2629 #define FILE_ATTRIBUTE_ARCHIVE          0x00000020L
2630 #define FILE_ATTRIBUTE_NORMAL           0x00000080L
2631 #define FILE_ATTRIBUTE_TEMPORARY        0x00000100L
2632 #define FILE_ATTRIBUTE_ATOMIC_WRITE     0x00000200L
2633 #define FILE_ATTRIBUTE_XACTION_WRITE    0x00000400L
2634 #define FILE_ATTRIBUTE_COMPRESSED       0x00000800L
2635 #define FILE_ATTRIBUTE_OFFLINE          0x00001000L
2636
2637 /* File notification flags */
2638 #define FILE_NOTIFY_CHANGE_FILE_NAME    0x00000001
2639 #define FILE_NOTIFY_CHANGE_DIR_NAME     0x00000002
2640 #define FILE_NOTIFY_CHANGE_ATTRIBUTES   0x00000004
2641 #define FILE_NOTIFY_CHANGE_SIZE         0x00000008
2642 #define FILE_NOTIFY_CHANGE_LAST_WRITE   0x00000010
2643 #define FILE_NOTIFY_CHANGE_LAST_ACCESS  0x00000020
2644 #define FILE_NOTIFY_CHANGE_CREATION     0x00000040
2645 #define FILE_NOTIFY_CHANGE_SECURITY     0x00000100
2646
2647 #define FILE_ACTION_ADDED               0x00000001
2648 #define FILE_ACTION_REMOVED             0x00000002
2649 #define FILE_ACTION_MODIFIED            0x00000003
2650 #define FILE_ACTION_RENAMED_OLD_NAME    0x00000004
2651 #define FILE_ACTION_RENAMED_NEW_NAME    0x00000005
2652
2653
2654 #define FILE_CASE_SENSITIVE_SEARCH      0x00000001
2655 #define FILE_CASE_PRESERVED_NAMES       0x00000002
2656 #define FILE_UNICODE_ON_DISK            0x00000004
2657 #define FILE_PERSISTENT_ACLS            0x00000008
2658 #define FILE_FILE_COMPRESSION           0x00000010
2659 #define FILE_VOLUME_IS_COMPRESSED       0x00008000
2660
2661 /* File alignments (NT) */
2662 #define FILE_BYTE_ALIGNMENT             0x00000000
2663 #define FILE_WORD_ALIGNMENT             0x00000001
2664 #define FILE_LONG_ALIGNMENT             0x00000003
2665 #define FILE_QUAD_ALIGNMENT             0x00000007
2666 #define FILE_OCTA_ALIGNMENT             0x0000000f
2667 #define FILE_32_BYTE_ALIGNMENT          0x0000001f
2668 #define FILE_64_BYTE_ALIGNMENT          0x0000003f
2669 #define FILE_128_BYTE_ALIGNMENT         0x0000007f
2670 #define FILE_256_BYTE_ALIGNMENT         0x000000ff
2671 #define FILE_512_BYTE_ALIGNMENT         0x000001ff
2672
2673 #define REG_NONE                0       /* no type */
2674 #define REG_SZ                  1       /* string type (ASCII) */
2675 #define REG_EXPAND_SZ           2       /* string, includes %ENVVAR% (expanded by caller) (ASCII) */
2676 #define REG_BINARY              3       /* binary format, callerspecific */
2677 /* YES, REG_DWORD == REG_DWORD_LITTLE_ENDIAN */
2678 #define REG_DWORD               4       /* DWORD in little endian format */
2679 #define REG_DWORD_LITTLE_ENDIAN 4       /* DWORD in little endian format */
2680 #define REG_DWORD_BIG_ENDIAN    5       /* DWORD in big endian format  */
2681 #define REG_LINK                6       /* symbolic link (UNICODE) */
2682 #define REG_MULTI_SZ            7       /* multiple strings, delimited by \0, terminated by \0\0 (ASCII) */
2683 #define REG_RESOURCE_LIST       8       /* resource list? huh? */
2684 #define REG_FULL_RESOURCE_DESCRIPTOR    9       /* full resource descriptor? huh? */
2685 #define REG_RESOURCE_REQUIREMENTS_LIST  10
2686
2687 /* ----------------------------- begin registry ----------------------------- */
2688
2689 /* Registry security values */
2690 #define OWNER_SECURITY_INFORMATION      0x00000001
2691 #define GROUP_SECURITY_INFORMATION      0x00000002
2692 #define DACL_SECURITY_INFORMATION       0x00000004
2693 #define SACL_SECURITY_INFORMATION       0x00000008
2694
2695 #define REG_OPTION_RESERVED             0x00000000
2696 #define REG_OPTION_NON_VOLATILE         0x00000000
2697 #define REG_OPTION_VOLATILE             0x00000001
2698 #define REG_OPTION_CREATE_LINK          0x00000002
2699 #define REG_OPTION_BACKUP_RESTORE       0x00000004 /* FIXME */
2700 #define REG_OPTION_OPEN_LINK            0x00000008
2701 #define REG_LEGAL_OPTION               (REG_OPTION_RESERVED|  \
2702                                         REG_OPTION_NON_VOLATILE|  \
2703                                         REG_OPTION_VOLATILE|  \
2704                                         REG_OPTION_CREATE_LINK|  \
2705                                         REG_OPTION_BACKUP_RESTORE|  \
2706                                         REG_OPTION_OPEN_LINK)
2707
2708
2709 #define REG_CREATED_NEW_KEY     0x00000001
2710 #define REG_OPENED_EXISTING_KEY 0x00000002
2711
2712 /* For RegNotifyChangeKeyValue */
2713 #define REG_NOTIFY_CHANGE_NAME  0x1
2714
2715 #define KEY_QUERY_VALUE         0x00000001
2716 #define KEY_SET_VALUE           0x00000002
2717 #define KEY_CREATE_SUB_KEY      0x00000004
2718 #define KEY_ENUMERATE_SUB_KEYS  0x00000008
2719 #define KEY_NOTIFY              0x00000010
2720 #define KEY_CREATE_LINK         0x00000020
2721
2722 #define KEY_READ              ((STANDARD_RIGHTS_READ|  \
2723                                 KEY_QUERY_VALUE|  \
2724                                 KEY_ENUMERATE_SUB_KEYS|  \
2725                                 KEY_NOTIFY)  \
2726                                 & (~SYNCHRONIZE)  \
2727                               )
2728 #define KEY_WRITE             ((STANDARD_RIGHTS_WRITE|  \
2729                                 KEY_SET_VALUE|  \
2730                                 KEY_CREATE_SUB_KEY)  \
2731                                 & (~SYNCHRONIZE)  \
2732                               )
2733 #define KEY_EXECUTE           ((KEY_READ)  \
2734                                 & (~SYNCHRONIZE))  \
2735                               )
2736 #define KEY_ALL_ACCESS        ((STANDARD_RIGHTS_ALL|  \
2737                                 KEY_QUERY_VALUE|  \
2738                                 KEY_SET_VALUE|  \
2739                                 KEY_CREATE_SUB_KEY|  \
2740                                 KEY_ENUMERATE_SUB_KEYS|  \
2741                                 KEY_NOTIFY|  \
2742                                 KEY_CREATE_LINK)  \
2743                                 & (~SYNCHRONIZE)  \
2744                               )
2745 /* ------------------------------ end registry ------------------------------ */
2746
2747
2748 typedef struct _RTL_CRITICAL_SECTION_DEBUG 
2749 {
2750   WORD   Type;
2751   WORD   CreatorBackTraceIndex;
2752   struct _RTL_CRITICAL_SECTION *CriticalSection;
2753   LIST_ENTRY ProcessLocksList;
2754   DWORD EntryCount;
2755   DWORD ContentionCount;
2756   DWORD Spare[ 2 ];
2757 } RTL_CRITICAL_SECTION_DEBUG, *PRTL_CRITICAL_SECTION_DEBUG, RTL_RESOURCE_DEBUG, *PRTL_RESOURCE_DEBUG;
2758
2759 typedef struct _RTL_CRITICAL_SECTION {
2760     PRTL_CRITICAL_SECTION_DEBUG DebugInfo;
2761     LONG LockCount;
2762     LONG RecursionCount;
2763     HANDLE OwningThread;
2764     HANDLE LockSemaphore;
2765     ULONG_PTR SpinCount;
2766 } RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION;
2767
2768
2769 #define EVENTLOG_SUCCESS                0x0000
2770 #define EVENTLOG_ERROR_TYPE             0x0001
2771 #define EVENTLOG_WARNING_TYPE           0x0002
2772 #define EVENTLOG_INFORMATION_TYPE       0x0004
2773 #define EVENTLOG_AUDIT_SUCCESS          0x0008
2774 #define EVENTLOG_AUDIT_FAILURE          0x0010
2775
2776 #define SERVICE_BOOT_START   0x00000000
2777 #define SERVICE_SYSTEM_START 0x00000001
2778 #define SERVICE_AUTO_START   0x00000002
2779 #define SERVICE_DEMAND_START 0x00000003
2780 #define SERVICE_DISABLED     0x00000004
2781
2782 #define SERVICE_ERROR_IGNORE   0x00000000
2783 #define SERVICE_ERROR_NORMAL   0x00000001
2784 #define SERVICE_ERROR_SEVERE   0x00000002
2785 #define SERVICE_ERROR_CRITICAL 0x00000003
2786
2787 /* Service types */
2788 #define SERVICE_KERNEL_DRIVER      0x00000001
2789 #define SERVICE_FILE_SYSTEM_DRIVER 0x00000002
2790 #define SERVICE_ADAPTER            0x00000004
2791 #define SERVICE_RECOGNIZER_DRIVER  0x00000008
2792
2793 #define SERVICE_DRIVER ( SERVICE_KERNEL_DRIVER | SERVICE_FILE_SYSTEM_DRIVER | \
2794                          SERVICE_RECOGNIZER_DRIVER )
2795
2796 #define SERVICE_WIN32_OWN_PROCESS   0x00000010
2797 #define SERVICE_WIN32_SHARE_PROCESS 0x00000020
2798 #define SERVICE_WIN32  (SERVICE_WIN32_OWN_PROCESS | SERVICE_WIN32_SHARE_PROCESS)
2799
2800 #define SERVICE_INTERACTIVE_PROCESS 0x00000100
2801
2802 #define SERVICE_TYPE_ALL ( SERVICE_WIN32 | SERVICE_ADAPTER | \
2803                            SERVICE_DRIVER | SERVICE_INTERACTIVE_PROCESS )
2804
2805
2806 typedef enum _CM_SERVICE_NODE_TYPE 
2807 {
2808   DriverType               = SERVICE_KERNEL_DRIVER,
2809   FileSystemType           = SERVICE_FILE_SYSTEM_DRIVER,
2810   Win32ServiceOwnProcess   = SERVICE_WIN32_OWN_PROCESS,
2811   Win32ServiceShareProcess = SERVICE_WIN32_SHARE_PROCESS,
2812   AdapterType              = SERVICE_ADAPTER,
2813   RecognizerType           = SERVICE_RECOGNIZER_DRIVER
2814 } SERVICE_NODE_TYPE;
2815
2816 typedef enum _CM_SERVICE_LOAD_TYPE 
2817 {
2818   BootLoad    = SERVICE_BOOT_START,
2819   SystemLoad  = SERVICE_SYSTEM_START,
2820   AutoLoad    = SERVICE_AUTO_START,
2821   DemandLoad  = SERVICE_DEMAND_START,
2822   DisableLoad = SERVICE_DISABLED
2823 } SERVICE_LOAD_TYPE;
2824
2825 typedef enum _CM_ERROR_CONTROL_TYPE 
2826 {
2827   IgnoreError   = SERVICE_ERROR_IGNORE,
2828   NormalError   = SERVICE_ERROR_NORMAL,
2829   SevereError   = SERVICE_ERROR_SEVERE,
2830   CriticalError = SERVICE_ERROR_CRITICAL
2831 } SERVICE_ERROR_TYPE;
2832
2833
2834
2835 #define RtlEqualMemory(Destination, Source, Length) (!memcmp((Destination),(Source),(Length)))
2836 #define RtlMoveMemory(Destination, Source, Length) memmove((Destination),(Source),(Length))
2837 #define RtlCopyMemory(Destination, Source, Length) memcpy((Destination),(Source),(Length))
2838 #define RtlFillMemory(Destination, Length, Fill) memset((Destination),(Fill),(Length))
2839 #define RtlZeroMemory(Destination, Length) memset((Destination),0,(Length))
2840
2841 #include "poppack.h"
2842
2843 #endif  /* __WINE_WINNT_H */