1 | /*++ BUILD Version: 0001 // Increment this if a change has global effects
|
---|
2 |
|
---|
3 | Copyright (c) Microsoft Corporation. All rights reserved.
|
---|
4 |
|
---|
5 | Module Name:
|
---|
6 |
|
---|
7 | ntdef.h
|
---|
8 |
|
---|
9 | Abstract:
|
---|
10 |
|
---|
11 | Type definitions for the basic types.
|
---|
12 |
|
---|
13 | Author:
|
---|
14 |
|
---|
15 | Mark Lucovsky (markl) 02-Feb-1989
|
---|
16 |
|
---|
17 | Revision History:
|
---|
18 |
|
---|
19 | --*/
|
---|
20 |
|
---|
21 | #ifndef _NTDEF_
|
---|
22 | #define _NTDEF_
|
---|
23 |
|
---|
24 | #if _MSC_VER > 1000
|
---|
25 | #pragma once
|
---|
26 | #endif
|
---|
27 |
|
---|
28 | #include <ctype.h> // winnt ntndis
|
---|
29 |
|
---|
30 | // begin_ntminiport begin_ntndis begin_ntminitape
|
---|
31 |
|
---|
32 | #ifndef IN
|
---|
33 | #define IN
|
---|
34 | #endif
|
---|
35 |
|
---|
36 | #ifndef OUT
|
---|
37 | #define OUT
|
---|
38 | #endif
|
---|
39 |
|
---|
40 | #ifndef OPTIONAL
|
---|
41 | #define OPTIONAL
|
---|
42 | #endif
|
---|
43 |
|
---|
44 | #ifndef NOTHING
|
---|
45 | #define NOTHING
|
---|
46 | #endif
|
---|
47 |
|
---|
48 | #ifndef CRITICAL
|
---|
49 | #define CRITICAL
|
---|
50 | #endif
|
---|
51 |
|
---|
52 | #ifndef ANYSIZE_ARRAY
|
---|
53 | #define ANYSIZE_ARRAY 1 // winnt
|
---|
54 | #endif
|
---|
55 |
|
---|
56 | // begin_winnt
|
---|
57 |
|
---|
58 | #if defined(_M_MRX000) && !(defined(MIDL_PASS) || defined(RC_INVOKED)) && defined(ENABLE_RESTRICTED)
|
---|
59 | #define RESTRICTED_POINTER __restrict
|
---|
60 | #else
|
---|
61 | #define RESTRICTED_POINTER
|
---|
62 | #endif
|
---|
63 |
|
---|
64 | #if defined(_M_MRX000) || defined(_M_ALPHA) || defined(_M_PPC) || defined(_M_IA64) || defined(_M_AMD64)
|
---|
65 | #define UNALIGNED __unaligned
|
---|
66 | #if defined(_WIN64)
|
---|
67 | #define UNALIGNED64 __unaligned
|
---|
68 | #else
|
---|
69 | #define UNALIGNED64
|
---|
70 | #endif
|
---|
71 | #else
|
---|
72 | #define UNALIGNED
|
---|
73 | #define UNALIGNED64
|
---|
74 | #endif
|
---|
75 |
|
---|
76 |
|
---|
77 | #if defined(_WIN64) || defined(_M_ALPHA)
|
---|
78 | #define MAX_NATURAL_ALIGNMENT sizeof(ULONGLONG)
|
---|
79 | #define MEMORY_ALLOCATION_ALIGNMENT 16
|
---|
80 | #else
|
---|
81 | #define MAX_NATURAL_ALIGNMENT sizeof(ULONG)
|
---|
82 | #define MEMORY_ALLOCATION_ALIGNMENT 8
|
---|
83 | #endif
|
---|
84 |
|
---|
85 | //
|
---|
86 | // TYPE_ALIGNMENT will return the alignment requirements of a given type for
|
---|
87 | // the current platform.
|
---|
88 | //
|
---|
89 |
|
---|
90 | #ifdef __cplusplus
|
---|
91 | #if _MSC_VER >= 1300
|
---|
92 | #define TYPE_ALIGNMENT( t ) __alignof(t)
|
---|
93 | #endif
|
---|
94 | #else
|
---|
95 | #define TYPE_ALIGNMENT( t ) \
|
---|
96 | FIELD_OFFSET( struct { char x; t test; }, test )
|
---|
97 | #endif
|
---|
98 |
|
---|
99 | #if defined(_WIN64)
|
---|
100 |
|
---|
101 | #define PROBE_ALIGNMENT( _s ) (TYPE_ALIGNMENT( _s ) > TYPE_ALIGNMENT( ULONG ) ? \
|
---|
102 | TYPE_ALIGNMENT( _s ) : TYPE_ALIGNMENT( ULONG ))
|
---|
103 |
|
---|
104 | #define PROBE_ALIGNMENT32( _s ) TYPE_ALIGNMENT( ULONG )
|
---|
105 |
|
---|
106 | #else
|
---|
107 |
|
---|
108 | #define PROBE_ALIGNMENT( _s ) TYPE_ALIGNMENT( ULONG )
|
---|
109 |
|
---|
110 | #endif
|
---|
111 |
|
---|
112 | //
|
---|
113 | // C_ASSERT() can be used to perform many compile-time assertions:
|
---|
114 | // type sizes, field offsets, etc.
|
---|
115 | //
|
---|
116 | // An assertion failure results in error C2118: negative subscript.
|
---|
117 | //
|
---|
118 |
|
---|
119 | #define C_ASSERT(e) typedef char __C_ASSERT__[(e)?1:-1]
|
---|
120 |
|
---|
121 | #if !defined(_MAC) && (defined(_M_MRX000) || defined(_M_AMD64) || defined(_M_IA64)) && (_MSC_VER >= 1100) && !(defined(MIDL_PASS) || defined(RC_INVOKED))
|
---|
122 | #define POINTER_64 __ptr64
|
---|
123 | typedef unsigned __int64 POINTER_64_INT;
|
---|
124 | #if defined(_WIN64)
|
---|
125 | #define POINTER_32 __ptr32
|
---|
126 | #else
|
---|
127 | #define POINTER_32
|
---|
128 | #endif
|
---|
129 | #else
|
---|
130 | #if defined(_MAC) && defined(_MAC_INT_64)
|
---|
131 | #define POINTER_64 __ptr64
|
---|
132 | typedef unsigned __int64 POINTER_64_INT;
|
---|
133 | #else
|
---|
134 | #define POINTER_64
|
---|
135 | typedef unsigned long POINTER_64_INT;
|
---|
136 | #endif
|
---|
137 | #define POINTER_32
|
---|
138 | #endif
|
---|
139 |
|
---|
140 | #if defined(_IA64_) || defined(_AMD64_)
|
---|
141 | #define FIRMWARE_PTR
|
---|
142 | #else
|
---|
143 | #define FIRMWARE_PTR POINTER_32
|
---|
144 | #endif
|
---|
145 |
|
---|
146 | #include <basetsd.h>
|
---|
147 |
|
---|
148 | // end_winnt
|
---|
149 |
|
---|
150 | #ifndef CONST
|
---|
151 | #define CONST const
|
---|
152 | #endif
|
---|
153 |
|
---|
154 | // begin_winnt
|
---|
155 |
|
---|
156 | #if (defined(_M_IX86) || defined(_M_IA64) || defined(_M_AMD64)) && !defined(MIDL_PASS)
|
---|
157 | #define DECLSPEC_IMPORT __declspec(dllimport)
|
---|
158 | #else
|
---|
159 | #define DECLSPEC_IMPORT
|
---|
160 | #endif
|
---|
161 |
|
---|
162 | #ifndef DECLSPEC_NORETURN
|
---|
163 | #if (_MSC_VER >= 1200) && !defined(MIDL_PASS)
|
---|
164 | #define DECLSPEC_NORETURN __declspec(noreturn)
|
---|
165 | #else
|
---|
166 | #define DECLSPEC_NORETURN
|
---|
167 | #endif
|
---|
168 | #endif
|
---|
169 |
|
---|
170 | #ifndef DECLSPEC_ALIGN
|
---|
171 | #if (_MSC_VER >= 1300) && !defined(MIDL_PASS)
|
---|
172 | #define DECLSPEC_ALIGN(x) __declspec(align(x))
|
---|
173 | #else
|
---|
174 | #define DECLSPEC_ALIGN(x)
|
---|
175 | #endif
|
---|
176 | #endif
|
---|
177 |
|
---|
178 | #ifndef DECLSPEC_CACHEALIGN
|
---|
179 | #define DECLSPEC_CACHEALIGN DECLSPEC_ALIGN(128)
|
---|
180 | #endif
|
---|
181 |
|
---|
182 | #ifndef DECLSPEC_UUID
|
---|
183 | #if (_MSC_VER >= 1100) && defined (__cplusplus)
|
---|
184 | #define DECLSPEC_UUID(x) __declspec(uuid(x))
|
---|
185 | #else
|
---|
186 | #define DECLSPEC_UUID(x)
|
---|
187 | #endif
|
---|
188 | #endif
|
---|
189 |
|
---|
190 | #ifndef DECLSPEC_NOVTABLE
|
---|
191 | #if (_MSC_VER >= 1100) && defined(__cplusplus)
|
---|
192 | #define DECLSPEC_NOVTABLE __declspec(novtable)
|
---|
193 | #else
|
---|
194 | #define DECLSPEC_NOVTABLE
|
---|
195 | #endif
|
---|
196 | #endif
|
---|
197 |
|
---|
198 | #ifndef DECLSPEC_SELECTANY
|
---|
199 | #if (_MSC_VER >= 1100)
|
---|
200 | #define DECLSPEC_SELECTANY __declspec(selectany)
|
---|
201 | #else
|
---|
202 | #define DECLSPEC_SELECTANY
|
---|
203 | #endif
|
---|
204 | #endif
|
---|
205 |
|
---|
206 | #ifndef NOP_FUNCTION
|
---|
207 | #if (_MSC_VER >= 1210)
|
---|
208 | #define NOP_FUNCTION __noop
|
---|
209 | #else
|
---|
210 | #define NOP_FUNCTION (void)0
|
---|
211 | #endif
|
---|
212 | #endif
|
---|
213 |
|
---|
214 | #ifndef DECLSPEC_ADDRSAFE
|
---|
215 | #if (_MSC_VER >= 1200) && (defined(_M_ALPHA) || defined(_M_AXP64))
|
---|
216 | #define DECLSPEC_ADDRSAFE __declspec(address_safe)
|
---|
217 | #else
|
---|
218 | #define DECLSPEC_ADDRSAFE
|
---|
219 | #endif
|
---|
220 | #endif
|
---|
221 |
|
---|
222 | #ifndef DECLSPEC_NOINLINE
|
---|
223 | #if (_MSC_VER >= 1300)
|
---|
224 | #define DECLSPEC_NOINLINE __declspec(noinline)
|
---|
225 | #else
|
---|
226 | #define DECLSPEC_NOINLINE
|
---|
227 | #endif
|
---|
228 | #endif
|
---|
229 |
|
---|
230 | #ifndef FORCEINLINE
|
---|
231 | #if (_MSC_VER >= 1200)
|
---|
232 | #define FORCEINLINE __forceinline
|
---|
233 | #else
|
---|
234 | #define FORCEINLINE __inline
|
---|
235 | #endif
|
---|
236 | #endif
|
---|
237 |
|
---|
238 | #ifndef DECLSPEC_DEPRECATED
|
---|
239 | #if (_MSC_VER >= 1300) && !defined(MIDL_PASS)
|
---|
240 | #define DECLSPEC_DEPRECATED __declspec(deprecated)
|
---|
241 | #define DEPRECATE_SUPPORTED
|
---|
242 | #else
|
---|
243 | #define DECLSPEC_DEPRECATED
|
---|
244 | #undef DEPRECATE_SUPPORTED
|
---|
245 | #endif
|
---|
246 | #endif
|
---|
247 |
|
---|
248 | #ifdef DEPRECATE_DDK_FUNCTIONS
|
---|
249 | #ifdef _NTDDK_
|
---|
250 | #define DECLSPEC_DEPRECATED_DDK DECLSPEC_DEPRECATED
|
---|
251 | #ifdef DEPRECATE_SUPPORTED
|
---|
252 | #define PRAGMA_DEPRECATED_DDK 1
|
---|
253 | #endif
|
---|
254 | #else
|
---|
255 | #define DECLSPEC_DEPRECATED_DDK
|
---|
256 | #define PRAGMA_DEPRECATED_DDK 1
|
---|
257 | #endif
|
---|
258 | #else
|
---|
259 | #define DECLSPEC_DEPRECATED_DDK
|
---|
260 | #define PRAGMA_DEPRECATED_DDK 0
|
---|
261 | #endif
|
---|
262 |
|
---|
263 | //
|
---|
264 | // Void
|
---|
265 | //
|
---|
266 |
|
---|
267 | typedef void *PVOID;
|
---|
268 | typedef void * POINTER_64 PVOID64;
|
---|
269 |
|
---|
270 | // end_winnt
|
---|
271 |
|
---|
272 | #if defined(_M_IX86)
|
---|
273 | #define FASTCALL _fastcall
|
---|
274 | #else
|
---|
275 | #define FASTCALL
|
---|
276 | #endif
|
---|
277 |
|
---|
278 | // end_ntminiport end_ntndis end_ntminitape
|
---|
279 |
|
---|
280 | // begin_winnt begin_ntndis
|
---|
281 |
|
---|
282 | #if ((_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED)) && !defined(_M_AMD64)
|
---|
283 | #define NTAPI __stdcall
|
---|
284 | #else
|
---|
285 | #define _cdecl
|
---|
286 | #define NTAPI
|
---|
287 | #endif
|
---|
288 |
|
---|
289 | //
|
---|
290 | // Define API decoration for direct importing system DLL references.
|
---|
291 | //
|
---|
292 |
|
---|
293 | #if !defined(_NTSYSTEM_)
|
---|
294 | #define NTSYSAPI DECLSPEC_IMPORT
|
---|
295 | #define NTSYSCALLAPI DECLSPEC_IMPORT
|
---|
296 | #else
|
---|
297 | #define NTSYSAPI
|
---|
298 | #if defined(_NTDLLBUILD_)
|
---|
299 | #define NTSYSCALLAPI
|
---|
300 | #else
|
---|
301 | #define NTSYSCALLAPI DECLSPEC_ADDRSAFE
|
---|
302 | #endif
|
---|
303 |
|
---|
304 | #endif
|
---|
305 |
|
---|
306 | // end_winnt end_ntndis
|
---|
307 |
|
---|
308 | // begin_winnt begin_ntminiport begin_ntndis begin_ntminitape
|
---|
309 |
|
---|
310 | //
|
---|
311 | // Basics
|
---|
312 | //
|
---|
313 |
|
---|
314 | #ifndef VOID
|
---|
315 | #define VOID void
|
---|
316 | typedef char CHAR;
|
---|
317 | typedef short SHORT;
|
---|
318 | typedef long LONG;
|
---|
319 | #endif
|
---|
320 |
|
---|
321 | //
|
---|
322 | // UNICODE (Wide Character) types
|
---|
323 | //
|
---|
324 |
|
---|
325 | #ifndef _MAC
|
---|
326 | typedef wchar_t WCHAR; // wc, 16-bit UNICODE character
|
---|
327 | #else
|
---|
328 | // some Macintosh compilers don't define wchar_t in a convenient location, or define it as a char
|
---|
329 | typedef unsigned short WCHAR; // wc, 16-bit UNICODE character
|
---|
330 | #endif
|
---|
331 |
|
---|
332 | typedef WCHAR *PWCHAR;
|
---|
333 | typedef WCHAR *LPWCH, *PWCH;
|
---|
334 | typedef CONST WCHAR *LPCWCH, *PCWCH;
|
---|
335 | typedef WCHAR *NWPSTR;
|
---|
336 | typedef WCHAR *LPWSTR, *PWSTR;
|
---|
337 | typedef WCHAR UNALIGNED *LPUWSTR, *PUWSTR;
|
---|
338 |
|
---|
339 | typedef CONST WCHAR *LPCWSTR, *PCWSTR;
|
---|
340 | typedef CONST WCHAR UNALIGNED *LPCUWSTR, *PCUWSTR;
|
---|
341 |
|
---|
342 | //
|
---|
343 | // ANSI (Multi-byte Character) types
|
---|
344 | //
|
---|
345 | typedef CHAR *PCHAR;
|
---|
346 | typedef CHAR *LPCH, *PCH;
|
---|
347 |
|
---|
348 | typedef CONST CHAR *LPCCH, *PCCH;
|
---|
349 | typedef CHAR *NPSTR;
|
---|
350 | typedef CHAR *LPSTR, *PSTR;
|
---|
351 | typedef CONST CHAR *LPCSTR, *PCSTR;
|
---|
352 |
|
---|
353 | //
|
---|
354 | // Neutral ANSI/UNICODE types and macros
|
---|
355 | //
|
---|
356 | #ifdef UNICODE // r_winnt
|
---|
357 |
|
---|
358 | #ifndef _TCHAR_DEFINED
|
---|
359 | typedef WCHAR TCHAR, *PTCHAR;
|
---|
360 | typedef WCHAR TUCHAR, *PTUCHAR;
|
---|
361 | #define _TCHAR_DEFINED
|
---|
362 | #endif /* !_TCHAR_DEFINED */
|
---|
363 |
|
---|
364 | typedef LPWSTR LPTCH, PTCH;
|
---|
365 | typedef LPWSTR PTSTR, LPTSTR;
|
---|
366 | typedef LPCWSTR PCTSTR, LPCTSTR;
|
---|
367 | typedef LPUWSTR PUTSTR, LPUTSTR;
|
---|
368 | typedef LPCUWSTR PCUTSTR, LPCUTSTR;
|
---|
369 | typedef LPWSTR LP;
|
---|
370 | #define __TEXT(quote) L##quote // r_winnt
|
---|
371 |
|
---|
372 | #else /* UNICODE */ // r_winnt
|
---|
373 |
|
---|
374 | #ifndef _TCHAR_DEFINED
|
---|
375 | typedef char TCHAR, *PTCHAR;
|
---|
376 | typedef unsigned char TUCHAR, *PTUCHAR;
|
---|
377 | #define _TCHAR_DEFINED
|
---|
378 | #endif /* !_TCHAR_DEFINED */
|
---|
379 |
|
---|
380 | typedef LPSTR LPTCH, PTCH;
|
---|
381 | typedef LPSTR PTSTR, LPTSTR, PUTSTR, LPUTSTR;
|
---|
382 | typedef LPCSTR PCTSTR, LPCTSTR, PCUTSTR, LPCUTSTR;
|
---|
383 | #define __TEXT(quote) quote // r_winnt
|
---|
384 |
|
---|
385 | #endif /* UNICODE */ // r_winnt
|
---|
386 | #define TEXT(quote) __TEXT(quote) // r_winnt
|
---|
387 |
|
---|
388 |
|
---|
389 | // end_winnt
|
---|
390 |
|
---|
391 | typedef double DOUBLE;
|
---|
392 |
|
---|
393 | typedef struct _QUAD { // QUAD is for those times we want
|
---|
394 | double DoNotUseThisField; // an 8 byte aligned 8 byte long structure
|
---|
395 | } QUAD; // which is NOT really a floating point
|
---|
396 | // number. Use DOUBLE if you want an FP
|
---|
397 | // number.
|
---|
398 |
|
---|
399 | //
|
---|
400 | // Pointer to Basics
|
---|
401 | //
|
---|
402 |
|
---|
403 | typedef SHORT *PSHORT; // winnt
|
---|
404 | typedef LONG *PLONG; // winnt
|
---|
405 | typedef QUAD *PQUAD;
|
---|
406 |
|
---|
407 | //
|
---|
408 | // Unsigned Basics
|
---|
409 | //
|
---|
410 |
|
---|
411 | // Tell windef.h that some types are already defined.
|
---|
412 | #define BASETYPES
|
---|
413 |
|
---|
414 | typedef unsigned char UCHAR;
|
---|
415 | typedef unsigned short USHORT;
|
---|
416 | typedef unsigned long ULONG;
|
---|
417 | typedef QUAD UQUAD;
|
---|
418 |
|
---|
419 | //
|
---|
420 | // Pointer to Unsigned Basics
|
---|
421 | //
|
---|
422 |
|
---|
423 | typedef UCHAR *PUCHAR;
|
---|
424 | typedef USHORT *PUSHORT;
|
---|
425 | typedef ULONG *PULONG;
|
---|
426 | typedef UQUAD *PUQUAD;
|
---|
427 |
|
---|
428 | //
|
---|
429 | // Signed characters
|
---|
430 | //
|
---|
431 |
|
---|
432 | typedef signed char SCHAR;
|
---|
433 | typedef SCHAR *PSCHAR;
|
---|
434 |
|
---|
435 | #ifndef NO_STRICT
|
---|
436 | #ifndef STRICT
|
---|
437 | #define STRICT 1
|
---|
438 | #endif
|
---|
439 | #endif
|
---|
440 |
|
---|
441 | //
|
---|
442 | // Handle to an Object
|
---|
443 | //
|
---|
444 |
|
---|
445 | // begin_winnt
|
---|
446 |
|
---|
447 | #ifdef STRICT
|
---|
448 | typedef void *HANDLE;
|
---|
449 | #define DECLARE_HANDLE(name) struct name##__ { int unused; }; typedef struct name##__ *name
|
---|
450 | #else
|
---|
451 | typedef PVOID HANDLE;
|
---|
452 | #define DECLARE_HANDLE(name) typedef HANDLE name
|
---|
453 | #endif
|
---|
454 | typedef HANDLE *PHANDLE;
|
---|
455 |
|
---|
456 | //
|
---|
457 | // Flag (bit) fields
|
---|
458 | //
|
---|
459 |
|
---|
460 | typedef UCHAR FCHAR;
|
---|
461 | typedef USHORT FSHORT;
|
---|
462 | typedef ULONG FLONG;
|
---|
463 |
|
---|
464 | // Component Object Model defines, and macros
|
---|
465 |
|
---|
466 | #ifndef _HRESULT_DEFINED
|
---|
467 | #define _HRESULT_DEFINED
|
---|
468 | typedef LONG HRESULT;
|
---|
469 |
|
---|
470 | #endif // !_HRESULT_DEFINED
|
---|
471 |
|
---|
472 | #ifdef __cplusplus
|
---|
473 | #define EXTERN_C extern "C"
|
---|
474 | #else
|
---|
475 | #define EXTERN_C extern
|
---|
476 | #endif
|
---|
477 |
|
---|
478 | #if defined(_WIN32) || defined(_MPPC_)
|
---|
479 |
|
---|
480 | // Win32 doesn't support __export
|
---|
481 |
|
---|
482 | #ifdef _68K_
|
---|
483 | #define STDMETHODCALLTYPE __cdecl
|
---|
484 | #else
|
---|
485 | #define STDMETHODCALLTYPE __stdcall
|
---|
486 | #endif
|
---|
487 | #define STDMETHODVCALLTYPE __cdecl
|
---|
488 |
|
---|
489 | #define STDAPICALLTYPE __stdcall
|
---|
490 | #define STDAPIVCALLTYPE __cdecl
|
---|
491 |
|
---|
492 | #else
|
---|
493 |
|
---|
494 | #define STDMETHODCALLTYPE __export __stdcall
|
---|
495 | #define STDMETHODVCALLTYPE __export __cdecl
|
---|
496 |
|
---|
497 | #define STDAPICALLTYPE __export __stdcall
|
---|
498 | #define STDAPIVCALLTYPE __export __cdecl
|
---|
499 |
|
---|
500 | #endif
|
---|
501 |
|
---|
502 |
|
---|
503 | #define STDAPI EXTERN_C HRESULT STDAPICALLTYPE
|
---|
504 | #define STDAPI_(type) EXTERN_C type STDAPICALLTYPE
|
---|
505 |
|
---|
506 | #define STDMETHODIMP HRESULT STDMETHODCALLTYPE
|
---|
507 | #define STDMETHODIMP_(type) type STDMETHODCALLTYPE
|
---|
508 |
|
---|
509 | // The 'V' versions allow Variable Argument lists.
|
---|
510 |
|
---|
511 | #define STDAPIV EXTERN_C HRESULT STDAPIVCALLTYPE
|
---|
512 | #define STDAPIV_(type) EXTERN_C type STDAPIVCALLTYPE
|
---|
513 |
|
---|
514 | #define STDMETHODIMPV HRESULT STDMETHODVCALLTYPE
|
---|
515 | #define STDMETHODIMPV_(type) type STDMETHODVCALLTYPE
|
---|
516 |
|
---|
517 | // end_winnt
|
---|
518 |
|
---|
519 |
|
---|
520 | //
|
---|
521 | // Low order two bits of a handle are ignored by the system and available
|
---|
522 | // for use by application code as tag bits. The remaining bits are opaque
|
---|
523 | // and used to store a serial number and table index.
|
---|
524 | //
|
---|
525 |
|
---|
526 | #define OBJ_HANDLE_TAGBITS 0x00000003L
|
---|
527 |
|
---|
528 | //
|
---|
529 | // Cardinal Data Types [0 - 2**N-2)
|
---|
530 | //
|
---|
531 |
|
---|
532 | typedef char CCHAR; // winnt
|
---|
533 | typedef short CSHORT;
|
---|
534 | typedef ULONG CLONG;
|
---|
535 |
|
---|
536 | typedef CCHAR *PCCHAR;
|
---|
537 | typedef CSHORT *PCSHORT;
|
---|
538 | typedef CLONG *PCLONG;
|
---|
539 |
|
---|
540 | // end_ntminiport end_ntndis end_ntminitape
|
---|
541 |
|
---|
542 | //
|
---|
543 | // NLS basics (Locale and Language Ids)
|
---|
544 | //
|
---|
545 |
|
---|
546 | typedef ULONG LCID; // winnt
|
---|
547 | typedef PULONG PLCID; // winnt
|
---|
548 | typedef USHORT LANGID; // winnt
|
---|
549 |
|
---|
550 | //
|
---|
551 | // Logical Data Type - These are 32-bit logical values.
|
---|
552 | //
|
---|
553 |
|
---|
554 | typedef ULONG LOGICAL;
|
---|
555 | typedef ULONG *PLOGICAL;
|
---|
556 |
|
---|
557 | // begin_ntndis begin_windbgkd
|
---|
558 | //
|
---|
559 | // NTSTATUS
|
---|
560 | //
|
---|
561 |
|
---|
562 | typedef LONG NTSTATUS;
|
---|
563 | /*lint -save -e624 */ // Don't complain about different typedefs.
|
---|
564 | typedef NTSTATUS *PNTSTATUS;
|
---|
565 | /*lint -restore */ // Resume checking for different typedefs.
|
---|
566 |
|
---|
567 | //
|
---|
568 | // Status values are 32 bit values arranged as follows:
|
---|
569 | //
|
---|
570 | // 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1
|
---|
571 | // 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
|
---|
572 | // +---+-+-------------------------+-------------------------------+
|
---|
573 | // |Sev|C| Facility | Code |
|
---|
574 | // +---+-+-------------------------+-------------------------------+
|
---|
575 | //
|
---|
576 | // where
|
---|
577 | //
|
---|
578 | // Sev - is the severity code
|
---|
579 | //
|
---|
580 | // 00 - Success
|
---|
581 | // 01 - Informational
|
---|
582 | // 10 - Warning
|
---|
583 | // 11 - Error
|
---|
584 | //
|
---|
585 | // C - is the Customer code flag
|
---|
586 | //
|
---|
587 | // Facility - is the facility code
|
---|
588 | //
|
---|
589 | // Code - is the facility's status code
|
---|
590 | //
|
---|
591 |
|
---|
592 | //
|
---|
593 | // Generic test for success on any status value (non-negative numbers
|
---|
594 | // indicate success).
|
---|
595 | //
|
---|
596 |
|
---|
597 | #define NT_SUCCESS(Status) ((NTSTATUS)(Status) >= 0)
|
---|
598 |
|
---|
599 | //
|
---|
600 | // Generic test for information on any status value.
|
---|
601 | //
|
---|
602 |
|
---|
603 | #define NT_INFORMATION(Status) ((ULONG)(Status) >> 30 == 1)
|
---|
604 |
|
---|
605 | //
|
---|
606 | // Generic test for warning on any status value.
|
---|
607 | //
|
---|
608 |
|
---|
609 | #define NT_WARNING(Status) ((ULONG)(Status) >> 30 == 2)
|
---|
610 |
|
---|
611 | //
|
---|
612 | // Generic test for error on any status value.
|
---|
613 | //
|
---|
614 |
|
---|
615 | #define NT_ERROR(Status) ((ULONG)(Status) >> 30 == 3)
|
---|
616 |
|
---|
617 | // end_windbgkd
|
---|
618 | // begin_winnt
|
---|
619 | #define APPLICATION_ERROR_MASK 0x20000000
|
---|
620 | #define ERROR_SEVERITY_SUCCESS 0x00000000
|
---|
621 | #define ERROR_SEVERITY_INFORMATIONAL 0x40000000
|
---|
622 | #define ERROR_SEVERITY_WARNING 0x80000000
|
---|
623 | #define ERROR_SEVERITY_ERROR 0xC0000000
|
---|
624 | // end_winnt
|
---|
625 |
|
---|
626 | #ifndef __SECSTATUS_DEFINED__
|
---|
627 | typedef long SECURITY_STATUS;
|
---|
628 | #define __SECSTATUS_DEFINED__
|
---|
629 | #endif
|
---|
630 |
|
---|
631 |
|
---|
632 | // end_ntndis
|
---|
633 | //
|
---|
634 | // Large (64-bit) integer types and operations
|
---|
635 | //
|
---|
636 |
|
---|
637 | #define TIME LARGE_INTEGER
|
---|
638 | #define _TIME _LARGE_INTEGER
|
---|
639 | #define PTIME PLARGE_INTEGER
|
---|
640 | #define LowTime LowPart
|
---|
641 | #define HighTime HighPart
|
---|
642 |
|
---|
643 | // begin_winnt
|
---|
644 |
|
---|
645 | //
|
---|
646 | // _M_IX86 included so that EM CONTEXT structure compiles with
|
---|
647 | // x86 programs. *** TBD should this be for all architectures?
|
---|
648 | //
|
---|
649 |
|
---|
650 | //
|
---|
651 | // 16 byte aligned type for 128 bit floats
|
---|
652 | //
|
---|
653 |
|
---|
654 | //
|
---|
655 | // For we define a 128 bit structure and use __declspec(align(16)) pragma to
|
---|
656 | // align to 128 bits.
|
---|
657 | //
|
---|
658 |
|
---|
659 | #if defined(_M_IA64) && !defined(MIDL_PASS)
|
---|
660 | __declspec(align(16))
|
---|
661 | #endif
|
---|
662 | typedef struct _FLOAT128 {
|
---|
663 | __int64 LowPart;
|
---|
664 | __int64 HighPart;
|
---|
665 | } FLOAT128;
|
---|
666 |
|
---|
667 | typedef FLOAT128 *PFLOAT128;
|
---|
668 |
|
---|
669 | // end_winnt
|
---|
670 |
|
---|
671 |
|
---|
672 | // begin_winnt begin_ntminiport begin_ntndis begin_ntminitape
|
---|
673 |
|
---|
674 | //
|
---|
675 | // __int64 is only supported by 2.0 and later midl.
|
---|
676 | // __midl is set by the 2.0 midl and not by 1.0 midl.
|
---|
677 | //
|
---|
678 |
|
---|
679 | #define _ULONGLONG_
|
---|
680 | #if (!defined (_MAC) && (!defined(MIDL_PASS) || defined(__midl)) && (!defined(_M_IX86) || (defined(_INTEGRAL_MAX_BITS) && _INTEGRAL_MAX_BITS >= 64)))
|
---|
681 | typedef __int64 LONGLONG;
|
---|
682 | typedef unsigned __int64 ULONGLONG;
|
---|
683 |
|
---|
684 | #define MAXLONGLONG (0x7fffffffffffffff)
|
---|
685 | #else
|
---|
686 |
|
---|
687 | #if defined(_MAC) && defined(_MAC_INT_64)
|
---|
688 | typedef __int64 LONGLONG;
|
---|
689 | typedef unsigned __int64 ULONGLONG;
|
---|
690 |
|
---|
691 | #define MAXLONGLONG (0x7fffffffffffffff)
|
---|
692 | #else
|
---|
693 | typedef double LONGLONG;
|
---|
694 | typedef double ULONGLONG;
|
---|
695 | #endif //_MAC and int64
|
---|
696 |
|
---|
697 | #endif
|
---|
698 |
|
---|
699 | typedef LONGLONG *PLONGLONG;
|
---|
700 | typedef ULONGLONG *PULONGLONG;
|
---|
701 |
|
---|
702 | // Update Sequence Number
|
---|
703 |
|
---|
704 | typedef LONGLONG USN;
|
---|
705 |
|
---|
706 | #if defined(MIDL_PASS)
|
---|
707 | typedef struct _LARGE_INTEGER {
|
---|
708 | #else // MIDL_PASS
|
---|
709 | typedef union _LARGE_INTEGER {
|
---|
710 | struct {
|
---|
711 | ULONG LowPart;
|
---|
712 | LONG HighPart;
|
---|
713 | };
|
---|
714 | struct {
|
---|
715 | ULONG LowPart;
|
---|
716 | LONG HighPart;
|
---|
717 | } u;
|
---|
718 | #endif //MIDL_PASS
|
---|
719 | LONGLONG QuadPart;
|
---|
720 | } LARGE_INTEGER;
|
---|
721 |
|
---|
722 | typedef LARGE_INTEGER *PLARGE_INTEGER;
|
---|
723 |
|
---|
724 | #if defined(MIDL_PASS)
|
---|
725 | typedef struct _ULARGE_INTEGER {
|
---|
726 | #else // MIDL_PASS
|
---|
727 | typedef union _ULARGE_INTEGER {
|
---|
728 | struct {
|
---|
729 | ULONG LowPart;
|
---|
730 | ULONG HighPart;
|
---|
731 | };
|
---|
732 | struct {
|
---|
733 | ULONG LowPart;
|
---|
734 | ULONG HighPart;
|
---|
735 | } u;
|
---|
736 | #endif //MIDL_PASS
|
---|
737 | ULONGLONG QuadPart;
|
---|
738 | } ULARGE_INTEGER;
|
---|
739 |
|
---|
740 | typedef ULARGE_INTEGER *PULARGE_INTEGER;
|
---|
741 |
|
---|
742 | // end_ntminiport end_ntndis end_ntminitape
|
---|
743 |
|
---|
744 |
|
---|
745 | //
|
---|
746 | // Locally Unique Identifier
|
---|
747 | //
|
---|
748 |
|
---|
749 | typedef struct _LUID {
|
---|
750 | ULONG LowPart;
|
---|
751 | LONG HighPart;
|
---|
752 | } LUID, *PLUID;
|
---|
753 |
|
---|
754 | #define _DWORDLONG_
|
---|
755 | typedef ULONGLONG DWORDLONG;
|
---|
756 | typedef DWORDLONG *PDWORDLONG;
|
---|
757 |
|
---|
758 | // end_winnt
|
---|
759 |
|
---|
760 | // begin_ntminiport begin_ntndis
|
---|
761 |
|
---|
762 | //
|
---|
763 | // Physical address.
|
---|
764 | //
|
---|
765 |
|
---|
766 | typedef LARGE_INTEGER PHYSICAL_ADDRESS, *PPHYSICAL_ADDRESS;
|
---|
767 |
|
---|
768 | // end_ntminiport end_ntndis
|
---|
769 |
|
---|
770 | // begin_winnt
|
---|
771 |
|
---|
772 | //
|
---|
773 | // Define operations to logically shift an int64 by 0..31 bits and to multiply
|
---|
774 | // 32-bits by 32-bits to form a 64-bit product.
|
---|
775 | //
|
---|
776 |
|
---|
777 | #if defined(MIDL_PASS) || defined(RC_INVOKED)
|
---|
778 |
|
---|
779 | //
|
---|
780 | // Midl does not understand inline assembler. Therefore, the Rtl functions
|
---|
781 | // are used for shifts by 0.31 and multiplies of 32-bits times 32-bits to
|
---|
782 | // form a 64-bit product.
|
---|
783 | //
|
---|
784 |
|
---|
785 | #define Int32x32To64(a, b) ((LONGLONG)((LONG)(a)) * (LONGLONG)((LONG)(b)))
|
---|
786 | #define UInt32x32To64(a, b) ((ULONGLONG)((ULONG)(a)) * (ULONGLONG)((ULONG)(b)))
|
---|
787 |
|
---|
788 | #define Int64ShllMod32(a, b) ((ULONGLONG)(a) << (b))
|
---|
789 | #define Int64ShraMod32(a, b) ((LONGLONG)(a) >> (b))
|
---|
790 | #define Int64ShrlMod32(a, b) ((ULONGLONG)(a) >> (b))
|
---|
791 |
|
---|
792 | #elif defined(_M_IX86)
|
---|
793 |
|
---|
794 | //
|
---|
795 | // The x86 C compiler understands inline assembler. Therefore, inline functions
|
---|
796 | // that employ inline assembler are used for shifts of 0..31. The multiplies
|
---|
797 | // rely on the compiler recognizing the cast of the multiplicand to int64 to
|
---|
798 | // generate the optimal code inline.
|
---|
799 | //
|
---|
800 |
|
---|
801 | #define Int32x32To64( a, b ) (LONGLONG)((LONGLONG)(LONG)(a) * (LONG)(b))
|
---|
802 | #define UInt32x32To64( a, b ) (ULONGLONG)((ULONGLONG)(ULONG)(a) * (ULONG)(b))
|
---|
803 |
|
---|
804 | ULONGLONG
|
---|
805 | NTAPI
|
---|
806 | Int64ShllMod32 (
|
---|
807 | ULONGLONG Value,
|
---|
808 | ULONG ShiftCount
|
---|
809 | );
|
---|
810 |
|
---|
811 | LONGLONG
|
---|
812 | NTAPI
|
---|
813 | Int64ShraMod32 (
|
---|
814 | LONGLONG Value,
|
---|
815 | ULONG ShiftCount
|
---|
816 | );
|
---|
817 |
|
---|
818 | ULONGLONG
|
---|
819 | NTAPI
|
---|
820 | Int64ShrlMod32 (
|
---|
821 | ULONGLONG Value,
|
---|
822 | ULONG ShiftCount
|
---|
823 | );
|
---|
824 |
|
---|
825 | #if _MSC_VER >= 1200
|
---|
826 | #pragma warning(push)
|
---|
827 | #endif
|
---|
828 | #pragma warning(disable:4035) // re-enable below
|
---|
829 |
|
---|
830 | __inline ULONGLONG
|
---|
831 | NTAPI
|
---|
832 | Int64ShllMod32 (
|
---|
833 | ULONGLONG Value,
|
---|
834 | ULONG ShiftCount
|
---|
835 | )
|
---|
836 | {
|
---|
837 | __asm {
|
---|
838 | mov ecx, ShiftCount
|
---|
839 | mov eax, dword ptr [Value]
|
---|
840 | mov edx, dword ptr [Value+4]
|
---|
841 | shld edx, eax, cl
|
---|
842 | shl eax, cl
|
---|
843 | }
|
---|
844 | }
|
---|
845 |
|
---|
846 | __inline LONGLONG
|
---|
847 | NTAPI
|
---|
848 | Int64ShraMod32 (
|
---|
849 | LONGLONG Value,
|
---|
850 | ULONG ShiftCount
|
---|
851 | )
|
---|
852 | {
|
---|
853 | __asm {
|
---|
854 | mov ecx, ShiftCount
|
---|
855 | mov eax, dword ptr [Value]
|
---|
856 | mov edx, dword ptr [Value+4]
|
---|
857 | shrd eax, edx, cl
|
---|
858 | sar edx, cl
|
---|
859 | }
|
---|
860 | }
|
---|
861 |
|
---|
862 | __inline ULONGLONG
|
---|
863 | NTAPI
|
---|
864 | Int64ShrlMod32 (
|
---|
865 | ULONGLONG Value,
|
---|
866 | ULONG ShiftCount
|
---|
867 | )
|
---|
868 | {
|
---|
869 | __asm {
|
---|
870 | mov ecx, ShiftCount
|
---|
871 | mov eax, dword ptr [Value]
|
---|
872 | mov edx, dword ptr [Value+4]
|
---|
873 | shrd eax, edx, cl
|
---|
874 | shr edx, cl
|
---|
875 | }
|
---|
876 | }
|
---|
877 |
|
---|
878 | #if _MSC_VER >= 1200
|
---|
879 | #pragma warning(pop)
|
---|
880 | #else
|
---|
881 | #pragma warning(default:4035)
|
---|
882 | #endif
|
---|
883 |
|
---|
884 | #elif defined(_68K_) || defined(_MPPC_)
|
---|
885 |
|
---|
886 | //
|
---|
887 | // The Macintosh 68K and PowerPC compilers do not currently support int64.
|
---|
888 | //
|
---|
889 |
|
---|
890 | #define Int32x32To64(a, b) ((LONGLONG)((LONG)(a)) * (LONGLONG)((LONG)(b)))
|
---|
891 | #define UInt32x32To64(a, b) ((DWORDLONG)((DWORD)(a)) * (DWORDLONG)((DWORD)(b)))
|
---|
892 |
|
---|
893 | #define Int64ShllMod32(a, b) ((DWORDLONG)(a) << (b))
|
---|
894 | #define Int64ShraMod32(a, b) ((LONGLONG)(a) >> (b))
|
---|
895 | #define Int64ShrlMod32(a, b) ((DWORDLONG)(a) >> (b))
|
---|
896 |
|
---|
897 | #elif defined(_M_IA64) || defined(_M_AMD64)
|
---|
898 |
|
---|
899 | //
|
---|
900 | // IA64 and AMD64 have native 64-bit operations that are just as fast as their
|
---|
901 | // 32-bit counter parts. Therefore, the int64 data type is used directly to form
|
---|
902 | // shifts of 0..31 and multiplies of 32-bits times 32-bits to form a 64-bit
|
---|
903 | // product.
|
---|
904 | //
|
---|
905 |
|
---|
906 | #define Int32x32To64(a, b) ((LONGLONG)((LONG)(a)) * (LONGLONG)((LONG)(b)))
|
---|
907 | #define UInt32x32To64(a, b) ((ULONGLONG)((ULONG)(a)) * (ULONGLONG)((ULONG)(b)))
|
---|
908 |
|
---|
909 | #define Int64ShllMod32(a, b) ((ULONGLONG)(a) << (b))
|
---|
910 | #define Int64ShraMod32(a, b) ((LONGLONG)(a) >> (b))
|
---|
911 | #define Int64ShrlMod32(a, b) ((ULONGLONG)(a) >> (b))
|
---|
912 |
|
---|
913 | #else
|
---|
914 |
|
---|
915 | #error Must define a target architecture.
|
---|
916 |
|
---|
917 | #endif
|
---|
918 |
|
---|
919 | // end_winnt
|
---|
920 |
|
---|
921 | //
|
---|
922 | // Define rotate intrinsics.
|
---|
923 | //
|
---|
924 |
|
---|
925 | #ifdef __cplusplus
|
---|
926 | extern "C" {
|
---|
927 | #endif
|
---|
928 |
|
---|
929 | #define RotateLeft32 _rotl
|
---|
930 | #define RotateLeft64 _rotl64
|
---|
931 | #define RotateRight32 _rotr
|
---|
932 | #define RotateRight64 _rotr64
|
---|
933 |
|
---|
934 | unsigned int
|
---|
935 | __cdecl
|
---|
936 | _rotl (
|
---|
937 | IN unsigned int Value,
|
---|
938 | IN int Shift
|
---|
939 | );
|
---|
940 |
|
---|
941 | unsigned __int64
|
---|
942 | __cdecl
|
---|
943 | _rotl64 (
|
---|
944 | IN unsigned __int64 Value,
|
---|
945 | IN int Shift
|
---|
946 | );
|
---|
947 |
|
---|
948 | unsigned int
|
---|
949 | __cdecl
|
---|
950 | _rotr (
|
---|
951 | IN unsigned int Value,
|
---|
952 | IN int Shift
|
---|
953 | );
|
---|
954 |
|
---|
955 | unsigned __int64
|
---|
956 | __cdecl
|
---|
957 | _rotr64 (
|
---|
958 | IN unsigned __int64 Value,
|
---|
959 | IN int Shift
|
---|
960 | );
|
---|
961 |
|
---|
962 | #pragma intrinsic(_rotl)
|
---|
963 | #pragma intrinsic(_rotl64)
|
---|
964 | #pragma intrinsic(_rotr)
|
---|
965 | #pragma intrinsic(_rotr64)
|
---|
966 |
|
---|
967 | #ifdef __cplusplus
|
---|
968 | }
|
---|
969 | #endif
|
---|
970 |
|
---|
971 | //
|
---|
972 | // Event type
|
---|
973 | //
|
---|
974 |
|
---|
975 | typedef enum _EVENT_TYPE {
|
---|
976 | NotificationEvent,
|
---|
977 | SynchronizationEvent
|
---|
978 | } EVENT_TYPE;
|
---|
979 |
|
---|
980 | //
|
---|
981 | // Timer type
|
---|
982 | //
|
---|
983 |
|
---|
984 | typedef enum _TIMER_TYPE {
|
---|
985 | NotificationTimer,
|
---|
986 | SynchronizationTimer
|
---|
987 | } TIMER_TYPE;
|
---|
988 |
|
---|
989 | //
|
---|
990 | // Wait type
|
---|
991 | //
|
---|
992 |
|
---|
993 | typedef enum _WAIT_TYPE {
|
---|
994 | WaitAll,
|
---|
995 | WaitAny
|
---|
996 | } WAIT_TYPE;
|
---|
997 |
|
---|
998 | //
|
---|
999 | // Pointer to an Asciiz string
|
---|
1000 | //
|
---|
1001 |
|
---|
1002 | typedef CHAR *PSZ;
|
---|
1003 | typedef CONST char *PCSZ;
|
---|
1004 |
|
---|
1005 | // begin_ntndis
|
---|
1006 | //
|
---|
1007 | // Counted String
|
---|
1008 | //
|
---|
1009 |
|
---|
1010 | typedef USHORT RTL_STRING_LENGTH_TYPE;
|
---|
1011 |
|
---|
1012 | typedef struct _STRING {
|
---|
1013 | USHORT Length;
|
---|
1014 | USHORT MaximumLength;
|
---|
1015 | #ifdef MIDL_PASS
|
---|
1016 | [size_is(MaximumLength), length_is(Length) ]
|
---|
1017 | #endif // MIDL_PASS
|
---|
1018 | PCHAR Buffer;
|
---|
1019 | } STRING;
|
---|
1020 | typedef STRING *PSTRING;
|
---|
1021 |
|
---|
1022 | typedef STRING ANSI_STRING;
|
---|
1023 | typedef PSTRING PANSI_STRING;
|
---|
1024 |
|
---|
1025 | typedef STRING OEM_STRING;
|
---|
1026 | typedef PSTRING POEM_STRING;
|
---|
1027 | typedef CONST STRING* PCOEM_STRING;
|
---|
1028 |
|
---|
1029 | //
|
---|
1030 | // CONSTCounted String
|
---|
1031 | //
|
---|
1032 |
|
---|
1033 | typedef struct _CSTRING {
|
---|
1034 | USHORT Length;
|
---|
1035 | USHORT MaximumLength;
|
---|
1036 | CONST char *Buffer;
|
---|
1037 | } CSTRING;
|
---|
1038 | typedef CSTRING *PCSTRING;
|
---|
1039 | #define ANSI_NULL ((CHAR)0) // winnt
|
---|
1040 |
|
---|
1041 | typedef STRING CANSI_STRING;
|
---|
1042 | typedef PSTRING PCANSI_STRING;
|
---|
1043 |
|
---|
1044 | //
|
---|
1045 | // Unicode strings are counted 16-bit character strings. If they are
|
---|
1046 | // NULL terminated, Length does not include trailing NULL.
|
---|
1047 | //
|
---|
1048 |
|
---|
1049 | typedef struct _UNICODE_STRING {
|
---|
1050 | USHORT Length;
|
---|
1051 | USHORT MaximumLength;
|
---|
1052 | #ifdef MIDL_PASS
|
---|
1053 | [size_is(MaximumLength / 2), length_is((Length) / 2) ] USHORT * Buffer;
|
---|
1054 | #else // MIDL_PASS
|
---|
1055 | PWSTR Buffer;
|
---|
1056 | #endif // MIDL_PASS
|
---|
1057 | } UNICODE_STRING;
|
---|
1058 | typedef UNICODE_STRING *PUNICODE_STRING;
|
---|
1059 | typedef const UNICODE_STRING *PCUNICODE_STRING;
|
---|
1060 | #define UNICODE_NULL ((WCHAR)0) // winnt
|
---|
1061 |
|
---|
1062 | #if _WIN32_WINNT >= 0x0501
|
---|
1063 |
|
---|
1064 | #define UNICODE_STRING_MAX_BYTES ((USHORT) 65534) // winnt
|
---|
1065 | #define UNICODE_STRING_MAX_CHARS (32767) // winnt
|
---|
1066 |
|
---|
1067 | #define DECLARE_CONST_UNICODE_STRING(_variablename, _string) \
|
---|
1068 | const WCHAR _variablename ## _buffer[] = _string; \
|
---|
1069 | const UNICODE_STRING _variablename = { sizeof(_string) - sizeof(WCHAR), sizeof(_string), (PWSTR) _variablename ## _buffer };
|
---|
1070 |
|
---|
1071 | #endif // _WIN32_WINNT >= 0x0501
|
---|
1072 |
|
---|
1073 | // begin_ntminiport begin_ntminitape
|
---|
1074 |
|
---|
1075 | //
|
---|
1076 | // Boolean
|
---|
1077 | //
|
---|
1078 |
|
---|
1079 | typedef UCHAR BOOLEAN; // winnt
|
---|
1080 | typedef BOOLEAN *PBOOLEAN; // winnt
|
---|
1081 |
|
---|
1082 | // end_ntminiport end_ntminitape
|
---|
1083 |
|
---|
1084 | // begin_winnt
|
---|
1085 | //
|
---|
1086 | // Doubly linked list structure. Can be used as either a list head, or
|
---|
1087 | // as link words.
|
---|
1088 | //
|
---|
1089 |
|
---|
1090 | typedef struct _LIST_ENTRY {
|
---|
1091 | struct _LIST_ENTRY *Flink;
|
---|
1092 | struct _LIST_ENTRY *Blink;
|
---|
1093 | } LIST_ENTRY, *PLIST_ENTRY, *RESTRICTED_POINTER PRLIST_ENTRY;
|
---|
1094 |
|
---|
1095 | //
|
---|
1096 | // Singly linked list structure. Can be used as either a list head, or
|
---|
1097 | // as link words.
|
---|
1098 | //
|
---|
1099 |
|
---|
1100 | typedef struct _SINGLE_LIST_ENTRY {
|
---|
1101 | struct _SINGLE_LIST_ENTRY *Next;
|
---|
1102 | } SINGLE_LIST_ENTRY, *PSINGLE_LIST_ENTRY;
|
---|
1103 | // end_winnt end_ntndis
|
---|
1104 |
|
---|
1105 | // begin_winnt
|
---|
1106 |
|
---|
1107 | //
|
---|
1108 | // These are needed for portable debugger support.
|
---|
1109 | //
|
---|
1110 |
|
---|
1111 | typedef struct LIST_ENTRY32 {
|
---|
1112 | ULONG Flink;
|
---|
1113 | ULONG Blink;
|
---|
1114 | } LIST_ENTRY32;
|
---|
1115 | typedef LIST_ENTRY32 *PLIST_ENTRY32;
|
---|
1116 |
|
---|
1117 | typedef struct LIST_ENTRY64 {
|
---|
1118 | ULONGLONG Flink;
|
---|
1119 | ULONGLONG Blink;
|
---|
1120 | } LIST_ENTRY64;
|
---|
1121 | typedef LIST_ENTRY64 *PLIST_ENTRY64;
|
---|
1122 |
|
---|
1123 | // end_winnt
|
---|
1124 |
|
---|
1125 |
|
---|
1126 | #if !defined(MIDL_PASS)
|
---|
1127 | __inline
|
---|
1128 | void
|
---|
1129 | ListEntry32To64(
|
---|
1130 | IN PLIST_ENTRY32 l32,
|
---|
1131 | OUT PLIST_ENTRY64 l64
|
---|
1132 | )
|
---|
1133 | {
|
---|
1134 | l64->Flink = (ULONGLONG)(LONGLONG)(LONG)l32->Flink;
|
---|
1135 | l64->Blink = (ULONGLONG)(LONGLONG)(LONG)l32->Blink;
|
---|
1136 | }
|
---|
1137 |
|
---|
1138 | __inline
|
---|
1139 | void
|
---|
1140 | ListEntry64To32(
|
---|
1141 | IN PLIST_ENTRY64 l64,
|
---|
1142 | OUT PLIST_ENTRY32 l32
|
---|
1143 | )
|
---|
1144 | {
|
---|
1145 | l32->Flink = (ULONG)l64->Flink;
|
---|
1146 | l32->Blink = (ULONG)l64->Blink;
|
---|
1147 | }
|
---|
1148 | #endif
|
---|
1149 |
|
---|
1150 | typedef struct _STRING32 {
|
---|
1151 | USHORT Length;
|
---|
1152 | USHORT MaximumLength;
|
---|
1153 | ULONG Buffer;
|
---|
1154 | } STRING32;
|
---|
1155 | typedef STRING32 *PSTRING32;
|
---|
1156 |
|
---|
1157 | typedef STRING32 UNICODE_STRING32;
|
---|
1158 | typedef UNICODE_STRING32 *PUNICODE_STRING32;
|
---|
1159 |
|
---|
1160 | typedef STRING32 ANSI_STRING32;
|
---|
1161 | typedef ANSI_STRING32 *PANSI_STRING32;
|
---|
1162 |
|
---|
1163 |
|
---|
1164 | typedef struct _STRING64 {
|
---|
1165 | USHORT Length;
|
---|
1166 | USHORT MaximumLength;
|
---|
1167 | ULONGLONG Buffer;
|
---|
1168 | } STRING64;
|
---|
1169 | typedef STRING64 *PSTRING64;
|
---|
1170 |
|
---|
1171 | typedef STRING64 UNICODE_STRING64;
|
---|
1172 | typedef UNICODE_STRING64 *PUNICODE_STRING64;
|
---|
1173 |
|
---|
1174 | typedef STRING64 ANSI_STRING64;
|
---|
1175 | typedef ANSI_STRING64 *PANSI_STRING64;
|
---|
1176 |
|
---|
1177 |
|
---|
1178 |
|
---|
1179 | //
|
---|
1180 | // Valid values for the Attributes field
|
---|
1181 | //
|
---|
1182 |
|
---|
1183 | #define OBJ_INHERIT 0x00000002L
|
---|
1184 | #define OBJ_PERMANENT 0x00000010L
|
---|
1185 | #define OBJ_EXCLUSIVE 0x00000020L
|
---|
1186 | #define OBJ_CASE_INSENSITIVE 0x00000040L
|
---|
1187 | #define OBJ_OPENIF 0x00000080L
|
---|
1188 | #define OBJ_OPENLINK 0x00000100L
|
---|
1189 | #define OBJ_KERNEL_HANDLE 0x00000200L
|
---|
1190 | #define OBJ_FORCE_ACCESS_CHECK 0x00000400L
|
---|
1191 | #define OBJ_VALID_ATTRIBUTES 0x000007F2L
|
---|
1192 |
|
---|
1193 | //
|
---|
1194 | // Object Attributes structure
|
---|
1195 | //
|
---|
1196 |
|
---|
1197 | typedef struct _OBJECT_ATTRIBUTES64 {
|
---|
1198 | ULONG Length;
|
---|
1199 | ULONG64 RootDirectory;
|
---|
1200 | ULONG64 ObjectName;
|
---|
1201 | ULONG Attributes;
|
---|
1202 | ULONG64 SecurityDescriptor;
|
---|
1203 | ULONG64 SecurityQualityOfService;
|
---|
1204 | } OBJECT_ATTRIBUTES64;
|
---|
1205 | typedef OBJECT_ATTRIBUTES64 *POBJECT_ATTRIBUTES64;
|
---|
1206 | typedef CONST OBJECT_ATTRIBUTES64 *PCOBJECT_ATTRIBUTES64;
|
---|
1207 |
|
---|
1208 | typedef struct _OBJECT_ATTRIBUTES32 {
|
---|
1209 | ULONG Length;
|
---|
1210 | ULONG RootDirectory;
|
---|
1211 | ULONG ObjectName;
|
---|
1212 | ULONG Attributes;
|
---|
1213 | ULONG SecurityDescriptor;
|
---|
1214 | ULONG SecurityQualityOfService;
|
---|
1215 | } OBJECT_ATTRIBUTES32;
|
---|
1216 | typedef OBJECT_ATTRIBUTES32 *POBJECT_ATTRIBUTES32;
|
---|
1217 | typedef CONST OBJECT_ATTRIBUTES32 *PCOBJECT_ATTRIBUTES32;
|
---|
1218 |
|
---|
1219 | typedef struct _OBJECT_ATTRIBUTES {
|
---|
1220 | ULONG Length;
|
---|
1221 | HANDLE RootDirectory;
|
---|
1222 | PUNICODE_STRING ObjectName;
|
---|
1223 | ULONG Attributes;
|
---|
1224 | PVOID SecurityDescriptor; // Points to type SECURITY_DESCRIPTOR
|
---|
1225 | PVOID SecurityQualityOfService; // Points to type SECURITY_QUALITY_OF_SERVICE
|
---|
1226 | } OBJECT_ATTRIBUTES;
|
---|
1227 | typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;
|
---|
1228 | typedef CONST OBJECT_ATTRIBUTES *PCOBJECT_ATTRIBUTES;
|
---|
1229 |
|
---|
1230 | //++
|
---|
1231 | //
|
---|
1232 | // VOID
|
---|
1233 | // InitializeObjectAttributes(
|
---|
1234 | // OUT POBJECT_ATTRIBUTES p,
|
---|
1235 | // IN PUNICODE_STRING n,
|
---|
1236 | // IN ULONG a,
|
---|
1237 | // IN HANDLE r,
|
---|
1238 | // IN PSECURITY_DESCRIPTOR s
|
---|
1239 | // )
|
---|
1240 | //
|
---|
1241 | //--
|
---|
1242 |
|
---|
1243 | #define InitializeObjectAttributes( p, n, a, r, s ) { \
|
---|
1244 | (p)->Length = sizeof( OBJECT_ATTRIBUTES ); \
|
---|
1245 | (p)->RootDirectory = r; \
|
---|
1246 | (p)->Attributes = a; \
|
---|
1247 | (p)->ObjectName = n; \
|
---|
1248 | (p)->SecurityDescriptor = s; \
|
---|
1249 | (p)->SecurityQualityOfService = NULL; \
|
---|
1250 | }
|
---|
1251 |
|
---|
1252 | // RTL_ to avoid collisions in the global namespace.
|
---|
1253 | // I don't believe there are possible/likely constant RootDirectory
|
---|
1254 | // or SecurityDescriptor values other than NULL, so they are hardcoded.
|
---|
1255 | // As well, the string will generally be const, so we cast that away.
|
---|
1256 | #define RTL_CONSTANT_OBJECT_ATTRIBUTES(n, a) \
|
---|
1257 | { sizeof(OBJECT_ATTRIBUTES), NULL, RTL_CONST_CAST(PUNICODE_STRING)(n), a, NULL, NULL }
|
---|
1258 |
|
---|
1259 | // This synonym is more appropriate for initializing what isn't actually const.
|
---|
1260 | #define RTL_INIT_OBJECT_ATTRIBUTES(n, a) RTL_CONSTANT_OBJECT_ATTRIBUTES(n, a)
|
---|
1261 |
|
---|
1262 | // begin_ntminiport begin_ntndis begin_ntminitape
|
---|
1263 |
|
---|
1264 | //
|
---|
1265 | // Constants
|
---|
1266 | //
|
---|
1267 |
|
---|
1268 | #define FALSE 0
|
---|
1269 | #define TRUE 1
|
---|
1270 |
|
---|
1271 | #ifndef NULL
|
---|
1272 | #ifdef __cplusplus
|
---|
1273 | #define NULL 0
|
---|
1274 | #define NULL64 0
|
---|
1275 | #else
|
---|
1276 | #define NULL ((void *)0)
|
---|
1277 | #define NULL64 ((void * POINTER_64)0)
|
---|
1278 | #endif
|
---|
1279 | #endif // NULL
|
---|
1280 |
|
---|
1281 | // end_ntminiport end_ntndis end_ntminitape
|
---|
1282 |
|
---|
1283 | // begin_winnt begin_ntndis
|
---|
1284 |
|
---|
1285 | #include <guiddef.h>
|
---|
1286 |
|
---|
1287 | #ifndef __OBJECTID_DEFINED
|
---|
1288 | #define __OBJECTID_DEFINED
|
---|
1289 |
|
---|
1290 | typedef struct _OBJECTID { // size is 20
|
---|
1291 | GUID Lineage;
|
---|
1292 | ULONG Uniquifier;
|
---|
1293 | } OBJECTID;
|
---|
1294 | #endif // !_OBJECTID_DEFINED
|
---|
1295 |
|
---|
1296 | // end_winnt end_ntndis
|
---|
1297 |
|
---|
1298 |
|
---|
1299 | #define MINCHAR 0x80 // winnt
|
---|
1300 | #define MAXCHAR 0x7f // winnt
|
---|
1301 | #define MINSHORT 0x8000 // winnt
|
---|
1302 | #define MAXSHORT 0x7fff // winnt
|
---|
1303 | #define MINLONG 0x80000000 // winnt
|
---|
1304 | #define MAXLONG 0x7fffffff // winnt
|
---|
1305 | #define MAXUCHAR 0xff // winnt
|
---|
1306 | #define MAXUSHORT 0xffff // winnt
|
---|
1307 | #define MAXULONG 0xffffffff // winnt
|
---|
1308 |
|
---|
1309 | //
|
---|
1310 | // Useful Helper Macros
|
---|
1311 | //
|
---|
1312 |
|
---|
1313 | // begin_ntndis
|
---|
1314 | //
|
---|
1315 | // Determine if an argument is present by testing the value of the pointer
|
---|
1316 | // to the argument value.
|
---|
1317 | //
|
---|
1318 |
|
---|
1319 | #define ARGUMENT_PRESENT(ArgumentPointer) (\
|
---|
1320 | (CHAR *)((ULONG_PTR)(ArgumentPointer)) != (CHAR *)(NULL) )
|
---|
1321 |
|
---|
1322 | // begin_winnt begin_ntminiport
|
---|
1323 | //
|
---|
1324 | // Calculate the byte offset of a field in a structure of type type.
|
---|
1325 | //
|
---|
1326 |
|
---|
1327 | #define FIELD_OFFSET(type, field) ((LONG)(LONG_PTR)&(((type *)0)->field))
|
---|
1328 |
|
---|
1329 | //
|
---|
1330 | // Calculate the size of a field in a structure of type type, without
|
---|
1331 | // knowing or stating the type of the field.
|
---|
1332 | //
|
---|
1333 | #define RTL_FIELD_SIZE(type, field) (sizeof(((type *)0)->field))
|
---|
1334 |
|
---|
1335 | //
|
---|
1336 | // Calculate the size of a structure of type type up through and
|
---|
1337 | // including a field.
|
---|
1338 | //
|
---|
1339 | #define RTL_SIZEOF_THROUGH_FIELD(type, field) \
|
---|
1340 | (FIELD_OFFSET(type, field) + RTL_FIELD_SIZE(type, field))
|
---|
1341 |
|
---|
1342 | //
|
---|
1343 | // RTL_CONTAINS_FIELD usage:
|
---|
1344 | //
|
---|
1345 | // if (RTL_CONTAINS_FIELD(pBlock, pBlock->cbSize, dwMumble)) { // safe to use pBlock->dwMumble
|
---|
1346 | //
|
---|
1347 | #define RTL_CONTAINS_FIELD(Struct, Size, Field) \
|
---|
1348 | ( (((PCHAR)(&(Struct)->Field)) + sizeof((Struct)->Field)) <= (((PCHAR)(Struct))+(Size)) )
|
---|
1349 |
|
---|
1350 | //
|
---|
1351 | // Return the number of elements in a statically sized array.
|
---|
1352 | // ULONG Buffer[100];
|
---|
1353 | // RTL_NUMBER_OF(Buffer) == 100
|
---|
1354 | // This is also popularly known as: NUMBER_OF, ARRSIZE, _countof, NELEM, etc.
|
---|
1355 | //
|
---|
1356 | #define RTL_NUMBER_OF(A) (sizeof(A)/sizeof((A)[0]))
|
---|
1357 |
|
---|
1358 | //
|
---|
1359 | // An expression that yields the type of a field in a struct.
|
---|
1360 | //
|
---|
1361 | #define RTL_FIELD_TYPE(type, field) (((type*)0)->field)
|
---|
1362 |
|
---|
1363 | // RTL_ to avoid collisions in the global namespace.
|
---|
1364 | //
|
---|
1365 | // Given typedef struct _FOO { BYTE Bar[123]; } FOO;
|
---|
1366 | // RTL_NUMBER_OF_FIELD(FOO, Bar) == 123
|
---|
1367 | //
|
---|
1368 | #define RTL_NUMBER_OF_FIELD(type, field) (RTL_NUMBER_OF(RTL_FIELD_TYPE(type, field)))
|
---|
1369 |
|
---|
1370 | //
|
---|
1371 | // eg:
|
---|
1372 | // typedef struct FOO {
|
---|
1373 | // ULONG Integer;
|
---|
1374 | // PVOID Pointer;
|
---|
1375 | // } FOO;
|
---|
1376 | //
|
---|
1377 | // RTL_PADDING_BETWEEN_FIELDS(FOO, Integer, Pointer) == 0 for Win32, 4 for Win64
|
---|
1378 | //
|
---|
1379 | #define RTL_PADDING_BETWEEN_FIELDS(T, F1, F2) \
|
---|
1380 | ((FIELD_OFFSET(T, F2) > FIELD_OFFSET(T, F1)) \
|
---|
1381 | ? (FIELD_OFFSET(T, F2) - FIELD_OFFSET(T, F1) - RTL_FIELD_SIZE(T, F1)) \
|
---|
1382 | : (FIELD_OFFSET(T, F1) - FIELD_OFFSET(T, F2) - RTL_FIELD_SIZE(T, F2)))
|
---|
1383 |
|
---|
1384 | // RTL_ to avoid collisions in the global namespace.
|
---|
1385 | #if defined(__cplusplus)
|
---|
1386 | #define RTL_CONST_CAST(type) const_cast<type>
|
---|
1387 | #else
|
---|
1388 | #define RTL_CONST_CAST(type) (type)
|
---|
1389 | #endif
|
---|
1390 |
|
---|
1391 | // end_winnt
|
---|
1392 | //
|
---|
1393 | // This works "generically" for Unicode and Ansi/Oem strings.
|
---|
1394 | // Usage:
|
---|
1395 | // const static UNICODE_STRING FooU = RTL_CONSTANT_STRING(L"Foo");
|
---|
1396 | // const static STRING Foo = RTL_CONSTANT_STRING( "Foo");
|
---|
1397 | // instead of the slower:
|
---|
1398 | // UNICODE_STRING FooU;
|
---|
1399 | // STRING Foo;
|
---|
1400 | // RtlInitUnicodeString(&FooU, L"Foo");
|
---|
1401 | // RtlInitString(&Foo , "Foo");
|
---|
1402 | //
|
---|
1403 | #define RTL_CONSTANT_STRING(s) { sizeof( s ) - sizeof( (s)[0] ), sizeof( s ), s }
|
---|
1404 | // begin_winnt
|
---|
1405 |
|
---|
1406 | // like sizeof
|
---|
1407 | // usually this would be * CHAR_BIT, but we don't necessarily have #include <limits.h>
|
---|
1408 | #define RTL_BITS_OF(sizeOfArg) (sizeof(sizeOfArg) * 8)
|
---|
1409 |
|
---|
1410 | #define RTL_BITS_OF_FIELD(type, field) (RTL_BITS_OF(RTL_FIELD_TYPE(type, field)))
|
---|
1411 |
|
---|
1412 | //
|
---|
1413 | // Calculate the address of the base of the structure given its type, and an
|
---|
1414 | // address of a field within the structure.
|
---|
1415 | //
|
---|
1416 |
|
---|
1417 | #define CONTAINING_RECORD(address, type, field) ((type *)( \
|
---|
1418 | (PCHAR)(address) - \
|
---|
1419 | (ULONG_PTR)(&((type *)0)->field)))
|
---|
1420 |
|
---|
1421 | // end_winnt end_ntminiport end_ntndis
|
---|
1422 |
|
---|
1423 | //
|
---|
1424 | // Exception handler routine definition.
|
---|
1425 | //
|
---|
1426 |
|
---|
1427 | struct _CONTEXT;
|
---|
1428 | struct _EXCEPTION_RECORD;
|
---|
1429 |
|
---|
1430 | typedef
|
---|
1431 | EXCEPTION_DISPOSITION
|
---|
1432 | (*PEXCEPTION_ROUTINE) (
|
---|
1433 | IN struct _EXCEPTION_RECORD *ExceptionRecord,
|
---|
1434 | IN PVOID EstablisherFrame,
|
---|
1435 | IN OUT struct _CONTEXT *ContextRecord,
|
---|
1436 | IN OUT PVOID DispatcherContext
|
---|
1437 | );
|
---|
1438 |
|
---|
1439 | // begin_ntminiport begin_ntndis
|
---|
1440 |
|
---|
1441 | //
|
---|
1442 | // Interrupt Request Level (IRQL)
|
---|
1443 | //
|
---|
1444 |
|
---|
1445 | typedef UCHAR KIRQL;
|
---|
1446 |
|
---|
1447 | typedef KIRQL *PKIRQL;
|
---|
1448 |
|
---|
1449 | // end_ntminiport end_ntndis
|
---|
1450 |
|
---|
1451 | //
|
---|
1452 | // Product types
|
---|
1453 | //
|
---|
1454 |
|
---|
1455 | typedef enum _NT_PRODUCT_TYPE {
|
---|
1456 | NtProductWinNt = 1,
|
---|
1457 | NtProductLanManNt,
|
---|
1458 | NtProductServer
|
---|
1459 | } NT_PRODUCT_TYPE, *PNT_PRODUCT_TYPE;
|
---|
1460 |
|
---|
1461 |
|
---|
1462 | //
|
---|
1463 | // the bit mask, SharedUserData->SuiteMask, is a ULONG
|
---|
1464 | // so there can be a maximum of 32 entries
|
---|
1465 | // in this enum.
|
---|
1466 | //
|
---|
1467 |
|
---|
1468 | typedef enum _SUITE_TYPE {
|
---|
1469 | SmallBusiness,
|
---|
1470 | Enterprise,
|
---|
1471 | BackOffice,
|
---|
1472 | CommunicationServer,
|
---|
1473 | TerminalServer,
|
---|
1474 | SmallBusinessRestricted,
|
---|
1475 | EmbeddedNT,
|
---|
1476 | DataCenter,
|
---|
1477 | SingleUserTS,
|
---|
1478 | Personal,
|
---|
1479 | Blade,
|
---|
1480 | EmbeddedRestricted,
|
---|
1481 | SecurityAppliance,
|
---|
1482 | MaxSuiteType
|
---|
1483 | } SUITE_TYPE;
|
---|
1484 |
|
---|
1485 | // begin_winnt
|
---|
1486 |
|
---|
1487 | #define VER_SERVER_NT 0x80000000
|
---|
1488 | #define VER_WORKSTATION_NT 0x40000000
|
---|
1489 | #define VER_SUITE_SMALLBUSINESS 0x00000001
|
---|
1490 | #define VER_SUITE_ENTERPRISE 0x00000002
|
---|
1491 | #define VER_SUITE_BACKOFFICE 0x00000004
|
---|
1492 | #define VER_SUITE_COMMUNICATIONS 0x00000008
|
---|
1493 | #define VER_SUITE_TERMINAL 0x00000010
|
---|
1494 | #define VER_SUITE_SMALLBUSINESS_RESTRICTED 0x00000020
|
---|
1495 | #define VER_SUITE_EMBEDDEDNT 0x00000040
|
---|
1496 | #define VER_SUITE_DATACENTER 0x00000080
|
---|
1497 | #define VER_SUITE_SINGLEUSERTS 0x00000100
|
---|
1498 | #define VER_SUITE_PERSONAL 0x00000200
|
---|
1499 | #define VER_SUITE_BLADE 0x00000400
|
---|
1500 | #define VER_SUITE_EMBEDDED_RESTRICTED 0x00000800
|
---|
1501 | #define VER_SUITE_SECURITY_APPLIANCE 0x00001000
|
---|
1502 |
|
---|
1503 | // end_winnt
|
---|
1504 |
|
---|
1505 | // begin_winnt begin_r_winnt
|
---|
1506 |
|
---|
1507 | //
|
---|
1508 | // Language IDs.
|
---|
1509 | //
|
---|
1510 | // The following two combinations of primary language ID and
|
---|
1511 | // sublanguage ID have special semantics:
|
---|
1512 | //
|
---|
1513 | // Primary Language ID Sublanguage ID Result
|
---|
1514 | // ------------------- --------------- ------------------------
|
---|
1515 | // LANG_NEUTRAL SUBLANG_NEUTRAL Language neutral
|
---|
1516 | // LANG_NEUTRAL SUBLANG_DEFAULT User default language
|
---|
1517 | // LANG_NEUTRAL SUBLANG_SYS_DEFAULT System default language
|
---|
1518 | // LANG_INVARIANT SUBLANG_NEUTRAL Invariant locale
|
---|
1519 | //
|
---|
1520 |
|
---|
1521 | //
|
---|
1522 | // Primary language IDs.
|
---|
1523 | //
|
---|
1524 |
|
---|
1525 | #define LANG_NEUTRAL 0x00
|
---|
1526 | #define LANG_INVARIANT 0x7f
|
---|
1527 |
|
---|
1528 | #define LANG_AFRIKAANS 0x36
|
---|
1529 | #define LANG_ALBANIAN 0x1c
|
---|
1530 | #define LANG_ARABIC 0x01
|
---|
1531 | #define LANG_ARMENIAN 0x2b
|
---|
1532 | #define LANG_ASSAMESE 0x4d
|
---|
1533 | #define LANG_AZERI 0x2c
|
---|
1534 | #define LANG_BASQUE 0x2d
|
---|
1535 | #define LANG_BELARUSIAN 0x23
|
---|
1536 | #define LANG_BENGALI 0x45
|
---|
1537 | #define LANG_BULGARIAN 0x02
|
---|
1538 | #define LANG_CATALAN 0x03
|
---|
1539 | #define LANG_CHINESE 0x04
|
---|
1540 | #define LANG_CROATIAN 0x1a
|
---|
1541 | #define LANG_CZECH 0x05
|
---|
1542 | #define LANG_DANISH 0x06
|
---|
1543 | #define LANG_DIVEHI 0x65
|
---|
1544 | #define LANG_DUTCH 0x13
|
---|
1545 | #define LANG_ENGLISH 0x09
|
---|
1546 | #define LANG_ESTONIAN 0x25
|
---|
1547 | #define LANG_FAEROESE 0x38
|
---|
1548 | #define LANG_FARSI 0x29
|
---|
1549 | #define LANG_FINNISH 0x0b
|
---|
1550 | #define LANG_FRENCH 0x0c
|
---|
1551 | #define LANG_GALICIAN 0x56
|
---|
1552 | #define LANG_GEORGIAN 0x37
|
---|
1553 | #define LANG_GERMAN 0x07
|
---|
1554 | #define LANG_GREEK 0x08
|
---|
1555 | #define LANG_GUJARATI 0x47
|
---|
1556 | #define LANG_HEBREW 0x0d
|
---|
1557 | #define LANG_HINDI 0x39
|
---|
1558 | #define LANG_HUNGARIAN 0x0e
|
---|
1559 | #define LANG_ICELANDIC 0x0f
|
---|
1560 | #define LANG_INDONESIAN 0x21
|
---|
1561 | #define LANG_ITALIAN 0x10
|
---|
1562 | #define LANG_JAPANESE 0x11
|
---|
1563 | #define LANG_KANNADA 0x4b
|
---|
1564 | #define LANG_KASHMIRI 0x60
|
---|
1565 | #define LANG_KAZAK 0x3f
|
---|
1566 | #define LANG_KONKANI 0x57
|
---|
1567 | #define LANG_KOREAN 0x12
|
---|
1568 | #define LANG_KYRGYZ 0x40
|
---|
1569 | #define LANG_LATVIAN 0x26
|
---|
1570 | #define LANG_LITHUANIAN 0x27
|
---|
1571 | #define LANG_MACEDONIAN 0x2f // the Former Yugoslav Republic of Macedonia
|
---|
1572 | #define LANG_MALAY 0x3e
|
---|
1573 | #define LANG_MALAYALAM 0x4c
|
---|
1574 | #define LANG_MANIPURI 0x58
|
---|
1575 | #define LANG_MARATHI 0x4e
|
---|
1576 | #define LANG_MONGOLIAN 0x50
|
---|
1577 | #define LANG_NEPALI 0x61
|
---|
1578 | #define LANG_NORWEGIAN 0x14
|
---|
1579 | #define LANG_ORIYA 0x48
|
---|
1580 | #define LANG_POLISH 0x15
|
---|
1581 | #define LANG_PORTUGUESE 0x16
|
---|
1582 | #define LANG_PUNJABI 0x46
|
---|
1583 | #define LANG_ROMANIAN 0x18
|
---|
1584 | #define LANG_RUSSIAN 0x19
|
---|
1585 | #define LANG_SANSKRIT 0x4f
|
---|
1586 | #define LANG_SERBIAN 0x1a
|
---|
1587 | #define LANG_SINDHI 0x59
|
---|
1588 | #define LANG_SLOVAK 0x1b
|
---|
1589 | #define LANG_SLOVENIAN 0x24
|
---|
1590 | #define LANG_SPANISH 0x0a
|
---|
1591 | #define LANG_SWAHILI 0x41
|
---|
1592 | #define LANG_SWEDISH 0x1d
|
---|
1593 | #define LANG_SYRIAC 0x5a
|
---|
1594 | #define LANG_TAMIL 0x49
|
---|
1595 | #define LANG_TATAR 0x44
|
---|
1596 | #define LANG_TELUGU 0x4a
|
---|
1597 | #define LANG_THAI 0x1e
|
---|
1598 | #define LANG_TURKISH 0x1f
|
---|
1599 | #define LANG_UKRAINIAN 0x22
|
---|
1600 | #define LANG_URDU 0x20
|
---|
1601 | #define LANG_UZBEK 0x43
|
---|
1602 | #define LANG_VIETNAMESE 0x2a
|
---|
1603 |
|
---|
1604 | //
|
---|
1605 | // Sublanguage IDs.
|
---|
1606 | //
|
---|
1607 | // The name immediately following SUBLANG_ dictates which primary
|
---|
1608 | // language ID that sublanguage ID can be combined with to form a
|
---|
1609 | // valid language ID.
|
---|
1610 | //
|
---|
1611 |
|
---|
1612 | #define SUBLANG_NEUTRAL 0x00 // language neutral
|
---|
1613 | #define SUBLANG_DEFAULT 0x01 // user default
|
---|
1614 | #define SUBLANG_SYS_DEFAULT 0x02 // system default
|
---|
1615 |
|
---|
1616 | #define SUBLANG_ARABIC_SAUDI_ARABIA 0x01 // Arabic (Saudi Arabia)
|
---|
1617 | #define SUBLANG_ARABIC_IRAQ 0x02 // Arabic (Iraq)
|
---|
1618 | #define SUBLANG_ARABIC_EGYPT 0x03 // Arabic (Egypt)
|
---|
1619 | #define SUBLANG_ARABIC_LIBYA 0x04 // Arabic (Libya)
|
---|
1620 | #define SUBLANG_ARABIC_ALGERIA 0x05 // Arabic (Algeria)
|
---|
1621 | #define SUBLANG_ARABIC_MOROCCO 0x06 // Arabic (Morocco)
|
---|
1622 | #define SUBLANG_ARABIC_TUNISIA 0x07 // Arabic (Tunisia)
|
---|
1623 | #define SUBLANG_ARABIC_OMAN 0x08 // Arabic (Oman)
|
---|
1624 | #define SUBLANG_ARABIC_YEMEN 0x09 // Arabic (Yemen)
|
---|
1625 | #define SUBLANG_ARABIC_SYRIA 0x0a // Arabic (Syria)
|
---|
1626 | #define SUBLANG_ARABIC_JORDAN 0x0b // Arabic (Jordan)
|
---|
1627 | #define SUBLANG_ARABIC_LEBANON 0x0c // Arabic (Lebanon)
|
---|
1628 | #define SUBLANG_ARABIC_KUWAIT 0x0d // Arabic (Kuwait)
|
---|
1629 | #define SUBLANG_ARABIC_UAE 0x0e // Arabic (U.A.E)
|
---|
1630 | #define SUBLANG_ARABIC_BAHRAIN 0x0f // Arabic (Bahrain)
|
---|
1631 | #define SUBLANG_ARABIC_QATAR 0x10 // Arabic (Qatar)
|
---|
1632 | #define SUBLANG_AZERI_LATIN 0x01 // Azeri (Latin)
|
---|
1633 | #define SUBLANG_AZERI_CYRILLIC 0x02 // Azeri (Cyrillic)
|
---|
1634 | #define SUBLANG_CHINESE_TRADITIONAL 0x01 // Chinese (Taiwan)
|
---|
1635 | #define SUBLANG_CHINESE_SIMPLIFIED 0x02 // Chinese (PR China)
|
---|
1636 | #define SUBLANG_CHINESE_HONGKONG 0x03 // Chinese (Hong Kong S.A.R., P.R.C.)
|
---|
1637 | #define SUBLANG_CHINESE_SINGAPORE 0x04 // Chinese (Singapore)
|
---|
1638 | #define SUBLANG_CHINESE_MACAU 0x05 // Chinese (Macau S.A.R.)
|
---|
1639 | #define SUBLANG_DUTCH 0x01 // Dutch
|
---|
1640 | #define SUBLANG_DUTCH_BELGIAN 0x02 // Dutch (Belgian)
|
---|
1641 | #define SUBLANG_ENGLISH_US 0x01 // English (USA)
|
---|
1642 | #define SUBLANG_ENGLISH_UK 0x02 // English (UK)
|
---|
1643 | #define SUBLANG_ENGLISH_AUS 0x03 // English (Australian)
|
---|
1644 | #define SUBLANG_ENGLISH_CAN 0x04 // English (Canadian)
|
---|
1645 | #define SUBLANG_ENGLISH_NZ 0x05 // English (New Zealand)
|
---|
1646 | #define SUBLANG_ENGLISH_EIRE 0x06 // English (Irish)
|
---|
1647 | #define SUBLANG_ENGLISH_SOUTH_AFRICA 0x07 // English (South Africa)
|
---|
1648 | #define SUBLANG_ENGLISH_JAMAICA 0x08 // English (Jamaica)
|
---|
1649 | #define SUBLANG_ENGLISH_CARIBBEAN 0x09 // English (Caribbean)
|
---|
1650 | #define SUBLANG_ENGLISH_BELIZE 0x0a // English (Belize)
|
---|
1651 | #define SUBLANG_ENGLISH_TRINIDAD 0x0b // English (Trinidad)
|
---|
1652 | #define SUBLANG_ENGLISH_ZIMBABWE 0x0c // English (Zimbabwe)
|
---|
1653 | #define SUBLANG_ENGLISH_PHILIPPINES 0x0d // English (Philippines)
|
---|
1654 | #define SUBLANG_FRENCH 0x01 // French
|
---|
1655 | #define SUBLANG_FRENCH_BELGIAN 0x02 // French (Belgian)
|
---|
1656 | #define SUBLANG_FRENCH_CANADIAN 0x03 // French (Canadian)
|
---|
1657 | #define SUBLANG_FRENCH_SWISS 0x04 // French (Swiss)
|
---|
1658 | #define SUBLANG_FRENCH_LUXEMBOURG 0x05 // French (Luxembourg)
|
---|
1659 | #define SUBLANG_FRENCH_MONACO 0x06 // French (Monaco)
|
---|
1660 | #define SUBLANG_GERMAN 0x01 // German
|
---|
1661 | #define SUBLANG_GERMAN_SWISS 0x02 // German (Swiss)
|
---|
1662 | #define SUBLANG_GERMAN_AUSTRIAN 0x03 // German (Austrian)
|
---|
1663 | #define SUBLANG_GERMAN_LUXEMBOURG 0x04 // German (Luxembourg)
|
---|
1664 | #define SUBLANG_GERMAN_LIECHTENSTEIN 0x05 // German (Liechtenstein)
|
---|
1665 | #define SUBLANG_ITALIAN 0x01 // Italian
|
---|
1666 | #define SUBLANG_ITALIAN_SWISS 0x02 // Italian (Swiss)
|
---|
1667 | #if _WIN32_WINNT >= 0x0501
|
---|
1668 | #define SUBLANG_KASHMIRI_SASIA 0x02 // Kashmiri (South Asia)
|
---|
1669 | #endif
|
---|
1670 | #define SUBLANG_KASHMIRI_INDIA 0x02 // For app compatibility only
|
---|
1671 | #define SUBLANG_KOREAN 0x01 // Korean (Extended Wansung)
|
---|
1672 | #define SUBLANG_LITHUANIAN 0x01 // Lithuanian
|
---|
1673 | #define SUBLANG_MALAY_MALAYSIA 0x01 // Malay (Malaysia)
|
---|
1674 | #define SUBLANG_MALAY_BRUNEI_DARUSSALAM 0x02 // Malay (Brunei Darussalam)
|
---|
1675 | #define SUBLANG_NEPALI_INDIA 0x02 // Nepali (India)
|
---|
1676 | #define SUBLANG_NORWEGIAN_BOKMAL 0x01 // Norwegian (Bokmal)
|
---|
1677 | #define SUBLANG_NORWEGIAN_NYNORSK 0x02 // Norwegian (Nynorsk)
|
---|
1678 | #define SUBLANG_PORTUGUESE 0x02 // Portuguese
|
---|
1679 | #define SUBLANG_PORTUGUESE_BRAZILIAN 0x01 // Portuguese (Brazilian)
|
---|
1680 | #define SUBLANG_SERBIAN_LATIN 0x02 // Serbian (Latin)
|
---|
1681 | #define SUBLANG_SERBIAN_CYRILLIC 0x03 // Serbian (Cyrillic)
|
---|
1682 | #define SUBLANG_SPANISH 0x01 // Spanish (Castilian)
|
---|
1683 | #define SUBLANG_SPANISH_MEXICAN 0x02 // Spanish (Mexican)
|
---|
1684 | #define SUBLANG_SPANISH_MODERN 0x03 // Spanish (Spain)
|
---|
1685 | #define SUBLANG_SPANISH_GUATEMALA 0x04 // Spanish (Guatemala)
|
---|
1686 | #define SUBLANG_SPANISH_COSTA_RICA 0x05 // Spanish (Costa Rica)
|
---|
1687 | #define SUBLANG_SPANISH_PANAMA 0x06 // Spanish (Panama)
|
---|
1688 | #define SUBLANG_SPANISH_DOMINICAN_REPUBLIC 0x07 // Spanish (Dominican Republic)
|
---|
1689 | #define SUBLANG_SPANISH_VENEZUELA 0x08 // Spanish (Venezuela)
|
---|
1690 | #define SUBLANG_SPANISH_COLOMBIA 0x09 // Spanish (Colombia)
|
---|
1691 | #define SUBLANG_SPANISH_PERU 0x0a // Spanish (Peru)
|
---|
1692 | #define SUBLANG_SPANISH_ARGENTINA 0x0b // Spanish (Argentina)
|
---|
1693 | #define SUBLANG_SPANISH_ECUADOR 0x0c // Spanish (Ecuador)
|
---|
1694 | #define SUBLANG_SPANISH_CHILE 0x0d // Spanish (Chile)
|
---|
1695 | #define SUBLANG_SPANISH_URUGUAY 0x0e // Spanish (Uruguay)
|
---|
1696 | #define SUBLANG_SPANISH_PARAGUAY 0x0f // Spanish (Paraguay)
|
---|
1697 | #define SUBLANG_SPANISH_BOLIVIA 0x10 // Spanish (Bolivia)
|
---|
1698 | #define SUBLANG_SPANISH_EL_SALVADOR 0x11 // Spanish (El Salvador)
|
---|
1699 | #define SUBLANG_SPANISH_HONDURAS 0x12 // Spanish (Honduras)
|
---|
1700 | #define SUBLANG_SPANISH_NICARAGUA 0x13 // Spanish (Nicaragua)
|
---|
1701 | #define SUBLANG_SPANISH_PUERTO_RICO 0x14 // Spanish (Puerto Rico)
|
---|
1702 | #define SUBLANG_SWEDISH 0x01 // Swedish
|
---|
1703 | #define SUBLANG_SWEDISH_FINLAND 0x02 // Swedish (Finland)
|
---|
1704 | #define SUBLANG_URDU_PAKISTAN 0x01 // Urdu (Pakistan)
|
---|
1705 | #define SUBLANG_URDU_INDIA 0x02 // Urdu (India)
|
---|
1706 | #define SUBLANG_UZBEK_LATIN 0x01 // Uzbek (Latin)
|
---|
1707 | #define SUBLANG_UZBEK_CYRILLIC 0x02 // Uzbek (Cyrillic)
|
---|
1708 |
|
---|
1709 | //
|
---|
1710 | // Sorting IDs.
|
---|
1711 | //
|
---|
1712 |
|
---|
1713 | #define SORT_DEFAULT 0x0 // sorting default
|
---|
1714 |
|
---|
1715 | #define SORT_JAPANESE_XJIS 0x0 // Japanese XJIS order
|
---|
1716 | #define SORT_JAPANESE_UNICODE 0x1 // Japanese Unicode order
|
---|
1717 |
|
---|
1718 | #define SORT_CHINESE_BIG5 0x0 // Chinese BIG5 order
|
---|
1719 | #define SORT_CHINESE_PRCP 0x0 // PRC Chinese Phonetic order
|
---|
1720 | #define SORT_CHINESE_UNICODE 0x1 // Chinese Unicode order
|
---|
1721 | #define SORT_CHINESE_PRC 0x2 // PRC Chinese Stroke Count order
|
---|
1722 | #define SORT_CHINESE_BOPOMOFO 0x3 // Traditional Chinese Bopomofo order
|
---|
1723 |
|
---|
1724 | #define SORT_KOREAN_KSC 0x0 // Korean KSC order
|
---|
1725 | #define SORT_KOREAN_UNICODE 0x1 // Korean Unicode order
|
---|
1726 |
|
---|
1727 | #define SORT_GERMAN_PHONE_BOOK 0x1 // German Phone Book order
|
---|
1728 |
|
---|
1729 | #define SORT_HUNGARIAN_DEFAULT 0x0 // Hungarian Default order
|
---|
1730 | #define SORT_HUNGARIAN_TECHNICAL 0x1 // Hungarian Technical order
|
---|
1731 |
|
---|
1732 | #define SORT_GEORGIAN_TRADITIONAL 0x0 // Georgian Traditional order
|
---|
1733 | #define SORT_GEORGIAN_MODERN 0x1 // Georgian Modern order
|
---|
1734 |
|
---|
1735 | // end_r_winnt
|
---|
1736 |
|
---|
1737 | //
|
---|
1738 | // A language ID is a 16 bit value which is the combination of a
|
---|
1739 | // primary language ID and a secondary language ID. The bits are
|
---|
1740 | // allocated as follows:
|
---|
1741 | //
|
---|
1742 | // +-----------------------+-------------------------+
|
---|
1743 | // | Sublanguage ID | Primary Language ID |
|
---|
1744 | // +-----------------------+-------------------------+
|
---|
1745 | // 15 10 9 0 bit
|
---|
1746 | //
|
---|
1747 | //
|
---|
1748 | // Language ID creation/extraction macros:
|
---|
1749 | //
|
---|
1750 | // MAKELANGID - construct language id from a primary language id and
|
---|
1751 | // a sublanguage id.
|
---|
1752 | // PRIMARYLANGID - extract primary language id from a language id.
|
---|
1753 | // SUBLANGID - extract sublanguage id from a language id.
|
---|
1754 | //
|
---|
1755 |
|
---|
1756 | #define MAKELANGID(p, s) ((((USHORT)(s)) << 10) | (USHORT)(p))
|
---|
1757 | #define PRIMARYLANGID(lgid) ((USHORT)(lgid) & 0x3ff)
|
---|
1758 | #define SUBLANGID(lgid) ((USHORT)(lgid) >> 10)
|
---|
1759 |
|
---|
1760 |
|
---|
1761 | //
|
---|
1762 | // A locale ID is a 32 bit value which is the combination of a
|
---|
1763 | // language ID, a sort ID, and a reserved area. The bits are
|
---|
1764 | // allocated as follows:
|
---|
1765 | //
|
---|
1766 | // +-------------+---------+-------------------------+
|
---|
1767 | // | Reserved | Sort ID | Language ID |
|
---|
1768 | // +-------------+---------+-------------------------+
|
---|
1769 | // 31 20 19 16 15 0 bit
|
---|
1770 | //
|
---|
1771 | //
|
---|
1772 | // Locale ID creation/extraction macros:
|
---|
1773 | //
|
---|
1774 | // MAKELCID - construct the locale id from a language id and a sort id.
|
---|
1775 | // MAKESORTLCID - construct the locale id from a language id, sort id, and sort version.
|
---|
1776 | // LANGIDFROMLCID - extract the language id from a locale id.
|
---|
1777 | // SORTIDFROMLCID - extract the sort id from a locale id.
|
---|
1778 | // SORTVERSIONFROMLCID - extract the sort version from a locale id.
|
---|
1779 | //
|
---|
1780 |
|
---|
1781 | #define NLS_VALID_LOCALE_MASK 0x000fffff
|
---|
1782 |
|
---|
1783 | #define MAKELCID(lgid, srtid) ((ULONG)((((ULONG)((USHORT)(srtid))) << 16) | \
|
---|
1784 | ((ULONG)((USHORT)(lgid)))))
|
---|
1785 | #define MAKESORTLCID(lgid, srtid, ver) \
|
---|
1786 | ((ULONG)((MAKELCID(lgid, srtid)) | \
|
---|
1787 | (((ULONG)((USHORT)(ver))) << 20)))
|
---|
1788 | #define LANGIDFROMLCID(lcid) ((USHORT)(lcid))
|
---|
1789 | #define SORTIDFROMLCID(lcid) ((USHORT)((((ULONG)(lcid)) >> 16) & 0xf))
|
---|
1790 | #define SORTVERSIONFROMLCID(lcid) ((USHORT)((((ULONG)(lcid)) >> 20) & 0xf))
|
---|
1791 |
|
---|
1792 |
|
---|
1793 | //
|
---|
1794 | // Default System and User IDs for language and locale.
|
---|
1795 | //
|
---|
1796 |
|
---|
1797 | #define LANG_SYSTEM_DEFAULT (MAKELANGID(LANG_NEUTRAL, SUBLANG_SYS_DEFAULT))
|
---|
1798 | #define LANG_USER_DEFAULT (MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT))
|
---|
1799 |
|
---|
1800 | #define LOCALE_SYSTEM_DEFAULT (MAKELCID(LANG_SYSTEM_DEFAULT, SORT_DEFAULT))
|
---|
1801 | #define LOCALE_USER_DEFAULT (MAKELCID(LANG_USER_DEFAULT, SORT_DEFAULT))
|
---|
1802 |
|
---|
1803 | #define LOCALE_NEUTRAL \
|
---|
1804 | (MAKELCID(MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL), SORT_DEFAULT))
|
---|
1805 |
|
---|
1806 | #define LOCALE_INVARIANT \
|
---|
1807 | (MAKELCID(MAKELANGID(LANG_INVARIANT, SUBLANG_NEUTRAL), SORT_DEFAULT))
|
---|
1808 |
|
---|
1809 | // begin_ntminiport begin_ntndis begin_ntminitape
|
---|
1810 |
|
---|
1811 | //
|
---|
1812 | // Macros used to eliminate compiler warning generated when formal
|
---|
1813 | // parameters or local variables are not declared.
|
---|
1814 | //
|
---|
1815 | // Use DBG_UNREFERENCED_PARAMETER() when a parameter is not yet
|
---|
1816 | // referenced but will be once the module is completely developed.
|
---|
1817 | //
|
---|
1818 | // Use DBG_UNREFERENCED_LOCAL_VARIABLE() when a local variable is not yet
|
---|
1819 | // referenced but will be once the module is completely developed.
|
---|
1820 | //
|
---|
1821 | // Use UNREFERENCED_PARAMETER() if a parameter will never be referenced.
|
---|
1822 | //
|
---|
1823 | // DBG_UNREFERENCED_PARAMETER and DBG_UNREFERENCED_LOCAL_VARIABLE will
|
---|
1824 | // eventually be made into a null macro to help determine whether there
|
---|
1825 | // is unfinished work.
|
---|
1826 | //
|
---|
1827 |
|
---|
1828 | #if ! defined(lint)
|
---|
1829 | #define UNREFERENCED_PARAMETER(P) (P)
|
---|
1830 | #define DBG_UNREFERENCED_PARAMETER(P) (P)
|
---|
1831 | #define DBG_UNREFERENCED_LOCAL_VARIABLE(V) (V)
|
---|
1832 |
|
---|
1833 | #else // lint
|
---|
1834 |
|
---|
1835 | // Note: lint -e530 says don't complain about uninitialized variables for
|
---|
1836 | // this variable. Error 527 has to do with unreachable code.
|
---|
1837 | // -restore restores checking to the -save state
|
---|
1838 |
|
---|
1839 | #define UNREFERENCED_PARAMETER(P) \
|
---|
1840 | /*lint -save -e527 -e530 */ \
|
---|
1841 | { \
|
---|
1842 | (P) = (P); \
|
---|
1843 | } \
|
---|
1844 | /*lint -restore */
|
---|
1845 | #define DBG_UNREFERENCED_PARAMETER(P) \
|
---|
1846 | /*lint -save -e527 -e530 */ \
|
---|
1847 | { \
|
---|
1848 | (P) = (P); \
|
---|
1849 | } \
|
---|
1850 | /*lint -restore */
|
---|
1851 | #define DBG_UNREFERENCED_LOCAL_VARIABLE(V) \
|
---|
1852 | /*lint -save -e527 -e530 */ \
|
---|
1853 | { \
|
---|
1854 | (V) = (V); \
|
---|
1855 | } \
|
---|
1856 | /*lint -restore */
|
---|
1857 |
|
---|
1858 | #endif // lint
|
---|
1859 |
|
---|
1860 | //
|
---|
1861 | // Macro used to eliminate compiler warning 4715 within a switch statement
|
---|
1862 | // when all possible cases have already been accounted for.
|
---|
1863 | //
|
---|
1864 | // switch (a & 3) {
|
---|
1865 | // case 0: return 1;
|
---|
1866 | // case 1: return Foo();
|
---|
1867 | // case 2: return Bar();
|
---|
1868 | // case 3: return 1;
|
---|
1869 | // DEFAULT_UNREACHABLE;
|
---|
1870 | //
|
---|
1871 |
|
---|
1872 | #if (_MSC_VER > 1200)
|
---|
1873 | #define DEFAULT_UNREACHABLE default: __assume(0)
|
---|
1874 | #else
|
---|
1875 |
|
---|
1876 | //
|
---|
1877 | // Older compilers do not support __assume(), and there is no other free
|
---|
1878 | // method of eliminating the warning.
|
---|
1879 | //
|
---|
1880 |
|
---|
1881 | #define DEFAULT_UNREACHABLE
|
---|
1882 |
|
---|
1883 | #endif
|
---|
1884 |
|
---|
1885 | // end_winnt
|
---|
1886 |
|
---|
1887 | //
|
---|
1888 | // Define standard min and max macros
|
---|
1889 | //
|
---|
1890 |
|
---|
1891 | #ifndef NOMINMAX
|
---|
1892 |
|
---|
1893 | #ifndef min
|
---|
1894 | #define min(a,b) (((a) < (b)) ? (a) : (b))
|
---|
1895 | #endif
|
---|
1896 |
|
---|
1897 | #ifndef max
|
---|
1898 | #define max(a,b) (((a) > (b)) ? (a) : (b))
|
---|
1899 | #endif
|
---|
1900 |
|
---|
1901 | #endif // NOMINMAX
|
---|
1902 |
|
---|
1903 | // end_ntminiport end_ntndis end_ntminitape
|
---|
1904 |
|
---|
1905 | #endif // _NTDEF_
|
---|
1906 |
|
---|