1 #ifndef __INCLUDE_NTOS_ZWTYPES_H
2 #define __INCLUDE_NTOS_ZWTYPES_H
6 typedef unsigned short LANGID
;
7 typedef LANGID
*PLANGID
;
9 typedef struct _LDT_ENTRY
{
27 DWORD Default_Big
: 1;
28 DWORD Granularity
: 1;
32 } LDT_ENTRY
, *PLDT_ENTRY
, *LPLDT_ENTRY
;
34 typedef enum _THREAD_STATE
{
45 typedef enum _DEBUG_CONTROL_CODE
47 DebugGetTraceInformation
= 1,
48 DebugSetInternalBreakpoint
,
50 DebugClearSpecialCalls
,
51 DebugQuerySpecialCalls
,
56 typedef enum _KPROFILE_SOURCE
61 // file disposition values
63 #define FILE_SUPERSEDE 0x0000
64 #define FILE_OPEN 0x0001
65 #define FILE_CREATE 0x0002
66 #define FILE_OPEN_IF 0x0003
67 #define FILE_OVERWRITE 0x0004
68 #define FILE_OVERWRITE_IF 0x0005
69 #define FILE_MAXIMUM_DISPOSITION 0x0005
71 // job query / set information class
73 typedef enum _JOBOBJECTINFOCLASS
{ // Q S
74 JobObjectBasicAccountingInformation
= 1, // Y N
75 JobObjectBasicLimitInformation
, // Y Y
76 JobObjectBasicProcessIdList
, // Y N
77 JobObjectBasicUIRestrictions
, // Y Y
78 JobObjectSecurityLimitInformation
, // Y Y
79 JobObjectEndOfJobTimeInformation
, // N Y
80 JobObjectAssociateCompletionPortInformation
, // N Y
81 JobObjectBasicAndIoAccountingInformation
, // Y N
82 JobObjectExtendedLimitInformation
, // Y Y
86 // {Nt|Zw}{Query|Set}SystemInformation
87 // (GN means Gary Nebbet in "NT/W2K Native API Reference")
90 enum _SYSTEM_INFORMATION_CLASS
92 SystemInformationClassMin
= 0,
93 SystemBasicInformation
= 0, /* Q */
95 SystemProcessorInformation
= 1, /* Q */
97 SystemPerformanceInformation
= 2, /* Q */
99 SystemTimeOfDayInformation
= 3, /* Q */
101 SystemPathInformation
= 4, /* Q (checked build only) */
102 SystemNotImplemented1
= 4, /* Q (GN) */
104 SystemProcessInformation
= 5, /* Q */
105 SystemProcessesAndThreadsInformation
= 5, /* Q (GN) */
107 SystemCallCountInfoInformation
= 6, /* Q */
108 SystemCallCounts
= 6, /* Q (GN) */
110 SystemDeviceInformation
= 7, /* Q */
111 // It conflicts with symbol in ntoskrnl/io/resource.c
112 // SystemConfigurationInformation = 7, /* Q (GN) */
114 SystemProcessorPerformanceInformation
= 8, /* Q */
115 SystemProcessorTimes
= 8, /* Q (GN) */
117 SystemFlagsInformation
= 9, /* QS */
118 SystemGlobalFlag
= 9, /* QS (GN) */
120 SystemCallTimeInformation
= 10,
121 SystemNotImplemented2
= 10, /* (GN) */
123 SystemModuleInformation
= 11, /* Q */
125 SystemLocksInformation
= 12, /* Q */
126 SystemLockInformation
= 12, /* Q (GN) */
128 SystemStackTraceInformation
= 13,
129 SystemNotImplemented3
= 13, /* Q (GN) */
131 SystemPagedPoolInformation
= 14,
132 SystemNotImplemented4
= 14, /* Q (GN) */
134 SystemNonPagedPoolInformation
= 15,
135 SystemNotImplemented5
= 15, /* Q (GN) */
137 SystemHandleInformation
= 16, /* Q */
139 SystemObjectInformation
= 17, /* Q */
141 SystemPageFileInformation
= 18, /* Q */
142 SystemPagefileInformation
= 18, /* Q (GN) */
144 SystemVdmInstemulInformation
= 19, /* Q */
145 SystemInstructionEmulationCounts
= 19, /* Q (GN) */
147 SystemVdmBopInformation
= 20,
148 SystemInvalidInfoClass1
= 20, /* (GN) */
150 SystemFileCacheInformation
= 21, /* QS */
151 SystemCacheInformation
= 21, /* QS (GN) */
153 SystemPoolTagInformation
= 22, /* Q (checked build only) */
155 SystemInterruptInformation
= 23, /* Q */
156 SystemProcessorStatistics
= 23, /* Q (GN) */
158 SystemDpcBehaviourInformation
= 24, /* QS */
159 SystemDpcInformation
= 24, /* QS (GN) */
161 SystemFullMemoryInformation
= 25,
162 SystemNotImplemented6
= 25, /* (GN) */
164 SystemLoadImage
= 26, /* S (callable) (GN) */
166 SystemUnloadImage
= 27, /* S (callable) (GN) */
168 SystemTimeAdjustmentInformation
= 28, /* QS */
169 SystemTimeAdjustment
= 28, /* QS (GN) */
171 SystemSummaryMemoryInformation
= 29,
172 SystemNotImplemented7
= 29, /* (GN) */
174 SystemNextEventIdInformation
= 30,
175 SystemNotImplemented8
= 30, /* (GN) */
177 SystemEventIdsInformation
= 31,
178 SystemNotImplemented9
= 31, /* (GN) */
180 SystemCrashDumpInformation
= 32, /* Q */
182 SystemExceptionInformation
= 33, /* Q */
184 SystemCrashDumpStateInformation
= 34, /* Q */
186 SystemKernelDebuggerInformation
= 35, /* Q */
188 SystemContextSwitchInformation
= 36, /* Q */
190 SystemRegistryQuotaInformation
= 37, /* QS */
192 SystemLoadAndCallImage
= 38, /* S (GN) */
194 SystemPrioritySeparation
= 39, /* S */
196 SystemPlugPlayBusInformation
= 40,
197 SystemNotImplemented10
= 40, /* Q (GN) */
199 SystemDockInformation
= 41,
200 SystemNotImplemented11
= 41, /* Q (GN) */
202 SystemPowerInformation
= 42,
203 SystemInvalidInfoClass2
= 42, /* (GN) */
205 SystemProcessorSpeedInformation
= 43,
206 SystemInvalidInfoClass3
= 43, /* (GN) */
208 SystemCurrentTimeZoneInformation
= 44, /* QS */
209 SystemTimeZoneInformation
= 44, /* QS (GN) */
211 SystemLookasideInformation
= 45, /* Q */
213 SystemSetTimeSlipEvent
= 46, /* S (GN) */
215 SystemCreateSession
= 47, /* S (GN) */
217 SystemDeleteSession
= 48, /* S (GN) */
219 SystemInvalidInfoClass4
= 49, /* (GN) */
221 SystemRangeStartInformation
= 50, /* Q (GN) */
223 SystemVerifierInformation
= 51, /* QS (GN) */
225 SystemAddVerifier
= 52, /* S (GN) */
227 SystemSessionProcessesInformation
= 53, /* Q (GN) */
228 SystemInformationClassMax
230 } SYSTEM_INFORMATION_CLASS
;
232 // SystemBasicInformation (0)
233 // Modified by Andrew Greenwood (15th July 2003) to match Win 32 API headers
235 struct _SYSTEM_BASIC_INFORMATION
238 ULONG MaximumIncrement
;
239 ULONG PhysicalPageSize
;
240 ULONG NumberOfPhysicalPages
;
241 ULONG LowestPhysicalPage
;
242 ULONG HighestPhysicalPage
;
243 ULONG AllocationGranularity
;
244 ULONG LowestUserAddress
;
245 ULONG HighestUserAddress
;
246 KAFFINITY ActiveProcessors
;
247 CCHAR NumberProcessors
;
248 } SYSTEM_BASIC_INFORMATION
, *PSYSTEM_BASIC_INFORMATION
;
250 // SystemProcessorInformation (1)
251 // Modified by Andrew Greenwood (15th July 2003) to match Win 32 API headers
252 typedef struct _SYSTEM_PROCESSOR_INFORMATION
{
253 USHORT ProcessorArchitecture
;
254 USHORT ProcessorLevel
;
255 USHORT ProcessorRevision
;
258 } SYSTEM_PROCESSOR_INFORMATION
, *PSYSTEM_PROCESSOR_INFORMATION
;
260 // SystemPerformanceInfo (2)
261 // Modified by Andrew Greenwood (15th July 2003) to match Win 32 API headers
262 typedef struct _SYSTEM_PERFORMANCE_INFORMATION
{
263 LARGE_INTEGER IdleTime
;
264 LARGE_INTEGER ReadTransferCount
;
265 LARGE_INTEGER WriteTransferCount
;
266 LARGE_INTEGER OtherTransferCount
;
267 ULONG ReadOperationCount
;
268 ULONG WriteOperationCount
;
269 ULONG OtherOperationCount
;
270 ULONG AvailablePages
;
271 ULONG TotalCommittedPages
;
272 ULONG TotalCommitLimit
;
273 ULONG PeakCommitment
;
275 ULONG WriteCopyFaults
;
276 ULONG TransitionFaults
;
277 ULONG CacheTransitionFaults
;
278 ULONG DemandZeroFaults
;
283 ULONG PagefilePagesWritten
;
284 ULONG PagefilePageWriteIos
;
285 ULONG MappedFilePagesWritten
;
286 ULONG MappedFilePageWriteIos
;
287 ULONG PagedPoolUsage
;
288 ULONG NonPagedPoolUsage
;
289 ULONG PagedPoolAllocs
;
290 ULONG PagedPoolFrees
;
291 ULONG NonPagedPoolAllocs
;
292 ULONG NonPagedPoolFrees
;
293 ULONG TotalFreeSystemPtes
;
294 ULONG SystemCodePage
;
295 ULONG TotalSystemDriverPages
;
296 ULONG TotalSystemCodePages
;
297 ULONG SmallNonPagedLookasideListAllocateHits
;
298 ULONG SmallPagedLookasideListAllocateHits
;
300 ULONG MmSystemCachePage
;
302 ULONG SystemDriverPage
;
303 ULONG FastReadNoWait
;
305 ULONG FastReadResourceMiss
;
306 ULONG FastReadNotPossible
;
307 ULONG FastMdlReadNoWait
;
308 ULONG FastMdlReadWait
;
309 ULONG FastMdlReadResourceMiss
;
310 ULONG FastMdlReadNotPossible
;
313 ULONG MapDataNoWaitMiss
;
314 ULONG MapDataWaitMiss
;
315 ULONG PinMappedDataCount
;
318 ULONG PinReadNoWaitMiss
;
319 ULONG PinReadWaitMiss
;
320 ULONG CopyReadNoWait
;
322 ULONG CopyReadNoWaitMiss
;
323 ULONG CopyReadWaitMiss
;
326 ULONG MdlReadNoWaitMiss
;
327 ULONG MdlReadWaitMiss
;
330 ULONG LazyWritePages
;
333 ULONG ContextSwitches
;
334 ULONG FirstLevelTbFills
;
335 ULONG SecondLevelTbFills
;
337 } SYSTEM_PERFORMANCE_INFORMATION
, *PSYSTEM_PERFORMANCE_INFORMATION
;
339 // SystemModuleInformation (11)
340 typedef struct _SYSTEM_MODULE_INFORMATION_ENTRY
{
347 /* Length of module name not including the path, this
348 field contains valid value only for NTOSKRNL module */
353 } SYSTEM_MODULE_INFORMATION_ENTRY
, *PSYSTEM_MODULE_INFORMATION_ENTRY
;
355 typedef struct _SYSTEM_MODULE_INFORMATION
{
357 SYSTEM_MODULE_INFORMATION_ENTRY Module
[1];
358 } SYSTEM_MODULE_INFORMATION
, *PSYSTEM_MODULE_INFORMATION
;
360 // SystemHandleInformation (16)
363 struct _SYSTEM_HANDLE_ENTRY
372 } SYSTEM_HANDLE_ENTRY
, *PSYSTEM_HANDLE_ENTRY
;
375 struct _SYSTEM_HANDLE_INFORMATION_NT4
378 SYSTEM_HANDLE_ENTRY Handle
[1];
380 } SYSTEM_HANDLE_INFORMATION_NT4
, *PSYSTEM_HANDLE_INFORMATION_NT4
;
382 typedef struct _SYSTEM_HANDLE_INFORMATION
{
384 UCHAR ObjectTypeNumber
;
388 ACCESS_MASK GrantedAccess
;
389 } SYSTEM_HANDLE_INFORMATION
, *PSYSTEM_HANDLE_INFORMATION
;
391 // SystemObjectInformation (17)
393 struct _SYSTEM_OBJECT_TYPE_INFORMATION
395 ULONG NextEntryOffset
;
399 ULONG InvalidAttributes
;
400 GENERIC_MAPPING GenericMapping
;
401 ACCESS_MASK ValidAccessMask
;
406 } SYSTEM_OBJECT_TYPE_INFORMATION
, *PSYSTEM_OBJECT_TYPE_INFORMATION
;
409 struct _SYSTEM_OBJECT_INFORMATION
411 ULONG NextEntryOffset
;
413 ULONG CreatorProcessId
;
418 ULONG PagedPoolUsage
;
419 ULONG NonPagedPoolUsage
;
420 ULONG ExclusiveProcessId
;
421 PSECURITY_DESCRIPTOR SecurityDescriptor
;
424 } SYSTEM_OBJECT_INFORMATION
, *PSYSTEM_OBJECT_INFORMATION
;
426 // SystemPageFileInformation (18)
428 struct _SYSTEM_PAGEFILE_INFORMATION
430 ULONG RelativeOffset
;
431 ULONG CurrentSizePages
;
432 ULONG TotalUsedPages
;
434 UNICODE_STRING PagefileFileName
;
436 } SYSTEM_PAGEFILE_INFORMATION
, *PSYSTEM_PAGEFILE_INFORMATION
;
438 // SystemCacheInformation (21)
440 struct _SYSTEM_CACHE_INFORMATION
444 ULONG PageFaultCount
;
445 ULONG MinimumWorkingSet
;
446 ULONG MaximumWorkingSet
;
447 ULONG TransitionSharedPages
;
448 ULONG TransitionSharedPagesPeak
;
451 } SYSTEM_CACHE_INFORMATION
;
453 // SystemDpcInformation (24)
455 struct _SYSTEM_DPC_INFORMATION
458 ULONG KiMaximumDpcQueueDepth
;
459 ULONG KiMinimumDpcRate
;
460 ULONG KiAdjustDpcThreshold
;
461 ULONG KiIdealDpcRate
;
463 } SYSTEM_DPC_INFORMATION
, *PSYSTEM_DPC_INFORMATION
;
465 // SystemLoadImage (26)
466 typedef struct _SYSTEM_LOAD_IMAGE
468 UNICODE_STRING ModuleName
;
470 PVOID SectionPointer
;
472 PVOID ExportDirectory
;
473 } SYSTEM_LOAD_IMAGE
, *PSYSTEM_LOAD_IMAGE
;
475 // SystemUnloadImage (27)
476 typedef struct _SYSTEM_UNLOAD_IMAGE
479 } SYSTEM_UNLOAD_IMAGE
, *PSYSTEM_UNLOAD_IMAGE
;
481 // SystemTimeAdjustmentInformation (28)
483 struct _SYSTEM_QUERY_TIME_ADJUSTMENT
485 ULONG TimeAdjustment
;
486 ULONG MaximumIncrement
;
487 BOOLEAN TimeSynchronization
;
489 } SYSTEM_QUERY_TIME_ADJUSTMENT
, *PSYSTEM_QUERY_TIME_ADJUSTMENT
;
492 struct _SYSTEM_SET_TIME_ADJUSTMENT
494 ULONG TimeAdjustment
;
495 BOOLEAN TimeSynchronization
;
497 } SYSTEM_SET_TIME_ADJUSTMENT
, *PSYSTEM_SET_TIME_ADJUSTMENT
;
501 typedef enum _ATOM_INFORMATION_CLASS
503 AtomBasicInformation
= 0,
504 AtomTableInformation
= 1,
505 } ATOM_INFORMATION_CLASS
;
507 typedef struct _ATOM_BASIC_INFORMATION
513 } ATOM_BASIC_INFORMATION
, *PATOM_BASIC_INFORMATION
;
515 // SystemLoadAndCallImage(38)
516 typedef struct _SYSTEM_LOAD_AND_CALL_IMAGE
518 UNICODE_STRING ModuleName
;
519 } SYSTEM_LOAD_AND_CALL_IMAGE
, *PSYSTEM_LOAD_AND_CALL_IMAGE
;
521 // SystemRegistryQuotaInformation (37)
522 typedef struct _SYSTEM_REGISTRY_QUOTA_INFORMATION
{
523 ULONG RegistryQuotaAllowed
;
524 ULONG RegistryQuotaUsed
;
526 } SYSTEM_REGISTRY_QUOTA_INFORMATION
, *PSYSTEM_REGISTRY_QUOTA_INFORMATION
;
529 // SystemTimeZoneInformation (44)
531 struct _SYSTEM_TIME_ZONE_INFORMATION
534 WCHAR StandardName
[32];
537 WCHAR DaylightName
[32];
541 } SYSTEM_TIME_ZONE_INFORMATION
, * PSYSTEM_TIME_ZONE_INFORMATION
;
543 // SystemLookasideInformation (45)
545 struct _SYSTEM_LOOKASIDE_INFORMATION
549 ULONG TotalAllocates
;
550 ULONG AllocatesMisses
;
557 } SYSTEM_LOOKASIDE_INFORMATION
, * PSYSTEM_LOOKASIDE_INFORMATION
;
559 // SystemSetTimeSlipEvent (46)
561 struct _SYSTEM_SET_TIME_SLIP_EVENT
563 HANDLE TimeSlipEvent
; /* IN */
565 } SYSTEM_SET_TIME_SLIP_EVENT
, * PSYSTEM_SET_TIME_SLIP_EVENT
;
567 // SystemCreateSession (47)
568 // (available only on TSE/NT5+)
570 struct _SYSTEM_CREATE_SESSION
572 ULONG SessionId
; /* OUT */
574 } SYSTEM_CREATE_SESSION
, * PSYSTEM_CREATE_SESSION
;
576 // SystemDeleteSession (48)
577 // (available only on TSE/NT5+)
579 struct _SYSTEM_DELETE_SESSION
581 ULONG SessionId
; /* IN */
583 } SYSTEM_DELETE_SESSION
, * PSYSTEM_DELETE_SESSION
;
585 // SystemRangeStartInformation (50)
587 struct _SYSTEM_RANGE_START_INFORMATION
589 PVOID SystemRangeStart
;
591 } SYSTEM_RANGE_START_INFORMATION
, * PSYSTEM_RANGE_START_INFORMATION
;
593 // SystemSessionProcessesInformation (53)
594 // (available only on TSE/NT5+)
596 struct _SYSTEM_SESSION_PROCESSES_INFORMATION
600 PVOID Buffer
; /* same format as in SystemProcessInformation */
602 } SYSTEM_SESSION_PROCESSES_INFORMATION
, * PSYSTEM_SESSION_PROCESSES_INFORMATION
;
604 // memory information
606 typedef enum _MEMORY_INFORMATION_CLASS
{
607 MemoryBasicInformation
,
608 MemoryWorkingSetList
,
609 MemorySectionName
//,
610 //MemoryBasicVlmInformation //???
611 } MEMORY_INFORMATION_CLASS
;
613 typedef struct _MEMORY_BASIC_INFORMATION
{ // Information Class 0
615 PVOID AllocationBase
;
616 ULONG AllocationProtect
;
621 } MEMORY_BASIC_INFORMATION
, *PMEMORY_BASIC_INFORMATION
;
623 typedef struct _MEMORY_WORKING_SET_LIST
{ // Information Class 1
625 ULONG WorkingSetList
[1];
626 } MEMORY_WORKING_SET_LIST
, *PMEMORY_WORKING_SET_LIST
;
628 // Information Class 2
629 /*#define _MEMORY_SECTION_NAME_STATIC(__bufsize__) \
631 UNICODE_STRING SectionFileName; \
632 WCHAR NameBuffer[(__bufsize__)]; \
637 UNICODE_STRING SectionFileName
;
638 WCHAR NameBuffer
[ANYSIZE_ARRAY
];
639 } MEMORY_SECTION_NAME
, *PMEMORY_SECTION_NAME
;
641 // Information class 0
642 typedef struct _PROCESS_BASIC_INFORMATION
646 KAFFINITY AffinityMask
;
647 KPRIORITY BasePriority
;
648 ULONG UniqueProcessId
;
649 ULONG InheritedFromUniqueProcessId
;
650 } PROCESS_BASIC_INFORMATION
, *PPROCESS_BASIC_INFORMATION
;
652 // Information class 1
653 typedef struct _QUOTA_LIMITS
655 ULONG PagedPoolLimit
;
656 ULONG NonPagedPoolLimit
;
657 SIZE_T MinimumWorkingSetSize
;
658 SIZE_T MaximumWorkingSetSize
;
661 } QUOTA_LIMITS
, *PQUOTA_LIMITS
;
663 // Information class 2
664 typedef struct _IO_COUNTERS
666 LARGE_INTEGER ReadOperationCount
;
667 LARGE_INTEGER WriteOperationCount
;
668 LARGE_INTEGER OtherOperationCount
;
669 LARGE_INTEGER ReadTransferCount
;
670 LARGE_INTEGER WriteTransferCount
;
671 LARGE_INTEGER OtherTransferCount
;
672 } IO_COUNTERS
, *PIO_COUNTERS
;
674 // Information class 3
675 typedef struct _VM_COUNTERS_
677 ULONG PeakVirtualSize
;
679 ULONG PageFaultCount
;
680 ULONG PeakWorkingSetSize
;
681 ULONG WorkingSetSize
;
682 ULONG QuotaPeakPagedPoolUsage
;
683 ULONG QuotaPagedPoolUsage
;
684 ULONG QuotaPeakNonPagedPoolUsage
;
685 ULONG QuotaNonPagedPoolUsage
;
687 ULONG PeakPagefileUsage
;
688 } VM_COUNTERS
, *PVM_COUNTERS
;
690 // Information class 4
691 typedef struct _KERNEL_USER_TIMES
697 } KERNEL_USER_TIMES
, *PKERNEL_USER_TIMES
;
699 // Information class 9
700 typedef struct _PROCESS_ACCESS_TOKEN
704 } PROCESS_ACCESS_TOKEN
, *PPROCESS_ACCESS_TOKEN
;
706 // Information class 14
707 typedef struct _POOLED_USAGE_AND_LIMITS_
709 ULONG PeakPagedPoolUsage
;
710 ULONG PagedPoolUsage
;
711 ULONG PagedPoolLimit
;
712 ULONG PeakNonPagedPoolUsage
;
713 ULONG NonPagedPoolUsage
;
714 ULONG NonPagedPoolLimit
;
715 ULONG PeakPagefileUsage
;
718 } POOLED_USAGE_AND_LIMITS
, *PPOOLED_USAGE_AND_LIMITS
;
720 // Information class 15
721 typedef struct _PROCESS_WS_WATCH_INFORMATION
725 } PROCESS_WS_WATCH_INFORMATION
, *PPROCESS_WS_WATCH_INFORMATION
;
727 // Information class 18
728 typedef struct _PROCESS_PRIORITY_CLASS
732 } PROCESS_PRIORITY_CLASS
, *PPROCESS_PRIORITY_CLASS
;
734 // Information class 23
735 typedef struct _PROCESS_DEVICEMAP_INFORMATION
739 HANDLE DirectoryHandle
;
746 } PROCESS_DEVICEMAP_INFORMATION
, *pPROCESS_DEVICEMAP_INFORMATION
;
748 // Information class 24
749 typedef struct _PROCESS_SESSION_INFORMATION
752 } PROCESS_SESSION_INFORMATION
, *PPROCESS_SESSION_INFORMATION
;
754 // thread information
756 // incompatible with MS NT
758 typedef struct _THREAD_BASIC_INFORMATION
761 PVOID TebBaseAddress
; // PNT_TIB (GN)
763 KAFFINITY AffinityMask
;
765 KPRIORITY BasePriority
;
766 } THREAD_BASIC_INFORMATION
, *PTHREAD_BASIC_INFORMATION
;
771 typedef struct _FILE_BASIC_INFORMATION
773 LARGE_INTEGER CreationTime
;
774 LARGE_INTEGER LastAccessTime
;
775 LARGE_INTEGER LastWriteTime
;
776 LARGE_INTEGER ChangeTime
;
777 ULONG FileAttributes
;
778 } FILE_BASIC_INFORMATION
, *PFILE_BASIC_INFORMATION
;
780 typedef struct _FILE_STANDARD_INFORMATION
782 LARGE_INTEGER AllocationSize
;
783 LARGE_INTEGER EndOfFile
;
785 BOOLEAN DeletePending
;
787 } FILE_STANDARD_INFORMATION
, *PFILE_STANDARD_INFORMATION
;
789 typedef struct _FILE_POSITION_INFORMATION
791 LARGE_INTEGER CurrentByteOffset
;
792 } FILE_POSITION_INFORMATION
, *PFILE_POSITION_INFORMATION
;
794 typedef struct _FILE_ALIGNMENT_INFORMATION
796 ULONG AlignmentRequirement
;
797 } FILE_ALIGNMENT_INFORMATION
, *PFILE_ALIGNMENT_INFORMATION
;
799 typedef struct _FILE_DISPOSITION_INFORMATION
801 BOOLEAN DoDeleteFile
;
802 } FILE_DISPOSITION_INFORMATION
, *PFILE_DISPOSITION_INFORMATION
;
804 typedef struct _FILE_END_OF_FILE_INFORMATION
806 LARGE_INTEGER EndOfFile
;
807 } FILE_END_OF_FILE_INFORMATION
, *PFILE_END_OF_FILE_INFORMATION
;
809 typedef struct _FILE_NETWORK_OPEN_INFORMATION
815 LARGE_INTEGER AllocationSize
;
816 LARGE_INTEGER EndOfFile
;
817 ULONG FileAttributes
;
818 } FILE_NETWORK_OPEN_INFORMATION
, *PFILE_NETWORK_OPEN_INFORMATION
;
820 typedef struct _FILE_FULL_EA_INFORMATION
822 ULONG NextEntryOffset
;
825 USHORT EaValueLength
;
827 } FILE_FULL_EA_INFORMATION
, *PFILE_FULL_EA_INFORMATION
;
830 typedef struct _FILE_EA_INFORMATION
{
832 } FILE_EA_INFORMATION
, *PFILE_EA_INFORMATION
;
835 typedef struct _FILE_GET_EA_INFORMATION
{
836 ULONG NextEntryOffset
;
839 } FILE_GET_EA_INFORMATION
, *PFILE_GET_EA_INFORMATION
;
841 typedef struct _FILE_STREAM_INFORMATION
{
842 ULONG NextEntryOffset
;
843 ULONG StreamNameLength
;
844 LARGE_INTEGER StreamSize
;
845 LARGE_INTEGER StreamAllocationSize
;
847 } FILE_STREAM_INFORMATION
, *PFILE_STREAM_INFORMATION
;
849 typedef struct _FILE_ALLOCATION_INFORMATION
{
850 LARGE_INTEGER AllocationSize
;
851 } FILE_ALLOCATION_INFORMATION
, *PFILE_ALLOCATION_INFORMATION
;
853 typedef struct _FILE_NAME_INFORMATION
{
854 ULONG FileNameLength
;
856 } FILE_NAME_INFORMATION
, *PFILE_NAME_INFORMATION
;
858 typedef struct _FILE_NAMES_INFORMATION
860 ULONG NextEntryOffset
;
862 ULONG FileNameLength
;
864 } FILE_NAMES_INFORMATION
, *PFILE_NAMES_INFORMATION
;
867 typedef struct _FILE_RENAME_INFORMATION
{
870 ULONG FileNameLength
;
872 } FILE_RENAME_INFORMATION
, *PFILE_RENAME_INFORMATION
;
875 typedef struct _FILE_INTERNAL_INFORMATION
{
876 LARGE_INTEGER IndexNumber
;
877 } FILE_INTERNAL_INFORMATION
, *PFILE_INTERNAL_INFORMATION
;
879 typedef struct _FILE_ACCESS_INFORMATION
{
880 ACCESS_MASK AccessFlags
;
881 } FILE_ACCESS_INFORMATION
, *PFILE_ACCESS_INFORMATION
;
884 typedef struct _FILE_MODE_INFORMATION
{
886 } FILE_MODE_INFORMATION
, *PFILE_MODE_INFORMATION
;
889 typedef struct _FILE_PIPE_INFORMATION
{
891 ULONG CompletionMode
;
892 } FILE_PIPE_INFORMATION
, *PFILE_PIPE_INFORMATION
;
894 typedef struct _FILE_PIPE_LOCAL_INFORMATION
{
896 ULONG NamedPipeConfiguration
;
897 ULONG MaximumInstances
;
898 ULONG CurrentInstances
;
900 ULONG ReadDataAvailable
;
902 ULONG WriteQuotaAvailable
;
903 ULONG NamedPipeState
;
905 } FILE_PIPE_LOCAL_INFORMATION
, *PFILE_PIPE_LOCAL_INFORMATION
;
907 typedef struct _FILE_PIPE_REMOTE_INFORMATION
{
908 LARGE_INTEGER CollectDataTime
;
909 ULONG MaximumCollectionCount
;
910 } FILE_PIPE_REMOTE_INFORMATION
, *PFILE_PIPE_REMOTE_INFORMATION
;
912 typedef struct _FILE_MAILSLOT_QUERY_INFORMATION
{
913 ULONG MaxMessageSize
;
914 ULONG Unknown
; /* ?? */
917 LARGE_INTEGER Timeout
;
918 } FILE_MAILSLOT_QUERY_INFORMATION
, *PFILE_MAILSLOT_QUERY_INFORMATION
;
920 typedef struct _FILE_MAILSLOT_SET_INFORMATION
{
921 LARGE_INTEGER Timeout
;
922 } FILE_MAILSLOT_SET_INFORMATION
, *PFILE_MAILSLOT_SET_INFORMATION
;
924 typedef struct _FILE_COMPRESSION_INFORMATION
{
925 LARGE_INTEGER CompressedFileSize
;
926 USHORT CompressionFormat
;
927 UCHAR CompressionUnitShift
;
931 } FILE_COMPRESSION_INFORMATION
, *PFILE_COMPRESSION_INFORMATION
;
933 typedef struct _FILE_COMPLETION_INFORMATION
{ // Information Class 30
934 HANDLE IoCompletionHandle
;
936 } FILE_COMPLETION_INFORMATION
, *PFILE_COMPLETION_INFORMATION
;
938 typedef struct _FILE_ALL_INFORMATION
{
939 FILE_BASIC_INFORMATION BasicInformation
;
940 FILE_STANDARD_INFORMATION StandardInformation
;
941 FILE_INTERNAL_INFORMATION InternalInformation
;
942 FILE_EA_INFORMATION EaInformation
;
943 FILE_ACCESS_INFORMATION AccessInformation
;
944 FILE_POSITION_INFORMATION PositionInformation
;
945 FILE_MODE_INFORMATION ModeInformation
;
946 FILE_ALIGNMENT_INFORMATION AlignmentInformation
;
947 FILE_NAME_INFORMATION NameInformation
;
948 } FILE_ALL_INFORMATION
, *PFILE_ALL_INFORMATION
;
951 // file system information structures
953 typedef struct _FILE_FS_DEVICE_INFORMATION
{
954 DEVICE_TYPE DeviceType
;
955 ULONG Characteristics
;
956 } FILE_FS_DEVICE_INFORMATION
, *PFILE_FS_DEVICE_INFORMATION
;
959 typedef struct _FILE_FS_VOLUME_INFORMATION
{
960 TIME VolumeCreationTime
;
961 ULONG VolumeSerialNumber
;
962 ULONG VolumeLabelLength
;
963 BOOLEAN SupportsObjects
;
964 WCHAR VolumeLabel
[0];
965 } FILE_FS_VOLUME_INFORMATION
, *PFILE_FS_VOLUME_INFORMATION
;
967 typedef struct _FILE_FS_SIZE_INFORMATION
{
968 LARGE_INTEGER TotalAllocationUnits
;
969 LARGE_INTEGER AvailableAllocationUnits
;
970 ULONG SectorsPerAllocationUnit
;
971 ULONG BytesPerSector
;
972 } FILE_FS_SIZE_INFORMATION
, *PFILE_FS_SIZE_INFORMATION
;
974 typedef struct _FILE_FS_ATTRIBUTE_INFORMATION
{
975 ULONG FileSystemAttributes
;
976 LONG MaximumComponentNameLength
;
977 ULONG FileSystemNameLength
;
978 WCHAR FileSystemName
[0];
979 } FILE_FS_ATTRIBUTE_INFORMATION
, *PFILE_FS_ATTRIBUTE_INFORMATION
;
982 FileSystemAttributes is one of the following values:
984 FILE_CASE_SENSITIVE_SEARCH 0x00000001
985 FILE_CASE_PRESERVED_NAMES 0x00000002
986 FILE_UNICODE_ON_DISK 0x00000004
987 FILE_PERSISTENT_ACLS 0x00000008
988 FILE_FILE_COMPRESSION 0x00000010
989 FILE_VOLUME_QUOTAS 0x00000020
990 FILE_VOLUME_IS_COMPRESSED 0x00008000
992 typedef struct _FILE_FS_LABEL_INFORMATION
{
993 ULONG VolumeLabelLength
;
994 WCHAR VolumeLabel
[0];
995 } FILE_FS_LABEL_INFORMATION
, *PFILE_FS_LABEL_INFORMATION
;
998 typedef struct _FILE_DIRECTORY_INFORMATION
{
999 ULONG NextEntryOffset
;
1002 TIME LastAccessTime
;
1005 LARGE_INTEGER EndOfFile
;
1006 LARGE_INTEGER AllocationSize
;
1007 ULONG FileAttributes
;
1008 ULONG FileNameLength
;
1010 } FILE_DIRECTORY_INFORMATION
, *PFILE_DIRECTORY_INFORMATION
;
1012 typedef struct _FILE_FULL_DIRECTORY_INFORMATION
{
1013 ULONG NextEntryOffset
;
1016 TIME LastAccessTime
;
1019 LARGE_INTEGER EndOfFile
;
1020 LARGE_INTEGER AllocationSize
;
1021 ULONG FileAttributes
;
1022 ULONG FileNameLength
;
1024 WCHAR FileName
[0]; // variable size
1025 } FILE_FULL_DIRECTORY_INFORMATION
, *PFILE_FULL_DIRECTORY_INFORMATION
,
1026 FILE_FULL_DIR_INFORMATION
, *PFILE_FULL_DIR_INFORMATION
;
1029 typedef struct _FILE_BOTH_DIRECTORY_INFORMATION
{
1030 ULONG NextEntryOffset
;
1033 TIME LastAccessTime
;
1036 LARGE_INTEGER EndOfFile
;
1037 LARGE_INTEGER AllocationSize
;
1038 ULONG FileAttributes
;
1039 ULONG FileNameLength
;
1041 CHAR ShortNameLength
;
1042 WCHAR ShortName
[12]; // 8.3 name
1044 } FILE_BOTH_DIRECTORY_INFORMATION
, *PFILE_BOTH_DIRECTORY_INFORMATION
,
1045 FILE_BOTH_DIR_INFORMATION
, *PFILE_BOTH_DIR_INFORMATION
;
1048 NotifyFilter / CompletionFilter:
1050 FILE_NOTIFY_CHANGE_FILE_NAME 0x00000001
1051 FILE_NOTIFY_CHANGE_DIR_NAME 0x00000002
1052 FILE_NOTIFY_CHANGE_NAME 0x00000003
1053 FILE_NOTIFY_CHANGE_ATTRIBUTES 0x00000004
1054 FILE_NOTIFY_CHANGE_SIZE 0x00000008
1055 FILE_NOTIFY_CHANGE_LAST_WRITE 0x00000010
1056 FILE_NOTIFY_CHANGE_LAST_ACCESS 0x00000020
1057 FILE_NOTIFY_CHANGE_CREATION 0x00000040
1058 FILE_NOTIFY_CHANGE_EA 0x00000080
1059 FILE_NOTIFY_CHANGE_SECURITY 0x00000100
1060 FILE_NOTIFY_CHANGE_STREAM_NAME 0x00000200
1061 FILE_NOTIFY_CHANGE_STREAM_SIZE 0x00000400
1062 FILE_NOTIFY_CHANGE_STREAM_WRITE 0x00000800
1065 typedef struct _FILE_NOTIFY_INFORMATION
{
1067 ULONG FileNameLength
;
1069 } FILE_NOTIFY_INFORMATION
;
1071 #define FSCTL_GET_VOLUME_BITMAP 0x9006F
1072 #define FSCTL_GET_RETRIEVAL_POINTERS 0x90073
1073 #define FSCTL_MOVE_FILE 0x90074
1075 typedef struct _MAPPING_PAIR
1079 } MAPPING_PAIR
, *PMAPPING_PAIR
;
1081 typedef struct _GET_RETRIEVAL_DESCRIPTOR
1083 ULONG NumberOfPairs
;
1085 MAPPING_PAIR Pair
[0]; // variable size
1086 } GET_RETRIEVAL_DESCRIPTOR
, *PGET_RETRIEVAL_DESCRIPTOR
;
1088 typedef struct _MOVEFILE_DESCRIPTOR
1092 LARGE_INTEGER StartVcn
;
1093 LARGE_INTEGER TargetLcn
;
1096 } MOVEFILE_DESCRIPTOR
, *PMOVEFILE_DESCRIPTOR
;
1098 typedef struct _SECTION_BASIC_INFORMATION
1103 } SECTION_BASIC_INFORMATION
, *PSECTION_BASIC_INFORMATION
;
1105 typedef enum _SECTION_INFORMATION_CLASS
1107 SectionBasicInformation
,
1108 SectionImageInformation
,
1109 } SECTION_INFORMATION_CLASS
;
1113 typedef enum SHUTDOWN_ACTION_TAG
{
1119 typedef enum _IO_COMPLETION_INFORMATION_CLASS
{
1120 IoCompletionBasicInformation
1121 } IO_COMPLETION_INFORMATION_CLASS
;
1123 typedef struct _IO_COMPLETION_BASIC_INFORMATION
{
1125 } IO_COMPLETION_BASIC_INFORMATION
, *PIO_COMPLETION_BASIC_INFORMATION
;
1127 #else /* __USE_W32API */
1129 #define DebugDbgLoadSymbols ((DEBUG_CONTROL_CODE)0xffffffff)
1131 #endif /* __USE_W32API */
1134 #include <ddk/ntddk.h>
1135 #endif /* __USE_W32API */
1136 #ifndef NtCurrentProcess
1137 #define NtCurrentProcess() ( (HANDLE) 0xFFFFFFFF )
1138 #endif /* NtCurrentProcess */
1139 #ifndef NtCurrentThread
1140 #define NtCurrentThread() ( (HANDLE) 0xFFFFFFFE )
1141 #endif /* NtCurrentThread */
1145 extern ULONG EXPORTED NtBuildNumber
;
1147 extern ULONG IMPORTED NtBuildNumber
;
1150 /* Microsoft-style declarations */
1152 extern EXPORTED ULONG NtBuildNumber
;
1154 extern IMPORTED ULONG NtBuildNumber
;
1156 #endif /* __GNUC__ */
1159 // event access mask
1161 #define EVENT_READ_ACCESS 1
1162 #define EVENT_WRITE_ACCESS 2
1164 //process query / set information class
1166 #define ProcessBasicInformation 0
1167 #define ProcessQuotaLimits 1
1168 #define ProcessIoCounters 2
1169 #define ProcessVmCounters 3
1170 #define ProcessTimes 4
1171 #define ProcessBasePriority 5
1172 #define ProcessRaisePriority 6
1173 #define ProcessDebugPort 7
1174 #define ProcessExceptionPort 8
1175 #define ProcessAccessToken 9
1176 #define ProcessLdtInformation 10
1177 #define ProcessLdtSize 11
1178 #define ProcessDefaultHardErrorMode 12
1179 #define ProcessIoPortHandlers 13
1180 #define ProcessPooledUsageAndLimits 14
1181 #define ProcessWorkingSetWatch 15
1182 #define ProcessUserModeIOPL 16
1183 #define ProcessEnableAlignmentFaultFixup 17
1184 #define ProcessPriorityClass 18
1185 #define ProcessWx86Information 19
1186 #define ProcessHandleCount 20
1187 #define ProcessAffinityMask 21
1188 #define ProcessPriorityBoost 22
1189 #define ProcessDeviceMap 23
1190 #define ProcessSessionInformation 24
1191 #define ProcessForegroundInformation 25
1192 #define ProcessWow64Information 26
1193 /* ReactOS private. */
1194 #define ProcessImageFileName 27
1195 #define ProcessDesktop 28
1196 #define MaxProcessInfoClass 29
1199 * thread query / set information class
1201 #define ThreadBasicInformation 0
1202 #define ThreadTimes 1
1203 #define ThreadPriority 2
1204 #define ThreadBasePriority 3
1205 #define ThreadAffinityMask 4
1206 #define ThreadImpersonationToken 5
1207 #define ThreadDescriptorTableEntry 6
1208 #define ThreadEnableAlignmentFaultFixup 7
1209 #define ThreadEventPair 8
1210 #define ThreadQuerySetWin32StartAddress 9
1211 #define ThreadZeroTlsCell 10
1212 #define ThreadPerformanceCount 11
1213 #define ThreadAmILastThread 12
1214 #define ThreadIdealProcessor 13
1215 #define ThreadPriorityBoost 14
1216 #define ThreadSetTlsArrayAddress 15
1217 #define ThreadIsIoPending 16
1218 #define ThreadHideFromDebugger 17
1219 #define MaxThreadInfoClass 17
1222 typedef struct _ATOM_TABLE_INFORMATION
1224 ULONG NumberOfAtoms
;
1226 } ATOM_TABLE_INFORMATION
, *PATOM_TABLE_INFORMATION
;
1229 // mutant information
1231 typedef enum _MUTANT_INFORMATION_CLASS
1233 MutantBasicInformation
= 0
1234 } MUTANT_INFORMATION_CLASS
;
1236 typedef struct _MUTANT_BASIC_INFORMATION
1241 } MUTANT_BASIC_INFORMATION
, *PMUTANT_BASIC_INFORMATION
;
1244 // SystemTimeOfDayInformation (3)
1246 struct _SYSTEM_TIMEOFDAY_INFORMATION
1248 LARGE_INTEGER BootTime
;
1249 LARGE_INTEGER CurrentTime
;
1250 LARGE_INTEGER TimeZoneBias
;
1253 } SYSTEM_TIMEOFDAY_INFORMATION
, *PSYSTEM_TIMEOFDAY_INFORMATION
;
1255 // SystemPathInformation (4)
1258 struct _SYSTEM_PATH_INFORMATION
1262 } SYSTEM_PATH_INFORMATION
, * PSYSTEM_PATH_INFORMATION
;
1264 // SystemProcessInformation (5)
1266 #ifndef __USE_W32API
1268 typedef struct _SYSTEM_THREADS
{
1269 LARGE_INTEGER KernelTime
;
1270 LARGE_INTEGER UserTime
;
1271 LARGE_INTEGER CreateTime
;
1276 KPRIORITY BasePriority
;
1277 ULONG ContextSwitchCount
;
1279 KWAIT_REASON WaitReason
;
1280 } SYSTEM_THREADS
, *PSYSTEM_THREADS
;
1282 #endif /* __USE_W32API */
1284 typedef struct _SYSTEM_PROCESSES_NT4
1286 SIZE_T NextEntryDelta
;
1292 UNICODE_STRING ProcessName
;
1293 KPRIORITY BasePriority
;
1295 ULONG InheritedFromProcessId
;
1298 VM_COUNTERS VmCounters
;
1299 SYSTEM_THREADS Threads
[ANYSIZE_ARRAY
];
1300 } SYSTEM_PROCESSES_NT4
, *PSYSTEM_PROCESSES_NT4
;
1302 typedef struct _SYSTEM_PROCESSES_NT5
1304 SIZE_T NextEntryDelta
;
1310 UNICODE_STRING ProcessName
;
1311 KPRIORITY BasePriority
;
1313 ULONG InheritedFromProcessId
;
1316 VM_COUNTERS VmCounters
;
1317 IO_COUNTERS IoCounters
;
1318 SYSTEM_THREADS Threads
[ANYSIZE_ARRAY
];
1319 } SYSTEM_PROCESSES_NT5
, *PSYSTEM_PROCESSES_NT5
;
1321 #ifndef __USE_W32API
1323 /* Not sure. What version are we emulating? */
1324 typedef SYSTEM_PROCESSES_NT5 SYSTEM_PROCESSES
, *PSYSTEM_PROCESSES
;
1326 #endif /* __USE_W32API */
1328 // SystemCallCountInformation (6)
1330 struct _SYSTEM_SDT_INFORMATION
1333 ULONG NumberOfSystemServiceTables
;
1334 ULONG NumberOfServices
[1];
1335 ULONG ServiceCounters
[1];
1337 } SYSTEM_SDT_INFORMATION
, *PSYSTEM_SDT_INFORMATION
;
1339 // SystemDeviceInformation (7)
1341 struct _SYSTEM_DEVICE_INFORMATION
1343 ULONG NumberOfDisks
;
1344 ULONG NumberOfFloppies
;
1345 ULONG NumberOfCdRoms
;
1346 ULONG NumberOfTapes
;
1347 ULONG NumberOfSerialPorts
;
1348 ULONG NumberOfParallelPorts
;
1349 } SYSTEM_DEVICE_INFORMATION
, *PSYSTEM_DEVICE_INFORMATION
;
1351 // SystemProcessorPerformanceInformation (8)
1352 // (one per processor in the system)
1354 struct _SYSTEM_PROCESSORTIME_INFO
1356 TIME TotalProcessorRunTime
;
1357 TIME TotalProcessorTime
;
1358 TIME TotalProcessorUserTime
;
1360 TIME TotalInterruptTime
;
1361 ULONG TotalInterrupts
;
1364 } SYSTEM_PROCESSORTIME_INFO
, *PSYSTEM_PROCESSORTIME_INFO
;
1366 // SystemFlagsInformation (9)
1368 struct _SYSTEM_FLAGS_INFORMATION
1372 } SYSTEM_FLAGS_INFORMATION
, * PSYSTEM_FLAGS_INFORMATION
;
1374 #define FLG_STOP_ON_EXCEPTION 0x00000001
1375 #define FLG_SHOW_LDR_SNAPS 0x00000002
1376 #define FLG_DEBUG_INITIAL_COMMAND 0x00000004
1377 #define FLG_STOP_ON_HANG_GUI 0x00000008
1378 #define FLG_HEAP_ENABLE_TAIL_CHECK 0x00000010
1379 #define FLG_HEAP_ENABLE_FREE_CHECK 0x00000020
1380 #define FLG_HEAP_VALIDATE_PARAMETERS 0x00000040
1381 #define FLG_HEAP_VALIDATE_ALL 0x00000080
1382 #define FLG_POOL_ENABLE_TAIL_CHECK 0x00000100
1383 #define FLG_POOL_ENABLE_FREE_CHECK 0x00000200
1384 #define FLG_POOL_ENABLE_TAGGING 0x00000400
1385 #define FLG_HEAP_ENABLE_TAGGING 0x00000800
1386 #define FLG_USER_STACK_TRACE_DB 0x00001000
1387 #define FLG_KERNEL_STACK_TRACE_DB 0x00002000
1388 #define FLG_MAINTAIN_OBJECT_TYPELIST 0x00004000
1389 #define FLG_HEAP_ENABLE_TAG_BY_DLL 0x00008000
1390 #define FLG_IGNORE_DEBUG_PRIV 0x00010000
1391 #define FLG_ENABLE_CSRDEBUG 0x00020000
1392 #define FLG_ENABLE_KDEBUG_SYMBOL_LOAD 0x00040000
1393 #define FLG_DISABLE_PAGE_KERNEL_STACKS 0x00080000
1394 #define FLG_HEAP_ENABLE_CALL_TRACING 0x00100000
1395 #define FLG_HEAP_DISABLE_COALESCING 0x00200000
1396 #define FLG_ENABLE_CLOSE_EXCEPTION 0x00400000
1397 #define FLG_ENABLE_EXCEPTION_LOGGING 0x00800000
1398 #define FLG_UNKNOWN_01000000 0x01000000
1399 #define FLG_UNKNOWN_02000000 0x02000000
1400 #define FLG_UNKNOWN_04000000 0x04000000
1401 #define FLG_ENABLE_DBGPRINT_BUFFERING 0x08000000
1402 #define FLG_UNKNOWN_10000000 0x10000000
1403 #define FLG_UNKNOWN_20000000 0x20000000
1404 #define FLG_UNKNOWN_40000000 0x40000000
1405 #define FLG_UNKNOWN_80000000 0x80000000
1407 // SystemCallTimeInformation (10)
1410 // SystemLocksInformation (12)
1412 struct _SYSTEM_RESOURCE_LOCK_ENTRY
1414 ULONG ResourceAddress
;
1418 ULONG ContentionCount
;
1420 ULONG NumberOfSharedWaiters
;
1421 ULONG NumberOfExclusiveWaiters
;
1423 } SYSTEM_RESOURCE_LOCK_ENTRY
, *PSYSTEM_RESOURCE_LOCK_ENTRY
;
1426 struct _SYSTEM_RESOURCE_LOCK_INFO
1429 SYSTEM_RESOURCE_LOCK_ENTRY Lock
[1];
1431 } SYSTEM_RESOURCE_LOCK_INFO
, *PSYSTEM_RESOURCE_LOCK_INFO
;
1433 // SystemInformation13 (13)
1436 // SystemInformation14 (14)
1439 // SystemInformation15 (15)
1442 // SystemInstructionEmulationInfo (19)
1444 struct _SYSTEM_VDM_INFORMATION
1446 ULONG VdmSegmentNotPresentCount
;
1448 ULONG VdmESPREFIXCount
;
1449 ULONG VdmCSPREFIXCount
;
1450 ULONG VdmSSPREFIXCount
;
1451 ULONG VdmDSPREFIXCount
;
1452 ULONG VdmFSPREFIXCount
;
1453 ULONG VdmGSPREFIXCount
;
1454 ULONG VdmOPER32PREFIXCount
;
1455 ULONG VdmADDR32PREFIXCount
;
1457 ULONG VdmINSWV86Count
;
1458 ULONG VdmOUTSBCount
;
1459 ULONG VdmOUTSWCount
;
1460 ULONG VdmPUSHFCount
;
1462 ULONG VdmINTNNCount
;
1465 ULONG VdmINBIMMCount
;
1466 ULONG VdmINWIMMCount
;
1467 ULONG VdmOUTBIMMCount
;
1468 ULONG VdmOUTWIMMCount
;
1473 ULONG VdmLOCKPREFIXCount
;
1474 ULONG VdmREPNEPREFIXCount
;
1475 ULONG VdmREPPREFIXCount
;
1481 } SYSTEM_VDM_INFORMATION
, *PSYSTEM_VDM_INFORMATION
;
1483 // SystemInformation20 (20)
1486 // SystemPoolTagInformation (22)
1487 // found by Klaus P. Gerlicher
1488 // (implemented only in checked builds)
1490 struct _POOL_TAG_STATS
1492 ULONG AllocationCount
;
1499 struct _SYSTEM_POOL_TAG_ENTRY
1502 POOL_TAG_STATS Paged
;
1503 POOL_TAG_STATS NonPaged
;
1505 } SYSTEM_POOL_TAG_ENTRY
, * PSYSTEM_POOL_TAG_ENTRY
;
1508 struct _SYSTEM_POOL_TAG_INFO
1511 SYSTEM_POOL_TAG_ENTRY PoolEntry
[1];
1513 } SYSTEM_POOL_TAG_INFO
, *PSYSTEM_POOL_TAG_INFO
;
1515 // SystemProcessorScheduleInfo (23)
1517 struct _SYSTEM_PROCESSOR_SCHEDULE_INFO
1519 ULONG nContextSwitches
;
1522 ULONG TimerResolution
;
1526 } SYSTEM_PROCESSOR_SCHEDULE_INFO
, *PSYSTEM_PROCESSOR_SCHEDULE_INFO
;
1528 // SystemInformation25 (25)
1531 // SystemProcessorFaultCountInfo (33)
1533 struct _SYSTEM_PROCESSOR_FAULT_INFO
1535 ULONG nAlignmentFixup
;
1536 ULONG nExceptionDispatches
;
1537 ULONG nFloatingEmulation
;
1540 } SYSTEM_PROCESSOR_FAULT_INFO
, *PSYSTEM_PROCESSOR_FAULT_INFO
;
1542 // SystemCrashDumpStateInfo (34)
1545 // SystemDebuggerInformation (35)
1547 struct _SYSTEM_DEBUGGER_INFO
1549 BOOLEAN KdDebuggerEnabled
;
1550 BOOLEAN KdDebuggerPresent
;
1552 } SYSTEM_DEBUGGER_INFO
, *PSYSTEM_DEBUGGER_INFO
;
1554 // SystemInformation36 (36)
1557 // SystemQuotaInformation (37)
1559 struct _SYSTEM_QUOTA_INFORMATION
1561 ULONG CmpGlobalQuota
;
1562 ULONG CmpGlobalQuotaUsed
;
1563 ULONG MmSizeofPagedPoolInBytes
;
1565 } SYSTEM_QUOTA_INFORMATION
, *PSYSTEM_QUOTA_INFORMATION
;
1570 // SystemVerifierInformation (51)
1573 // SystemAddVerifier (52)
1581 // number of wait objects
1583 #define THREAD_WAIT_OBJECTS 3
1584 //#define MAXIMUM_WAIT_OBJECTS 64
1586 // object type access rights
1588 #define OBJECT_TYPE_CREATE 0x0001
1589 #define OBJECT_TYPE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
1591 // directory access rights
1593 #ifndef __USE_W32API
1594 #define DIRECTORY_QUERY 0x0001
1595 #define DIRECTORY_TRAVERSE 0x0002
1596 #define DIRECTORY_CREATE_OBJECT 0x0004
1597 #define DIRECTORY_CREATE_SUBDIRECTORY 0x0008
1600 #define DIRECTORY_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0xF)
1602 // symbolic link access rights
1604 #define SYMBOLIC_LINK_QUERY 0x0001
1605 #define SYMBOLIC_LINK_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
1608 /* object information class */
1610 #ifndef __USE_W32API
1612 typedef enum _OBJECT_INFORMATION_CLASS
1614 ObjectBasicInformation
,
1615 ObjectNameInformation
,
1616 ObjectTypeInformation
,
1617 ObjectAllTypesInformation
,
1618 ObjectHandleInformation
1619 } OBJECT_INFORMATION_CLASS
;
1622 // directory information
1624 typedef struct _DIRECTORY_BASIC_INFORMATION
1626 UNICODE_STRING ObjectName
;
1627 UNICODE_STRING ObjectTypeName
; // Directory, Device ...
1628 } DIRECTORY_BASIC_INFORMATION
, *PDIRECTORY_BASIC_INFORMATION
;
1631 // power information levels
1632 typedef enum _POWER_INFORMATION_LEVEL
{
1633 SystemPowerPolicyAc
,
1634 SystemPowerPolicyDc
,
1635 VerifySystemPolicyAc
,
1636 VerifySystemPolicyDc
,
1637 SystemPowerCapabilities
,
1639 SystemPowerStateHandler
,
1640 ProcessorStateHandler
,
1641 SystemPowerPolicyCurrent
,
1642 AdministratorPowerPolicy
,
1643 SystemReserveHiberFile
,
1644 ProcessorInformation
,
1645 SystemPowerInformationData
1646 } POWER_INFORMATION_LEVEL
;
1648 #endif /* __USE_W32API */
1651 Action is one of the following values:
1653 FILE_ACTION_ADDED 0x00000001
1654 FILE_ACTION_REMOVED 0x00000002
1655 FILE_ACTION_MODIFIED 0x00000003
1656 FILE_ACTION_RENAMED_OLD_NAME 0x00000004
1657 FILE_ACTION_RENAMED_NEW_NAME 0x00000005
1658 FILE_ACTION_ADDED_STREAM 0x00000006
1659 FILE_ACTION_REMOVED_STREAM 0x00000007
1660 FILE_ACTION_MODIFIED_STREAM 0x00000008
1665 // File System Control commands ( related to defragging )
1667 #define FSCTL_READ_MFT_RECORD 0x90068 // NTFS only
1669 typedef struct _BITMAP_DESCRIPTOR
1672 ULONGLONG ClustersToEndOfVol
;
1673 BYTE Map
[0]; // variable size
1674 } BITMAP_DESCRIPTOR
, *PBITMAP_DESCRIPTOR
;
1677 //typedef enum _TIMER_TYPE
1679 // NotificationTimer,
1680 // SynchronizationTimer
1683 typedef struct _TIMER_BASIC_INFORMATION
1685 LARGE_INTEGER TimeRemaining
;
1686 BOOLEAN SignalState
;
1687 } TIMER_BASIC_INFORMATION
, *PTIMER_BASIC_INFORMATION
;
1689 typedef enum _TIMER_INFORMATION_CLASS
1691 TimerBasicInformation
1692 } TIMER_INFORMATION_CLASS
;
1694 #ifndef __USE_W32API
1698 UNUSED_MSG_TYPE
= 0x0, /* ReactOS */
1699 LPC_NEW_MESSAGE
= 0x0, /* NT */
1703 LPC_LOST_REPLY
= 0x4,
1704 LPC_PORT_CLOSED
= 0x5,
1705 LPC_CLIENT_DIED
= 0x6,
1706 LPC_EXCEPTION
= 0x7,
1707 LPC_DEBUG_EVENT
= 0x8,
1708 LPC_ERROR_EVENT
= 0x9,
1709 LPC_CONNECTION_REQUEST
= 0xa,
1710 LPC_CONNECTION_REFUSED
= 0xb
1712 } LPC_TYPE
, *PLPC_TYPE
;
1714 typedef struct _LPC_SECTION_WRITE
1717 HANDLE SectionHandle
;
1718 ULONG SectionOffset
;
1721 PVOID TargetViewBase
;
1722 } LPC_SECTION_WRITE
, *PLPC_SECTION_WRITE
;
1724 typedef struct _LPC_SECTION_READ
1729 } LPC_SECTION_READ
, *PLPC_SECTION_READ
;
1731 typedef struct _LPC_MESSAGE
1736 USHORT VirtualRangesOffset
;
1739 ULONG SectionSize
; /* CallbackID */
1740 } LPC_MESSAGE
, *PLPC_MESSAGE
;
1742 #define LPC_MESSAGE_BASE_SIZE sizeof(LPC_MESSAGE)
1744 #define PORT_MESSAGE_TYPE(m) (LPC_TYPE)((m).Header.MessageType)
1746 #define PORT_MAX_DATA_LENGTH 0x104
1747 #define PORT_MAX_MESSAGE_LENGTH 0x148
1749 #endif /* __USE_W32API */
1751 #define MAX_MESSAGE_DATA (0x130)
1753 typedef struct _LPC_MAX_MESSAGE
1756 BYTE Data
[MAX_MESSAGE_DATA
];
1757 } LPC_MAX_MESSAGE
, *PLPC_MAX_MESSAGE
;
1759 typedef struct _LPC_PORT_BASIC_INFORMATION
1776 } LPC_PORT_BASIC_INFORMATION
, * PLPC_PORT_BASIC_INFORMATION
;
1779 typedef struct _KINTERRUPT
1782 KAFFINITY ProcessorEnableMask
;
1783 PKSPIN_LOCK IrqLock
;
1785 BOOLEAN FloatingSave
;
1786 PKSERVICE_ROUTINE ServiceRoutine
;
1787 PVOID ServiceContext
;
1792 #ifndef __USE_W32API
1794 typedef struct _KINTERRUPT
*PKINTERRUPT
;
1796 #endif /* __USE_W32API */
1798 /* BEGIN REACTOS ONLY */
1800 typedef enum _TRAVERSE_METHOD
{
1801 TraverseMethodPreorder
,
1802 TraverseMethodInorder
,
1803 TraverseMethodPostorder
1806 typedef LONG STDCALL_FUNC
1807 (*PKEY_COMPARATOR
)(IN PVOID Key1
,
1810 typedef BOOLEAN STDCALL_FUNC
1811 (*PTRAVERSE_ROUTINE
)(IN PVOID Context
,
1815 struct _BINARY_TREE_NODE
;
1817 typedef struct _BINARY_TREE
1819 struct _BINARY_TREE_NODE
* RootNode
;
1820 PKEY_COMPARATOR Compare
;
1821 BOOLEAN UseNonPagedPool
;
1823 NPAGED_LOOKASIDE_LIST NonPaged
;
1824 PAGED_LOOKASIDE_LIST Paged
;
1827 KSPIN_LOCK NonPaged
;
1830 } BINARY_TREE
, *PBINARY_TREE
;
1833 struct _SPLAY_TREE_NODE
;
1835 typedef struct _SPLAY_TREE
1837 struct _SPLAY_TREE_NODE
* RootNode
;
1838 PKEY_COMPARATOR Compare
;
1840 BOOLEAN UseNonPagedPool
;
1842 NPAGED_LOOKASIDE_LIST NonPaged
;
1843 PAGED_LOOKASIDE_LIST Paged
;
1846 KSPIN_LOCK NonPaged
;
1850 } SPLAY_TREE
, *PSPLAY_TREE
;
1853 typedef struct _HASH_TABLE
1855 // Size of hash table in number of bits
1856 ULONG HashTableSize
;
1858 // Use non-paged pool memory?
1859 BOOLEAN UseNonPagedPool
;
1861 // Lock for this structure
1863 KSPIN_LOCK NonPaged
;
1867 // Pointer to array of hash buckets with splay trees
1868 PSPLAY_TREE HashTrees
;
1869 } HASH_TABLE
, *PHASH_TABLE
;
1872 /* END REACTOS ONLY */