source: trunk/include/win/winnt.h@ 2015

Last change on this file since 2015 was 1927, checked in by sandervl, 26 years ago

LARGE_INTEGER change

File size: 38.1 KB
Line 
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 "windef.h"
11
12#include "pshpack1.h"
13/* Defines */
14
15/* Argument 1 passed to the DllEntryProc. */
16#define DLL_PROCESS_DETACH 0 /* detach process (unload library) */
17#define DLL_PROCESS_ATTACH 1 /* attach process (load library) */
18#define DLL_THREAD_ATTACH 2 /* attach new thread */
19#define DLL_THREAD_DETACH 3 /* detach thread */
20
21
22/* u.x.wProcessorArchitecture (NT) */
23#define PROCESSOR_ARCHITECTURE_INTEL 0
24#define PROCESSOR_ARCHITECTURE_MIPS 1
25#define PROCESSOR_ARCHITECTURE_ALPHA 2
26#define PROCESSOR_ARCHITECTURE_PPC 3
27#define PROCESSOR_ARCHITECTURE_SHX 4
28#define PROCESSOR_ARCHITECTURE_ARM 5
29#define PROCESSOR_ARCHITECTURE_UNKNOWN 0xFFFF
30
31/* dwProcessorType */
32#define PROCESSOR_INTEL_386 386
33#define PROCESSOR_INTEL_486 486
34#define PROCESSOR_INTEL_PENTIUM 586
35#define PROCESSOR_INTEL_860 860
36#define PROCESSOR_MIPS_R2000 2000
37#define PROCESSOR_MIPS_R3000 3000
38#define PROCESSOR_MIPS_R4000 4000
39#define PROCESSOR_ALPHA_21064 21064
40#define PROCESSOR_PPC_601 601
41#define PROCESSOR_PPC_603 603
42#define PROCESSOR_PPC_604 604
43#define PROCESSOR_PPC_620 620
44#define PROCESSOR_HITACHI_SH3 10003
45#define PROCESSOR_HITACHI_SH3E 10004
46#define PROCESSOR_HITACHI_SH4 10005
47#define PROCESSOR_MOTOROLA_821 821
48#define PROCESSOR_SHx_SH3 103
49#define PROCESSOR_SHx_SH4 104
50#define PROCESSOR_STRONGARM 2577
51#define PROCESSOR_ARM720 1824 /* 0x720 */
52#define PROCESSOR_ARM820 2080 /* 0x820 */
53#define PROCESSOR_ARM920 2336 /* 0x920 */
54#define PROCESSOR_ARM_7TDMI 70001
55
56#define ANYSIZE_ARRAY 1
57
58#define MINCHAR 0x80
59#define MAXCHAR 0x7f
60#define MINSHORT 0x8000
61#define MAXSHORT 0x7fff
62#define MINLONG 0x80000000
63#define MAXLONG 0x7fffffff
64#define MAXBYTE 0xff
65#define MAXWORD 0xffff
66#define MAXDWORD 0xffffffff
67
68#define FIELD_OFFSET(type, field) \
69 ((LONG)(INT)&(((type *)0)->field))
70
71#define CONTAINING_RECORD(address, type, field) \
72 ((type *)((PCHAR)(address) - (PCHAR)(&((type *)0)->field)))
73
74/* Types */
75
76/* TCHAR data types definitions for Winelib. */
77/* These types are _not_ defined for the emulator, because they */
78/* depend on the UNICODE macro that only exists in user's code. */
79
80#ifndef __WINE__
81# ifdef UNICODE
82typedef LPWSTR LPTSTR;
83typedef LPCWSTR LPCTSTR;
84#define __TEXT(string) L##string /*probably wrong */
85# else /* UNICODE */
86typedef LPSTR LPTSTR;
87typedef LPCSTR LPCTSTR;
88#define __TEXT(string) string
89# endif /* UNICODE */
90#endif /* __WINE__ */
91#define TEXT(quote) __TEXT(quote)
92
93typedef BYTE BOOLEAN;
94typedef BOOLEAN *PBOOLEAN;
95
96typedef struct _LIST_ENTRY {
97 struct _LIST_ENTRY *Flink;
98 struct _LIST_ENTRY *Blink;
99} LIST_ENTRY, *PLIST_ENTRY;
100
101typedef struct _SINGLE_LIST_ENTRY {
102 struct _SINGLE_LIST_ENTRY *Next;
103} SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
104
105/* Heap flags */
106
107#define HEAP_NO_SERIALIZE 0x00000001
108#define HEAP_GROWABLE 0x00000002
109#define HEAP_GENERATE_EXCEPTIONS 0x00000004
110#define HEAP_ZERO_MEMORY 0x00000008
111#define HEAP_REALLOC_IN_PLACE_ONLY 0x00000010
112#define HEAP_TAIL_CHECKING_ENABLED 0x00000020
113#define HEAP_FREE_CHECKING_ENABLED 0x00000040
114#define HEAP_DISABLE_COALESCE_ON_FREE 0x00000080
115#define HEAP_CREATE_ALIGN_16 0x00010000
116#define HEAP_CREATE_ENABLE_TRACING 0x00020000
117#define HEAP_WINE_SEGPTR 0x01000000 /* Not a Win32 flag */
118#define HEAP_WINE_CODESEG 0x02000000 /* Not a Win32 flag */
119#define HEAP_WINE_CODE16SEG 0x04000000 /* Not a Win32 flag */
120
121/* Processor feature flags. */
122#define PF_FLOATING_POINT_PRECISION_ERRATA 0
123#define PF_FLOATING_POINT_EMULATED 1
124#define PF_COMPARE_EXCHANGE_DOUBLE 2
125#define PF_MMX_INSTRUCTIONS_AVAILABLE 3
126#define PF_PPC_MOVEMEM_64BIT_OK 4
127#define PF_ALPHA_BYTE_INSTRUCTIONS 5
128
129
130/* The Win32 register context */
131
132/* CONTEXT is the CPU-dependent context; it should be used */
133/* wherever a platform-specific context is needed (e.g. exception */
134/* handling, Win32 register functions). */
135
136/* CONTEXT86 is the i386-specific context; it should be used */
137/* wherever only a 386 context makes sense (e.g. DOS interrupts, */
138/* Win16 register functions), so that this code can be compiled */
139/* on all platforms. */
140
141#define SIZE_OF_80387_REGISTERS 80
142
143typedef struct _FLOATING_SAVE_AREA
144{
145 DWORD ControlWord;
146 DWORD StatusWord;
147 DWORD TagWord;
148 DWORD ErrorOffset;
149 DWORD ErrorSelector;
150 DWORD DataOffset;
151 DWORD DataSelector;
152 BYTE RegisterArea[SIZE_OF_80387_REGISTERS];
153 DWORD Cr0NpxState;
154} FLOATING_SAVE_AREA, *PFLOATING_SAVE_AREA;
155
156typedef struct _CONTEXT86
157{
158 DWORD ContextFlags;
159
160 /* These are selected by CONTEXT_DEBUG_REGISTERS */
161 DWORD Dr0;
162 DWORD Dr1;
163 DWORD Dr2;
164 DWORD Dr3;
165 DWORD Dr6;
166 DWORD Dr7;
167
168 /* These are selected by CONTEXT_FLOATING_POINT */
169 FLOATING_SAVE_AREA FloatSave;
170
171 /* These are selected by CONTEXT_SEGMENTS */
172 DWORD SegGs;
173 DWORD SegFs;
174 DWORD SegEs;
175 DWORD SegDs;
176
177 /* These are selected by CONTEXT_INTEGER */
178 DWORD Edi;
179 DWORD Esi;
180 DWORD Ebx;
181 DWORD Edx;
182 DWORD Ecx;
183 DWORD Eax;
184
185 /* These are selected by CONTEXT_CONTROL */
186 DWORD Ebp;
187 DWORD Eip;
188 DWORD SegCs;
189 DWORD EFlags;
190 DWORD Esp;
191 DWORD SegSs;
192} CONTEXT86;
193
194#define CONTEXT_X86 0x00010000
195#define CONTEXT_i386 CONTEXT_X86
196#define CONTEXT_i486 CONTEXT_X86
197
198#define CONTEXT86_CONTROL (CONTEXT_i386 | 0x0001) /* SS:SP, CS:IP, FLAGS, BP */
199#define CONTEXT86_INTEGER (CONTEXT_i386 | 0x0002) /* AX, BX, CX, DX, SI, DI */
200#define CONTEXT86_SEGMENTS (CONTEXT_i386 | 0x0004) /* DS, ES, FS, GS */
201#define CONTEXT86_FLOATING_POINT (CONTEXT_i386 | 0x0008L) /* 387 state */
202#define CONTEXT86_DEBUG_REGISTERS (CONTEXT_i386 | 0x0010L) /* DB 0-3,6,7 */
203#define CONTEXT86_FULL (CONTEXT86_CONTROL | CONTEXT86_INTEGER | CONTEXT86_SEGMENTS)
204
205/* i386 context definitions */
206#ifdef __i386__
207
208#define CONTEXT_CONTROL CONTEXT86_CONTROL
209#define CONTEXT_INTEGER CONTEXT86_INTEGER
210#define CONTEXT_SEGMENTS CONTEXT86_SEGMENTS
211#define CONTEXT_FLOATING_POINT CONTEXT86_FLOATING_POINT
212#define CONTEXT_DEBUG_REGISTERS CONTEXT86_DEBUG_REGISTERS
213#define CONTEXT_FULL CONTEXT86_FULL
214
215typedef CONTEXT86 CONTEXT;
216
217#endif /* __i386__ */
218
219/* Alpha context definitions */
220#ifdef _ALPHA_
221
222#define CONTEXT_ALPHA 0x00020000
223
224#define CONTEXT_CONTROL (CONTEXT_ALPHA | 0x00000001L)
225#define CONTEXT_FLOATING_POINT (CONTEXT_ALPHA | 0x00000002L)
226#define CONTEXT_INTEGER (CONTEXT_ALPHA | 0x00000004L)
227#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
228
229typedef struct _CONTEXT
230{
231 /* selected by CONTEXT_FLOATING_POINT */
232 ULONGLONG FltF0;
233 ULONGLONG FltF1;
234 ULONGLONG FltF2;
235 ULONGLONG FltF3;
236 ULONGLONG FltF4;
237 ULONGLONG FltF5;
238 ULONGLONG FltF6;
239 ULONGLONG FltF7;
240 ULONGLONG FltF8;
241 ULONGLONG FltF9;
242 ULONGLONG FltF10;
243 ULONGLONG FltF11;
244 ULONGLONG FltF12;
245 ULONGLONG FltF13;
246 ULONGLONG FltF14;
247 ULONGLONG FltF15;
248 ULONGLONG FltF16;
249 ULONGLONG FltF17;
250 ULONGLONG FltF18;
251 ULONGLONG FltF19;
252 ULONGLONG FltF20;
253 ULONGLONG FltF21;
254 ULONGLONG FltF22;
255 ULONGLONG FltF23;
256 ULONGLONG FltF24;
257 ULONGLONG FltF25;
258 ULONGLONG FltF26;
259 ULONGLONG FltF27;
260 ULONGLONG FltF28;
261 ULONGLONG FltF29;
262 ULONGLONG FltF30;
263 ULONGLONG FltF31;
264
265 /* selected by CONTEXT_INTEGER */
266 ULONGLONG IntV0;
267 ULONGLONG IntT0;
268 ULONGLONG IntT1;
269 ULONGLONG IntT2;
270 ULONGLONG IntT3;
271 ULONGLONG IntT4;
272 ULONGLONG IntT5;
273 ULONGLONG IntT6;
274 ULONGLONG IntT7;
275 ULONGLONG IntS0;
276 ULONGLONG IntS1;
277 ULONGLONG IntS2;
278 ULONGLONG IntS3;
279 ULONGLONG IntS4;
280 ULONGLONG IntS5;
281 ULONGLONG IntFp;
282 ULONGLONG IntA0;
283 ULONGLONG IntA1;
284 ULONGLONG IntA2;
285 ULONGLONG IntA3;
286 ULONGLONG IntA4;
287 ULONGLONG IntA5;
288 ULONGLONG IntT8;
289 ULONGLONG IntT9;
290 ULONGLONG IntT10;
291 ULONGLONG IntT11;
292 ULONGLONG IntRa;
293 ULONGLONG IntT12;
294 ULONGLONG IntAt;
295 ULONGLONG IntGp;
296 ULONGLONG IntSp;
297 ULONGLONG IntZero;
298
299 /* selected by CONTEXT_FLOATING_POINT */
300 ULONGLONG Fpcr;
301 ULONGLONG SoftFpcr;
302
303 /* selected by CONTEXT_CONTROL */
304 ULONGLONG Fir;
305 DWORD Psr;
306 DWORD ContextFlags;
307 DWORD Fill[4];
308} CONTEXT;
309
310#define _QUAD_PSR_OFFSET HighSoftFpcr
311#define _QUAD_FLAGS_OFFSET HighFir
312
313#endif /* _ALPHA_ */
314
315/* Mips context definitions */
316#ifdef _MIPS_
317
318#define CONTEXT_R4000 0x00010000
319
320#define CONTEXT_CONTROL (CONTEXT_R4000 | 0x00000001)
321#define CONTEXT_FLOATING_POINT (CONTEXT_R4000 | 0x00000002)
322#define CONTEXT_INTEGER (CONTEXT_R4000 | 0x00000004)
323
324#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
325
326typedef struct _CONTEXT
327{
328 DWORD Argument[4];
329 /* These are selected by CONTEXT_FLOATING_POINT */
330 DWORD FltF0;
331 DWORD FltF1;
332 DWORD FltF2;
333 DWORD FltF3;
334 DWORD FltF4;
335 DWORD FltF5;
336 DWORD FltF6;
337 DWORD FltF7;
338 DWORD FltF8;
339 DWORD FltF9;
340 DWORD FltF10;
341 DWORD FltF11;
342 DWORD FltF12;
343 DWORD FltF13;
344 DWORD FltF14;
345 DWORD FltF15;
346 DWORD FltF16;
347 DWORD FltF17;
348 DWORD FltF18;
349 DWORD FltF19;
350 DWORD FltF20;
351 DWORD FltF21;
352 DWORD FltF22;
353 DWORD FltF23;
354 DWORD FltF24;
355 DWORD FltF25;
356 DWORD FltF26;
357 DWORD FltF27;
358 DWORD FltF28;
359 DWORD FltF29;
360 DWORD FltF30;
361 DWORD FltF31;
362
363 /* These are selected by CONTEXT_INTEGER */
364 DWORD IntZero;
365 DWORD IntAt;
366 DWORD IntV0;
367 DWORD IntV1;
368 DWORD IntA0;
369 DWORD IntA1;
370 DWORD IntA2;
371 DWORD IntA3;
372 DWORD IntT0;
373 DWORD IntT1;
374 DWORD IntT2;
375 DWORD IntT3;
376 DWORD IntT4;
377 DWORD IntT5;
378 DWORD IntT6;
379 DWORD IntT7;
380 DWORD IntS0;
381 DWORD IntS1;
382 DWORD IntS2;
383 DWORD IntS3;
384 DWORD IntS4;
385 DWORD IntS5;
386 DWORD IntS6;
387 DWORD IntS7;
388 DWORD IntT8;
389 DWORD IntT9;
390 DWORD IntK0;
391 DWORD IntK1;
392 DWORD IntGp;
393 DWORD IntSp;
394 DWORD IntS8;
395 DWORD IntRa;
396 DWORD IntLo;
397 DWORD IntHi;
398
399 /* These are selected by CONTEXT_FLOATING_POINT */
400 DWORD Fsr;
401
402 /* These are selected by CONTEXT_CONTROL */
403 DWORD Fir;
404 DWORD Psr;
405
406 DWORD ContextFlags;
407 DWORD Fill[2];
408} CONTEXT;
409
410#endif /* _MIPS_ */
411
412/* PowerPC context definitions */
413#ifdef __PPC__
414
415#define CONTEXT_CONTROL 0x0001
416#define CONTEXT_FLOATING_POINT 0x0002
417#define CONTEXT_INTEGER 0x0004
418#define CONTEXT_DEBUG_REGISTERS 0x0008
419#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
420
421typedef struct
422{
423 /* These are selected by CONTEXT_FLOATING_POINT */
424 double Fpr0;
425 double Fpr1;
426 double Fpr2;
427 double Fpr3;
428 double Fpr4;
429 double Fpr5;
430 double Fpr6;
431 double Fpr7;
432 double Fpr8;
433 double Fpr9;
434 double Fpr10;
435 double Fpr11;
436 double Fpr12;
437 double Fpr13;
438 double Fpr14;
439 double Fpr15;
440 double Fpr16;
441 double Fpr17;
442 double Fpr18;
443 double Fpr19;
444 double Fpr20;
445 double Fpr21;
446 double Fpr22;
447 double Fpr23;
448 double Fpr24;
449 double Fpr25;
450 double Fpr26;
451 double Fpr27;
452 double Fpr28;
453 double Fpr29;
454 double Fpr30;
455 double Fpr31;
456 double Fpscr;
457
458 /* These are selected by CONTEXT_INTEGER */
459 DWORD Gpr0;
460 DWORD Gpr1;
461 DWORD Gpr2;
462 DWORD Gpr3;
463 DWORD Gpr4;
464 DWORD Gpr5;
465 DWORD Gpr6;
466 DWORD Gpr7;
467 DWORD Gpr8;
468 DWORD Gpr9;
469 DWORD Gpr10;
470 DWORD Gpr11;
471 DWORD Gpr12;
472 DWORD Gpr13;
473 DWORD Gpr14;
474 DWORD Gpr15;
475 DWORD Gpr16;
476 DWORD Gpr17;
477 DWORD Gpr18;
478 DWORD Gpr19;
479 DWORD Gpr20;
480 DWORD Gpr21;
481 DWORD Gpr22;
482 DWORD Gpr23;
483 DWORD Gpr24;
484 DWORD Gpr25;
485 DWORD Gpr26;
486 DWORD Gpr27;
487 DWORD Gpr28;
488 DWORD Gpr29;
489 DWORD Gpr30;
490 DWORD Gpr31;
491
492 DWORD Cr;
493 DWORD Xer;
494
495 /* These are selected by CONTEXT_CONTROL */
496 DWORD Msr;
497 DWORD Iar;
498 DWORD Lr;
499 DWORD Ctr;
500
501 DWORD ContextFlags;
502 DWORD Fill[3];
503
504 /* These are selected by CONTEXT_DEBUG_REGISTERS */
505 DWORD Dr0;
506 DWORD Dr1;
507 DWORD Dr2;
508 DWORD Dr3;
509 DWORD Dr4;
510 DWORD Dr5;
511 DWORD Dr6;
512 DWORD Dr7;
513} CONTEXT;
514
515typedef struct _STACK_FRAME_HEADER
516{
517 DWORD BackChain;
518 DWORD GlueSaved1;
519 DWORD GlueSaved2;
520 DWORD Reserved1;
521 DWORD Spare1;
522 DWORD Spare2;
523
524 DWORD Parameter0;
525 DWORD Parameter1;
526 DWORD Parameter2;
527 DWORD Parameter3;
528 DWORD Parameter4;
529 DWORD Parameter5;
530 DWORD Parameter6;
531 DWORD Parameter7;
532} STACK_FRAME_HEADER,*PSTACK_FRAME_HEADER;
533
534#endif /* __PPC__ */
535
536#ifdef __sparc__
537
538/*
539 * FIXME:
540 *
541 * There is no official CONTEXT structure defined for the SPARC
542 * architecture, so I just made one up.
543 *
544 * This structure is valid only for 32-bit SPARC architectures,
545 * not for 64-bit SPARC.
546 *
547 * Note that this structure contains only the 'top-level' registers;
548 * the rest of the register window chain is not visible.
549 *
550 * The layout follows the Solaris 'prgregset_t' structure.
551 *
552 */
553
554#define CONTEXT_SPARC 0x10000000
555
556#define CONTEXT_CONTROL (CONTEXT_SPARC | 0x00000001)
557#define CONTEXT_FLOATING_POINT (CONTEXT_SPARC | 0x00000002)
558#define CONTEXT_INTEGER (CONTEXT_SPARC | 0x00000004)
559
560#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER)
561
562typedef struct _CONTEXT
563{
564 DWORD ContextFlags;
565
566 /* These are selected by CONTEXT_INTEGER */
567 DWORD g0;
568 DWORD g1;
569 DWORD g2;
570 DWORD g3;
571 DWORD g4;
572 DWORD g5;
573 DWORD g6;
574 DWORD g7;
575 DWORD o0;
576 DWORD o1;
577 DWORD o2;
578 DWORD o3;
579 DWORD o4;
580 DWORD o5;
581 DWORD o6;
582 DWORD o7;
583 DWORD l0;
584 DWORD l1;
585 DWORD l2;
586 DWORD l3;
587 DWORD l4;
588 DWORD l5;
589 DWORD l6;
590 DWORD l7;
591 DWORD i0;
592 DWORD i1;
593 DWORD i2;
594 DWORD i3;
595 DWORD i4;
596 DWORD i5;
597 DWORD i6;
598 DWORD i7;
599
600 /* These are selected by CONTEXT_CONTROL */
601 DWORD psr;
602 DWORD pc;
603 DWORD npc;
604 DWORD y;
605 DWORD wim;
606 DWORD tbr;
607
608 /* FIXME: floating point registers missing */
609
610} CONTEXT;
611
612#endif
613
614#if !defined(CONTEXT_FULL) && !defined(RC_INVOKED)
615#error You need to define a CONTEXT for your CPU
616#endif
617
618typedef CONTEXT *PCONTEXT;
619typedef HANDLE *PHANDLE;
620
621#ifdef __WINE__
622
623/* Macros for easier access to i386 context registers */
624
625#define EAX_reg(context) ((context)->Eax)
626#define EBX_reg(context) ((context)->Ebx)
627#define ECX_reg(context) ((context)->Ecx)
628#define EDX_reg(context) ((context)->Edx)
629#define ESI_reg(context) ((context)->Esi)
630#define EDI_reg(context) ((context)->Edi)
631#define EBP_reg(context) ((context)->Ebp)
632
633#define CS_reg(context) ((context)->SegCs)
634#define DS_reg(context) ((context)->SegDs)
635#define ES_reg(context) ((context)->SegEs)
636#define FS_reg(context) ((context)->SegFs)
637#define GS_reg(context) ((context)->SegGs)
638#define SS_reg(context) ((context)->SegSs)
639
640#define EFL_reg(context) ((context)->EFlags)
641#define EIP_reg(context) ((context)->Eip)
642#define ESP_reg(context) ((context)->Esp)
643
644#define AX_reg(context) (*(WORD*)&EAX_reg(context))
645#define BX_reg(context) (*(WORD*)&EBX_reg(context))
646#define CX_reg(context) (*(WORD*)&ECX_reg(context))
647#define DX_reg(context) (*(WORD*)&EDX_reg(context))
648#define SI_reg(context) (*(WORD*)&ESI_reg(context))
649#define DI_reg(context) (*(WORD*)&EDI_reg(context))
650#define BP_reg(context) (*(WORD*)&EBP_reg(context))
651
652#define AL_reg(context) (*(BYTE*)&EAX_reg(context))
653#define AH_reg(context) (*((BYTE*)&EAX_reg(context)+1))
654#define BL_reg(context) (*(BYTE*)&EBX_reg(context))
655#define BH_reg(context) (*((BYTE*)&EBX_reg(context)+1))
656#define CL_reg(context) (*(BYTE*)&ECX_reg(context))
657#define CH_reg(context) (*((BYTE*)&ECX_reg(context)+1))
658#define DL_reg(context) (*(BYTE*)&EDX_reg(context))
659#define DH_reg(context) (*((BYTE*)&EDX_reg(context)+1))
660
661#define SET_CFLAG(context) (EFL_reg(context) |= 0x0001)
662#define RESET_CFLAG(context) (EFL_reg(context) &= ~0x0001)
663#define SET_ZFLAG(context) (EFL_reg(context) |= 0x0040)
664#define RESET_ZFLAG(context) (EFL_reg(context) &= ~0x0040)
665
666#define ISV86(context) (EFL_reg(context) & 0x00020000)
667#define V86BASE(context) ((context)->Dr7) /* ugly */
668
669
670/* Macros to retrieve the current context */
671
672#ifdef __i386__
673#define _DEFINE_REGS_ENTRYPOINT( name, fn, args ) \
674 __asm__(".align 4\n\t" \
675 ".globl " #name "\n\t" \
676 ".type " #name ",@function\n\t" \
677 #name ":\n\t" \
678 "call CALL32_Regs\n\t" \
679 ".long " #fn "\n\t" \
680 ".byte " #args ", " #args "\n\t");
681
682#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
683 _DEFINE_REGS_ENTRYPOINT( name, fn, 0 )
684#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
685 _DEFINE_REGS_ENTRYPOINT( name, fn, 4 )
686#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
687 _DEFINE_REGS_ENTRYPOINT( name, fn, 8 )
688#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
689 _DEFINE_REGS_ENTRYPOINT( name, fn, 12 )
690#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
691 _DEFINE_REGS_ENTRYPOINT( name, fn, 16 )
692
693#endif /* __i386__ */
694
695#ifdef __sparc__
696/* FIXME: use getcontext() to retrieve full context */
697#define _GET_CONTEXT \
698 CONTEXT context; \
699 do { memset(&context, 0, sizeof(CONTEXT)); \
700 context.ContextFlags = CONTEXT_CONTROL; \
701 context.pc = (DWORD)__builtin_return_address(0); \
702 } while (0)
703
704#define DEFINE_REGS_ENTRYPOINT_0( name, fn ) \
705 void WINAPI name ( void ) \
706 { _GET_CONTEXT; fn( &context ); }
707#define DEFINE_REGS_ENTRYPOINT_1( name, fn, t1 ) \
708 void WINAPI name ( t1 a1 ) \
709 { _GET_CONTEXT; fn( a1, &context ); }
710#define DEFINE_REGS_ENTRYPOINT_2( name, fn, t1, t2 ) \
711 void WINAPI name ( t1 a1, t2 a2 ) \
712 { _GET_CONTEXT; fn( a1, a2, &context ); }
713#define DEFINE_REGS_ENTRYPOINT_3( name, fn, t1, t2, t3 ) \
714 void WINAPI name ( t1 a1, t2 a2, t3 a3 ) \
715 { _GET_CONTEXT; fn( a1, a2, a3, &context ); }
716#define DEFINE_REGS_ENTRYPOINT_4( name, fn, t1, t2, t3, t4 ) \
717 void WINAPI name ( t1 a1, t2 a2, t3 a3, t4 a4 ) \
718 { _GET_CONTEXT; fn( a1, a2, a3, a4, &context ); }
719
720#endif /* __sparc__ */
721
722#ifndef DEFINE_REGS_ENTRYPOINT_0
723#error You need to define DEFINE_REGS_ENTRYPOINT macros for your CPU
724#endif
725
726#ifdef __i386__
727# define GET_IP(context) ((LPVOID)(context)->Eip)
728#endif
729#ifdef __sparc__
730# define GET_IP(context) ((LPVOID)(context)->pc)
731#endif
732
733#if !defined(GET_IP) && !defined(RC_INVOKED)
734# error You must define GET_IP for this CPU
735#endif
736
737#endif /* __WINE__ */
738
739/*
740 * Exception codes
741 */
742
743#define STATUS_SUCCESS 0x00000000
744#define STATUS_WAIT_0 0x00000000
745#define STATUS_ABANDONED_WAIT_0 0x00000080
746#define STATUS_USER_APC 0x000000C0
747#define STATUS_TIMEOUT 0x00000102
748#define STATUS_PENDING 0x00000103
749#define STATUS_GUARD_PAGE_VIOLATION 0x80000001
750#define STATUS_DATATYPE_MISALIGNMENT 0x80000002
751#define STATUS_BREAKPOINT 0x80000003
752#define STATUS_SINGLE_STEP 0x80000004
753#define STATUS_BUFFER_OVERFLOW 0x80000005
754#define STATUS_UNSUCCESSFUL 0xC0000001
755#define STATUS_ACCESS_VIOLATION 0xC0000005
756#define STATUS_IN_PAGE_ERROR 0xC0000006
757#define STATUS_INVALID_PARAMETER 0xC000000D
758#define STATUS_NO_MEMORY 0xC0000017
759#define STATUS_CONFLICTING_ADDRESSES 0xC0000018
760#define STATUS_ILLEGAL_INSTRUCTION 0xC000001D
761#define STATUS_BUFFER_TOO_SMALL 0xC0000023
762#define STATUS_NONCONTINUABLE_EXCEPTION 0xC0000025
763#define STATUS_INVALID_DISPOSITION 0xC0000026
764#define STATUS_UNWIND 0xC0000027
765#define STATUS_BAD_STACK 0xC0000028
766#define STATUS_INVALID_UNWIND_TARGET 0xC0000029
767#define STATUS_UNKNOWN_REVISION 0xC0000058
768#define STATUS_INVALID_SECURITY_DESCR 0xC0000079
769#define STATUS_ARRAY_BOUNDS_EXCEEDED 0xC000008C
770#define STATUS_FLOAT_DENORMAL_OPERAND 0xC000008D
771#define STATUS_FLOAT_DIVIDE_BY_ZERO 0xC000008E
772#define STATUS_FLOAT_INEXACT_RESULT 0xC000008F
773#define STATUS_FLOAT_INVALID_OPERATION 0xC0000090
774#define STATUS_FLOAT_OVERFLOW 0xC0000091
775#define STATUS_FLOAT_STACK_CHECK 0xC0000092
776#define STATUS_FLOAT_UNDERFLOW 0xC0000093
777#define STATUS_INTEGER_DIVIDE_BY_ZERO 0xC0000094
778#define STATUS_INTEGER_OVERFLOW 0xC0000095
779#define STATUS_PRIVILEGED_INSTRUCTION 0xC0000096
780#define STATUS_INVALID_PARAMETER_2 0xC00000F0
781#define STATUS_STACK_OVERFLOW 0xC00000FD
782#define STATUS_CONTROL_C_EXIT 0xC000013A
783
784#define MAXIMUM_WAIT_OBJECTS 64
785#define MAXIMUM_SUSPEND_COUNT 127
786
787#define EXCEPTION_ACCESS_VIOLATION STATUS_ACCESS_VIOLATION
788#define EXCEPTION_DATATYPE_MISALIGNMENT STATUS_DATATYPE_MISALIGNMENT
789#define EXCEPTION_BREAKPOINT STATUS_BREAKPOINT
790#define EXCEPTION_SINGLE_STEP STATUS_SINGLE_STEP
791#define EXCEPTION_ARRAY_BOUNDS_EXCEEDED STATUS_ARRAY_BOUNDS_EXCEEDED
792#define EXCEPTION_FLT_DENORMAL_OPERAND STATUS_FLOAT_DENORMAL_OPERAND
793#define EXCEPTION_FLT_DIVIDE_BY_ZERO STATUS_FLOAT_DIVIDE_BY_ZERO
794#define EXCEPTION_FLT_INEXACT_RESULT STATUS_FLOAT_INEXACT_RESULT
795#define EXCEPTION_FLT_INVALID_OPERATION STATUS_FLOAT_INVALID_OPERATION
796#define EXCEPTION_FLT_OVERFLOW STATUS_FLOAT_OVERFLOW
797#define EXCEPTION_FLT_STACK_CHECK STATUS_FLOAT_STACK_CHECK
798#define EXCEPTION_FLT_UNDERFLOW STATUS_FLOAT_UNDERFLOW
799#define EXCEPTION_INT_DIVIDE_BY_ZERO STATUS_INTEGER_DIVIDE_BY_ZERO
800#define EXCEPTION_INT_OVERFLOW STATUS_INTEGER_OVERFLOW
801#define EXCEPTION_PRIV_INSTRUCTION STATUS_PRIVILEGED_INSTRUCTION
802#define EXCEPTION_IN_PAGE_ERROR STATUS_IN_PAGE_ERROR
803#define EXCEPTION_ILLEGAL_INSTRUCTION STATUS_ILLEGAL_INSTRUCTION
804#define EXCEPTION_NONCONTINUABLE_EXCEPTION STATUS_NONCONTINUABLE_EXCEPTION
805#define EXCEPTION_STACK_OVERFLOW STATUS_STACK_OVERFLOW
806#define EXCEPTION_INVALID_DISPOSITION STATUS_INVALID_DISPOSITION
807#define EXCEPTION_GUARD_PAGE STATUS_GUARD_PAGE_VIOLATION
808#define EXCEPTION_INVALID_HANDLE STATUS_INVALID_HANDLE
809#define CONTROL_C_EXIT STATUS_CONTROL_C_EXIT
810
811/* Wine extension; Windows doesn't have a name for this code */
812#define EXCEPTION_CRITICAL_SECTION_WAIT 0xc0000194
813
814
815/*
816 * Return values from the actual exception handlers
817 */
818
819#define ExceptionContinueExecution 0
820#define ExceptionContinueSearch 1
821#define ExceptionNestedException 2
822#define ExceptionCollidedUnwind 3
823
824/*
825 * Return values from filters in except() and from UnhandledExceptionFilter
826 */
827
828#define EXCEPTION_EXECUTE_HANDLER 1
829#define EXCEPTION_CONTINUE_SEARCH 0
830#define EXCEPTION_CONTINUE_EXECUTION -1
831
832/*
833 * From OS/2 2.0 exception handling
834 * Win32 seems to use the same flags as ExceptionFlags in an EXCEPTION_RECORD
835 */
836
837#define EH_NONCONTINUABLE 0x01
838#define EH_UNWINDING 0x02
839#define EH_EXIT_UNWIND 0x04
840#define EH_STACK_INVALID 0x08
841#define EH_NESTED_CALL 0x10
842
843#define EXCEPTION_CONTINUABLE 0
844#define EXCEPTION_NONCONTINUABLE EH_NONCONTINUABLE
845
846/*
847 * The exception record used by Win32 to give additional information
848 * about exception to exception handlers.
849 */
850
851#define EXCEPTION_MAXIMUM_PARAMETERS 15
852
853typedef struct __EXCEPTION_RECORD
854{
855 DWORD ExceptionCode;
856 DWORD ExceptionFlags;
857 struct __EXCEPTION_RECORD *ExceptionRecord;
858
859 LPVOID ExceptionAddress;
860 DWORD NumberParameters;
861 DWORD ExceptionInformation[EXCEPTION_MAXIMUM_PARAMETERS];
862} EXCEPTION_RECORD, *PEXCEPTION_RECORD;
863
864/*
865 * The exception pointers structure passed to exception filters
866 * in except() and the UnhandledExceptionFilter().
867 */
868
869typedef struct _EXCEPTION_POINTERS
870{
871 PEXCEPTION_RECORD ExceptionRecord;
872 PCONTEXT ContextRecord;
873} EXCEPTION_POINTERS, *PEXCEPTION_POINTERS;
874
875
876/*
877 * The exception frame, used for registering exception handlers
878 * Win32 cares only about this, but compilers generally emit
879 * larger exception frames for their own use.
880 */
881
882struct __EXCEPTION_FRAME;
883
884typedef DWORD (*PEXCEPTION_HANDLER)(PEXCEPTION_RECORD,struct __EXCEPTION_FRAME*,
885 PCONTEXT,struct __EXCEPTION_FRAME **);
886
887typedef struct __EXCEPTION_FRAME
888{
889 struct __EXCEPTION_FRAME *Prev;
890 PEXCEPTION_HANDLER Handler;
891} EXCEPTION_FRAME, *PEXCEPTION_FRAME;
892
893#include "poppack.h"
894
895/*
896 * function pointer to a exception filter
897 */
898
899typedef LONG (* CALLBACK PTOP_LEVEL_EXCEPTION_FILTER)(PEXCEPTION_POINTERS ExceptionInfo);
900typedef PTOP_LEVEL_EXCEPTION_FILTER LPTOP_LEVEL_EXCEPTION_FILTER;
901
902DWORD WINAPI UnhandledExceptionFilter( PEXCEPTION_POINTERS epointers );
903LPTOP_LEVEL_EXCEPTION_FILTER
904WINAPI SetUnhandledExceptionFilter( LPTOP_LEVEL_EXCEPTION_FILTER filter );
905
906/* status values for ContinueDebugEvent */
907#define DBG_CONTINUE 0x00010002
908#define DBG_TERMINATE_THREAD 0x40010003
909#define DBG_TERMINATE_PROCESS 0x40010004
910#define DBG_CONTROL_C 0x40010005
911#define DBG_CONTROL_BREAK 0x40010008
912#define DBG_EXCEPTION_NOT_HANDLED 0x80010001
913
914struct _TEB;
915
916#ifdef __WINE__
917
918#ifndef __WIN32OS2__
919#if defined(__i386__)
920static inline struct _TEB * WINE_UNUSED __get_teb(void)
921{
922 struct _TEB *teb;
923 __asm__(".byte 0x64\n\tmovl (0x18),%0" : "=r" (teb));
924 return teb;
925}
926#elif defined(HAVE__LWP_CREATE)
927extern void *_lwp_getprivate(void);
928static inline struct _TEB * WINE_UNUSED __get_teb(void)
929{
930 return (struct _TEB *)_lwp_getprivate();
931}
932#else
933#error NtCurrentTeb() not defined for this architecture!
934#endif
935
936#define NtCurrentTeb() __get_teb()
937
938#else /* __WINE__ */
939extern struct _TEB * WINAPI NtCurrentTeb(void);
940#endif
941#endif //__WIN32OS2__
942
943/*
944 * Here follows typedefs for security and tokens.
945 */
946
947/*
948 * First a constant for the following typdefs.
949 */
950
951#define ANYSIZE_ARRAY 1
952
953/* FIXME: Orphan. What does it point to? */
954typedef PVOID PACCESS_TOKEN;
955
956/*
957 * TOKEN_INFORMATION_CLASS
958 */
959
960typedef enum _TOKEN_INFORMATION_CLASS {
961 TokenUser = 1,
962 TokenGroups,
963 TokenPrivileges,
964 TokenOwner,
965 TokenPrimaryGroup,
966 TokenDefaultDacl,
967 TokenSource,
968 TokenType,
969 TokenImpersonationLevel,
970 TokenStatistics
971} TOKEN_INFORMATION_CLASS;
972
973#ifndef _SECURITY_DEFINED
974#define _SECURITY_DEFINED
975
976#include "pshpack1.h"
977
978typedef DWORD ACCESS_MASK, *PACCESS_MASK;
979
980typedef struct _GENERIC_MAPPING {
981 ACCESS_MASK GenericRead;
982 ACCESS_MASK GenericWrite;
983 ACCESS_MASK GenericExecute;
984 ACCESS_MASK GenericAll;
985} GENERIC_MAPPING, *PGENERIC_MAPPING;
986
987#ifndef SID_IDENTIFIER_AUTHORITY_DEFINED
988#define SID_IDENTIFIER_AUTHORITY_DEFINED
989typedef struct {
990 BYTE Value[6];
991} SID_IDENTIFIER_AUTHORITY,*PSID_IDENTIFIER_AUTHORITY,*LPSID_IDENTIFIER_AUTHORITY;
992#endif /* !defined(SID_IDENTIFIER_AUTHORITY_DEFINED) */
993
994#ifndef SID_DEFINED
995#define SID_DEFINED
996typedef struct _SID {
997 BYTE Revision;
998 BYTE SubAuthorityCount;
999 SID_IDENTIFIER_AUTHORITY IdentifierAuthority;
1000 DWORD SubAuthority[1];
1001} SID,*PSID;
1002#endif /* !defined(SID_DEFINED) */
1003
1004#define SID_REVISION (1) /* Current revision */
1005#define SID_MAX_SUB_AUTHORITIES (15) /* current max subauths */
1006#define SID_RECOMMENDED_SUB_AUTHORITIES (1) /* recommended subauths */
1007
1008
1009/*
1010 * ACL
1011 */
1012
1013typedef struct _ACL {
1014 BYTE AclRevision;
1015 BYTE Sbz1;
1016 WORD AclSize;
1017 WORD AceCount;
1018 WORD Sbz2;
1019} ACL, *PACL;
1020
1021/* SECURITY_DESCRIPTOR */
1022#define SECURITY_DESCRIPTOR_REVISION 1
1023#define SECURITY_DESCRIPTOR_REVISION1 1
1024
1025
1026#define SE_OWNER_DEFAULTED 0x0001
1027#define SE_GROUP_DEFAULTED 0x0002
1028#define SE_DACL_PRESENT 0x0004
1029#define SE_DACL_DEFAULTED 0x0008
1030#define SE_SACL_PRESENT 0x0010
1031#define SE_SACL_DEFAULTED 0x0020
1032#define SE_SELF_RELATIVE 0x8000
1033
1034typedef DWORD SECURITY_INFORMATION, *PSECURITY_INFORMATION;
1035typedef WORD SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL, *LPSECURITY_DESCRIPTOR;
1036
1037/* The security descriptor structure */
1038typedef struct {
1039 BYTE Revision;
1040 BYTE Sbz1;
1041 SECURITY_DESCRIPTOR_CONTROL Control;
1042 PSID Owner;
1043 PSID Group;
1044 PACL Sacl;
1045 PACL Dacl;
1046} SECURITY_DESCRIPTOR, *PSECURITY_DESCRIPTOR;
1047
1048#define SECURITY_DESCRIPTOR_MIN_LENGTH (sizeof(SECURITY_DESCRIPTOR))
1049
1050#include "poppack.h"
1051
1052#endif /* _SECURITY_DEFINED */
1053
1054#include "pshpack1.h"
1055
1056/*
1057 * SID_AND_ATTRIBUTES
1058 */
1059
1060typedef struct _SID_AND_ATTRIBUTES {
1061 PSID Sid;
1062 DWORD Attributes;
1063} SID_AND_ATTRIBUTES ;
1064
1065/*
1066 * TOKEN_USER
1067 */
1068
1069typedef struct _TOKEN_USER {
1070 SID_AND_ATTRIBUTES User;
1071} TOKEN_USER;
1072
1073/*
1074 * TOKEN_GROUPS
1075 */
1076
1077typedef struct _TOKEN_GROUPS {
1078 DWORD GroupCount;
1079 SID_AND_ATTRIBUTES Groups[ANYSIZE_ARRAY];
1080} TOKEN_GROUPS;
1081
1082/*
1083 * LUID_AND_ATTRIBUTES
1084 */
1085#ifdef __WIN32OS2__
1086typedef struct _LARGE_INTEGER {
1087 ULONG LowPart;
1088 LONG HighPart;
1089} LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
1090
1091typedef struct _ULARGE_INTEGER {
1092 ULONG LowPart;
1093 LONG HighPart;
1094} ULARGE_INTEGER, *LPULARGE_INTEGER, *PULARGE_INTEGER;
1095#else
1096typedef union _LARGE_INTEGER {
1097 struct {
1098 DWORD LowPart;
1099 LONG HighPart;
1100 } DUMMYSTRUCTNAME;
1101 LONGLONG QuadPart;
1102} LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
1103
1104typedef union _ULARGE_INTEGER {
1105 struct {
1106 DWORD LowPart;
1107 LONG HighPart;
1108 } DUMMYSTRUCTNAME;
1109 LONGLONG QuadPart;
1110} ULARGE_INTEGER, *LPULARGE_INTEGER, *PULARGE_INTEGER;
1111#endif
1112/*
1113 * Locally Unique Identifier
1114 */
1115
1116typedef LARGE_INTEGER LUID,*PLUID;
1117
1118typedef struct _LUID_AND_ATTRIBUTES {
1119 LUID Luid;
1120 DWORD Attributes;
1121} LUID_AND_ATTRIBUTES;
1122
1123/*
1124 * PRIVILEGE_SET
1125 */
1126
1127typedef struct _PRIVILEGE_SET {
1128 DWORD PrivilegeCount;
1129 DWORD Control;
1130 LUID_AND_ATTRIBUTES Privilege[ANYSIZE_ARRAY];
1131} PRIVILEGE_SET, *PPRIVILEGE_SET;
1132
1133/*
1134 * TOKEN_PRIVILEGES
1135 */
1136
1137typedef struct _TOKEN_PRIVILEGES {
1138 DWORD PrivilegeCount;
1139 LUID_AND_ATTRIBUTES Privileges[ANYSIZE_ARRAY];
1140} TOKEN_PRIVILEGES, *PTOKEN_PRIVILEGES;
1141
1142/*
1143 * TOKEN_OWNER
1144 */
1145
1146typedef struct _TOKEN_OWNER {
1147 PSID Owner;
1148} TOKEN_OWNER;
1149
1150/*
1151 * TOKEN_PRIMARY_GROUP
1152 */
1153
1154typedef struct _TOKEN_PRIMARY_GROUP {
1155 PSID PrimaryGroup;
1156} TOKEN_PRIMARY_GROUP;
1157
1158
1159/*
1160 * TOKEN_DEFAULT_DACL
1161 */
1162
1163typedef struct _TOKEN_DEFAULT_DACL {
1164 PACL DefaultDacl;
1165} TOKEN_DEFAULT_DACL;
1166
1167/*
1168 * TOKEN_SOURCEL
1169 */
1170
1171typedef struct _TOKEN_SOURCE {
1172 char Sourcename[8];
1173 LUID SourceIdentifier;
1174} TOKEN_SOURCE;
1175
1176/*
1177 * TOKEN_TYPE
1178 */
1179
1180typedef enum tagTOKEN_TYPE {
1181 TokenPrimary = 1,
1182 TokenImpersonation
1183} TOKEN_TYPE;
1184
1185/*
1186 * SECURITY_IMPERSONATION_LEVEL
1187 */
1188
1189typedef enum _SECURITY_IMPERSONATION_LEVEL {
1190 SecurityAnonymous,
1191 SecurityIdentification,
1192 SecurityImpersonation,
1193 SecurityDelegation
1194} SECURITY_IMPERSONATION_LEVEL, *PSECURITY_IMPERSONATION_LEVEL;
1195
1196
1197typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,
1198 * PSECURITY_CONTEXT_TRACKING_MODE;
1199/*
1200 * Quality of Service
1201 */
1202
1203typedef struct _SECURITY_QUALITY_OF_SERVICE {
1204 DWORD Length;
1205 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
1206 SECURITY_CONTEXT_TRACKING_MODE ContextTrackingMode;
1207 BOOL EffectiveOnly;
1208} SECURITY_QUALITY_OF_SERVICE, *PSECURITY_QUALITY_OF_SERVICE;
1209
1210/*
1211 * TOKEN_STATISTICS
1212 */
1213
1214typedef struct _TOKEN_STATISTICS {
1215 LUID TokenId;
1216 LUID AuthenticationId;
1217 LARGE_INTEGER ExpirationTime;
1218 TOKEN_TYPE TokenType;
1219 SECURITY_IMPERSONATION_LEVEL ImpersonationLevel;
1220 DWORD DynamicCharged;
1221 DWORD DynamicAvailable;
1222 DWORD GroupCount;
1223 DWORD PrivilegeCount;
1224 LUID ModifiedId;
1225} TOKEN_STATISTICS;
1226
1227/*
1228 * ACLs of NT
1229 */
1230
1231#define ACL_REVISION 2
1232
1233#define ACL_REVISION1 1
1234#define ACL_REVISION2 2
1235
1236/* ACEs, directly starting after an ACL */
1237typedef struct _ACE_HEADER {
1238 BYTE AceType;
1239 BYTE AceFlags;
1240 WORD AceSize;
1241} ACE_HEADER,*PACE_HEADER;
1242
1243/* AceType */
1244#define ACCESS_ALLOWED_ACE_TYPE 0
1245#define ACCESS_DENIED_ACE_TYPE 1
1246#define SYSTEM_AUDIT_ACE_TYPE 2
1247#define SYSTEM_ALARM_ACE_TYPE 3
1248
1249/* inherit AceFlags */
1250#define OBJECT_INHERIT_ACE 0x01
1251#define CONTAINER_INHERIT_ACE 0x02
1252#define NO_PROPAGATE_INHERIT_ACE 0x04
1253#define INHERIT_ONLY_ACE 0x08
1254#define VALID_INHERIT_FLAGS 0x0F
1255
1256/* AceFlags mask for what events we (should) audit */
1257#define SUCCESSFUL_ACCESS_ACE_FLAG 0x40
1258#define FAILED_ACCESS_ACE_FLAG 0x80
1259
1260/* different ACEs depending on AceType
1261 * SidStart marks the begin of a SID
1262 * so the thing finally looks like this:
1263 * 0: ACE_HEADER
1264 * 4: ACCESS_MASK
1265 * 8... : SID
1266 */
1267typedef struct _ACCESS_ALLOWED_ACE {
1268 ACE_HEADER Header;
1269 DWORD Mask;
1270 DWORD SidStart;
1271} ACCESS_ALLOWED_ACE,*PACCESS_ALLOWED_ACE;
1272
1273typedef struct _ACCESS_DENIED_ACE {
1274 ACE_HEADER Header;
1275 DWORD Mask;
1276 DWORD SidStart;
1277} ACCESS_DENIED_ACE,*PACCESS_DENIED_ACE;
1278
1279typedef struct _SYSTEM_AUDIT_ACE {
1280 ACE_HEADER Header;
1281 DWORD Mask;
1282 DWORD SidStart;
1283} SYSTEM_AUDIT_ACE,*PSYSTEM_AUDIT_ACE;
1284
1285typedef struct _SYSTEM_ALARM_ACE {
1286 ACE_HEADER Header;
1287 DWORD Mask;
1288 DWORD SidStart;
1289} SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
1290
1291typedef enum tagSID_NAME_USE {
1292 SidTypeUser = 1,
1293 SidTypeGroup,
1294 SidTypeDomain,
1295 SidTypeAlias,
1296 SidTypeWellKnownGroup,
1297 SidTypeDeletedAccount,
1298 SidTypeInvalid,
1299 SidTypeUnknown
1300} SID_NAME_USE,*PSID_NAME_USE;
1301
1302/* Access rights */
1303
1304#define DELETE 0x00010000
1305#define READ_CONTROL 0x00020000
1306#define WRITE_DAC 0x00040000
1307#define WRITE_OWNER 0x00080000
1308#define SYNCHRONIZE 0x00100000
1309#define STANDARD_RIGHTS_REQUIRED 0x000f0000
1310
1311#define STANDARD_RIGHTS_READ READ_CONTROL
1312#define STANDARD_RIGHTS_WRITE READ_CONTROL
1313#define STANDARD_RIGHTS_EXECUTE READ_CONTROL
1314
1315#define STANDARD_RIGHTS_ALL 0x001f0000
1316
1317#define SPECIFIC_RIGHTS_ALL 0x0000ffff
1318
1319#define GENERIC_READ 0x80000000
1320#define GENERIC_WRITE 0x40000000
1321#define GENERIC_EXECUTE 0x20000000
1322#define GENERIC_ALL 0x10000000
1323
1324#define MAXIMUM_ALLOWED 0x02000000
1325#define ACCESS_SYSTEM_SECURITY 0x01000000
1326
1327#define EVENT_MODIFY_STATE 0x0002
1328#define EVENT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
1329
1330#define SEMAPHORE_MODIFY_STATE 0x0002
1331#define SEMAPHORE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3)
1332
1333#define MUTEX_MODIFY_STATE 0x0001
1334#define MUTEX_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1)
1335
1336#define PROCESS_TERMINATE 0x0001
1337#define PROCESS_CREATE_THREAD 0x0002
1338#define PROCESS_VM_OPERATION 0x0008
1339#define PROCESS_VM_READ 0x0010
1340#define PROCESS_VM_WRITE 0x0020
1341#define PROCESS_DUP_HANDLE 0x0040
1342#define PROCESS_CREATE_PROCESS 0x0080
1343#define PROCESS_SET_QUOTA 0x0100
1344#define PROCESS_SET_INFORMATION 0x0200
1345#define PROCESS_QUERY_INFORMATION 0x0400
1346#define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0xfff)
1347
1348#define THREAD_TERMINATE 0x0001
1349#define THREAD_SUSPEND_RESUME 0x0002
1350#define THREAD_GET_CONTEXT 0x0008
1351#define THREAD_SET_CONTEXT 0x0010
1352#define THREAD_SET_INFORMATION 0x0020
1353#define THREAD_QUERY_INFORMATION 0x0040
1354#define THREAD_SET_THREAD_TOKEN 0x0080
1355#define THREAD_IMPERSONATE 0x0100
1356#define THREAD_DIRECT_IMPERSONATION 0x0200
1357#define THREAD_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x3ff)
1358
1359#define THREAD_BASE_PRIORITY_LOWRT 15
1360#define THREAD_BASE_PRIORITY_MAX 2
1361#define THREAD_BASE_PRIORITY_MIN -2
1362#define THREAD_BASE_PRIORITY_IDLE -15
1363
1364#define FILE_READ_DATA 0x0001 /* file & pipe */
1365#define FILE_LIST_DIRECTORY 0x0001 /* directory */
1366#define FILE_WRITE_DATA 0x0002 /* file & pipe */
1367#define FILE_ADD_FILE 0x0002 /* directory */
1368#define FILE_APPEND_DATA 0x0004 /* file */
1369#define FILE_ADD_SUBDIRECTORY 0x0004 /* directory */
1370#define FILE_CREATE_PIPE_INSTANCE 0x0004 /* named pipe */
1371#define FILE_READ_EA 0x0008 /* file & directory */
1372#define FILE_READ_PROPERTIES FILE_READ_EA
1373#define FILE_WRITE_EA 0x0010 /* file & directory */
1374#define FILE_WRITE_PROPERTIES FILE_WRITE_EA
1375#define FILE_EXECUTE 0x0020 /* file */
1376#define FILE_TRAVERSE 0x0020 /* directory */
1377#define FILE_DELETE_CHILD 0x0040 /* directory */
1378#define FILE_READ_ATTRIBUTES 0x0080 /* all */
1379#define FILE_WRITE_ATTRIBUTES 0x0100 /* all */
1380#define FILE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED|SYNCHRONIZE|0x1ff)
1381
1382#define FILE_GENERIC_READ (STANDARD_RIGHTS_READ | FILE_READ_DATA | \
1383 FILE_READ_ATTRIBUTES | FILE_READ_EA | \
1384 SYNCHRONIZE)
1385#define FILE_GENERIC_WRITE (STANDARD_RIGHTS_WRITE | FILE_WRITE_DATA | \
1386 FILE_WRITE_ATTRIBUTES | FILE_WRITE_EA | \
1387 FILE_APPEND_DATA | SYNCHRONIZE)
1388#define FILE_GENERIC_EXECUTE (STANDARD_RIGHTS_EXECUTE | FILE_EXECUTE | \
1389 FILE_READ_ATTRIBUTES | SYNCHRONIZE)
1390
1391
1392/* File attribute flags
1393 */
1394#define FILE_SHARE_READ 0x00000001L
1395#define FILE_SHARE_WRITE 0x00000002L
1396#define FILE_SHARE_DELETE 0x00000004L
1397#define FILE_ATTRIBUTE_READONLY 0x00000001L
1398#define FILE_ATTRIBUTE_HIDDEN 0x00000002L
1399#define FILE_ATTRIBUTE_SYSTEM 0x00000004L
1400#define FILE_ATTRIBUTE_LABEL 0x00000008L /* Not in Windows API */
1401#define FILE_ATTRIBUTE_DIRECTORY 0x00000010L
1402#define FILE_ATTRIBUTE_ARCHIVE 0x00000020L
1403#define FILE_ATTRIBUTE_NORMAL 0x00000080L
1404#define FILE_ATTRIBUTE_TEMPORARY 0x00000100L
1405#define FILE_ATTRIBUTE_ATOMIC_WRITE 0x00000200L
1406#define FILE_ATTRIBUTE_XACTION_WRITE 0x00000400L
1407#define FILE_ATTRIBUTE_COMPRESSED 0x00000800L
1408#define FILE_ATTRIBUTE_OFFLINE 0x00001000L
1409
1410/* File alignments (NT) */
1411#define FILE_BYTE_ALIGNMENT 0x00000000
1412#define FILE_WORD_ALIGNMENT 0x00000001
1413#define FILE_LONG_ALIGNMENT 0x00000003
1414#define FILE_QUAD_ALIGNMENT 0x00000007
1415#define FILE_OCTA_ALIGNMENT 0x0000000f
1416#define FILE_32_BYTE_ALIGNMENT 0x0000001f
1417#define FILE_64_BYTE_ALIGNMENT 0x0000003f
1418#define FILE_128_BYTE_ALIGNMENT 0x0000007f
1419#define FILE_256_BYTE_ALIGNMENT 0x000000ff
1420#define FILE_512_BYTE_ALIGNMENT 0x000001ff
1421
1422/* Registry security values */
1423#define OWNER_SECURITY_INFORMATION 0x00000001
1424#define GROUP_SECURITY_INFORMATION 0x00000002
1425#define DACL_SECURITY_INFORMATION 0x00000004
1426#define SACL_SECURITY_INFORMATION 0x00000008
1427
1428#include "poppack.h"
1429
1430#endif /* __WINE_WINNT_H */
Note: See TracBrowser for help on using the repository browser.