update for HEAD-2003021201
[reactos.git] / include / ntos / zwtypes.h
old mode 100644 (file)
new mode 100755 (executable)
similarity index 97%
rename from include/ddk/zwtypes.h
rename to include/ntos/zwtypes.h
index 1095c91..cc1fe02
@@ -1,6 +1,8 @@
 #ifndef __INCLUDE_DDK_ZWTYPES_H
 #define __INCLUDE_DDK_ZWTYPES_H
 
+#ifndef __USE_W32API
+
 typedef enum _DEBUG_CONTROL_CODE
 {
   DebugGetTraceInformation = 1,
@@ -17,25 +19,8 @@ typedef enum _KPROFILE_SOURCE
   ProfileTime
 } KPROFILE_SOURCE;
 
-#define NtCurrentProcess() ( (HANDLE) 0xFFFFFFFF )
-#define NtCurrentThread() ( (HANDLE) 0xFFFFFFFE )
-
-#ifdef __NTOSKRNL__
-extern ULONG EXPORTED NtBuildNumber;
-#else
-extern ULONG IMPORTED NtBuildNumber;
-#endif
-
-
-// event access mask
-
-#define EVENT_READ_ACCESS                      1
-#define EVENT_WRITE_ACCESS                     2
-
-
 // file disposition values
 
-
 #define FILE_SUPERSEDE                  0x0000
 #define FILE_OPEN                       0x0001
 #define FILE_CREATE                     0x0002
@@ -58,137 +43,6 @@ typedef enum _JOBOBJECTINFOCLASS {               // Q S
     JobObjectExtendedLimitInformation,           // Y Y
 } JOBOBJECTINFOCLASS;
 
-//process query / set information class
-
-#define ProcessBasicInformation                        0
-#define ProcessQuotaLimits                     1
-#define ProcessIoCounters                      2
-#define ProcessVmCounters                      3
-#define ProcessTimes                           4
-#define ProcessBasePriority                    5
-#define ProcessRaisePriority                   6
-#define ProcessDebugPort                       7
-#define ProcessExceptionPort                   8
-#define ProcessAccessToken                     9
-#define ProcessLdtInformation                  10
-#define ProcessLdtSize                         11
-#define ProcessDefaultHardErrorMode            12
-#define ProcessIoPortHandlers                  13
-#define ProcessPooledUsageAndLimits            14
-#define ProcessWorkingSetWatch                 15
-#define ProcessUserModeIOPL                    16
-#define ProcessEnableAlignmentFaultFixup       17
-#define ProcessPriorityClass                   18
-#define ProcessWx86Information                 19
-#define ProcessHandleCount                     20
-#define ProcessAffinityMask                    21
-#define ProcessPriorityBoost                   22
-#define ProcessDeviceMap                       23
-#define ProcessSessionInformation              24
-#define ProcessForegroundInformation           25
-#define ProcessWow64Information                        26
-/* ReactOS private. */
-#define ProcessImageFileName                   27
-#define ProcessDesktop                          28
-#define MaxProcessInfoClass                    29
-
-/*
- * thread query / set information class
- */
-#define ThreadBasicInformation                 0
-#define ThreadTimes                            1
-#define ThreadPriority                         2
-#define ThreadBasePriority                     3
-#define ThreadAffinityMask                     4
-#define ThreadImpersonationToken               5
-#define ThreadDescriptorTableEntry             6
-#define ThreadEnableAlignmentFaultFixup                7
-#define ThreadEventPair                                8
-#define ThreadQuerySetWin32StartAddress                9
-#define ThreadZeroTlsCell                      10
-#define ThreadPerformanceCount                 11
-#define ThreadAmILastThread                    12
-#define ThreadIdealProcessor                   13
-#define ThreadPriorityBoost                    14
-#define ThreadSetTlsArrayAddress               15
-#define ThreadIsIoPending                      16
-#define ThreadHideFromDebugger                 17
-#define MaxThreadInfoClass                     17
-
-// object handle information
-
-#define ObjectBasicInformation                 0
-#define ObjectNameInformation                  1
-#define ObjectTypeInformation                  2
-#define ObjectAllInformation                   3
-#define ObjectDataInformation                  4
-
-// atom information
-
-typedef enum _ATOM_INFORMATION_CLASS
-{
-   AtomBasicInformation                = 0,
-   AtomTableInformation                = 1,
-} ATOM_INFORMATION_CLASS;
-
-typedef struct _ATOM_BASIC_INFORMATION
-{
-   USHORT UsageCount;
-   USHORT Flags;
-   USHORT NameLength;
-   WCHAR Name[1];
-} ATOM_BASIC_INFORMATION, *PATOM_BASIC_INFORMATION;
-
-typedef struct _ATOM_TABLE_INFORMATION
-{
-   ULONG NumberOfAtoms;
-   RTL_ATOM Atoms[1];
-} ATOM_TABLE_INFORMATION, *PATOM_TABLE_INFORMATION;
-
-
-// mutant information
-
-typedef enum _MUTANT_INFORMATION_CLASS
-{
-  MutantBasicInformation = 0
-} MUTANT_INFORMATION_CLASS;
-
-typedef struct _MUTANT_BASIC_INFORMATION
-{
-  LONG Count;
-  BOOLEAN Owned;
-  BOOLEAN Abandoned;
-} MUTANT_BASIC_INFORMATION, *PMUTANT_BASIC_INFORMATION;
-
-
-// semaphore information
-
-typedef enum _SEMAPHORE_INFORMATION_CLASS
-{
-       SemaphoreBasicInformation               = 0
-} SEMAPHORE_INFORMATION_CLASS;
-
-typedef struct _SEMAPHORE_BASIC_INFORMATION
-{
-       LONG CurrentCount;
-       LONG MaximumCount;
-} SEMAPHORE_BASIC_INFORMATION, *PSEMAPHORE_BASIC_INFORMATION;
-
-
-// event information
-
-typedef enum _EVENT_INFORMATION_CLASS
-{
-       EventBasicInformation                   = 0
-} EVENT_INFORMATION_CLASS;
-
-typedef struct _EVENT_BASIC_INFORMATION
-{
-       EVENT_TYPE EventType;
-       LONG EventState;
-} EVENT_BASIC_INFORMATION, *PEVENT_BASIC_INFORMATION;
-
-
 // system information
 // {Nt|Zw}{Query|Set}SystemInformation
 // (GN means Gary Nebbet in "NT/W2K Native API Reference")
@@ -445,529 +299,234 @@ struct _SYSTEM_PERFORMANCE_INFORMATION
 
 } SYSTEM_PERFORMANCE_INFO, *PSYSTEM_PERFORMANCE_INFO;
 
-// SystemTimeOfDayInformation (3)
+// SystemModuleInformation (11)
 typedef
-struct _SYSTEM_TIMEOFDAY_INFORMATION
+struct _SYSTEM_MODULE_ENTRY
 {
-       LARGE_INTEGER   BootTime;
-       LARGE_INTEGER   CurrentTime;
-       LARGE_INTEGER   TimeZoneBias;
-       ULONG           TimeZoneId;
-       ULONG           Reserved;
-} SYSTEM_TIMEOFDAY_INFORMATION, *PSYSTEM_TIMEOFDAY_INFORMATION;
+       ULONG   Unknown1;
+       ULONG   Unknown2;
+       PVOID   BaseAddress;
+       ULONG   Size;
+       ULONG   Flags;
+       ULONG   EntryIndex;
+       USHORT  NameLength; /* Length of module name not including the path, this field contains valid value only for NTOSKRNL module*/
+       USHORT  PathLength; /* Length of 'directory path' part of modulename*/
+       CHAR    Name [256];
+} SYSTEM_MODULE_ENTRY, * PSYSTEM_MODULE_ENTRY;
 
-// SystemPathInformation (4)
-// IT DOES NOT WORK
 typedef
-struct _SYSTEM_PATH_INFORMATION
+struct _SYSTEM_MODULE_INFORMATION
 {
-       PVOID   Dummy;
+       ULONG                   Count;
+       SYSTEM_MODULE_ENTRY     Module [1];
+} SYSTEM_MODULE_INFORMATION, *PSYSTEM_MODULE_INFORMATION;
 
-} SYSTEM_PATH_INFORMATION, * PSYSTEM_PATH_INFORMATION;
+// SystemHandleInformation (16)
+// (see ontypes.h)
+typedef
+struct _SYSTEM_HANDLE_ENTRY
+{
+       ULONG   OwnerPid;
+       BYTE    ObjectType;
+       BYTE    HandleFlags;
+       USHORT  HandleValue;
+       PVOID   ObjectPointer;
+       ULONG   AccessMask;
+       
+} SYSTEM_HANDLE_ENTRY, *PSYSTEM_HANDLE_ENTRY;
 
-// SystemProcessInformation (5)
 typedef
-struct _SYSTEM_THREAD_INFORMATION
+struct _SYSTEM_HANDLE_INFORMATION
 {
-       TIME            KernelTime;
-       TIME            UserTime;
-       TIME            CreateTime;
-       ULONG           TickCount;
-       ULONG           StartEIP;
-       CLIENT_ID       ClientId;
-       ULONG           DynamicPriority;
-       ULONG           BasePriority;
-       ULONG           nSwitches;
-       DWORD           State;
-       KWAIT_REASON    WaitReason;
+       ULONG                   Count;
+       SYSTEM_HANDLE_ENTRY     Handle [1];
        
-} SYSTEM_THREAD_INFORMATION, *PSYSTEM_THREAD_INFORMATION;
+} SYSTEM_HANDLE_INFORMATION, *PSYSTEM_HANDLE_INFORMATION;
 
+// SystemObjectInformation (17)
 typedef
