| 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
|
|---|
| 82 | typedef LPWSTR LPTSTR;
|
|---|
| 83 | typedef LPCWSTR LPCTSTR;
|
|---|
| 84 | #define __TEXT(string) L##string /*probably wrong */
|
|---|
| 85 | # else /* UNICODE */
|
|---|
| 86 | typedef LPSTR LPTSTR;
|
|---|
| 87 | typedef LPCSTR LPCTSTR;
|
|---|
| 88 | #define __TEXT(string) string
|
|---|
| 89 | # endif /* UNICODE */
|
|---|
| 90 | #endif /* __WINE__ */
|
|---|
| 91 | #define TEXT(quote) __TEXT(quote)
|
|---|
| 92 |
|
|---|
| 93 | typedef BYTE BOOLEAN;
|
|---|
| 94 | typedef BOOLEAN *PBOOLEAN;
|
|---|
| 95 |
|
|---|
| 96 | typedef struct _LIST_ENTRY {
|
|---|
| 97 | struct _LIST_ENTRY *Flink;
|
|---|
| 98 | struct _LIST_ENTRY *Blink;
|
|---|
| 99 | } LIST_ENTRY, *PLIST_ENTRY;
|
|---|
| 100 |
|
|---|
| 101 | typedef 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 |
|
|---|
| 143 | typedef 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 |
|
|---|
| 156 | typedef 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 |
|
|---|
| 215 | typedef 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 |
|
|---|
| 229 | typedef 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 |
|
|---|
| 326 | typedef 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 |
|
|---|
| 421 | typedef 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 |
|
|---|
| 515 | typedef 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 |
|
|---|
| 562 | typedef 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 |
|
|---|
| 618 | typedef CONTEXT *PCONTEXT;
|
|---|
| 619 | typedef 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 |
|
|---|
| 853 | typedef 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 |
|
|---|
| 869 | typedef 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 |
|
|---|
| 882 | struct __EXCEPTION_FRAME;
|
|---|
| 883 |
|
|---|
| 884 | typedef DWORD (*PEXCEPTION_HANDLER)(PEXCEPTION_RECORD,struct __EXCEPTION_FRAME*,
|
|---|
| 885 | PCONTEXT,struct __EXCEPTION_FRAME **);
|
|---|
| 886 |
|
|---|
| 887 | typedef 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 |
|
|---|
| 899 | typedef LONG (* CALLBACK PTOP_LEVEL_EXCEPTION_FILTER)(PEXCEPTION_POINTERS ExceptionInfo);
|
|---|
| 900 | typedef PTOP_LEVEL_EXCEPTION_FILTER LPTOP_LEVEL_EXCEPTION_FILTER;
|
|---|
| 901 |
|
|---|
| 902 | DWORD WINAPI UnhandledExceptionFilter( PEXCEPTION_POINTERS epointers );
|
|---|
| 903 | LPTOP_LEVEL_EXCEPTION_FILTER
|
|---|
| 904 | WINAPI 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 |
|
|---|
| 914 | struct _TEB;
|
|---|
| 915 |
|
|---|
| 916 | #ifdef __WINE__
|
|---|
| 917 |
|
|---|
| 918 | #ifndef __WIN32OS2__
|
|---|
| 919 | #if defined(__i386__)
|
|---|
| 920 | static 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)
|
|---|
| 927 | extern void *_lwp_getprivate(void);
|
|---|
| 928 | static 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__ */
|
|---|
| 939 | extern 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? */
|
|---|
| 954 | typedef PVOID PACCESS_TOKEN;
|
|---|
| 955 |
|
|---|
| 956 | /*
|
|---|
| 957 | * TOKEN_INFORMATION_CLASS
|
|---|
| 958 | */
|
|---|
| 959 |
|
|---|
| 960 | typedef 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 |
|
|---|
| 978 | typedef DWORD ACCESS_MASK, *PACCESS_MASK;
|
|---|
| 979 |
|
|---|
| 980 | typedef 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
|
|---|
| 989 | typedef 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
|
|---|
| 996 | typedef 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 |
|
|---|
| 1013 | typedef 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 |
|
|---|
| 1034 | typedef DWORD SECURITY_INFORMATION, *PSECURITY_INFORMATION;
|
|---|
| 1035 | typedef WORD SECURITY_DESCRIPTOR_CONTROL, *PSECURITY_DESCRIPTOR_CONTROL, *LPSECURITY_DESCRIPTOR;
|
|---|
| 1036 |
|
|---|
| 1037 | /* The security descriptor structure */
|
|---|
| 1038 | typedef 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 |
|
|---|
| 1060 | typedef struct _SID_AND_ATTRIBUTES {
|
|---|
| 1061 | PSID Sid;
|
|---|
| 1062 | DWORD Attributes;
|
|---|
| 1063 | } SID_AND_ATTRIBUTES ;
|
|---|
| 1064 |
|
|---|
| 1065 | /*
|
|---|
| 1066 | * TOKEN_USER
|
|---|
| 1067 | */
|
|---|
| 1068 |
|
|---|
| 1069 | typedef struct _TOKEN_USER {
|
|---|
| 1070 | SID_AND_ATTRIBUTES User;
|
|---|
| 1071 | } TOKEN_USER;
|
|---|
| 1072 |
|
|---|
| 1073 | /*
|
|---|
| 1074 | * TOKEN_GROUPS
|
|---|
| 1075 | */
|
|---|
| 1076 |
|
|---|
| 1077 | typedef 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__
|
|---|
| 1086 | typedef struct _LARGE_INTEGER {
|
|---|
| 1087 | ULONG LowPart;
|
|---|
| 1088 | LONG HighPart;
|
|---|
| 1089 | } LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
|
|---|
| 1090 |
|
|---|
| 1091 | typedef struct _ULARGE_INTEGER {
|
|---|
| 1092 | ULONG LowPart;
|
|---|
| 1093 | LONG HighPart;
|
|---|
| 1094 | } ULARGE_INTEGER, *LPULARGE_INTEGER, *PULARGE_INTEGER;
|
|---|
| 1095 | #else
|
|---|
| 1096 | typedef union _LARGE_INTEGER {
|
|---|
| 1097 | struct {
|
|---|
| 1098 | DWORD LowPart;
|
|---|
| 1099 | LONG HighPart;
|
|---|
| 1100 | } DUMMYSTRUCTNAME;
|
|---|
| 1101 | LONGLONG QuadPart;
|
|---|
| 1102 | } LARGE_INTEGER, *LPLARGE_INTEGER, *PLARGE_INTEGER;
|
|---|
| 1103 |
|
|---|
| 1104 | typedef 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 |
|
|---|
| 1116 | typedef LARGE_INTEGER LUID,*PLUID;
|
|---|
| 1117 |
|
|---|
| 1118 | typedef struct _LUID_AND_ATTRIBUTES {
|
|---|
| 1119 | LUID Luid;
|
|---|
| 1120 | DWORD Attributes;
|
|---|
| 1121 | } LUID_AND_ATTRIBUTES;
|
|---|
| 1122 |
|
|---|
| 1123 | /*
|
|---|
| 1124 | * PRIVILEGE_SET
|
|---|
| 1125 | */
|
|---|
| 1126 |
|
|---|
| 1127 | typedef 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 |
|
|---|
| 1137 | typedef 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 |
|
|---|
| 1146 | typedef struct _TOKEN_OWNER {
|
|---|
| 1147 | PSID Owner;
|
|---|
| 1148 | } TOKEN_OWNER;
|
|---|
| 1149 |
|
|---|
| 1150 | /*
|
|---|
| 1151 | * TOKEN_PRIMARY_GROUP
|
|---|
| 1152 | */
|
|---|
| 1153 |
|
|---|
| 1154 | typedef struct _TOKEN_PRIMARY_GROUP {
|
|---|
| 1155 | PSID PrimaryGroup;
|
|---|
| 1156 | } TOKEN_PRIMARY_GROUP;
|
|---|
| 1157 |
|
|---|
| 1158 |
|
|---|
| 1159 | /*
|
|---|
| 1160 | * TOKEN_DEFAULT_DACL
|
|---|
| 1161 | */
|
|---|
| 1162 |
|
|---|
| 1163 | typedef struct _TOKEN_DEFAULT_DACL {
|
|---|
| 1164 | PACL DefaultDacl;
|
|---|
| 1165 | } TOKEN_DEFAULT_DACL;
|
|---|
| 1166 |
|
|---|
| 1167 | /*
|
|---|
| 1168 | * TOKEN_SOURCEL
|
|---|
| 1169 | */
|
|---|
| 1170 |
|
|---|
| 1171 | typedef struct _TOKEN_SOURCE {
|
|---|
| 1172 | char Sourcename[8];
|
|---|
| 1173 | LUID SourceIdentifier;
|
|---|
| 1174 | } TOKEN_SOURCE;
|
|---|
| 1175 |
|
|---|
| 1176 | /*
|
|---|
| 1177 | * TOKEN_TYPE
|
|---|
| 1178 | */
|
|---|
| 1179 |
|
|---|
| 1180 | typedef enum tagTOKEN_TYPE {
|
|---|
| 1181 | TokenPrimary = 1,
|
|---|
| 1182 | TokenImpersonation
|
|---|
| 1183 | } TOKEN_TYPE;
|
|---|
| 1184 |
|
|---|
| 1185 | /*
|
|---|
| 1186 | * SECURITY_IMPERSONATION_LEVEL
|
|---|
| 1187 | */
|
|---|
| 1188 |
|
|---|
| 1189 | typedef enum _SECURITY_IMPERSONATION_LEVEL {
|
|---|
| 1190 | SecurityAnonymous,
|
|---|
| 1191 | SecurityIdentification,
|
|---|
| 1192 | SecurityImpersonation,
|
|---|
| 1193 | SecurityDelegation
|
|---|
| 1194 | } SECURITY_IMPERSONATION_LEVEL, *PSECURITY_IMPERSONATION_LEVEL;
|
|---|
| 1195 |
|
|---|
| 1196 |
|
|---|
| 1197 | typedef BOOLEAN SECURITY_CONTEXT_TRACKING_MODE,
|
|---|
| 1198 | * PSECURITY_CONTEXT_TRACKING_MODE;
|
|---|
| 1199 | /*
|
|---|
| 1200 | * Quality of Service
|
|---|
| 1201 | */
|
|---|
| 1202 |
|
|---|
| 1203 | typedef 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 |
|
|---|
| 1214 | typedef 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 */
|
|---|
| 1237 | typedef 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 | */
|
|---|
| 1267 | typedef struct _ACCESS_ALLOWED_ACE {
|
|---|
| 1268 | ACE_HEADER Header;
|
|---|
| 1269 | DWORD Mask;
|
|---|
| 1270 | DWORD SidStart;
|
|---|
| 1271 | } ACCESS_ALLOWED_ACE,*PACCESS_ALLOWED_ACE;
|
|---|
| 1272 |
|
|---|
| 1273 | typedef struct _ACCESS_DENIED_ACE {
|
|---|
| 1274 | ACE_HEADER Header;
|
|---|
| 1275 | DWORD Mask;
|
|---|
| 1276 | DWORD SidStart;
|
|---|
| 1277 | } ACCESS_DENIED_ACE,*PACCESS_DENIED_ACE;
|
|---|
| 1278 |
|
|---|
| 1279 | typedef struct _SYSTEM_AUDIT_ACE {
|
|---|
| 1280 | ACE_HEADER Header;
|
|---|
| 1281 | DWORD Mask;
|
|---|
| 1282 | DWORD SidStart;
|
|---|
| 1283 | } SYSTEM_AUDIT_ACE,*PSYSTEM_AUDIT_ACE;
|
|---|
| 1284 |
|
|---|
| 1285 | typedef struct _SYSTEM_ALARM_ACE {
|
|---|
| 1286 | ACE_HEADER Header;
|
|---|
| 1287 | DWORD Mask;
|
|---|
| 1288 | DWORD SidStart;
|
|---|
| 1289 | } SYSTEM_ALARM_ACE,*PSYSTEM_ALARM_ACE;
|
|---|
| 1290 |
|
|---|
| 1291 | typedef 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 */
|
|---|