-struct SYSTEM_PROCESS_INFORMATION
+struct _SYSTEM_OBJECT_TYPE_INFORMATION
 {
-       ULONG                           RelativeOffset;
-       ULONG                           ThreadCount;
-       ULONG                           Unused1 [6];
-       TIME                            CreateTime;
-       TIME                            UserTime;
-       TIME                            KernelTime;
-       UNICODE_STRING                  Name;
-       ULONG                           BasePriority;
-       ULONG                           ProcessId;
-       ULONG                           ParentProcessId;
-       ULONG                           HandleCount;
-       ULONG                           Unused2[2];
-       ULONG                           PeakVirtualSizeBytes;
-       ULONG                           TotalVirtualSizeBytes;
-       ULONG                           PageFaultCount;
-       ULONG                           PeakWorkingSetSizeBytes;
-       ULONG                           TotalWorkingSetSizeBytes;
-       ULONG                           PeakPagedPoolUsagePages;
-       ULONG                           TotalPagedPoolUsagePages;
-       ULONG                           PeakNonPagedPoolUsagePages;
-       ULONG                           TotalNonPagedPoolUsagePages;
-       ULONG                           TotalPageFileUsageBytes;
-       ULONG                           PeakPageFileUsageBytes;
-       ULONG                           TotalPrivateBytes;
-       SYSTEM_THREAD_INFORMATION       ThreadSysInfo [1];
+       ULONG           NextEntryOffset;
+       ULONG           ObjectCount;
+       ULONG           HandleCount;
+       ULONG           TypeNumber;
+       ULONG           InvalidAttributes;
+       GENERIC_MAPPING GenericMapping;
+       ACCESS_MASK     ValidAccessMask;
+       POOL_TYPE       PoolType;
+       UCHAR           Unknown;
+       UNICODE_STRING  Name;
        
-} SYSTEM_PROCESS_INFORMATION, *PSYSTEM_PROCESS_INFORMATION;
+} SYSTEM_OBJECT_TYPE_INFORMATION, *PSYSTEM_OBJECT_TYPE_INFORMATION;
 
-// SystemCallCountInformation (6)
 typedef
-struct _SYSTEM_SDT_INFORMATION
+struct _SYSTEM_OBJECT_INFORMATION
 {
-       ULONG   BufferLength;
-       ULONG   NumberOfSystemServiceTables;
-       ULONG   NumberOfServices [1];
-       ULONG   ServiceCounters [1];
+       ULONG                   NextEntryOffset;
+       PVOID                   Object;
+       ULONG                   CreatorProcessId;
+       USHORT                  Unknown;
+       USHORT                  Flags;
+       ULONG                   PointerCount;
+       ULONG                   HandleCount;
+       ULONG                   PagedPoolUsage;
+       ULONG                   NonPagedPoolUsage;
+       ULONG                   ExclusiveProcessId;
+       PSECURITY_DESCRIPTOR    SecurityDescriptor;
+       UNICODE_STRING          Name;
 
-} SYSTEM_SDT_INFORMATION, *PSYSTEM_SDT_INFORMATION;
+} SYSTEM_OBJECT_INFORMATION, *PSYSTEM_OBJECT_INFORMATION;
 
-// SystemDeviceInformation (7)
+// SystemPageFileInformation (18)
 typedef
-struct _SYSTEM_DEVICE_INFORMATION
+struct _SYSTEM_PAGEFILE_INFORMATION
 {
-       ULONG   NumberOfDisks;
-       ULONG   NumberOfFloppies;
-       ULONG   NumberOfCdRoms;
-       ULONG   NumberOfTapes;
-       ULONG   NumberOfSerialPorts;
-       ULONG   NumberOfParallelPorts;
-} SYSTEM_DEVICE_INFORMATION, *PSYSTEM_DEVICE_INFORMATION;
+       ULONG           RelativeOffset;
+       ULONG           CurrentSizePages;
+       ULONG           TotalUsedPages;
+       ULONG           PeakUsedPages;
+       UNICODE_STRING  PagefileFileName;
+       
+} SYSTEM_PAGEFILE_INFORMATION, *PSYSTEM_PAGEFILE_INFORMATION;
 
-// SystemProcessorPerformanceInformation (8)
-// (one per processor in the system)
+// SystemCacheInformation (21)
 typedef
-struct _SYSTEM_PROCESSORTIME_INFO
+struct _SYSTEM_CACHE_INFORMATION
 {
-       TIME    TotalProcessorRunTime;
-       TIME    TotalProcessorTime;
-       TIME    TotalProcessorUserTime;
-       TIME    TotalDPCTime;
-       TIME    TotalInterruptTime;
-       ULONG   TotalInterrupts;
-       ULONG   Unused;
+       ULONG   CurrentSize;
+       ULONG   PeakSize;
+       ULONG   PageFaultCount;
+       ULONG   MinimumWorkingSet;
+       ULONG   MaximumWorkingSet;
+       ULONG   Unused[4];
 
-} SYSTEM_PROCESSORTIME_INFO, *PSYSTEM_PROCESSORTIME_INFO;
+} SYSTEM_CACHE_INFORMATION;
 
-// SystemFlagsInformation (9)
+// SystemDpcInformation (24)
 typedef
-struct _SYSTEM_FLAGS_INFORMATION
+struct _SYSTEM_DPC_INFORMATION
 {
-       ULONG   Flags;
-
-} SYSTEM_FLAGS_INFORMATION, * PSYSTEM_FLAGS_INFORMATION;
-
-#define FLG_STOP_ON_EXCEPTION          0x00000001
-#define FLG_SHOW_LDR_SNAPS             0x00000002
-#define FLG_DEBUG_INITIAL_COMMAND      0x00000004
-#define FLG_STOP_ON_HANG_GUI           0x00000008
-#define FLG_HEAP_ENABLE_TAIL_CHECK     0x00000010
-#define FLG_HEAP_ENABLE_FREE_CHECK     0x00000020
-#define FLG_HEAP_VALIDATE_PARAMETERS   0x00000040
-#define FLG_HEAP_VALIDATE_ALL          0x00000080
-#define FLG_POOL_ENABLE_TAIL_CHECK     0x00000100
-#define FLG_POOL_ENABLE_FREE_CHECK     0x00000200
-#define FLG_POOL_ENABLE_TAGGING                0x00000400
-#define FLG_HEAP_ENABLE_TAGGING                0x00000800
-#define FLG_USER_STACK_TRACE_DB                0x00001000
-#define FLG_KERNEL_STACK_TRACE_DB      0x00002000
-#define FLG_MAINTAIN_OBJECT_TYPELIST   0x00004000
-#define FLG_HEAP_ENABLE_TAG_BY_DLL     0x00008000
-#define FLG_IGNORE_DEBUG_PRIV          0x00010000
-#define FLG_ENABLE_CSRDEBUG            0x00020000
-#define FLG_ENABLE_KDEBUG_SYMBOL_LOAD  0x00040000
-#define FLG_DISABLE_PAGE_KERNEL_STACKS 0x00080000
-#define FLG_HEAP_ENABLE_CALL_TRACING   0x00100000
-#define FLG_HEAP_DISABLE_COALESCING    0x00200000
-#define FLG_ENABLE_CLOSE_EXCEPTION     0x00400000
-#define FLG_ENABLE_EXCEPTION_LOGGING   0x00800000
-#define FLG_UNKNOWN_01000000           0x01000000
-#define FLG_UNKNOWN_02000000           0x02000000
-#define FLG_UNKNOWN_04000000           0x04000000
-#define FLG_ENABLE_DBGPRINT_BUFFERING  0x08000000
-#define FLG_UNKNOWN_10000000           0x10000000
-#define FLG_UNKNOWN_20000000           0x20000000
-#define FLG_UNKNOWN_40000000           0x40000000
-#define FLG_UNKNOWN_80000000           0x80000000
+       ULONG   Unused;
+       ULONG   KiMaximumDpcQueueDepth;
+       ULONG   KiMinimumDpcRate;
+       ULONG   KiAdjustDpcThreshold;
+       ULONG   KiIdealDpcRate;
 
-// SystemCallTimeInformation (10)
-// UNKNOWN
+} SYSTEM_DPC_INFORMATION, *PSYSTEM_DPC_INFORMATION;
 
-// SystemModuleInformation (11)
-typedef
-struct _SYSTEM_MODULE_ENTRY
+// SystemLoadImage (26)
+typedef struct _SYSTEM_LOAD_IMAGE
 {
-       ULONG   Unknown1;
-       ULONG   Unknown2;
-       PVOID   BaseAddress;
-       ULONG   Size;
-       ULONG   Flags;
-       ULONG   EntryIndex;
-       USHORT  NameLength; /* Length of module name not including the path, this field contains valid value only for NTOSKRNL module*/
-       USHORT  PathLength; /* Length of 'directory path' part of modulename*/
-       CHAR    Name [256];
-} SYSTEM_MODULE_ENTRY, * PSYSTEM_MODULE_ENTRY;
+  UNICODE_STRING ModuleName;
+  PVOID ModuleBase;
+  PVOID SectionPointer;
+  PVOID EntryPoint;
+  PVOID ExportDirectory;
+} SYSTEM_LOAD_IMAGE, *PSYSTEM_LOAD_IMAGE;
 
-typedef
-struct _SYSTEM_MODULE_INFORMATION
+// SystemUnloadImage (27)
+typedef struct _SYSTEM_UNLOAD_IMAGE
 {
-       ULONG                   Count;
-       SYSTEM_MODULE_ENTRY     Module [1];
-} SYSTEM_MODULE_INFORMATION, *PSYSTEM_MODULE_INFORMATION;
+  PVOID ModuleBase;
+} SYSTEM_UNLOAD_IMAGE, *PSYSTEM_UNLOAD_IMAGE;
 
-// SystemLocksInformation (12)
+// SystemTimeAdjustmentInformation (28)
 typedef
-struct _SYSTEM_RESOURCE_LOCK_ENTRY
+struct _SYSTEM_QUERY_TIME_ADJUSTMENT
 {
-       ULONG   ResourceAddress;
-       ULONG   Always1;
-       ULONG   Unknown;
-       ULONG   ActiveCount;
-       ULONG   ContentionCount;
-       ULONG   Unused[2];
-       ULONG   NumberOfSharedWaiters;
-       ULONG   NumberOfExclusiveWaiters;
-       
-} SYSTEM_RESOURCE_LOCK_ENTRY, *PSYSTEM_RESOURCE_LOCK_ENTRY;
+       ULONG   TimeAdjustment;
+       ULONG   MaximumIncrement;
+       BOOLEAN TimeSynchronization;
+
+} SYSTEM_QUERY_TIME_ADJUSTMENT, *PSYSTEM_QUERY_TIME_ADJUSTMENT;
 
 typedef
-struct _SYSTEM_RESOURCE_LOCK_INFO
+struct _SYSTEM_SET_TIME_ADJUSTMENT
 {
-       ULONG                           Count;
-       SYSTEM_RESOURCE_LOCK_ENTRY      Lock [1];
+       ULONG   TimeAdjustment;
+       BOOLEAN TimeSynchronization;
        
-} SYSTEM_RESOURCE_LOCK_INFO, *PSYSTEM_RESOURCE_LOCK_INFO;
+} SYSTEM_TIME_ADJUSTMENT_INFO, *PSYSTEM_TIME_ADJUSTMENT_INFO;
 
-// SystemInformation13 (13)
-// UNKNOWN
+// atom information
 
-// SystemInformation14 (14)
-// UNKNOWN
+typedef enum _ATOM_INFORMATION_CLASS
+{
+   AtomBasicInformation                = 0,
+   AtomTableInformation                = 1,
+} ATOM_INFORMATION_CLASS;
 
-// SystemInformation15 (15)
-// UNKNOWN
+typedef struct _ATOM_BASIC_INFORMATION
+{
+   USHORT UsageCount;
+   USHORT Flags;
+   USHORT NameLength;
+   WCHAR Name[1];
+} ATOM_BASIC_INFORMATION, *PATOM_BASIC_INFORMATION;
 
-// SystemHandleInformation (16)
-// (see ontypes.h)
-typedef
-struct _SYSTEM_HANDLE_ENTRY
+// SystemLoadAndCallImage(38)
+typedef struct _SYSTEM_LOAD_AND_CALL_IMAGE
 {
-       ULONG   OwnerPid;
-       BYTE    ObjectType;
-       BYTE    HandleFlags;
-       USHORT  HandleValue;
-       PVOID   ObjectPointer;
-       ULONG   AccessMask;
-       
-} SYSTEM_HANDLE_ENTRY, *PSYSTEM_HANDLE_ENTRY;
+  UNICODE_STRING ModuleName;
+} SYSTEM_LOAD_AND_CALL_IMAGE, *PSYSTEM_LOAD_AND_CALL_IMAGE;
 
+// SystemTimeZoneInformation (44)
 typedef
-struct _SYSTEM_HANDLE_INFORMATION
+struct _SYSTEM_TIME_ZONE_INFORMATION
 {
-       ULONG                   Count;
-       SYSTEM_HANDLE_ENTRY     Handle [1];
-       
-} SYSTEM_HANDLE_INFORMATION, *PSYSTEM_HANDLE_INFORMATION;
+       LONG    Bias;
+       WCHAR   StandardName [32];
+       TIME    StandardDate;
+       LONG    StandardBias;
+       WCHAR   DaylightName [32];
+       TIME    DaylightDate;
+       LONG    DaylightBias;
 
-// SystemObjectInformation (17)
+} SYSTEM_TIME_ZONE_INFORMATION, * PSYSTEM_TIME_ZONE_INFORMATION;
+
+// SystemLookasideInformation (45)
 typedef
-struct _SYSTEM_OBJECT_TYPE_INFORMATION
+struct _SYSTEM_LOOKASIDE_INFORMATION
 {
-       ULONG           NextEntryOffset;
-       ULONG           ObjectCount;
-       ULONG           HandleCount;
-       ULONG           TypeNumber;
-       ULONG           InvalidAttributes;
-       GENERIC_MAPPING GenericMapping;
-       ACCESS_MASK     ValidAccessMask;
-       POOL_TYPE       PoolType;
-       UCHAR           Unknown;
-       UNICODE_STRING  Name;
+       USHORT          Depth;
+       USHORT          MaximumDepth;
+       ULONG           TotalAllocates;
+       ULONG           AllocatesMisses;
+       ULONG           TotalFrees;
+       ULONG           FreeMisses;
+       POOL_TYPE       Type;
+       ULONG           Tag;
+       ULONG           Size;
        
-} SYSTEM_OBJECT_TYPE_INFORMATION, *PSYSTEM_OBJECT_TYPE_INFORMATION;
+} SYSTEM_LOOKASIDE_INFORMATION, * PSYSTEM_LOOKASIDE_INFORMATION;
 
+// SystemSetTimeSlipEvent (46)
 typedef
-struct _SYSTEM_OBJECT_INFORMATION
+struct _SYSTEM_SET_TIME_SLIP_EVENT
 {
-       ULONG                   NextEntryOffset;
-       PVOID                   Object;
-       ULONG                   CreatorProcessId;
-       USHORT                  Unknown;
-       USHORT                  Flags;
-       ULONG                   PointerCount;
-       ULONG                   HandleCount;
-       ULONG                   PagedPoolUsage;
-       ULONG                   NonPagedPoolUsage;
-       ULONG                   ExclusiveProcessId;
-       PSECURITY_DESCRIPTOR    SecurityDescriptor;
-       UNICODE_STRING          Name;
+       HANDLE  TimeSlipEvent; /* IN */
 
-} SYSTEM_OBJECT_INFORMATION, *PSYSTEM_OBJECT_INFORMATION;
+} SYSTEM_SET_TIME_SLIP_EVENT, * PSYSTEM_SET_TIME_SLIP_EVENT;
 
-// SystemPageFileInformation (18)
+// SystemCreateSession (47)
+// (available only on TSE/NT5+)
 typedef
-struct _SYSTEM_PAGEFILE_INFORMATION
+struct _SYSTEM_CREATE_SESSION
 {
-       ULONG           RelativeOffset;
-       ULONG           CurrentSizePages;
-       ULONG           TotalUsedPages;
-       ULONG           PeakUsedPages;
-       UNICODE_STRING  PagefileFileName;
-       
-} SYSTEM_PAGEFILE_INFORMATION, *PSYSTEM_PAGEFILE_INFORMATION;
+       ULONG   SessionId; /* OUT */
 
-// SystemInstructionEmulationInfo (19)
+} SYSTEM_CREATE_SESSION, * PSYSTEM_CREATE_SESSION;
+
+// SystemDeleteSession (48)
+// (available only on TSE/NT5+)
 typedef
-struct _SYSTEM_VDM_INFORMATION
-{
-       ULONG VdmSegmentNotPresentCount;
-       ULONG VdmINSWCount;
-       ULONG VdmESPREFIXCount;
-       ULONG VdmCSPREFIXCount;
-       ULONG VdmSSPREFIXCount;
-       ULONG VdmDSPREFIXCount;
-       ULONG VdmFSPREFIXCount;
-       ULONG VdmGSPREFIXCount;
-       ULONG VdmOPER32PREFIXCount;
-       ULONG VdmADDR32PREFIXCount;
-       ULONG VdmINSBCount;
-       ULONG VdmINSWV86Count;
-       ULONG VdmOUTSBCount;
-       ULONG VdmOUTSWCount;
-       ULONG VdmPUSHFCount;
-       ULONG VdmPOPFCount;
-       ULONG VdmINTNNCount;
-       ULONG VdmINTOCount;
-       ULONG VdmIRETCount;
-       ULONG VdmINBIMMCount;
-       ULONG VdmINWIMMCount;
-       ULONG VdmOUTBIMMCount;
-       ULONG VdmOUTWIMMCount;
-       ULONG VdmINBCount;
-       ULONG VdmINWCount;
-       ULONG VdmOUTBCount;
-       ULONG VdmOUTWCount;
-       ULONG VdmLOCKPREFIXCount;
-       ULONG VdmREPNEPREFIXCount;
-       ULONG VdmREPPREFIXCount;
-       ULONG VdmHLTCount;
-       ULONG VdmCLICount;
-       ULONG VdmSTICount;
-       ULONG VdmBopCount;
-
-} SYSTEM_VDM_INFORMATION, *PSYSTEM_VDM_INFORMATION;
-
-// SystemInformation20 (20)
-// UNKNOWN
-
-// SystemCacheInformation (21)
-typedef
-struct _SYSTEM_CACHE_INFORMATION
-{
-       ULONG   CurrentSize;
-       ULONG   PeakSize;
-       ULONG   PageFaultCount;
-       ULONG   MinimumWorkingSet;
-       ULONG   MaximumWorkingSet;
-       ULONG   Unused[4];
-
-} SYSTEM_CACHE_INFORMATION;
-
-// SystemPoolTagInformation (22)
-// found by Klaus P. Gerlicher
-// (implemented only in checked builds)
-typedef
-struct _POOL_TAG_STATS
-{
-       ULONG AllocationCount;
-       ULONG FreeCount;
-       ULONG SizeBytes;
-       
-} POOL_TAG_STATS;
-
-typedef
-struct _SYSTEM_POOL_TAG_ENTRY
-{
-       ULONG           Tag;
-       POOL_TAG_STATS  Paged;
-       POOL_TAG_STATS  NonPaged;
-
-} SYSTEM_POOL_TAG_ENTRY, * PSYSTEM_POOL_TAG_ENTRY;
-
-typedef
-struct _SYSTEM_POOL_TAG_INFO
-{
-       ULONG                   Count;
-       SYSTEM_POOL_TAG_ENTRY   PoolEntry [1];
-
-} SYSTEM_POOL_TAG_INFO, *PSYSTEM_POOL_TAG_INFO;
-
-// SystemProcessorScheduleInfo (23)
-typedef
-struct _SYSTEM_PROCESSOR_SCHEDULE_INFO
-{
-       ULONG nContextSwitches;
-       ULONG nDPCQueued;
-       ULONG nDPCRate;
-       ULONG TimerResolution;
-       ULONG nDPCBypasses;
-       ULONG nAPCBypasses;
-       
-} SYSTEM_PROCESSOR_SCHEDULE_INFO, *PSYSTEM_PROCESSOR_SCHEDULE_INFO;
-
-// SystemDpcInformation (24)
-typedef
-struct _SYSTEM_DPC_INFORMATION
-{
-       ULONG   Unused;
-       ULONG   KiMaximumDpcQueueDepth;
-       ULONG   KiMinimumDpcRate;
-       ULONG   KiAdjustDpcThreshold;
-       ULONG   KiIdealDpcRate;
-
-} SYSTEM_DPC_INFORMATION, *PSYSTEM_DPC_INFORMATION;
-
-// SystemInformation25 (25)
-// UNKNOWN
-
-// SystemLoadImage (26)
-typedef struct _SYSTEM_LOAD_IMAGE
-{
-  UNICODE_STRING ModuleName;
-  PVOID ModuleBase;
-  PVOID SectionPointer;
-  PVOID EntryPoint;
-  PVOID ExportDirectory;
-} SYSTEM_LOAD_IMAGE, *PSYSTEM_LOAD_IMAGE;
-
-// SystemUnloadImage (27)
-typedef struct _SYSTEM_UNLOAD_IMAGE
-{
-  PVOID ModuleBase;
-} SYSTEM_UNLOAD_IMAGE, *PSYSTEM_UNLOAD_IMAGE;
-
-// SystemTimeAdjustmentInformation (28)
-typedef
-struct _SYSTEM_QUERY_TIME_ADJUSTMENT
-{
-       ULONG   TimeAdjustment;
-       ULONG   MaximumIncrement;
-       BOOLEAN TimeSynchronization;
-
-} SYSTEM_QUERY_TIME_ADJUSTMENT, *PSYSTEM_QUERY_TIME_ADJUSTMENT;
-
-typedef
-struct _SYSTEM_SET_TIME_ADJUSTMENT
-{
-       ULONG   TimeAdjustment;
-       BOOLEAN TimeSynchronization;
-       
-} SYSTEM_TIME_ADJUSTMENT_INFO, *PSYSTEM_TIME_ADJUSTMENT_INFO;
-
-// SystemProcessorFaultCountInfo (33)
-typedef
-struct _SYSTEM_PROCESSOR_FAULT_INFO
-{
-       ULONG   nAlignmentFixup;
-       ULONG   nExceptionDispatches;
-       ULONG   nFloatingEmulation;
-       ULONG   Unknown;
-       
-} SYSTEM_PROCESSOR_FAULT_INFO, *PSYSTEM_PROCESSOR_FAULT_INFO;
-
-// SystemCrashDumpStateInfo (34)
-//
-
-// SystemDebuggerInformation (35)
-typedef
-struct _SYSTEM_DEBUGGER_INFO
-{
-       BOOLEAN KdDebuggerEnabled;
-       BOOLEAN KdDebuggerPresent;
-       
-} SYSTEM_DEBUGGER_INFO, *PSYSTEM_DEBUGGER_INFO;
-
-// SystemInformation36 (36)
-// UNKNOWN
-
-// SystemQuotaInformation (37)
-typedef
-struct _SYSTEM_QUOTA_INFORMATION
-{
-       ULONG   CmpGlobalQuota;
-       ULONG   CmpGlobalQuotaUsed;
-       ULONG   MmSizeofPagedPoolInBytes;
-       
-} SYSTEM_QUOTA_INFORMATION, *PSYSTEM_QUOTA_INFORMATION;
-
-// SystemLoadAndCallImage(38)
-typedef struct _SYSTEM_LOAD_AND_CALL_IMAGE
-{
-  UNICODE_STRING ModuleName;
-} SYSTEM_LOAD_AND_CALL_IMAGE, *PSYSTEM_LOAD_AND_CALL_IMAGE;
-
-// SystemTimeZoneInformation (44)
-typedef
-struct _SYSTEM_TIME_ZONE_INFORMATION
-{
-       LONG    Bias;
-       WCHAR   StandardName [32];
-       TIME    StandardDate;
-       LONG    StandardBias;
-       WCHAR   DaylightName [32];
-       TIME    DaylightDate;
-       LONG    DaylightBias;
-
-} SYSTEM_TIME_ZONE_INFORMATION, * PSYSTEM_TIME_ZONE_INFORMATION;
-
-// SystemLookasideInformation (45)
-typedef
-struct _SYSTEM_LOOKASIDE_INFORMATION
-{
-       USHORT          Depth;
-       USHORT          MaximumDepth;
-       ULONG           TotalAllocates;
-       ULONG           AllocatesMisses;
-       ULONG           TotalFrees;
-       ULONG           FreeMisses;
-       POOL_TYPE       Type;
-       ULONG           Tag;
-       ULONG           Size;
-       
-} SYSTEM_LOOKASIDE_INFORMATION, * PSYSTEM_LOOKASIDE_INFORMATION;
-
-// SystemSetTimeSlipEvent (46)
-typedef
-struct _SYSTEM_SET_TIME_SLIP_EVENT
-{
-       HANDLE  TimeSlipEvent; /* IN */
-
-} SYSTEM_SET_TIME_SLIP_EVENT, * PSYSTEM_SET_TIME_SLIP_EVENT;
-
-// SystemCreateSession (47)
-// (available only on TSE/NT5+)
-typedef
-struct _SYSTEM_CREATE_SESSION
-{
-       ULONG   SessionId; /* OUT */
-
-} SYSTEM_CREATE_SESSION, * PSYSTEM_CREATE_SESSION;
-
-// SystemDeleteSession (48)
-// (available only on TSE/NT5+)
-typedef
-struct _SYSTEM_DELETE_SESSION
+struct _SYSTEM_DELETE_SESSION
 {
        ULONG   SessionId; /* IN */
 
 } SYSTEM_DELETE_SESSION, * PSYSTEM_DELETE_SESSION;
 
-// (49)
-// UNKNOWN
-
 // SystemRangeStartInformation (50)
 typedef
 struct _SYSTEM_RANGE_START_INFORMATION
@@ -976,12 +535,6 @@ struct _SYSTEM_RANGE_START_INFORMATION
 
 } SYSTEM_RANGE_START_INFORMATION, * PSYSTEM_RANGE_START_INFORMATION;
 
-// SystemVerifierInformation (51)
-// UNKNOWN
-
-// SystemAddVerifier (52)
-// UNKNOWN
-
 // SystemSessionProcessesInformation (53)
 // (available only on TSE/NT5+)
 typedef
@@ -1030,58 +583,16 @@ typedef struct _MEMORY_WORKING_SET_LIST { // Information Class 1
 typedef struct _MEMORY_SECTION_NAME_STATIC(ANYSIZE_ARRAY)
  MEMORY_SECTION_NAME, *PMEMORY_SECTION_NAME;
 
-// shutdown action
-
-typedef enum SHUTDOWN_ACTION_TAG {
-       ShutdownNoReboot,
-       ShutdownReboot,
-       ShutdownPowerOff
-} SHUTDOWN_ACTION;
-
-// wait type
-
-#define WaitAll                                        0
-#define WaitAny                                        1
-
-// number of wait objects
-
-#define THREAD_WAIT_OBJECTS                    3
-//#define MAXIMUM_WAIT_OBJECTS                 64
-
-// key restore flags
-
-#define REG_WHOLE_HIVE_VOLATILE                        1
-#define REG_REFRESH_HIVE                       2
-
-// object type  access rights
-
-#define OBJECT_TYPE_CREATE             0x0001
-#define OBJECT_TYPE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
-
-// directory access rights
-
-#define DIRECTORY_QUERY                                0x0001
-#define DIRECTORY_TRAVERSE                     0x0002
-#define DIRECTORY_CREATE_OBJECT                        0x0004
-#define DIRECTORY_CREATE_SUBDIRECTORY          0x0008
-
-#define DIRECTORY_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0xF)
-
-// symbolic link access rights
-
-#define SYMBOLIC_LINK_QUERY                    0x0001
-#define SYMBOLIC_LINK_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
-
-// Information class 0
-typedef struct _PROCESS_BASIC_INFORMATION
-{
-       NTSTATUS ExitStatus;
-       PPEB PebBaseAddress;
-       KAFFINITY AffinityMask;
-       KPRIORITY BasePriority;
-       ULONG UniqueProcessId;
-       ULONG InheritedFromUniqueProcessId;
-} PROCESS_BASIC_INFORMATION, *PPROCESS_BASIC_INFORMATION;
+// Information class 0
+typedef struct _PROCESS_BASIC_INFORMATION
+{
+       NTSTATUS ExitStatus;
+       PPEB PebBaseAddress;
+       KAFFINITY AffinityMask;
+       KPRIORITY BasePriority;
+       ULONG UniqueProcessId;
+       ULONG InheritedFromUniqueProcessId;
+} PROCESS_BASIC_INFORMATION, *PPROCESS_BASIC_INFORMATION;
 
 // Information class 1
 typedef struct _QUOTA_LIMITS
@@ -1206,23 +717,6 @@ typedef struct _OBJECT_NAME_INFORMATION
        UNICODE_STRING  Name;
 } OBJECT_NAME_INFORMATION, *POBJECT_NAME_INFORMATION;
 
-
-
-typedef struct _OBJECT_DATA_INFORMATION
-{
-       BOOLEAN bInheritHandle;
-       BOOLEAN bProtectFromClose;
-} OBJECT_DATA_INFORMATION, *POBJECT_DATA_INFORMATION;
-
-
-typedef struct _OBJECT_TYPE_INFORMATION
-{
-       UNICODE_STRING  Name;
-       UNICODE_STRING Type;
-       ULONG TotalHandles;
-       ULONG ReferenceCount;
-} OBJECT_TYPE_INFORMATION, *POBJECT_TYPE_INFORMATION;
-
 // file information
 
 typedef struct _FILE_BASIC_INFORMATION
@@ -1338,121 +832,720 @@ typedef struct _FILE_ACCESS_INFORMATION {
 } FILE_ACCESS_INFORMATION, *PFILE_ACCESS_INFORMATION;
 
 
-typedef struct _FILE_MODE_INFORMATION {
-       ULONG Mode;
-} FILE_MODE_INFORMATION, *PFILE_MODE_INFORMATION;
+typedef struct _FILE_MODE_INFORMATION {
+       ULONG Mode;
+} FILE_MODE_INFORMATION, *PFILE_MODE_INFORMATION;
+
+
+typedef struct _FILE_PIPE_INFORMATION {
+       ULONG ReadMode;
+       ULONG CompletionMode;
+} FILE_PIPE_INFORMATION, *PFILE_PIPE_INFORMATION;
+
+typedef struct _FILE_PIPE_LOCAL_INFORMATION {
+       ULONG NamedPipeType;
+       ULONG NamedPipeConfiguration;
+       ULONG MaximumInstances;
+       ULONG CurrentInstances;
+       ULONG InboundQuota;
+       ULONG ReadDataAvailable;
+       ULONG OutboundQuota;
+       ULONG WriteQuotaAvailable;
+       ULONG NamedPipeState;
+       ULONG NamedPipeEnd;
+} FILE_PIPE_LOCAL_INFORMATION, *PFILE_PIPE_LOCAL_INFORMATION;
+
+typedef struct _FILE_PIPE_REMOTE_INFORMATION {
+       LARGE_INTEGER CollectDataTime;
+       ULONG MaximumCollectionCount;
+} FILE_PIPE_REMOTE_INFORMATION, *PFILE_PIPE_REMOTE_INFORMATION;
+
+typedef struct _FILE_MAILSLOT_QUERY_INFORMATION {
+       ULONG MaxMessageSize;
+       ULONG Unknown; /* ?? */
+       ULONG NextSize;
+       ULONG MessageCount;
+       LARGE_INTEGER Timeout;
+} FILE_MAILSLOT_QUERY_INFORMATION, *PFILE_MAILSLOT_QUERY_INFORMATION;
+
+typedef struct _FILE_MAILSLOT_SET_INFORMATION {
+       LARGE_INTEGER Timeout;
+} FILE_MAILSLOT_SET_INFORMATION, *PFILE_MAILSLOT_SET_INFORMATION;
+
+typedef struct _FILE_COMPRESSION_INFORMATION {
+       LARGE_INTEGER CompressedFileSize;
+       USHORT CompressionFormat;
+       UCHAR CompressionUnitShift;
+       UCHAR ChunkShift;
+       UCHAR ClusterShift;
+       UCHAR Reserved[3];
+} FILE_COMPRESSION_INFORMATION, *PFILE_COMPRESSION_INFORMATION;
+
+typedef struct _FILE_ALL_INFORMATION {
+       FILE_BASIC_INFORMATION BasicInformation;
+       FILE_STANDARD_INFORMATION StandardInformation;
+       FILE_INTERNAL_INFORMATION InternalInformation;
+       FILE_EA_INFORMATION EaInformation;
+       FILE_ACCESS_INFORMATION AccessInformation;
+       FILE_POSITION_INFORMATION PositionInformation;
+       FILE_MODE_INFORMATION ModeInformation;
+       FILE_ALIGNMENT_INFORMATION AlignmentInformation;
+       FILE_NAME_INFORMATION NameInformation;
+} FILE_ALL_INFORMATION, *PFILE_ALL_INFORMATION;
+
+
+// file system information structures
+
+typedef struct _FILE_FS_DEVICE_INFORMATION {
+       DEVICE_TYPE DeviceType;
+       ULONG Characteristics;
+} FILE_FS_DEVICE_INFORMATION,  *PFILE_FS_DEVICE_INFORMATION;
+
+
+typedef struct _FILE_FS_VOLUME_INFORMATION {
+       TIME VolumeCreationTime;
+       ULONG VolumeSerialNumber;
+       ULONG VolumeLabelLength;
+       BOOLEAN SupportsObjects;
+       WCHAR VolumeLabel[0];
+} FILE_FS_VOLUME_INFORMATION, *PFILE_FS_VOLUME_INFORMATION;
+
+typedef struct _FILE_FS_SIZE_INFORMATION {
+       LARGE_INTEGER TotalAllocationUnits;
+       LARGE_INTEGER AvailableAllocationUnits;
+       ULONG SectorsPerAllocationUnit;
+       ULONG BytesPerSector;
+} FILE_FS_SIZE_INFORMATION, *PFILE_FS_SIZE_INFORMATION;
+
+typedef struct _FILE_FS_ATTRIBUTE_INFORMATION {
+       ULONG FileSystemAttributes;
+       LONG MaximumComponentNameLength;
+       ULONG FileSystemNameLength;
+       WCHAR FileSystemName[0];
+} FILE_FS_ATTRIBUTE_INFORMATION, *PFILE_FS_ATTRIBUTE_INFORMATION;
+
+/*
+       FileSystemAttributes is one of the following values:
+
+       FILE_CASE_SENSITIVE_SEARCH      0x00000001
+        FILE_CASE_PRESERVED_NAMES       0x00000002
+        FILE_UNICODE_ON_DISK            0x00000004
+        FILE_PERSISTENT_ACLS            0x00000008
+        FILE_FILE_COMPRESSION           0x00000010
+        FILE_VOLUME_QUOTAS              0x00000020
+        FILE_VOLUME_IS_COMPRESSED       0x00008000
+*/
+typedef struct _FILE_FS_LABEL_INFORMATION {
+       ULONG VolumeLabelLength;
+       WCHAR VolumeLabel[0];
+} FILE_FS_LABEL_INFORMATION, *PFILE_FS_LABEL_INFORMATION;
+
+// read file scatter / write file scatter
+//FIXME I am a win32 struct aswell
+
+typedef union _FILE_SEGMENT_ELEMENT {
+       PVOID Buffer;
+       ULONG Alignment;
+}FILE_SEGMENT_ELEMENT, *PFILE_SEGMENT_ELEMENT;
+
+typedef struct _FILE_DIRECTORY_INFORMATION {
+       ULONG   NextEntryOffset;
+       ULONG   FileIndex;
+       TIME CreationTime;
+       TIME LastAccessTime;
+       TIME LastWriteTime;
+       TIME ChangeTime;
+       LARGE_INTEGER EndOfFile;
+       LARGE_INTEGER AllocationSize;
+       ULONG FileAttributes;
+       ULONG FileNameLength;
+       WCHAR FileName[0];
+} FILE_DIRECTORY_INFORMATION, *PFILE_DIRECTORY_INFORMATION;
+
+typedef struct _FILE_FULL_DIRECTORY_INFORMATION {
+       ULONG   NextEntryOffset;
+       ULONG   FileIndex;
+       TIME CreationTime;
+       TIME LastAccessTime;
+       TIME LastWriteTime;
+       TIME ChangeTime;
+       LARGE_INTEGER EndOfFile;
+       LARGE_INTEGER AllocationSize;
+       ULONG FileAttributes;
+       ULONG FileNameLength;
+       ULONG EaSize;
+       WCHAR FileName[0]; // variable size
+} FILE_FULL_DIRECTORY_INFORMATION, *PFILE_FULL_DIRECTORY_INFORMATION,
+  FILE_FULL_DIR_INFORMATION, *PFILE_FULL_DIR_INFORMATION;
+
+
+typedef struct _FILE_BOTH_DIRECTORY_INFORMATION {
+       ULONG           NextEntryOffset;
+       ULONG           FileIndex;
+       TIME            CreationTime;
+       TIME            LastAccessTime;
+       TIME            LastWriteTime;
+       TIME            ChangeTime;
+       LARGE_INTEGER   EndOfFile;
+       LARGE_INTEGER   AllocationSize;
+       ULONG           FileAttributes;
+       ULONG           FileNameLength;
+       ULONG           EaSize;
+       CHAR            ShortNameLength;
+       WCHAR           ShortName[12]; // 8.3 name
+       WCHAR           FileName[0];
+} FILE_BOTH_DIRECTORY_INFORMATION, *PFILE_BOTH_DIRECTORY_INFORMATION,
+  FILE_BOTH_DIR_INFORMATION, *PFILE_BOTH_DIR_INFORMATION;
+
+/*
+       NotifyFilter / CompletionFilter:
+
+       FILE_NOTIFY_CHANGE_FILE_NAME        0x00000001
+       FILE_NOTIFY_CHANGE_DIR_NAME         0x00000002
+       FILE_NOTIFY_CHANGE_NAME             0x00000003
+       FILE_NOTIFY_CHANGE_ATTRIBUTES       0x00000004
+       FILE_NOTIFY_CHANGE_SIZE             0x00000008
+       FILE_NOTIFY_CHANGE_LAST_WRITE       0x00000010
+       FILE_NOTIFY_CHANGE_LAST_ACCESS      0x00000020
+       FILE_NOTIFY_CHANGE_CREATION         0x00000040
+       FILE_NOTIFY_CHANGE_EA               0x00000080
+       FILE_NOTIFY_CHANGE_SECURITY         0x00000100
+       FILE_NOTIFY_CHANGE_STREAM_NAME      0x00000200
+       FILE_NOTIFY_CHANGE_STREAM_SIZE      0x00000400
+       FILE_NOTIFY_CHANGE_STREAM_WRITE     0x00000800
+*/
+
+typedef struct _FILE_NOTIFY_INFORMATION {
+       ULONG Action;
+       ULONG FileNameLength;
+       WCHAR FileName[0]; 
+} FILE_NOTIFY_INFORMATION;
+
+#define FSCTL_GET_VOLUME_BITMAP                        0x9006F
+#define FSCTL_GET_RETRIEVAL_POINTERS           0x90073
+#define FSCTL_MOVE_FILE                                0x90074
+
+typedef struct _MAPPING_PAIR
+{
+       ULONGLONG       Vcn;
+       ULONGLONG       Lcn;
+} MAPPING_PAIR, *PMAPPING_PAIR;
+
+typedef struct _GET_RETRIEVAL_DESCRIPTOR
+{
+       ULONG           NumberOfPairs;
+       ULONGLONG       StartVcn;
+       MAPPING_PAIR    Pair[0]; // variable size 
+} GET_RETRIEVAL_DESCRIPTOR, *PGET_RETRIEVAL_DESCRIPTOR;
+
+typedef struct _MOVEFILE_DESCRIPTOR
+{
+       HANDLE            FileHandle;
+       ULONG             Reserved;
+       LARGE_INTEGER     StartVcn;
+       LARGE_INTEGER     TargetLcn;
+       ULONG             NumVcns;
+       ULONG             Reserved1;
+} MOVEFILE_DESCRIPTOR, *PMOVEFILE_DESCRIPTOR;
+
+typedef struct _SECTION_BASIC_INFORMATION
+{
+  PVOID BaseAddress;
+  ULONG Attributes;
+  LARGE_INTEGER Size;
+} SECTION_BASIC_INFORMATION, *PSECTION_BASIC_INFORMATION;
+
+typedef enum _SECTION_INFORMATION_CLASS 
+{
+  SectionBasicInformation,
+  SectionImageInformation,
+} SECTION_INFORMATION_CLASS;
+
+// shutdown action
+
+typedef enum SHUTDOWN_ACTION_TAG {
+  ShutdownNoReboot,
+  ShutdownReboot,
+  ShutdownPowerOff
+} SHUTDOWN_ACTION;
+
+#else /* __USE_W32API */
+
+#define DebugDbgLoadSymbols ((DEBUG_CONTROL_CODE)0xffffffff)
+
+#endif /* __USE_W32API */
+
+#define NtCurrentProcess() ( (HANDLE) 0xFFFFFFFF )
+#define NtCurrentThread() ( (HANDLE) 0xFFFFFFFE )
+#if 1
+extern ULONG NtBuildNumber;
+#else
+#ifdef __NTOSKRNL__
+extern ULONG NtBuildNumber;
+#else
+extern ULONG NtBuildNumber;
+#endif
+#endif
+
+// event access mask
+
+#define EVENT_READ_ACCESS                      1
+#define EVENT_WRITE_ACCESS                     2
+
+//process query / set information class
+
+#define ProcessBasicInformation                        0
+#define ProcessQuotaLimits                     1
+#define ProcessIoCounters                      2
+#define ProcessVmCounters                      3
+#define ProcessTimes                           4
+#define ProcessBasePriority                    5
+#define ProcessRaisePriority                   6
+#define ProcessDebugPort                       7
+#define ProcessExceptionPort                   8
+#define ProcessAccessToken                     9
+#define ProcessLdtInformation                  10
+#define ProcessLdtSize                         11
+#define ProcessDefaultHardErrorMode            12
+#define ProcessIoPortHandlers                  13
+#define ProcessPooledUsageAndLimits            14
+#define ProcessWorkingSetWatch                 15
+#define ProcessUserModeIOPL                    16
+#define ProcessEnableAlignmentFaultFixup       17
+#define ProcessPriorityClass                   18
+#define ProcessWx86Information                 19
+#define ProcessHandleCount                     20
+#define ProcessAffinityMask                    21
+#define ProcessPriorityBoost                   22
+#define ProcessDeviceMap                       23
+#define ProcessSessionInformation              24
+#define ProcessForegroundInformation           25
+#define ProcessWow64Information                        26
+/* ReactOS private. */
+#define ProcessImageFileName                   27
+#define ProcessDesktop                          28
+#define MaxProcessInfoClass                    29
+
+/*
+ * thread query / set information class
+ */
+#define ThreadBasicInformation                 0
+#define ThreadTimes                            1
+#define ThreadPriority                         2
+#define ThreadBasePriority                     3
+#define ThreadAffinityMask                     4
+#define ThreadImpersonationToken               5
+#define ThreadDescriptorTableEntry             6
+#define ThreadEnableAlignmentFaultFixup                7
+#define ThreadEventPair                                8
+#define ThreadQuerySetWin32StartAddress                9
+#define ThreadZeroTlsCell                      10
+#define ThreadPerformanceCount                 11
+#define ThreadAmILastThread                    12
+#define ThreadIdealProcessor                   13
+#define ThreadPriorityBoost                    14
+#define ThreadSetTlsArrayAddress               15
+#define ThreadIsIoPending                      16
+#define ThreadHideFromDebugger                 17
+#define MaxThreadInfoClass                     17
+
+// object handle information
+
+#define ObjectBasicInformation                 0
+#define ObjectNameInformation                  1
+#define ObjectTypeInformation                  2
+#define ObjectAllInformation                   3
+#define ObjectDataInformation                  4
+
+typedef struct _ATOM_TABLE_INFORMATION
+{
+   ULONG NumberOfAtoms;
+   RTL_ATOM Atoms[1];
+} ATOM_TABLE_INFORMATION, *PATOM_TABLE_INFORMATION;
+
+
+// mutant information
+
+typedef enum _MUTANT_INFORMATION_CLASS
+{
+  MutantBasicInformation = 0
+} MUTANT_INFORMATION_CLASS;
+
+typedef struct _MUTANT_BASIC_INFORMATION
+{
+  LONG Count;
+  BOOLEAN Owned;
+  BOOLEAN Abandoned;
+} MUTANT_BASIC_INFORMATION, *PMUTANT_BASIC_INFORMATION;
+
+
+// SystemTimeOfDayInformation (3)
+typedef
+struct _SYSTEM_TIMEOFDAY_INFORMATION
+{
+       LARGE_INTEGER   BootTime;
+       LARGE_INTEGER   CurrentTime;
+       LARGE_INTEGER   TimeZoneBias;
+       ULONG           TimeZoneId;
+       ULONG           Reserved;
+} SYSTEM_TIMEOFDAY_INFORMATION, *PSYSTEM_TIMEOFDAY_INFORMATION;
+
+// SystemPathInformation (4)
+// IT DOES NOT WORK
+typedef
+struct _SYSTEM_PATH_INFORMATION
+{
+       PVOID   Dummy;
+
+} SYSTEM_PATH_INFORMATION, * PSYSTEM_PATH_INFORMATION;
+
+// SystemProcessInformation (5)
+typedef
+struct _SYSTEM_THREAD_INFORMATION
+{
+       TIME            KernelTime;
+       TIME            UserTime;
+       TIME            CreateTime;
+       ULONG           TickCount;
+       ULONG           StartEIP;
+       CLIENT_ID       ClientId;
+       ULONG           DynamicPriority;
+       ULONG           BasePriority;
+       ULONG           nSwitches;
+       DWORD           State;
+       KWAIT_REASON    WaitReason;
+       
+} SYSTEM_THREAD_INFORMATION, *PSYSTEM_THREAD_INFORMATION;
+
+typedef
+struct SYSTEM_PROCESS_INFORMATION
+{
+       ULONG                           RelativeOffset;
+       ULONG                           ThreadCount;
+       ULONG                           Unused1 [6];
+       TIME                            CreateTime;
+       TIME                            UserTime;
+       TIME                            KernelTime;
+       UNICODE_STRING                  Name;
+       ULONG                           BasePriority;
+       ULONG                           ProcessId;
+       ULONG                           ParentProcessId;
+       ULONG                           HandleCount;
+       ULONG                           Unused2[2];
+       ULONG                           PeakVirtualSizeBytes;
+       ULONG                           TotalVirtualSizeBytes;
+       ULONG                           PageFaultCount;
+       ULONG                           PeakWorkingSetSizeBytes;
+       ULONG                           TotalWorkingSetSizeBytes;
+       ULONG                           PeakPagedPoolUsagePages;
+       ULONG                           TotalPagedPoolUsagePages;
+       ULONG                           PeakNonPagedPoolUsagePages;
+       ULONG                           TotalNonPagedPoolUsagePages;
+       ULONG                           TotalPageFileUsageBytes;
+       ULONG                           PeakPageFileUsageBytes;
+       ULONG                           TotalPrivateBytes;
+       SYSTEM_THREAD_INFORMATION       ThreadSysInfo [1];
+       
+} SYSTEM_PROCESS_INFORMATION, *PSYSTEM_PROCESS_INFORMATION;
+
+// SystemCallCountInformation (6)
+typedef
+struct _SYSTEM_SDT_INFORMATION
+{
+       ULONG   BufferLength;
+       ULONG   NumberOfSystemServiceTables;
+       ULONG   NumberOfServices [1];
+       ULONG   ServiceCounters [1];
+
+} SYSTEM_SDT_INFORMATION, *PSYSTEM_SDT_INFORMATION;
+
+// SystemDeviceInformation (7)
+typedef
+struct _SYSTEM_DEVICE_INFORMATION
+{
+       ULONG   NumberOfDisks;
+       ULONG   NumberOfFloppies;
+       ULONG   NumberOfCdRoms;
+       ULONG   NumberOfTapes;
+       ULONG   NumberOfSerialPorts;
+       ULONG   NumberOfParallelPorts;
+} SYSTEM_DEVICE_INFORMATION, *PSYSTEM_DEVICE_INFORMATION;
+
+// SystemProcessorPerformanceInformation (8)
+// (one per processor in the system)
+typedef
+struct _SYSTEM_PROCESSORTIME_INFO
+{
+       TIME    TotalProcessorRunTime;
+       TIME    TotalProcessorTime;
+       TIME    TotalProcessorUserTime;
+       TIME    TotalDPCTime;
+       TIME    TotalInterruptTime;
+       ULONG   TotalInterrupts;
+       ULONG   Unused;
+
+} SYSTEM_PROCESSORTIME_INFO, *PSYSTEM_PROCESSORTIME_INFO;
+
+// SystemFlagsInformation (9)
+typedef
+struct _SYSTEM_FLAGS_INFORMATION
+{
+       ULONG   Flags;
+
+} SYSTEM_FLAGS_INFORMATION, * PSYSTEM_FLAGS_INFORMATION;
+
+#define FLG_STOP_ON_EXCEPTION          0x00000001
+#define FLG_SHOW_LDR_SNAPS             0x00000002
+#define FLG_DEBUG_INITIAL_COMMAND      0x00000004
+#define FLG_STOP_ON_HANG_GUI           0x00000008
+#define FLG_HEAP_ENABLE_TAIL_CHECK     0x00000010
+#define FLG_HEAP_ENABLE_FREE_CHECK     0x00000020
+#define FLG_HEAP_VALIDATE_PARAMETERS   0x00000040
+#define FLG_HEAP_VALIDATE_ALL          0x00000080
+#define FLG_POOL_ENABLE_TAIL_CHECK     0x00000100
+#define FLG_POOL_ENABLE_FREE_CHECK     0x00000200
+#define FLG_POOL_ENABLE_TAGGING                0x00000400
+#define FLG_HEAP_ENABLE_TAGGING                0x00000800
+#define FLG_USER_STACK_TRACE_DB                0x00001000
+#define FLG_KERNEL_STACK_TRACE_DB      0x00002000
+#define FLG_MAINTAIN_OBJECT_TYPELIST   0x00004000
+#define FLG_HEAP_ENABLE_TAG_BY_DLL     0x00008000
+#define FLG_IGNORE_DEBUG_PRIV          0x00010000
+#define FLG_ENABLE_CSRDEBUG            0x00020000
+#define FLG_ENABLE_KDEBUG_SYMBOL_LOAD  0x00040000
+#define FLG_DISABLE_PAGE_KERNEL_STACKS 0x00080000
+#define FLG_HEAP_ENABLE_CALL_TRACING   0x00100000
+#define FLG_HEAP_DISABLE_COALESCING    0x00200000
+#define FLG_ENABLE_CLOSE_EXCEPTION     0x00400000
+#define FLG_ENABLE_EXCEPTION_LOGGING   0x00800000
+#define FLG_UNKNOWN_01000000           0x01000000
+#define FLG_UNKNOWN_02000000           0x02000000
+#define FLG_UNKNOWN_04000000           0x04000000
+#define FLG_ENABLE_DBGPRINT_BUFFERING  0x08000000
+#define FLG_UNKNOWN_10000000           0x10000000
+#define FLG_UNKNOWN_20000000           0x20000000
+#define FLG_UNKNOWN_40000000           0x40000000
+#define FLG_UNKNOWN_80000000           0x80000000
+
+// SystemCallTimeInformation (10)
+// UNKNOWN
+
+// SystemLocksInformation (12)
+typedef
+struct _SYSTEM_RESOURCE_LOCK_ENTRY
+{
+       ULONG   ResourceAddress;
+       ULONG   Always1;
+       ULONG   Unknown;
+       ULONG   ActiveCount;
+       ULONG   ContentionCount;
+       ULONG   Unused[2];
+       ULONG   NumberOfSharedWaiters;
+       ULONG   NumberOfExclusiveWaiters;
+       
+} SYSTEM_RESOURCE_LOCK_ENTRY, *PSYSTEM_RESOURCE_LOCK_ENTRY;
+
+typedef
+struct _SYSTEM_RESOURCE_LOCK_INFO
+{
+       ULONG                           Count;
+       SYSTEM_RESOURCE_LOCK_ENTRY      Lock [1];
+       
+} SYSTEM_RESOURCE_LOCK_INFO, *PSYSTEM_RESOURCE_LOCK_INFO;
+
+// SystemInformation13 (13)
+// UNKNOWN
+
+// SystemInformation14 (14)
+// UNKNOWN
+
+// SystemInformation15 (15)
+// UNKNOWN
+
+// SystemInstructionEmulationInfo (19)
+typedef
+struct _SYSTEM_VDM_INFORMATION
+{
+       ULONG VdmSegmentNotPresentCount;
+       ULONG VdmINSWCount;
+       ULONG VdmESPREFIXCount;
+       ULONG VdmCSPREFIXCount;
+       ULONG VdmSSPREFIXCount;
+       ULONG VdmDSPREFIXCount;
+       ULONG VdmFSPREFIXCount;
+       ULONG VdmGSPREFIXCount;
+       ULONG VdmOPER32PREFIXCount;
+       ULONG VdmADDR32PREFIXCount;
+       ULONG VdmINSBCount;
+       ULONG VdmINSWV86Count;
+       ULONG VdmOUTSBCount;
+       ULONG VdmOUTSWCount;
+       ULONG VdmPUSHFCount;
+       ULONG VdmPOPFCount;
+       ULONG VdmINTNNCount;
+       ULONG VdmINTOCount;
+       ULONG VdmIRETCount;
+       ULONG VdmINBIMMCount;
+       ULONG VdmINWIMMCount;
+       ULONG VdmOUTBIMMCount;
+       ULONG VdmOUTWIMMCount;
+       ULONG VdmINBCount;
+       ULONG VdmINWCount;
+       ULONG VdmOUTBCount;
+       ULONG VdmOUTWCount;
+       ULONG VdmLOCKPREFIXCount;
+       ULONG VdmREPNEPREFIXCount;
+       ULONG VdmREPPREFIXCount;
+       ULONG VdmHLTCount;
+       ULONG VdmCLICount;
+       ULONG VdmSTICount;
+       ULONG VdmBopCount;
+
+} SYSTEM_VDM_INFORMATION, *PSYSTEM_VDM_INFORMATION;
+
+// SystemInformation20 (20)
+// UNKNOWN
+
+// SystemPoolTagInformation (22)
+// found by Klaus P. Gerlicher
+// (implemented only in checked builds)
+typedef
+struct _POOL_TAG_STATS
+{
+       ULONG AllocationCount;
+       ULONG FreeCount;
+       ULONG SizeBytes;
+       
+} POOL_TAG_STATS;
+
+typedef
+struct _SYSTEM_POOL_TAG_ENTRY
+{
+       ULONG           Tag;
+       POOL_TAG_STATS  Paged;
+       POOL_TAG_STATS  NonPaged;
+
+} SYSTEM_POOL_TAG_ENTRY, * PSYSTEM_POOL_TAG_ENTRY;
+
+typedef
+struct _SYSTEM_POOL_TAG_INFO
+{
+       ULONG                   Count;
+       SYSTEM_POOL_TAG_ENTRY   PoolEntry [1];
+
+} SYSTEM_POOL_TAG_INFO, *PSYSTEM_POOL_TAG_INFO;
+
+// SystemProcessorScheduleInfo (23)
+typedef
+struct _SYSTEM_PROCESSOR_SCHEDULE_INFO
+{
+       ULONG nContextSwitches;
+       ULONG nDPCQueued;
+       ULONG nDPCRate;
+       ULONG TimerResolution;
+       ULONG nDPCBypasses;
+       ULONG nAPCBypasses;
+       
+} SYSTEM_PROCESSOR_SCHEDULE_INFO, *PSYSTEM_PROCESSOR_SCHEDULE_INFO;
+
+// SystemInformation25 (25)
+// UNKNOWN
+
+// SystemProcessorFaultCountInfo (33)
+typedef
+struct _SYSTEM_PROCESSOR_FAULT_INFO
+{
+       ULONG   nAlignmentFixup;
+       ULONG   nExceptionDispatches;
+       ULONG   nFloatingEmulation;
+       ULONG   Unknown;
+       
+} SYSTEM_PROCESSOR_FAULT_INFO, *PSYSTEM_PROCESSOR_FAULT_INFO;
+
+// SystemCrashDumpStateInfo (34)
+//
+
+// SystemDebuggerInformation (35)
+typedef
+struct _SYSTEM_DEBUGGER_INFO
+{
+       BOOLEAN KdDebuggerEnabled;
+       BOOLEAN KdDebuggerPresent;
+       
+} SYSTEM_DEBUGGER_INFO, *PSYSTEM_DEBUGGER_INFO;
+
+// SystemInformation36 (36)
+// UNKNOWN
+
+// SystemQuotaInformation (37)
+typedef
+struct _SYSTEM_QUOTA_INFORMATION
+{
+       ULONG   CmpGlobalQuota;
+       ULONG   CmpGlobalQuotaUsed;
+       ULONG   MmSizeofPagedPoolInBytes;
+       
+} SYSTEM_QUOTA_INFORMATION, *PSYSTEM_QUOTA_INFORMATION;
+
+// (49)
+// UNKNOWN
+
+// SystemVerifierInformation (51)
+// UNKNOWN
 
+// SystemAddVerifier (52)
+// UNKNOWN
 
-typedef struct _FILE_PIPE_INFORMATION {
-       ULONG ReadMode;
-       ULONG CompletionMode;
-} FILE_PIPE_INFORMATION, *PFILE_PIPE_INFORMATION;
+// wait type
 
-typedef struct _FILE_PIPE_LOCAL_INFORMATION {
-       ULONG NamedPipeType;
-       ULONG NamedPipeConfiguration;
-       ULONG MaximumInstances;
-       ULONG CurrentInstances;
-       ULONG InboundQuota;
-       ULONG ReadDataAvailable;
-       ULONG OutboundQuota;
-       ULONG WriteQuotaAvailable;
-       ULONG NamedPipeState;
-       ULONG NamedPipeEnd;
-} FILE_PIPE_LOCAL_INFORMATION, *PFILE_PIPE_LOCAL_INFORMATION;
+#define WaitAll                                        0
+#define WaitAny                                        1
 
-typedef struct _FILE_PIPE_REMOTE_INFORMATION {
-       LARGE_INTEGER CollectDataTime;
-       ULONG MaximumCollectionCount;
-} FILE_PIPE_REMOTE_INFORMATION, *PFILE_PIPE_REMOTE_INFORMATION;
+// number of wait objects
 
-typedef struct _FILE_MAILSLOT_QUERY_INFORMATION {
-       ULONG MaxMessageSize;
-       ULONG Unknown; /* ?? */
-       ULONG NextSize;
-       ULONG MessageCount;
-       LARGE_INTEGER Timeout;
-} FILE_MAILSLOT_QUERY_INFORMATION, *PFILE_MAILSLOT_QUERY_INFORMATION;
+#define THREAD_WAIT_OBJECTS                    3
+//#define MAXIMUM_WAIT_OBJECTS                 64
 
-typedef struct _FILE_MAILSLOT_SET_INFORMATION {
-       LARGE_INTEGER Timeout;
-} FILE_MAILSLOT_SET_INFORMATION, *PFILE_MAILSLOT_SET_INFORMATION;
+// key restore flags
 
-typedef struct _FILE_COMPRESSION_INFORMATION {
-       LARGE_INTEGER CompressedFileSize;
-       USHORT CompressionFormat;
-       UCHAR CompressionUnitShift;
-       UCHAR ChunkShift;
-       UCHAR ClusterShift;
-       UCHAR Reserved[3];
-} FILE_COMPRESSION_INFORMATION, *PFILE_COMPRESSION_INFORMATION;
+#define REG_WHOLE_HIVE_VOLATILE                        1
+#define REG_REFRESH_HIVE                       2
 
-typedef struct _FILE_ALL_INFORMATION {
-       FILE_BASIC_INFORMATION BasicInformation;
-       FILE_STANDARD_INFORMATION StandardInformation;
-       FILE_INTERNAL_INFORMATION InternalInformation;
-       FILE_EA_INFORMATION EaInformation;
-       FILE_ACCESS_INFORMATION AccessInformation;
-       FILE_POSITION_INFORMATION PositionInformation;
-       FILE_MODE_INFORMATION ModeInformation;
-       FILE_ALIGNMENT_INFORMATION AlignmentInformation;
-       FILE_NAME_INFORMATION NameInformation;
-} FILE_ALL_INFORMATION, *PFILE_ALL_INFORMATION;
+// object type  access rights
 
+#define OBJECT_TYPE_CREATE             0x0001
+#define OBJECT_TYPE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
 
-// file system information structures
+// directory access rights
 
-typedef struct _FILE_FS_DEVICE_INFORMATION {
-       DEVICE_TYPE DeviceType;
-       ULONG Characteristics;
-} FILE_FS_DEVICE_INFORMATION,  *PFILE_FS_DEVICE_INFORMATION;
+#define DIRECTORY_QUERY                                0x0001
+#define DIRECTORY_TRAVERSE                     0x0002
+#define DIRECTORY_CREATE_OBJECT                        0x0004
+#define DIRECTORY_CREATE_SUBDIRECTORY          0x0008
 
+#define DIRECTORY_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0xF)
 
-typedef struct _FILE_FS_VOLUME_INFORMATION {
-       TIME VolumeCreationTime;
-       ULONG VolumeSerialNumber;
-       ULONG VolumeLabelLength;
-       BOOLEAN SupportsObjects;
-       WCHAR VolumeLabel[0];
-} FILE_FS_VOLUME_INFORMATION, *PFILE_FS_VOLUME_INFORMATION;
+// symbolic link access rights
 
-typedef struct _FILE_FS_SIZE_INFORMATION {
-       LARGE_INTEGER TotalAllocationUnits;
-       LARGE_INTEGER AvailableAllocationUnits;
-       ULONG SectorsPerAllocationUnit;
-       ULONG BytesPerSector;
-} FILE_FS_SIZE_INFORMATION, *PFILE_FS_SIZE_INFORMATION;
+#define SYMBOLIC_LINK_QUERY                    0x0001
+#define SYMBOLIC_LINK_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | 0x1)
 
-typedef struct _FILE_FS_ATTRIBUTE_INFORMATION {
-       ULONG FileSystemAttributes;
-       LONG MaximumComponentNameLength;
-       ULONG FileSystemNameLength;
-       WCHAR FileSystemName[0];
-} FILE_FS_ATTRIBUTE_INFORMATION, *PFILE_FS_ATTRIBUTE_INFORMATION;
 
-/*
-       FileSystemAttributes is one of the following values:
+typedef struct _OBJECT_DATA_INFORMATION
+{
+       BOOLEAN bInheritHandle;
+       BOOLEAN bProtectFromClose;
+} OBJECT_DATA_INFORMATION, *POBJECT_DATA_INFORMATION;
 
-       FILE_CASE_SENSITIVE_SEARCH      0x00000001
-        FILE_CASE_PRESERVED_NAMES       0x00000002
-        FILE_UNICODE_ON_DISK            0x00000004
-        FILE_PERSISTENT_ACLS            0x00000008
-        FILE_FILE_COMPRESSION           0x00000010
-        FILE_VOLUME_QUOTAS              0x00000020
-        FILE_VOLUME_IS_COMPRESSED       0x00008000
-*/
-typedef struct _FILE_FS_LABEL_INFORMATION {
-       ULONG VolumeLabelLength;
-       WCHAR VolumeLabel[0];
-} FILE_FS_LABEL_INFORMATION, *PFILE_FS_LABEL_INFORMATION;
 
-// read file scatter / write file scatter
-//FIXME I am a win32 struct aswell
+typedef struct _OBJECT_TYPE_INFORMATION
+{
+       UNICODE_STRING  Name;
+       UNICODE_STRING Type;
+       ULONG TotalHandles;
+       ULONG ReferenceCount;
+} OBJECT_TYPE_INFORMATION, *POBJECT_TYPE_INFORMATION;
 
-typedef union _FILE_SEGMENT_ELEMENT {
-       PVOID Buffer;
-       ULONG Alignment;
-}FILE_SEGMENT_ELEMENT, *PFILE_SEGMENT_ELEMENT;
 
 // directory information
 
@@ -1463,81 +1556,6 @@ typedef struct _OBJDIR_INFORMATION {
 } OBJDIR_INFORMATION, *POBJDIR_INFORMATION;
 
 
-typedef struct _FILE_DIRECTORY_INFORMATION {
-       ULONG   NextEntryOffset;
-       ULONG   FileIndex;
-       TIME CreationTime;
-       TIME LastAccessTime;
-       TIME LastWriteTime;
-       TIME ChangeTime;
-       LARGE_INTEGER EndOfFile;
-       LARGE_INTEGER AllocationSize;
-       ULONG FileAttributes;
-       ULONG FileNameLength;
-       WCHAR FileName[0];
-} FILE_DIRECTORY_INFORMATION, *PFILE_DIRECTORY_INFORMATION;
-
-typedef struct _FILE_FULL_DIRECTORY_INFORMATION {
-       ULONG   NextEntryOffset;
-       ULONG   FileIndex;
-       TIME CreationTime;
-       TIME LastAccessTime;
-       TIME LastWriteTime;
-       TIME ChangeTime;
-       LARGE_INTEGER EndOfFile;
-       LARGE_INTEGER AllocationSize;
-       ULONG FileAttributes;
-       ULONG FileNameLength;
-       ULONG EaSize;
-       WCHAR FileName[0]; // variable size
-} FILE_FULL_DIRECTORY_INFORMATION, *PFILE_FULL_DIRECTORY_INFORMATION,
-  FILE_FULL_DIR_INFORMATION, *PFILE_FULL_DIR_INFORMATION;
-
-
-typedef struct _FILE_BOTH_DIRECTORY_INFORMATION {
-       ULONG           NextEntryOffset;
-       ULONG           FileIndex;
-       TIME            CreationTime;
-       TIME            LastAccessTime;
-       TIME            LastWriteTime;
-       TIME            ChangeTime;
-       LARGE_INTEGER   EndOfFile;
-       LARGE_INTEGER   AllocationSize;
-       ULONG           FileAttributes;
-       ULONG           FileNameLength;
-       ULONG           EaSize;
-       CHAR            ShortNameLength;
-       WCHAR           ShortName[12]; // 8.3 name
-       WCHAR           FileName[0];
-} FILE_BOTH_DIRECTORY_INFORMATION, *PFILE_BOTH_DIRECTORY_INFORMATION,
-  FILE_BOTH_DIR_INFORMATION, *PFILE_BOTH_DIR_INFORMATION;
-
-
-/*
-       NotifyFilter / CompletionFilter:
-
-       FILE_NOTIFY_CHANGE_FILE_NAME        0x00000001
-       FILE_NOTIFY_CHANGE_DIR_NAME         0x00000002
-       FILE_NOTIFY_CHANGE_NAME             0x00000003
-       FILE_NOTIFY_CHANGE_ATTRIBUTES       0x00000004
-       FILE_NOTIFY_CHANGE_SIZE             0x00000008
-       FILE_NOTIFY_CHANGE_LAST_WRITE       0x00000010
-       FILE_NOTIFY_CHANGE_LAST_ACCESS      0x00000020
-       FILE_NOTIFY_CHANGE_CREATION         0x00000040
-       FILE_NOTIFY_CHANGE_EA               0x00000080
-       FILE_NOTIFY_CHANGE_SECURITY         0x00000100
-       FILE_NOTIFY_CHANGE_STREAM_NAME      0x00000200
-       FILE_NOTIFY_CHANGE_STREAM_SIZE      0x00000400
-       FILE_NOTIFY_CHANGE_STREAM_WRITE     0x00000800
-*/
-
-typedef struct _FILE_NOTIFY_INFORMATION {
-       ULONG Action;
-       ULONG FileNameLength;
-       WCHAR FileName[0]; 
-} FILE_NOTIFY_INFORMATION;
-
-
 /*
         Action is one of the following values:
 
@@ -1556,22 +1574,6 @@ typedef struct _FILE_NOTIFY_INFORMATION {
 // File System Control commands ( related to defragging )
 
 #define        FSCTL_READ_MFT_RECORD                   0x90068 // NTFS only
-#define FSCTL_GET_VOLUME_BITMAP                        0x9006F
-#define FSCTL_GET_RETRIEVAL_POINTERS           0x90073
-#define FSCTL_MOVE_FILE                                0x90074
-
-typedef struct _MAPPING_PAIR
-{
-       ULONGLONG       Vcn;
-       ULONGLONG       Lcn;
-} MAPPING_PAIR, *PMAPPING_PAIR;
-
-typedef struct _GET_RETRIEVAL_DESCRIPTOR
-{
-       ULONG           NumberOfPairs;
-       ULONGLONG       StartVcn;
-       MAPPING_PAIR    Pair[0]; // variable size 
-} GET_RETRIEVAL_DESCRIPTOR, *PGET_RETRIEVAL_DESCRIPTOR;
 
 typedef struct _BITMAP_DESCRIPTOR
 {
@@ -1580,17 +1582,6 @@ typedef struct _BITMAP_DESCRIPTOR
        BYTE            Map[0]; // variable size
 } BITMAP_DESCRIPTOR, *PBITMAP_DESCRIPTOR;
 
-typedef struct _MOVEFILE_DESCRIPTOR
-{
-       HANDLE            FileHandle;
-       ULONG             Reserved;
-       LARGE_INTEGER     StartVcn;
-       LARGE_INTEGER     TargetLcn;
-       ULONG             NumVcns;
-       ULONG             Reserved1;
-} MOVEFILE_DESCRIPTOR, *PMOVEFILE_DESCRIPTOR;
-
-
 
 //typedef enum _TIMER_TYPE 
 //{
@@ -1629,34 +1620,4 @@ struct _LPC_PORT_BASIC_INFORMATION
 
 } LPC_PORT_BASIC_INFORMATION, * PLPC_PORT_BASIC_INFORMATION;
 
-typedef struct _SECTION_BASIC_INFORMATION
-{
-  PVOID BaseAddress;
-  ULONG Attributes;
-  LARGE_INTEGER Size;
-} SECTION_BASIC_INFORMATION, *PSECTION_BASIC_INFORMATION;
-
-typedef struct _SECTION_IMAGE_INFORMATION
-{
-  PVOID EntryPoint;
-  ULONG Unknown1;
-  ULONG StackReserve;
-  ULONG StackCommit;
-  ULONG Subsystem;
-  USHORT MinorSubsystemVersion;
-  USHORT MajorSubsystemVersion;
-  ULONG Unknown2;
-  ULONG Characteristics;
-  USHORT ImageNumber;
-  BOOLEAN Executable;
-  UCHAR Unknown3;
-  ULONG Unknown4[3];
-} SECTION_IMAGE_INFORMATION, *PSECTION_IMAGE_INFORMATION;
-
-typedef enum _SECTION_INFORMATION_CLASS 
-{
-  SectionBasicInformation,
-  SectionImageInformation,
-} SECTION_INFORMATION_CLASS;
-
 #endif