ReactOS 0.4.16-dev-1890-gbb7a613
winternl.h File Reference
#include <windef.h>
Include dependency graph for winternl.h:

Go to the source code of this file.

Classes

struct  _STRING
 
struct  _UNICODE_STRING
 
struct  _RTL_USER_PROCESS_PARAMETERS
 
struct  _PEB_LDR_DATA
 
struct  _LDR_DATA_TABLE_ENTRY
 
struct  _PEB
 
struct  _TEB
 
struct  _OBJECT_ATTRIBUTES
 
struct  _IO_STATUS_BLOCK
 
struct  _KEY_VALUE_ENTRY
 
struct  _PROCESS_BASIC_INFORMATION
 
struct  _PUBLIC_OBJECT_BASIC_INFORMATION
 
struct  __PUBLIC_OBJECT_TYPE_INFORMATION
 
struct  _SYSTEM_BASIC_INFORMATION
 
struct  _SYSTEM_PERFORMANCE_INFORMATION
 
struct  _SYSTEM_TIMEOFDAY_INFORMATION
 
struct  _SYSTEM_PROCESS_INFORMATION
 
struct  _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION
 
struct  _SYSTEM_INTERRUPT_INFORMATION
 
struct  _SYSTEM_EXCEPTION_INFORMATION
 
struct  _SYSTEM_REGISTRY_QUOTA_INFORMATION
 
struct  _SYSTEM_LOOKASIDE_INFORMATION
 
struct  _SYSTEM_POLICY_INFORMATION
 
struct  _WINSTATIONINFORMATIONW
 

Macros

#define _WINTERNL_
 
#define NT_SUCCESS(Status)   (((NTSTATUS)(Status)) >= 0)
 
#define NT_INFORMATION(Status)   ((((ULONG)(Status)) >> 30) == 1)
 
#define NT_WARNING(Status)   ((((ULONG)(Status)) >> 30) == 2)
 
#define NT_ERROR(Status)   ((((ULONG)(Status)) >> 30) == 3)
 
#define INTERNAL_TS_ACTIVE_CONSOLE_ID   (*((volatile ULONG*)0x7ffe02d8))
 
#define LOGONID_CURRENT   ((ULONG)-1)
 
#define SERVERNAME_CURRENT   ((HANDLE)NULL)
 
#define FILE_DIRECTORY_FILE   0x00000001
 
#define FILE_WRITE_THROUGH   0x00000002
 
#define FILE_SEQUENTIAL_ONLY   0x00000004
 
#define FILE_NO_INTERMEDIATE_BUFFERING   0x00000008
 
#define FILE_SYNCHRONOUS_IO_ALERT   0x00000010
 
#define FILE_SYNCHRONOUS_IO_NONALERT   0x00000020
 
#define FILE_NON_DIRECTORY_FILE   0x00000040
 
#define FILE_CREATE_TREE_CONNECTION   0x00000080
 
#define FILE_COMPLETE_IF_OPLOCKED   0x00000100
 
#define FILE_NO_EA_KNOWLEDGE   0x00000200
 
#define FILE_OPEN_REMOTE_INSTANCE   0x00000400
 
#define FILE_RANDOM_ACCESS   0x00000800
 
#define FILE_DELETE_ON_CLOSE   0x00001000
 
#define FILE_OPEN_BY_FILE_ID   0x00002000
 
#define FILE_OPEN_FOR_BACKUP_INTENT   0x00004000
 
#define FILE_NO_COMPRESSION   0x00008000
 
#define FILE_OPEN_REQUIRING_OPLOCK   0x00010000
 
#define FILE_RESERVE_OPFILTER   0x00100000
 
#define FILE_OPEN_REPARSE_POINT   0x00200000
 
#define FILE_OPEN_NO_RECALL   0x00400000
 
#define FILE_OPEN_FOR_FREE_SPACE_QUERY   0x00800000
 
#define FILE_SUPERSEDED   0x00000000
 
#define FILE_OPENED   0x00000001
 
#define FILE_CREATED   0x00000002
 
#define FILE_OVERWRITTEN   0x00000003
 
#define FILE_EXISTS   0x00000004
 
#define FILE_DOES_NOT_EXIST   0x00000005
 
#define FILE_VALID_OPTION_FLAGS   0x00ffffff
 
#define FILE_VALID_PIPE_OPTION_FLAGS   0x00000032
 
#define FILE_VALID_MAILSLOT_OPTION_FLAGS   0x00000032
 
#define FILE_VALID_SET_FLAGS   0x00000036
 
#define FILE_SUPERSEDE   0x00000000
 
#define FILE_OPEN   0x00000001
 
#define FILE_CREATE   0x00000002
 
#define FILE_OPEN_IF   0x00000003
 
#define FILE_OVERWRITE   0x00000004
 
#define FILE_OVERWRITE_IF   0x00000005
 
#define FILE_MAXIMUM_DISPOSITION   0x00000005
 
#define OBJ_INHERIT   0x00000002L
 
#define OBJ_PERMANENT   0x00000010L
 
#define OBJ_EXCLUSIVE   0x00000020L
 
#define OBJ_CASE_INSENSITIVE   0x00000040L
 
#define OBJ_OPENIF   0x00000080L
 
#define OBJ_OPENLINK   0x00000100L
 
#define OBJ_KERNEL_HANDLE   0x00000200L
 
#define OBJ_FORCE_ACCESS_CHECK   0x00000400L
 
#define OBJ_VALID_ATTRIBUTES   0x000007F2L
 
#define InitializeObjectAttributes(p, n, a, r, s)
 
#define PIO_APC_ROUTINE_DEFINED
 
#define RtlMoveMemory(Dest, Source, Length)   memmove((Dest),(Source),(Length))
 
#define RtlFillMemory(Dest, Length, Fill)   memset((Dest),(Fill),(Length))
 
#define RtlZeroMemory(Dest, Length)   RtlFillMemory((Dest),(Length),0)
 

Typedefs

typedef CONST charPCSZ
 
typedef struct _STRING STRING
 
typedef struct _STRINGPSTRING
 
typedef STRING ANSI_STRING
 
typedef PSTRING PANSI_STRING
 
typedef PSTRING PCANSI_STRING
 
typedef STRING OEM_STRING
 
typedef PSTRING POEM_STRING
 
typedef const STRINGPCOEM_STRING
 
typedef struct _UNICODE_STRING UNICODE_STRING
 
typedef struct _UNICODE_STRINGPUNICODE_STRING
 
typedef const UNICODE_STRINGPCUNICODE_STRING
 
typedef struct _RTL_USER_PROCESS_PARAMETERS RTL_USER_PROCESS_PARAMETERS
 
typedef struct _RTL_USER_PROCESS_PARAMETERSPRTL_USER_PROCESS_PARAMETERS
 
typedef struct _PEB_LDR_DATA PEB_LDR_DATA
 
typedef struct _PEB_LDR_DATAPPEB_LDR_DATA
 
typedef struct _LDR_DATA_TABLE_ENTRY LDR_DATA_TABLE_ENTRY
 
typedef struct _LDR_DATA_TABLE_ENTRYPLDR_DATA_TABLE_ENTRY
 
typedef VOID(NTAPIPPS_POST_PROCESS_INIT_ROUTINE) (VOID)
 
typedef struct _PEB PEB
 
typedef struct _PEBPPEB
 
typedef struct _TEB TEB
 
typedef struct _TEBPTEB
 
typedef enum _FILE_INFORMATION_CLASS FILE_INFORMATION_CLASS
 
typedef struct _OBJECT_ATTRIBUTES OBJECT_ATTRIBUTES
 
typedef struct _OBJECT_ATTRIBUTESPOBJECT_ATTRIBUTES
 
typedef struct _IO_STATUS_BLOCK IO_STATUS_BLOCK
 
typedef struct _IO_STATUS_BLOCKPIO_STATUS_BLOCK
 
typedef VOID(NTAPIPIO_APC_ROUTINE) (_In_ PVOID ApcContext, _In_ PIO_STATUS_BLOCK IoStatusBlock, _In_ ULONG Reserved)
 
typedef struct _KEY_VALUE_ENTRY KEY_VALUE_ENTRY
 
typedef struct _KEY_VALUE_ENTRYPKEY_VALUE_ENTRY
 
typedef enum _KEY_SET_INFORMATION_CLASS KEY_SET_INFORMATION_CLASS
 
typedef enum _PROCESSINFOCLASS PROCESSINFOCLASS
 
typedef struct _PROCESS_BASIC_INFORMATION PROCESS_BASIC_INFORMATION
 
typedef struct _PROCESS_BASIC_INFORMATIONPPROCESS_BASIC_INFORMATION
 
typedef enum _THREADINFOCLASS THREADINFOCLASS
 
typedef enum _OBJECT_INFORMATION_CLASS OBJECT_INFORMATION_CLASS
 
typedef struct _PUBLIC_OBJECT_BASIC_INFORMATION PUBLIC_OBJECT_BASIC_INFORMATION
 
typedef struct _PUBLIC_OBJECT_BASIC_INFORMATIONPPUBLIC_OBJECT_BASIC_INFORMATION
 
typedef struct __PUBLIC_OBJECT_TYPE_INFORMATION PUBLIC_OBJECT_TYPE_INFORMATION
 
typedef struct __PUBLIC_OBJECT_TYPE_INFORMATIONPPUBLIC_OBJECT_TYPE_INFORMATION
 
typedef enum _SYSTEM_INFORMATION_CLASS SYSTEM_INFORMATION_CLASS
 
typedef struct _SYSTEM_BASIC_INFORMATION SYSTEM_BASIC_INFORMATION
 
typedef struct _SYSTEM_BASIC_INFORMATIONPSYSTEM_BASIC_INFORMATION
 
typedef struct _SYSTEM_PERFORMANCE_INFORMATION SYSTEM_PERFORMANCE_INFORMATION
 
typedef struct _SYSTEM_PERFORMANCE_INFORMATIONPSYSTEM_PERFORMANCE_INFORMATION
 
typedef struct _SYSTEM_TIMEOFDAY_INFORMATION SYSTEM_TIMEOFDAY_INFORMATION
 
typedef struct _SYSTEM_TIMEOFDAY_INFORMATIONPSYSTEM_TIMEOFDAY_INFORMATION
 
typedef struct _SYSTEM_PROCESS_INFORMATION SYSTEM_PROCESS_INFORMATION
 
typedef struct _SYSTEM_PROCESS_INFORMATIONPSYSTEM_PROCESS_INFORMATION
 
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION
 
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATIONPSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION
 
typedef struct _SYSTEM_INTERRUPT_INFORMATION SYSTEM_INTERRUPT_INFORMATION
 
typedef struct _SYSTEM_INTERRUPT_INFORMATIONPSYSTEM_INTERRUPT_INFORMATION
 
typedef struct _SYSTEM_EXCEPTION_INFORMATION SYSTEM_EXCEPTION_INFORMATION
 
typedef struct _SYSTEM_EXCEPTION_INFORMATIONPSYSTEM_EXCEPTION_INFORMATION
 
typedef struct _SYSTEM_REGISTRY_QUOTA_INFORMATION SYSTEM_REGISTRY_QUOTA_INFORMATION
 
typedef struct _SYSTEM_REGISTRY_QUOTA_INFORMATIONPSYSTEM_REGISTRY_QUOTA_INFORMATION
 
typedef struct _SYSTEM_LOOKASIDE_INFORMATION SYSTEM_LOOKASIDE_INFORMATION
 
typedef struct _SYSTEM_LOOKASIDE_INFORMATIONPSYSTEM_LOOKASIDE_INFORMATION
 
typedef struct _SYSTEM_POLICY_INFORMATION SYSTEM_POLICY_INFORMATION
 
typedef struct _SYSTEM_POLICY_INFORMATIONPSYSTEM_POLICY_INFORMATION
 
typedef enum _WINSTATIONINFOCLASS WINSTATIONINFOCLASS
 
typedef struct _WINSTATIONINFORMATIONW WINSTATIONINFORMATIONW
 
typedef struct _WINSTATIONINFORMATIONWPWINSTATIONINFORMATIONW
 
typedef BOOLEAN(WINAPIPWINSTATIONQUERYINFORMATIONW) (HANDLE, ULONG, WINSTATIONINFOCLASS, PVOID, ULONG, PULONG)
 

Enumerations

enum  _FILE_INFORMATION_CLASS {
  FileDirectoryInformation = 1 , FileFullDirectoryInformation , FileBothDirectoryInformation , FileBasicInformation ,
  FileStandardInformation , FileInternalInformation , FileEaInformation , FileAccessInformation ,
  FileNameInformation , FileRenameInformation , FileLinkInformation , FileNamesInformation ,
  FileDispositionInformation , FilePositionInformation , FileFullEaInformation , FileModeInformation ,
  FileAlignmentInformation , FileAllInformation , FileAllocationInformation , FileEndOfFileInformation ,
  FileAlternateNameInformation , FileStreamInformation , FilePipeInformation , FilePipeLocalInformation ,
  FilePipeRemoteInformation , FileMailslotQueryInformation , FileMailslotSetInformation , FileCompressionInformation ,
  FileObjectIdInformation , FileCompletionInformation , FileMoveClusterInformation , FileQuotaInformation ,
  FileReparsePointInformation , FileNetworkOpenInformation , FileAttributeTagInformation , FileTrackingInformation ,
  FileIdBothDirectoryInformation , FileIdFullDirectoryInformation , FileValidDataLengthInformation , FileShortNameInformation ,
  FileIoCompletionNotificationInformation , FileIoStatusBlockRangeInformation , FileIoPriorityHintInformation , FileSfioReserveInformation ,
  FileSfioVolumeInformation , FileHardLinkInformation , FileProcessIdsUsingFileInformation , FileNormalizedNameInformation ,
  FileNetworkPhysicalNameInformation , FileIdGlobalTxDirectoryInformation , FileMaximumInformation , FileDirectoryInformation = 1 ,
  FileFullDirectoryInformation , FileBothDirectoryInformation , FileBasicInformation , FileStandardInformation ,
  FileInternalInformation , FileEaInformation , FileAccessInformation , FileNameInformation ,
  FileRenameInformation , FileLinkInformation , FileNamesInformation , FileDispositionInformation ,
  FilePositionInformation , FileFullEaInformation , FileModeInformation , FileAlignmentInformation ,
  FileAllInformation , FileAllocationInformation , FileEndOfFileInformation , FileAlternateNameInformation ,
  FileStreamInformation , FilePipeInformation , FilePipeLocalInformation , FilePipeRemoteInformation ,
  FileMailslotQueryInformation , FileMailslotSetInformation , FileCompressionInformation , FileCopyOnWriteInformation ,
  FileCompletionInformation , FileMoveClusterInformation , FileOleClassIdInformation , FileOleStateBitsInformation ,
  FileNetworkOpenInformation , FileObjectIdInformation , FileOleAllInformation , FileOleDirectoryInformation ,
  FileContentIndexInformation , FileInheritContentIndexInformation , FileOleInformation , FileMaximumInformation ,
  FileDirectoryInformation = 1 , FileFullDirectoryInformation , FileBothDirectoryInformation , FileBasicInformation ,
  FileStandardInformation , FileInternalInformation , FileEaInformation , FileAccessInformation ,
  FileNameInformation , FileRenameInformation , FileLinkInformation , FileNamesInformation ,
  FileDispositionInformation , FilePositionInformation , FileFullEaInformation , FileModeInformation ,
  FileAlignmentInformation , FileAllInformation , FileAllocationInformation , FileEndOfFileInformation ,
  FileAlternateNameInformation , FileStreamInformation , FilePipeInformation , FilePipeLocalInformation ,
  FilePipeRemoteInformation , FileMailslotQueryInformation , FileMailslotSetInformation , FileCompressionInformation ,
  FileCopyOnWriteInformation , FileCompletionInformation , FileMoveClusterInformation , FileOleClassIdInformation ,
  FileOleStateBitsInformation , FileNetworkOpenInformation , FileObjectIdInformation , FileOleAllInformation ,
  FileOleDirectoryInformation , FileContentIndexInformation , FileInheritContentIndexInformation , FileOleInformation ,
  FileMaximumInformation , FileDirectoryInformation = 1 , FileDirectoryInformation = 1 , FileFullDirectoryInformation ,
  FileBothDirectoryInformation , FileBasicInformation , FileStandardInformation , FileInternalInformation ,
  FileEaInformation , FileAccessInformation , FileNameInformation , FileRenameInformation ,
  FileLinkInformation , FileNamesInformation , FileDispositionInformation , FilePositionInformation ,
  FileFullEaInformation , FileModeInformation , FileAlignmentInformation , FileAllInformation ,
  FileAllocationInformation , FileEndOfFileInformation , FileAlternateNameInformation , FileStreamInformation ,
  FilePipeInformation , FilePipeLocalInformation , FilePipeRemoteInformation , FileMailslotQueryInformation ,
  FileMailslotSetInformation , FileCompressionInformation , FileObjectIdInformation , FileCompletionInformation ,
  FileMoveClusterInformation , FileQuotaInformation , FileReparsePointInformation , FileNetworkOpenInformation ,
  FileAttributeTagInformation , FileTrackingInformation , FileIdBothDirectoryInformation , FileIdFullDirectoryInformation ,
  FileValidDataLengthInformation , FileShortNameInformation , FileIoCompletionNotificationInformation , FileIoStatusBlockRangeInformation ,
  FileIoPriorityHintInformation , FileSfioReserveInformation , FileSfioVolumeInformation , FileHardLinkInformation ,
  FileProcessIdsUsingFileInformation , FileNormalizedNameInformation , FileNetworkPhysicalNameInformation , FileIdGlobalTxDirectoryInformation ,
  FileIsRemoteDeviceInformation , FileAttributeCacheInformation , FileNumaNodeInformation , FileStandardLinkInformation ,
  FileRemoteProtocolInformation , FileRenameInformationBypassAccessCheck , FileLinkInformationBypassAccessCheck , FileVolumeNameInformation ,
  FileIdInformation , FileIdExtdDirectoryInformation , FileReplaceCompletionInformation , FileHardLinkFullIdInformation ,
  FileIdExtdBothDirectoryInformation , FileDispositionInformationEx , FileRenameInformationEx , FileRenameInformationExBypassAccessCheck ,
  FileDesiredStorageClassInformation , FileStatInformation , FileMemoryPartitionInformation , FileStatLxInformation ,
  FileCaseSensitiveInformation , FileLinkInformationEx , FileLinkInformationExBypassAccessCheck , FileStorageReserveIdInformation ,
  FileCaseSensitiveInformationForceAccessCheck , FileKnownFolderInformation , FileMaximumInformation , FileDirectoryInformation = 1 ,
  FileFullDirectoryInformation , FileBothDirectoryInformation , FileBasicInformation , FileStandardInformation ,
  FileInternalInformation , FileEaInformation , FileAccessInformation , FileNameInformation ,
  FileRenameInformation , FileLinkInformation , FileNamesInformation , FileDispositionInformation ,
  FilePositionInformation , FileFullEaInformation , FileModeInformation , FileAlignmentInformation ,
  FileAllInformation , FileAllocationInformation , FileEndOfFileInformation , FileAlternateNameInformation ,
  FileStreamInformation , FilePipeInformation , FilePipeLocalInformation , FilePipeRemoteInformation ,
  FileMailslotQueryInformation , FileMailslotSetInformation , FileCompressionInformation , FileObjectIdInformation ,
  FileCompletionInformation , FileMoveClusterInformation , FileQuotaInformation , FileReparsePointInformation ,
  FileNetworkOpenInformation , FileAttributeTagInformation , FileTrackingInformation , FileIdBothDirectoryInformation ,
  FileIdFullDirectoryInformation , FileValidDataLengthInformation , FileShortNameInformation , FileIoCompletionNotificationInformation ,
  FileIoStatusBlockRangeInformation , FileIoPriorityHintInformation , FileSfioReserveInformation , FileSfioVolumeInformation ,
  FileHardLinkInformation , FileProcessIdsUsingFileInformation , FileNormalizedNameInformation , FileNetworkPhysicalNameInformation ,
  FileIdGlobalTxDirectoryInformation , FileIsRemoteDeviceInformation , FileAttributeCacheInformation , FileNumaNodeInformation ,
  FileStandardLinkInformation , FileRemoteProtocolInformation , FileMaximumInformation
}
 
enum  _KEY_SET_INFORMATION_CLASS {
  KeyWriteTimeInformation , KeyWriteTimeInformation , KeyWow64FlagsInformation , KeyControlFlagsInformation ,
  KeySetVirtualizationInformation , KeySetDebugInformation , KeySetHandleTagsInformation , MaxKeySetInfoClass ,
  KeyWriteTimeInformation , KeyWow64FlagsInformation , KeyControlFlagsInformation , KeySetVirtualizationInformation ,
  KeySetDebugInformation , KeySetHandleTagsInformation , MaxKeySetInfoClass
}
 
enum  _PROCESSINFOCLASS {
  ProcessBasicInformation = 0 , ProcessDebugPort = 7 , ProcessWow64Information = 26 , ProcessImageFileName = 27 ,
  ProcessBreakOnTermination = 29 , ProcessBasicInformation = 0 , ProcessDebugPort = 7 , ProcessWow64Information = 26 ,
  ProcessImageFileName = 27 , ProcessBreakOnTermination = 29 , ProcessBasicInformation = 0 , ProcessQuotaLimits = 1 ,
  ProcessIoCounters = 2 , ProcessVmCounters = 3 , ProcessTimes = 4 , ProcessBasePriority = 5 ,
  ProcessRaisePriority = 6 , ProcessDebugPort = 7 , ProcessExceptionPort = 8 , ProcessAccessToken = 9 ,
  ProcessLdtInformation = 10 , ProcessLdtSize = 11 , ProcessDefaultHardErrorMode = 12 , ProcessIoPortHandlers = 13 ,
  ProcessPooledUsageAndLimits = 14 , ProcessWorkingSetWatch = 15 , ProcessUserModeIOPL = 16 , ProcessEnableAlignmentFaultFixup = 17 ,
  ProcessPriorityClass = 18 , ProcessWx86Information = 19 , ProcessHandleCount = 20 , ProcessAffinityMask = 21 ,
  ProcessPriorityBoost = 22 , ProcessDeviceMap = 23 , ProcessSessionInformation = 24 , ProcessForegroundInformation = 25 ,
  ProcessWow64Information = 26 , ProcessImageFileName = 27 , ProcessLUIDDeviceMapsEnabled = 28 , ProcessBreakOnTermination = 29 ,
  ProcessDebugObjectHandle = 30 , ProcessDebugFlags = 31 , ProcessHandleTracing = 32 , ProcessIoPriority = 33 ,
  ProcessExecuteFlags = 34 , ProcessTlsInformation = 35 , ProcessCookie = 36 , ProcessImageInformation = 37 ,
  ProcessCycleTime = 38 , ProcessPagePriority = 39 , ProcessInstrumentationCallback = 40 , ProcessThreadStackAllocation = 41 ,
  ProcessWorkingSetWatchEx = 42 , ProcessImageFileNameWin32 = 43 , ProcessImageFileMapping = 44 , ProcessAffinityUpdateMode = 45 ,
  ProcessMemoryAllocationMode = 46 , ProcessGroupInformation = 47 , ProcessTokenVirtualizationEnabled = 48 , ProcessConsoleHostProcess = 49 ,
  ProcessWindowInformation = 50 , ProcessHandleInformation = 51 , ProcessMitigationPolicy = 52 , ProcessDynamicFunctionTableInformation = 53 ,
  ProcessHandleCheckingMode = 54 , ProcessKeepAliveCount = 55 , ProcessRevokeFileHandles = 56 , ProcessWorkingSetControl = 57 ,
  ProcessHandleTable = 58 , ProcessCheckStackExtentsMode = 59 , ProcessCommandLineInformation = 60 , ProcessProtectionInformation = 61 ,
  ProcessMemoryExhaustion = 62 , ProcessFaultInformation = 63 , ProcessTelemetryIdInformation = 64 , ProcessCommitReleaseInformation = 65 ,
  ProcessDefaultCpuSetsInformation = 66 , ProcessAllowedCpuSetsInformation = 67 , ProcessSubsystemProcess = 68 , ProcessJobMemoryInformation = 69 ,
  ProcessInPrivate = 70 , ProcessRaiseUMExceptionOnInvalidHandleClose = 71 , ProcessIumChallengeResponse = 72 , ProcessChildProcessInformation = 73 ,
  ProcessHighGraphicsPriorityInformation = 74 , ProcessSubsystemInformation = 75 , ProcessEnergyValues = 76 , ProcessPowerThrottlingState = 77 ,
  ProcessReserved3Information = 78 , ProcessWin32kSyscallFilterInformation = 79 , ProcessDisableSystemAllowedCpuSets = 80 , ProcessWakeInformation = 81 ,
  ProcessEnergyTrackingState = 82 , ProcessManageWritesToExecutableMemory = 83 , ProcessCaptureTrustletLiveDump = 84 , ProcessTelemetryCoverage = 85 ,
  ProcessEnclaveInformation = 86 , ProcessEnableReadWriteVmLogging = 87 , ProcessUptimeInformation = 88 , ProcessImageSection = 89 ,
  ProcessDebugAuthInformation = 90 , ProcessSystemResourceManagement = 91 , ProcessSequenceNumber = 92 , ProcessLoaderDetour = 93 ,
  ProcessSecurityDomainInformation = 94 , ProcessCombineSecurityDomainsInformation = 95 , ProcessEnableLogging = 96 , ProcessLeapSecondInformation = 97 ,
  ProcessFiberShadowStackAllocation = 98 , ProcessFreeFiberShadowStackAllocation = 99 , ProcessAltSystemCallInformation = 100 , ProcessDynamicEHContinuationTargets = 101 ,
  ProcessDynamicEnforcedCetCompatibleRanges = 102 , ProcessCreateStateChange = 103 , ProcessApplyStateChange = 104 , ProcessEnableOptionalXStateFeatures = 105 ,
  ProcessAltPrefetchParam = 106 , ProcessAssignCpuPartitions = 107 , ProcessPriorityClassEx = 108 , ProcessMembershipInformation = 109 ,
  ProcessEffectiveIoPriority = 110 , ProcessEffectivePagePriority = 111 , MaxProcessInfoClass , ProcessBasicInformation ,
  ProcessQuotaLimits , ProcessIoCounters , ProcessVmCounters , ProcessTimes ,
  ProcessBasePriority , ProcessRaisePriority , ProcessDebugPort , ProcessExceptionPort ,
  ProcessAccessToken , ProcessLdtInformation , ProcessLdtSize , ProcessDefaultHardErrorMode ,
  ProcessIoPortHandlers , ProcessPooledUsageAndLimits , ProcessWorkingSetWatch , ProcessUserModeIOPL ,
  ProcessEnableAlignmentFaultFixup , ProcessPriorityClass , ProcessWx86Information , ProcessHandleCount ,
  ProcessAffinityMask , ProcessPriorityBoost , ProcessDeviceMap , ProcessSessionInformation ,
  ProcessForegroundInformation , ProcessWow64Information , ProcessImageFileName , ProcessLUIDDeviceMapsEnabled ,
  ProcessBreakOnTermination , ProcessDebugObjectHandle , ProcessDebugFlags , ProcessHandleTracing ,
  ProcessIoPriority , ProcessExecuteFlags , ProcessTlsInformation , ProcessCookie ,
  ProcessImageInformation , ProcessCycleTime , ProcessPagePriority , ProcessInstrumentationCallback ,
  ProcessThreadStackAllocation , ProcessWorkingSetWatchEx , ProcessImageFileNameWin32 , ProcessImageFileMapping ,
  ProcessAffinityUpdateMode , ProcessMemoryAllocationMode , ProcessGroupInformation , ProcessTokenVirtualizationEnabled ,
  ProcessConsoleHostProcess , ProcessWindowInformation , MaxProcessInfoClass
}
 
enum  _THREADINFOCLASS {
  ThreadBasicInformation , ThreadTimes , ThreadPriority , ThreadBasePriority ,
  ThreadAffinityMask , ThreadImpersonationToken , ThreadDescriptorTableEntry , ThreadEnableAlignmentFaultFixup ,
  ThreadEventPair_Reusable , ThreadQuerySetWin32StartAddress , ThreadZeroTlsCell , ThreadPerformanceCount ,
  ThreadAmILastThread , ThreadIdealProcessor , ThreadPriorityBoost , ThreadSetTlsArrayAddress ,
  ThreadIsIoPending , ThreadHideFromDebugger , ThreadBreakOnTermination , ThreadSwitchLegacyState ,
  ThreadIsTerminated , ThreadLastSystemCall , ThreadIoPriority , ThreadCycleTime ,
  ThreadPagePriority , ThreadActualBasePriority , ThreadTebInformation , ThreadCSwitchMon ,
  ThreadCSwitchPmu , ThreadWow64Context , ThreadGroupInformation , ThreadUmsInformation ,
  ThreadCounterProfiling , ThreadIdealProcessorEx , MaxThreadInfoClass , ThreadIsIoPending = 16 ,
  ThreadBasicInformation = 0 , ThreadTimes , ThreadPriority , ThreadBasePriority ,
  ThreadAffinityMask , ThreadImpersonationToken , ThreadDescriptorTableEntry , ThreadEnableAlignmentFaultFixup ,
  ThreadEventPair_Reusable , ThreadQuerySetWin32StartAddress , ThreadZeroTlsCell , ThreadPerformanceCount ,
  ThreadAmILastThread , ThreadIdealProcessor , ThreadPriorityBoost , ThreadSetTlsArrayAddress ,
  ThreadIsIoPending , ThreadHideFromDebugger , ThreadBreakOnTermination , ThreadSwitchLegacyState ,
  ThreadIsTerminated , ThreadLastSystemCall , ThreadIoPriority , ThreadCycleTime ,
  ThreadPagePriority , ThreadActualBasePriority , ThreadTebInformation , ThreadCSwitchMon ,
  ThreadCSwitchPmu , ThreadWow64Context , ThreadGroupInformation , ThreadUmsInformation ,
  ThreadCounterProfiling , ThreadIdealProcessorEx , ThreadCpuAccountingInformation , ThreadSuspendCount ,
  ThreadHeterogeneousCpuPolicy , ThreadContainerId , ThreadNameInformation , ThreadSelectedCpuSets ,
  ThreadSystemThreadInformation , ThreadActualGroupAffinity , ThreadDynamicCodePolicyInfo , ThreadExplicitCaseSensitivity ,
  ThreadWorkOnBehalfTicket , ThreadSubsystemInformation , ThreadDbgkWerReportActive , ThreadAttachContainer ,
  ThreadManageWritesToExecutableMemory , ThreadPowerThrottlingState , ThreadWorkloadClass , ThreadCreateStateChange ,
  ThreadApplyStateChange , ThreadStrongerBadHandleChecks , ThreadEffectiveIoPriority , ThreadEffectivePagePriority ,
  MaxThreadInfoClass , ThreadBasicInformation , ThreadTimes , ThreadPriority ,
  ThreadBasePriority , ThreadAffinityMask , ThreadImpersonationToken , ThreadDescriptorTableEntry ,
  ThreadEnableAlignmentFaultFixup , ThreadEventPair_Reusable , ThreadQuerySetWin32StartAddress , ThreadZeroTlsCell ,
  ThreadPerformanceCount , ThreadAmILastThread , ThreadIdealProcessor , ThreadPriorityBoost ,
  ThreadSetTlsArrayAddress , ThreadIsIoPending , ThreadHideFromDebugger , ThreadBreakOnTermination ,
  ThreadSwitchLegacyState , ThreadIsTerminated , ThreadLastSystemCall , ThreadIoPriority ,
  ThreadCycleTime , ThreadPagePriority , ThreadActualBasePriority , ThreadTebInformation ,
  ThreadCSwitchMon , ThreadCSwitchPmu , ThreadWow64Context , ThreadGroupInformation ,
  ThreadUmsInformation , ThreadCounterProfiling , ThreadIdealProcessorEx , ThreadCpuAccountingInformation ,
  ThreadSuspendCount , ThreadHeterogeneousCpuPolicy , ThreadContainerId , ThreadNameInformation ,
  ThreadSelectedCpuSets , ThreadSystemThreadInformation , ThreadActualGroupAffinity , ThreadDynamicCodePolicyInfo ,
  ThreadExplicitCaseSensitivity , ThreadWorkOnBehalfTicket , ThreadSubsystemInformation , ThreadDbgkWerReportActive ,
  ThreadAttachContainer , ThreadManageWritesToExecutableMemory , ThreadPowerThrottlingState , ThreadWorkloadClass ,
  ThreadCreateStateChange , ThreadApplyStateChange , ThreadStrongerBadHandleChecks , ThreadEffectiveIoPriority ,
  ThreadEffectivePagePriority , MaxThreadInfoClass
}
 
enum  _OBJECT_INFORMATION_CLASS {
  ObjectBasicInformation , ObjectNameInformation , ObjectTypeInformation , ObjectAllTypesInformation ,
  ObjectHandleInformation , ObjectBasicInformation = 0 , ObjectTypeInformation = 2 , ObjectBasicInformation ,
  ObjectNameInformation , ObjectTypeInformation , ObjectTypesInformation , ObjectHandleFlagInformation ,
  ObjectSessionInformation , ObjectSessionObjectInformation
}
 
enum  _SYSTEM_INFORMATION_CLASS {
  SystemBasicInformation , SystemProcessorInformation , SystemPerformanceInformation , SystemTimeOfDayInformation ,
  SystemPathInformation , SystemProcessInformation , SystemCallCountInformation , SystemDeviceInformation ,
  SystemProcessorPerformanceInformation , SystemFlagsInformation , SystemCallTimeInformation , SystemModuleInformation ,
  SystemLocksInformation , SystemStackTraceInformation , SystemPagedPoolInformation , SystemNonPagedPoolInformation ,
  SystemHandleInformation , SystemObjectInformation , SystemPageFileInformation , SystemVdmInstemulInformation ,
  SystemVdmBopInformation , SystemFileCacheInformation , SystemPoolTagInformation , SystemInterruptInformation ,
  SystemDpcBehaviorInformation , SystemFullMemoryInformation , SystemLoadGdiDriverInformation , SystemUnloadGdiDriverInformation ,
  SystemTimeAdjustmentInformation , SystemSummaryMemoryInformation , SystemNextEventIdInformation , SystemEventIdsInformation ,
  SystemCrashDumpInformation , SystemExceptionInformation , SystemCrashDumpStateInformation , SystemKernelDebuggerInformation ,
  SystemContextSwitchInformation , SystemRegistryQuotaInformation , SystemExtendServiceTableInformation , SystemPrioritySeperation ,
  SystemPlugPlayBusInformation , SystemDockInformation , SystemPowerInformation , SystemProcessorSpeedInformation ,
  SystemCurrentTimeZoneInformation , SystemLookasideInformation , SystemBasicInformation , SystemProcessorInformation ,
  SystemPerformanceInformation , SystemTimeOfDayInformation , SystemPathInformation , SystemProcessInformation ,
  SystemCallCountInformation , SystemDeviceInformation , SystemProcessorPerformanceInformation , SystemFlagsInformation ,
  SystemCallTimeInformation , SystemModuleInformation , SystemLocksInformation , SystemStackTraceInformation ,
  SystemPagedPoolInformation , SystemNonPagedPoolInformation , SystemHandleInformation , SystemObjectInformation ,
  SystemPageFileInformation , SystemVdmInstemulInformation , SystemVdmBopInformation , SystemFileCacheInformation ,
  SystemPoolTagInformation , SystemInterruptInformation , SystemDpcBehaviorInformation , SystemFullMemoryInformation ,
  SystemLoadGdiDriverInformation , SystemUnloadGdiDriverInformation , SystemTimeAdjustmentInformation , SystemSummaryMemoryInformation ,
  SystemNextEventIdInformation , SystemEventIdsInformation , SystemCrashDumpInformation , SystemExceptionInformation ,
  SystemCrashDumpStateInformation , SystemKernelDebuggerInformation , SystemContextSwitchInformation , SystemRegistryQuotaInformation ,
  SystemExtendServiceTableInformation , SystemPrioritySeperation , SystemPlugPlayBusInformation , SystemDockInformation ,
  SystemPowerInformation , SystemProcessorSpeedInformation , SystemCurrentTimeZoneInformation , SystemLookasideInformation ,
  SystemBasicInformation = 0 , SystemProcessorInformation = 1 , SystemPerformanceInformation = 2 , SystemTimeOfDayInformation = 3 ,
  SystemPathInformation = 4 , SystemProcessInformation = 5 , SystemCallCountInformation = 6 , SystemDeviceInformation = 7 ,
  SystemProcessorPerformanceInformation = 8 , SystemFlagsInformation = 9 , SystemCallTimeInformation = 10 , SystemModuleInformation = 11 ,
  SystemLocksInformation = 12 , SystemStackTraceInformation = 13 , SystemPagedPoolInformation = 14 , SystemNonPagedPoolInformation = 15 ,
  SystemHandleInformation = 16 , SystemObjectInformation = 17 , SystemPageFileInformation = 18 , SystemVdmInstemulInformation = 19 ,
  SystemVdmBopInformation = 20 , SystemFileCacheInformation = 21 , SystemPoolTagInformation = 22 , SystemInterruptInformation = 23 ,
  SystemDpcBehaviorInformation = 24 , SystemFullMemoryInformation = 25 , SystemLoadGdiDriverInformation = 26 , SystemUnloadGdiDriverInformation = 27 ,
  SystemTimeAdjustmentInformation = 28 , SystemSummaryMemoryInformation = 29 , SystemMirrorMemoryInformation = 30 , SystemPerformanceTraceInformation = 31 ,
  SystemObsolete0 = 32 , SystemExceptionInformation = 33 , SystemCrashDumpStateInformation = 34 , SystemKernelDebuggerInformation = 35 ,
  SystemContextSwitchInformation = 36 , SystemRegistryQuotaInformation = 37 , SystemExtendServiceTableInformation = 38 , SystemPrioritySeperation = 39 ,
  SystemVerifierAddDriverInformation = 40 , SystemVerifierRemoveDriverInformation = 41 , SystemProcessorIdleInformation = 42 , SystemLegacyDriverInformation = 43 ,
  SystemCurrentTimeZoneInformation = 44 , SystemLookasideInformation = 45 , SystemTimeSlipNotification = 46 , SystemSessionCreate = 47 ,
  SystemSessionDetach = 48 , SystemSessionInformation = 49 , SystemRangeStartInformation = 50 , SystemVerifierInformation = 51 ,
  SystemVerifierThunkExtend = 52 , SystemSessionProcessInformation = 53 , SystemLoadGdiDriverInSystemSpace = 54 , SystemNumaProcessorMap = 55 ,
  SystemPrefetcherInformation = 56 , SystemExtendedProcessInformation = 57 , SystemRecommendedSharedDataAlignment = 58 , SystemComPlusPackage = 59 ,
  SystemNumaAvailableMemory = 60 , SystemProcessorPowerInformation = 61 , SystemEmulationBasicInformation = 62 , SystemEmulationProcessorInformation = 63 ,
  SystemExtendedHandleInformation = 64 , SystemLostDelayedWriteInformation = 65 , SystemBigPoolInformation = 66 , SystemSessionPoolTagInformation = 67 ,
  SystemSessionMappedViewInformation = 68 , SystemHotpatchInformation = 69 , SystemObjectSecurityMode = 70 , SystemWatchdogTimerHandler = 71 ,
  SystemWatchdogTimerInformation = 72 , SystemLogicalProcessorInformation = 73 , SystemWow64SharedInformationObsolete = 74 , SystemRegisterFirmwareTableInformationHandler = 75 ,
  SystemFirmwareTableInformation = 76 , SystemModuleInformationEx = 77 , SystemVerifierTriageInformation = 78 , SystemSuperfetchInformation = 79 ,
  SystemMemoryListInformation = 80 , SystemFileCacheInformationEx = 81 , SystemThreadPriorityClientIdInformation = 82 , SystemProcessorIdleCycleTimeInformation = 83 ,
  SystemVerifierCancellationInformation = 84 , SystemProcessorPowerInformationEx = 85 , SystemRefTraceInformation = 86 , SystemSpecialPoolInformation = 87 ,
  SystemProcessIdInformation = 88 , SystemErrorPortInformation = 89 , SystemBootEnvironmentInformation = 90 , SystemHypervisorInformation = 91 ,
  SystemVerifierInformationEx = 92 , SystemTimeZoneInformation = 93 , SystemImageFileExecutionOptionsInformation = 94 , SystemCoverageInformation = 95 ,
  SystemPrefetchPatchInformation = 96 , SystemVerifierFaultsInformation = 97 , SystemSystemPartitionInformation = 98 , SystemSystemDiskInformation = 99 ,
  SystemProcessorPerformanceDistribution = 100 , SystemNumaProximityNodeInformation = 101 , SystemDynamicTimeZoneInformation = 102 , SystemCodeIntegrityInformation = 103 ,
  SystemProcessorMicrocodeUpdateInformation = 104 , SystemProcessorBrandString = 105 , SystemVirtualAddressInformation = 106 , SystemLogicalProcessorAndGroupInformation = 107 ,
  SystemProcessorCycleTimeInformation = 108 , SystemStoreInformation = 109 , SystemRegistryAppendString = 110 , SystemAitSamplingValue = 111 ,
  SystemVhdBootInformation = 112 , SystemCpuQuotaInformation = 113 , SystemNativeBasicInformation = 114 , SystemErrorPortTimeouts = 115 ,
  SystemLowPriorityIoInformation = 116 , SystemBootEntropyInformation = 117 , SystemVerifierCountersInformation = 118 , SystemPagedPoolInformationEx = 119 ,
  SystemSystemPtesInformationEx = 120 , SystemNodeDistanceInformation = 121 , SystemAcpiAuditInformation = 122 , SystemBasicPerformanceInformation = 123 ,
  SystemQueryPerformanceCounterInformation = 124 , SystemSessionBigPoolInformation = 125 , SystemBootGraphicsInformation = 126 , SystemScrubPhysicalMemoryInformation = 127 ,
  SystemBadPageInformation = 128 , SystemProcessorProfileControlArea = 129 , SystemCombinePhysicalMemoryInformation = 130 , SystemEntropyInterruptTimingInformation = 131 ,
  SystemConsoleInformation = 132 , SystemPlatformBinaryInformation = 133 , SystemThrottleNotificationInformation = 134 , SystemPolicyInformation = 134 ,
  SystemHypervisorProcessorCountInformation = 135 , SystemDeviceDataInformation = 136 , SystemDeviceDataEnumerationInformation = 137 , SystemMemoryTopologyInformation = 138 ,
  SystemMemoryChannelInformation = 139 , SystemBootLogoInformation = 140 , SystemProcessorPerformanceInformationEx = 141 , SystemSpare0 = 142 ,
  SystemCriticalProcessErrorLogInformation = 142 , SystemSecureBootPolicyInformation = 143 , SystemPageFileInformationEx = 144 , SystemSecureBootInformation = 145 ,
  SystemEntropyInterruptTimingRawInformation = 146 , SystemPortableWorkspaceEfiLauncherInformation = 147 , SystemFullProcessInformation = 148 , SystemKernelDebuggerInformationEx = 149 ,
  SystemBootMetadataInformation = 150 , SystemSoftRebootInformation = 151 , SystemElamCertificateInformation = 152 , SystemOfflineDumpConfigInformation = 153 ,
  SystemProcessorFeaturesInformation = 154 , SystemRegistryReconciliationInformation = 155 , SystemEdidInformation = 156 , SystemManufacturingInformation = 157 ,
  SystemEnergyEstimationConfigInformation = 158 , SystemHypervisorDetailInformation = 159 , SystemProcessorCycleStatsInformation = 160 , SystemVmGenerationCountInformation = 161 ,
  SystemTrustedPlatformModuleInformation = 162 , SystemKernelDebuggerFlags = 163 , SystemCodeIntegrityPolicyInformation = 164 , SystemIsolatedUserModeInformation = 165 ,
  SystemHardwareSecurityTestInterfaceResultsInformation = 166 , SystemSingleModuleInformation = 167 , SystemAllowedCpuSetsInformation = 168 , SystemVsmProtectionInformation = 169 ,
  SystemInterruptCpuSetsInformation = 170 , SystemSecureBootPolicyFullInformation = 171 , SystemCodeIntegrityPolicyFullInformation = 172 , SystemAffinitizedInterruptProcessorInformation = 173 ,
  SystemRootSiloInformation = 174 , SystemCpuSetInformation = 175 , SystemCpuSetTagInformation = 176 , SystemWin32WerStartCallout = 177 ,
  SystemSecureKernelProfileInformation = 178 , SystemCodeIntegrityPlatformManifestInformation = 179 , SystemInterruptSteeringInformation = 180 , SystemSupportedProcessorArchitectures = 181 ,
  SystemMemoryUsageInformation = 182 , SystemCodeIntegrityCertificateInformation = 183 , SystemPhysicalMemoryInformation = 184 , SystemControlFlowTransition = 185 ,
  SystemKernelDebuggingAllowed = 186 , SystemActivityModerationExeState = 187 , SystemActivityModerationUserSettings = 188 , SystemCodeIntegrityPoliciesFullInformation = 189 ,
  SystemCodeIntegrityUnlockInformation = 190 , SystemIntegrityQuotaInformation = 191 , SystemFlushInformation = 192 , SystemProcessorIdleMaskInformation = 193 ,
  SystemSecureDumpEncryptionInformation = 194 , SystemWriteConstraintInformation = 195 , SystemKernelVaShadowInformation = 196 , SystemHypervisorSharedPageInformation = 197 ,
  SystemFirmwareBootPerformanceInformation = 198 , SystemCodeIntegrityVerificationInformation = 199 , SystemFirmwarePartitionInformation = 200 , SystemSpeculationControlInformation = 201 ,
  SystemDmaGuardPolicyInformation = 202 , SystemEnclaveLaunchControlInformation = 203 , SystemWorkloadAllowedCpuSetsInformation = 204 , SystemCodeIntegrityUnlockModeInformation = 205 ,
  SystemLeapSecondInformation = 206 , SystemFlags2Information = 207 , SystemSecurityModelInformation = 208 , SystemCodeIntegritySyntheticCacheInformation = 209 ,
  SystemFeatureConfigurationInformation = 210 , SystemFeatureConfigurationSectionInformation = 211 , SystemFeatureUsageSubscriptionInformation = 212 , SystemSecureSpeculationControlInformation = 213 ,
  SystemSpacesBootInformation = 214 , SystemFwRamdiskInformation = 215 , SystemWheaIpmiHardwareInformation = 216 , SystemDifSetRuleClassInformation = 217 ,
  SystemDifClearRuleClassInformation = 218 , SystemDifApplyPluginVerificationOnDriver = 219 , SystemDifRemovePluginVerificationOnDriver = 220 , SystemShadowStackInformation = 221 ,
  SystemBuildVersionInformation = 222 , SystemPoolLimitInformation = 223 , SystemCodeIntegrityAddDynamicStore = 224 , SystemCodeIntegrityClearDynamicStores = 225 ,
  SystemDifPoolTrackingInformation = 226 , SystemPoolZeroingInformation = 227 , SystemDpcWatchdogInformation = 228 , SystemDpcWatchdogInformation2 = 229 ,
  SystemSupportedProcessorArchitectures2 = 230 , SystemSingleProcessorRelationshipInformation = 231 , SystemXfgCheckFailureInformation = 232 , SystemIommuStateInformation = 233 ,
  SystemHypervisorMinrootInformation = 234 , SystemHypervisorBootPagesInformation = 235 , SystemPointerAuthInformation = 236 , SystemSecureKernelDebuggerInformation = 237 ,
  SystemOriginalImageFeatureInformation = 238 , SystemMemoryNumaInformation = 239 , SystemMemoryNumaPerformanceInformation = 240 , SystemCodeIntegritySignedPoliciesFullInformation = 241 ,
  SystemSecureSecretsInformation = 242 , SystemTrustedAppsRuntimeInformation = 243 , SystemBadPageInformationEx = 244 , SystemResourceDeadlockTimeout = 245 ,
  SystemBreakOnContextUnwindFailureInformation = 246 , SystemOslRamdiskInformation = 247 , MaxSystemInfoClass , SystemBasicInformation = 0 ,
  SystemPerformanceInformation = 2 , SystemTimeOfDayInformation = 3 , SystemProcessInformation = 5 , SystemProcessorPerformanceInformation = 8 ,
  SystemInterruptInformation = 23 , SystemExceptionInformation = 33 , SystemRegistryQuotaInformation = 37 , SystemLookasideInformation = 45 ,
  SystemPolicyInformation = 134 , SystemBasicInformation = 0 , SystemCpuInformation = 1 , SystemPerformanceInformation = 2 ,
  SystemTimeOfDayInformation = 3 , SystemPathInformation = 4 , SystemProcessInformation = 5 , SystemCallCountInformation = 6 ,
  SystemDeviceInformation = 7 , SystemProcessorPerformanceInformation = 8 , SystemFlagsInformation = 9 , SystemCallTimeInformation = 10 ,
  SystemModuleInformation = 11 , SystemLocksInformation = 12 , SystemStackTraceInformation = 13 , SystemPagedPoolInformation = 14 ,
  SystemNonPagedPoolInformation = 15 , SystemHandleInformation = 16 , SystemObjectInformation = 17 , SystemPageFileInformation = 18 ,
  SystemVdmInstemulInformation = 19 , SystemVdmBopInformation = 20 , SystemFileCacheInformation = 21 , SystemPoolTagInformation = 22 ,
  SystemInterruptInformation = 23 , SystemDpcBehaviorInformation = 24 , SystemFullMemoryInformation = 25 , SystemNotImplemented6 = 25 ,
  SystemLoadGdiDriverInformation = 26 , SystemUnloadGdiDriverInformation = 27 , SystemTimeAdjustmentInformation = 28 , SystemTimeAdjustment = 28 ,
  SystemSummaryMemoryInformation = 29 , SystemMirrorMemoryInformation = 30 , SystemPerformanceTraceInformation = 31 , SystemObsolete0 = 32 ,
  SystemExceptionInformation = 33 , SystemCrashDumpStateInformation = 34 , SystemKernelDebuggerInformation = 35 , SystemContextSwitchInformation = 36 ,
  SystemRegistryQuotaInformation = 37 , SystemExtendServiceTableInformation = 38 , SystemPrioritySeparation = 39 , SystemVerifierAddDriverInformation = 40 ,
  SystemVerifierRemoveDriverInformation = 41 , SystemProcessorIdleInformation = 42 , SystemLegacyDriverInformation = 43 , SystemCurrentTimeZoneInformation = 44 ,
  SystemLookasideInformation = 45 , SystemTimeSlipNotification = 46 , SystemSessionCreate = 47 , SystemSessionDetach = 48 ,
  SystemSessionInformation = 49 , SystemRangeStartInformation = 50 , SystemVerifierInformation = 51 , SystemVerifierThunkExtend = 52 ,
  SystemSessionProcessesInformation = 53 , SystemLoadGdiDriverInSystemSpace = 54 , SystemNumaProcessorMap = 55 , SystemPrefetcherInformation = 56 ,
  SystemExtendedProcessInformation = 57 , SystemRecommendedSharedDataAlignment = 58 , SystemComPlusPackage = 59 , SystemNumaAvailableMemory = 60 ,
  SystemProcessorPowerInformation = 61 , SystemEmulationBasicInformation = 62 , SystemEmulationProcessorInformation = 63 , SystemExtendedHandleInformation = 64 ,
  SystemLostDelayedWriteInformation = 65 , SystemBigPoolInformation = 66 , SystemSessionPoolTagInformation = 67 , SystemSessionMappedViewInformation = 68 ,
  SystemHotpatchInformation = 69 , SystemObjectSecurityMode = 70 , SystemWatchdogTimerHandler = 71 , SystemWatchdogTimerInformation = 72 ,
  SystemLogicalProcessorInformation = 73 , SystemWow64SharedInformationObsolete = 74 , SystemRegisterFirmwareTableInformationHandler = 75 , SystemFirmwareTableInformation = 76 ,
  SystemModuleInformationEx = 77 , SystemVerifierTriageInformation = 78 , SystemSuperfetchInformation = 79 , SystemMemoryListInformation = 80 ,
  SystemFileCacheInformationEx = 81 , SystemThreadPriorityClientIdInformation = 82 , SystemProcessorIdleCycleTimeInformation = 83 , SystemVerifierCancellationInformation = 84 ,
  SystemProcessorPowerInformationEx = 85 , SystemRefTraceInformation = 86 , SystemSpecialPoolInformation = 87 , SystemProcessIdInformation = 88 ,
  SystemErrorPortInformation = 89 , SystemBootEnvironmentInformation = 90 , SystemHypervisorInformation = 91 , SystemVerifierInformationEx = 92 ,
  SystemTimeZoneInformation = 93 , SystemImageFileExecutionOptionsInformation = 94 , SystemCoverageInformation = 95 , SystemPrefetchPatchInformation = 96 ,
  SystemVerifierFaultsInformation = 97 , SystemSystemPartitionInformation = 98 , SystemSystemDiskInformation = 99 , SystemProcessorPerformanceDistribution = 100 ,
  SystemNumaProximityNodeInformation = 101 , SystemDynamicTimeZoneInformation = 102 , SystemCodeIntegrityInformation = 103 , SystemProcessorMicrocodeUpdateInformation = 104 ,
  SystemProcessorBrandString = 105 , SystemVirtualAddressInformation = 106 , SystemLogicalProcessorInformationEx = 107 , SystemProcessorCycleTimeInformation = 108 ,
  SystemStoreInformation = 109 , SystemRegistryAppendString = 110 , SystemAitSamplingValue = 111 , SystemVhdBootInformation = 112 ,
  SystemCpuQuotaInformation = 113 , SystemNativeBasicInformation = 114 , SystemErrorPortTimeouts = 115 , SystemLowPriorityIoInformation = 116 ,
  SystemTpmBootEntropyInformation = 117 , SystemVerifierCountersInformation = 118 , SystemPagedPoolInformationEx = 119 , SystemSystemPtesInformationEx = 120 ,
  SystemNodeDistanceInformation = 121 , SystemAcpiAuditInformation = 122 , SystemBasicPerformanceInformation = 123 , SystemQueryPerformanceCounterInformation = 124 ,
  SystemSessionBigPoolInformation = 125 , SystemBootGraphicsInformation = 126 , SystemScrubPhysicalMemoryInformation = 127 , SystemBadPageInformation = 128 ,
  SystemProcessorProfileControlArea = 129 , SystemCombinePhysicalMemoryInformation = 130 , SystemEntropyInterruptTimingInformation = 131 , SystemConsoleInformation = 132 ,
  SystemPlatformBinaryInformation = 133 , SystemPolicyInformation = 134 , SystemHypervisorProcessorCountInformation = 135 , SystemDeviceDataInformation = 136 ,
  SystemDeviceDataEnumerationInformation = 137 , SystemMemoryTopologyInformation = 138 , SystemMemoryChannelInformation = 139 , SystemBootLogoInformation = 140 ,
  SystemProcessorPerformanceInformationEx = 141 , SystemCriticalProcessErrorLogInformation = 142 , SystemSecureBootPolicyInformation = 143 , SystemPageFileInformationEx = 144 ,
  SystemSecureBootInformation = 145 , SystemEntropyInterruptTimingRawInformation = 146 , SystemPortableWorkspaceEfiLauncherInformation = 147 , SystemFullProcessInformation = 148 ,
  SystemKernelDebuggerInformationEx = 149 , SystemBootMetadataInformation = 150 , SystemSoftRebootInformation = 151 , SystemElamCertificateInformation = 152 ,
  SystemOfflineDumpConfigInformation = 153 , SystemProcessorFeaturesInformation = 154 , SystemRegistryReconciliationInformation = 155 , SystemEdidInformation = 156 ,
  SystemManufacturingInformation = 157 , SystemEnergyEstimationConfigInformation = 158 , SystemHypervisorDetailInformation = 159 , SystemProcessorCycleStatsInformation = 160 ,
  SystemVmGenerationCountInformation = 161 , SystemTrustedPlatformModuleInformation = 162 , SystemKernelDebuggerFlags = 163 , SystemCodeIntegrityPolicyInformation = 164 ,
  SystemIsolatedUserModeInformation = 165 , SystemHardwareSecurityTestInterfaceResultsInformation = 166 , SystemSingleModuleInformation = 167 , SystemAllowedCpuSetsInformation = 168 ,
  SystemVsmProtectionInformation = 169 , SystemInterruptCpuSetsInformation = 170 , SystemSecureBootPolicyFullInformation = 171 , SystemCodeIntegrityPolicyFullInformation = 172 ,
  SystemAffinitizedInterruptProcessorInformation = 173 , SystemRootSiloInformation = 174 , SystemCpuSetInformation = 175 , SystemCpuSetTagInformation = 176 ,
  SystemWin32WerStartCallout = 177 , SystemSecureKernelProfileInformation = 178 , SystemCodeIntegrityPlatformManifestInformation = 179 , SystemInterruptSteeringInformation = 180 ,
  SystemSupportedProcessorArchitectures = 181 , SystemMemoryUsageInformation = 182 , SystemCodeIntegrityCertificateInformation = 183 , SystemPhysicalMemoryInformation = 184 ,
  SystemControlFlowTransition = 185 , SystemKernelDebuggingAllowed = 186 , SystemActivityModerationExeState = 187 , SystemActivityModerationUserSettings = 188 ,
  SystemCodeIntegrityPoliciesFullInformation = 189 , SystemCodeIntegrityUnlockInformation = 190 , SystemIntegrityQuotaInformation = 191 , SystemFlushInformation = 192 ,
  SystemProcessorIdleMaskInformation = 193 , SystemSecureDumpEncryptionInformation = 194 , SystemWriteConstraintInformation = 195 , SystemKernelVaShadowInformation = 196 ,
  SystemHypervisorSharedPageInformation = 197 , SystemFirmwareBootPerformanceInformation = 198 , SystemCodeIntegrityVerificationInformation = 199 , SystemFirmwarePartitionInformation = 200 ,
  SystemSpeculationControlInformation = 201 , SystemDmaGuardPolicyInformation = 202 , SystemEnclaveLaunchControlInformation = 203 , SystemWorkloadAllowedCpuSetsInformation = 204 ,
  SystemCodeIntegrityUnlockModeInformation = 205 , SystemLeapSecondInformation = 206 , SystemFlags2Information = 207 , SystemSecurityModelInformation = 208 ,
  SystemCodeIntegritySyntheticCacheInformation = 209 , SystemFeatureConfigurationInformation = 210 , SystemFeatureConfigurationSectionInformation = 211 , SystemFeatureUsageSubscriptionInformation = 212 ,
  SystemSecureSpeculationControlInformation = 213 , SystemSpacesBootInformation = 214 , SystemFwRamdiskInformation = 215 , SystemWheaIpmiHardwareInformation = 216 ,
  SystemDifSetRuleClassInformation = 217 , SystemDifClearRuleClassInformation = 218 , SystemDifApplyPluginVerificationOnDriver = 219 , SystemDifRemovePluginVerificationOnDriver = 220 ,
  SystemShadowStackInformation = 221 , SystemBuildVersionInformation = 222 , SystemPoolLimitInformation = 223 , SystemCodeIntegrityAddDynamicStore = 224 ,
  SystemCodeIntegrityClearDynamicStores = 225 , SystemDifPoolTrackingInformation = 226 , SystemPoolZeroingInformation = 227 , SystemDpcWatchdogInformation = 228 ,
  SystemDpcWatchdogInformation2 = 229 , SystemSupportedProcessorArchitectures2 = 230 , SystemSingleProcessorRelationshipInformation = 231 , SystemXfgCheckFailureInformation = 232 ,
  SystemIommuStateInformation = 233 , SystemHypervisorMinrootInformation = 234 , SystemHypervisorBootPagesInformation = 235 , SystemPointerAuthInformation = 236 ,
  SystemSecureKernelDebuggerInformation = 237 , SystemOriginalImageFeatureInformation = 238
}
 
enum  _WINSTATIONINFOCLASS { WinStationInformation = 8 , WinStationInformation = 8 }
 

Functions

typedef _Return_type_success_ (return >=0) LONG NTSTATUS
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtCreateFile (_Out_ PHANDLE FileHandle, _In_ ACCESS_MASK DesiredAccess, _In_ POBJECT_ATTRIBUTES ObjectAttributes, _Out_ PIO_STATUS_BLOCK IoStatusBlock, _In_opt_ PLARGE_INTEGER AllocationSize, _In_ ULONG FileAttributes, _In_ ULONG ShareAccess, _In_ ULONG CreateDisposition, _In_ ULONG CreateOptions, _In_reads_bytes_opt_(EaLength) PVOID EaBuffer, _In_ ULONG EaLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtOpenFile (_Out_ PHANDLE FileHandle, _In_ ACCESS_MASK DesiredAccess, _In_ POBJECT_ATTRIBUTES ObjectAttributes, _Out_ PIO_STATUS_BLOCK IoStatusBlock, _In_ ULONG ShareAccess, _In_ ULONG OpenOptions)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtClose (_In_ HANDLE Handle)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtDeviceIoControlFile (_In_ HANDLE FileHandle, _In_opt_ HANDLE Event, _In_opt_ PIO_APC_ROUTINE ApcRoutine, _In_opt_ PVOID ApcContext, _Out_ PIO_STATUS_BLOCK IoStatusBlock, _In_ ULONG IoControlCode, _In_reads_bytes_opt_(InputBufferLength) PVOID InputBuffer, _In_ ULONG InputBufferLength, _Out_writes_bytes_opt_(OutputBufferLength) PVOID OutputBuffer, _In_ ULONG OutputBufferLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtWaitForSingleObject (_In_ HANDLE Object, _In_ BOOLEAN Alertable, _In_opt_ PLARGE_INTEGER Timeout)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtRenameKey (_In_ HANDLE KeyHandle, _In_ PUNICODE_STRING NewName)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtNotifyChangeMultipleKeys (_In_ HANDLE MasterKeyHandle, _In_opt_ ULONG Count, _In_reads_opt_(Count) OBJECT_ATTRIBUTES SubordinateObjects[], _In_opt_ HANDLE Event, _In_opt_ PIO_APC_ROUTINE ApcRoutine, _In_opt_ PVOID ApcContext, _Out_ PIO_STATUS_BLOCK IoStatusBlock, _In_ ULONG CompletionFilter, _In_ BOOLEAN WatchTree, _Out_writes_bytes_opt_(BufferSize) PVOID Buffer, _In_ ULONG BufferSize, _In_ BOOLEAN Asynchronous)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryMultipleValueKey (_In_ HANDLE KeyHandle, _Inout_updates_(EntryCount) PKEY_VALUE_ENTRY ValueEntries, _In_ ULONG EntryCount, _Out_writes_bytes_(*BufferLength) PVOID ValueBuffer, _Inout_ PULONG BufferLength, _Out_opt_ PULONG RequiredBufferLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtSetInformationKey (_In_ HANDLE KeyHandle, _In_ _Strict_type_match_ KEY_SET_INFORMATION_CLASS KeySetInformationClass, _In_reads_bytes_(KeySetInformationLength) PVOID KeySetInformation, _In_ ULONG KeySetInformationLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryInformationProcess (_In_ HANDLE ProcessHandle, _In_ PROCESSINFOCLASS ProcessInformationClass, _Out_ PVOID ProcessInformation, _In_ ULONG ProcessInformationLength, _Out_opt_ PULONG ReturnLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryInformationThread (_In_ HANDLE ThreadHandle, _In_ THREADINFOCLASS ThreadInformationClass, _Out_ PVOID ThreadInformation, _In_ ULONG ThreadInformationLength, _Out_opt_ PULONG ReturnLength)
 
 _IRQL_requires_max_ (PASSIVE_LEVEL) __kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryObject(_In_opt_ HANDLE Handle
 Queries information details about a security descriptor.
 
_In_ OBJECT_INFORMATION_CLASS _Out_writes_bytes_opt_ (ObjectInformationLength) PVOID ObjectInformation
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQuerySystemInformation (_In_ SYSTEM_INFORMATION_CLASS SystemInformationClass, _Out_ PVOID SystemInformation, _In_ ULONG InformationLength, _Out_opt_ PULONG ResultLength)
 
__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQuerySystemTime (_Out_ PLARGE_INTEGER SystemTime)
 
VOID NTAPI RtlInitString (PSTRING DestinationString, PCSZ SourceString)
 
VOID NTAPI RtlInitAnsiString (PANSI_STRING DestinationString, PCSZ SourceString)
 
VOID NTAPI RtlInitUnicodeString (PUNICODE_STRING DestinationString, PCWSTR SourceString)
 
VOID NTAPI RtlFreeAnsiString (PANSI_STRING AnsiString)
 
VOID NTAPI RtlFreeOemString (POEM_STRING OemString)
 
VOID NTAPI RtlFreeUnicodeString (PUNICODE_STRING UnicodeString)
 
NTSTATUS NTAPI RtlAnsiStringToUnicodeString (PUNICODE_STRING DestinationString, PCANSI_STRING SourceString, BOOLEAN AllocateDestinationString)
 
NTSTATUS NTAPI RtlUnicodeStringToAnsiString (PANSI_STRING DestinationString, PCUNICODE_STRING SourceString, BOOLEAN AllocateDestinationString)
 
NTSTATUS NTAPI RtlUnicodeStringToOemString (POEM_STRING DestinationString, PCUNICODE_STRING SourceString, BOOLEAN AllocateDestinationString)
 
NTSTATUS NTAPI RtlUnicodeToMultiByteSize (_Out_ PULONG BytesInMultiByteString, _In_reads_bytes_(BytesInUnicodeString) PWCH UnicodeString, _In_ ULONG BytesInUnicodeString)
 
NTSTATUS NTAPI RtlCharToInteger (PCSZ String, ULONG Base, PULONG Value)
 
BOOLEAN NTAPI RtlIsNameLegalDOS8Dot3 (_In_ PUNICODE_STRING Name, _Inout_opt_ POEM_STRING OemName, _Inout_opt_ PBOOLEAN NameContainsSpaces)
 
NTSTATUS NTAPI RtlLocalTimeToSystemTime (IN PLARGE_INTEGER LocalTime, _Out_ PLARGE_INTEGER SystemTime)
 
BOOLEAN NTAPI RtlTimeToSecondsSince1970 (PLARGE_INTEGER Time, PULONG ElapsedSeconds)
 
 _When_ (Status< 0, _Out_range_(>, 0)) _When_(Status >=0
 
 _Out_range_ (==, 0)) ULONG NTAPI RtlNtStatusToDosError(_In_ NTSTATUS Status)
 
NTSTATUS NTAPI RtlConvertSidToUnicodeString (PUNICODE_STRING UnicodeString, PSID Sid, BOOLEAN AllocateDestinationString)
 
ULONG NTAPI RtlUniform (PULONG Seed)
 

Variables

_In_ OBJECT_INFORMATION_CLASS ObjectInformationClass
 
_In_ OBJECT_INFORMATION_CLASS _In_ ULONG ObjectInformationLength
 
_In_ OBJECT_INFORMATION_CLASS _In_ ULONG _Out_opt_ PULONG ReturnLength
 

Macro Definition Documentation

◆ _WINTERNL_

#define _WINTERNL_

Definition at line 35 of file winternl.h.

◆ FILE_COMPLETE_IF_OPLOCKED

#define FILE_COMPLETE_IF_OPLOCKED   0x00000100

Definition at line 177 of file winternl.h.

◆ FILE_CREATE

#define FILE_CREATE   0x00000002

Definition at line 209 of file winternl.h.

◆ FILE_CREATE_TREE_CONNECTION

#define FILE_CREATE_TREE_CONNECTION   0x00000080

Definition at line 176 of file winternl.h.

◆ FILE_CREATED

#define FILE_CREATED   0x00000002

Definition at line 196 of file winternl.h.

◆ FILE_DELETE_ON_CLOSE

#define FILE_DELETE_ON_CLOSE   0x00001000

Definition at line 181 of file winternl.h.

◆ FILE_DIRECTORY_FILE

#define FILE_DIRECTORY_FILE   0x00000001

Definition at line 169 of file winternl.h.

◆ FILE_DOES_NOT_EXIST

#define FILE_DOES_NOT_EXIST   0x00000005

Definition at line 199 of file winternl.h.

◆ FILE_EXISTS

#define FILE_EXISTS   0x00000004

Definition at line 198 of file winternl.h.

◆ FILE_MAXIMUM_DISPOSITION

#define FILE_MAXIMUM_DISPOSITION   0x00000005

Definition at line 213 of file winternl.h.

◆ FILE_NO_COMPRESSION

#define FILE_NO_COMPRESSION   0x00008000

Definition at line 184 of file winternl.h.

◆ FILE_NO_EA_KNOWLEDGE

#define FILE_NO_EA_KNOWLEDGE   0x00000200

Definition at line 178 of file winternl.h.

◆ FILE_NO_INTERMEDIATE_BUFFERING

#define FILE_NO_INTERMEDIATE_BUFFERING   0x00000008

Definition at line 172 of file winternl.h.

◆ FILE_NON_DIRECTORY_FILE

#define FILE_NON_DIRECTORY_FILE   0x00000040

Definition at line 175 of file winternl.h.

◆ FILE_OPEN

#define FILE_OPEN   0x00000001

Definition at line 208 of file winternl.h.

◆ FILE_OPEN_BY_FILE_ID

#define FILE_OPEN_BY_FILE_ID   0x00002000

Definition at line 182 of file winternl.h.

◆ FILE_OPEN_FOR_BACKUP_INTENT

#define FILE_OPEN_FOR_BACKUP_INTENT   0x00004000

Definition at line 183 of file winternl.h.

◆ FILE_OPEN_FOR_FREE_SPACE_QUERY

#define FILE_OPEN_FOR_FREE_SPACE_QUERY   0x00800000

Definition at line 191 of file winternl.h.

◆ FILE_OPEN_IF

#define FILE_OPEN_IF   0x00000003

Definition at line 210 of file winternl.h.

◆ FILE_OPEN_NO_RECALL

#define FILE_OPEN_NO_RECALL   0x00400000

Definition at line 190 of file winternl.h.

◆ FILE_OPEN_REMOTE_INSTANCE

#define FILE_OPEN_REMOTE_INSTANCE   0x00000400

Definition at line 179 of file winternl.h.

◆ FILE_OPEN_REPARSE_POINT

#define FILE_OPEN_REPARSE_POINT   0x00200000

Definition at line 189 of file winternl.h.

◆ FILE_OPEN_REQUIRING_OPLOCK

#define FILE_OPEN_REQUIRING_OPLOCK   0x00010000

Definition at line 186 of file winternl.h.

◆ FILE_OPENED

#define FILE_OPENED   0x00000001

Definition at line 195 of file winternl.h.

◆ FILE_OVERWRITE

#define FILE_OVERWRITE   0x00000004

Definition at line 211 of file winternl.h.

◆ FILE_OVERWRITE_IF

#define FILE_OVERWRITE_IF   0x00000005

Definition at line 212 of file winternl.h.

◆ FILE_OVERWRITTEN

#define FILE_OVERWRITTEN   0x00000003

Definition at line 197 of file winternl.h.

◆ FILE_RANDOM_ACCESS

#define FILE_RANDOM_ACCESS   0x00000800

Definition at line 180 of file winternl.h.

◆ FILE_RESERVE_OPFILTER

#define FILE_RESERVE_OPFILTER   0x00100000

Definition at line 188 of file winternl.h.

◆ FILE_SEQUENTIAL_ONLY

#define FILE_SEQUENTIAL_ONLY   0x00000004

Definition at line 171 of file winternl.h.

◆ FILE_SUPERSEDE

#define FILE_SUPERSEDE   0x00000000

Definition at line 207 of file winternl.h.

◆ FILE_SUPERSEDED

#define FILE_SUPERSEDED   0x00000000

Definition at line 194 of file winternl.h.

◆ FILE_SYNCHRONOUS_IO_ALERT

#define FILE_SYNCHRONOUS_IO_ALERT   0x00000010

Definition at line 173 of file winternl.h.

◆ FILE_SYNCHRONOUS_IO_NONALERT

#define FILE_SYNCHRONOUS_IO_NONALERT   0x00000020

Definition at line 174 of file winternl.h.

◆ FILE_VALID_MAILSLOT_OPTION_FLAGS

#define FILE_VALID_MAILSLOT_OPTION_FLAGS   0x00000032

Definition at line 203 of file winternl.h.

◆ FILE_VALID_OPTION_FLAGS

#define FILE_VALID_OPTION_FLAGS   0x00ffffff

Definition at line 201 of file winternl.h.

◆ FILE_VALID_PIPE_OPTION_FLAGS

#define FILE_VALID_PIPE_OPTION_FLAGS   0x00000032

Definition at line 202 of file winternl.h.

◆ FILE_VALID_SET_FLAGS

#define FILE_VALID_SET_FLAGS   0x00000036

Definition at line 204 of file winternl.h.

◆ FILE_WRITE_THROUGH

#define FILE_WRITE_THROUGH   0x00000002

Definition at line 170 of file winternl.h.

◆ InitializeObjectAttributes

#define InitializeObjectAttributes (   p,
  n,
  a,
  r,
  s 
)
Value:
{ \
(p)->Length = sizeof(OBJECT_ATTRIBUTES); \
(p)->RootDirectory = r; \
(p)->Attributes = a; \
(p)->ObjectName = n; \
(p)->SecurityQualityOfService = NULL; \
}
WCHAR RootDirectory[MAX_PATH]
Definition: format.c:74
#define NULL
Definition: types.h:112
GLdouble s
Definition: gl.h:2039
GLdouble GLdouble GLdouble r
Definition: gl.h:2055
GLdouble n
Definition: glext.h:7729
GLfloat GLfloat p
Definition: glext.h:8902
GLboolean GLboolean GLboolean GLboolean a
Definition: glext.h:6204
_In_ ULONG _In_ ULONG _In_ ULONG Length
Definition: ntddpcm.h:102
_Must_inspect_result_ _In_ WDFDMAENABLER _In_ _In_opt_ PWDF_OBJECT_ATTRIBUTES Attributes
_In_ USHORT _In_ ULONG _In_ PSOCKADDR _In_ PSOCKADDR _Reserved_ ULONG _In_opt_ PVOID _In_opt_ const WSK_CLIENT_CONNECTION_DISPATCH _In_opt_ PEPROCESS _In_opt_ PETHREAD _In_opt_ PSECURITY_DESCRIPTOR SecurityDescriptor
Definition: wsk.h:191
_In_ PVOID _Out_opt_ PULONG_PTR _Outptr_opt_ PCUNICODE_STRING * ObjectName
Definition: cmfuncs.h:64

Definition at line 236 of file winternl.h.

◆ INTERNAL_TS_ACTIVE_CONSOLE_ID

#define INTERNAL_TS_ACTIVE_CONSOLE_ID   (*((volatile ULONG*)0x7ffe02d8))

Definition at line 164 of file winternl.h.

◆ LOGONID_CURRENT

#define LOGONID_CURRENT   ((ULONG)-1)

Definition at line 165 of file winternl.h.

◆ NT_ERROR

#define NT_ERROR (   Status)    ((((ULONG)(Status)) >> 30) == 3)

Definition at line 59 of file winternl.h.

◆ NT_INFORMATION

#define NT_INFORMATION (   Status)    ((((ULONG)(Status)) >> 30) == 1)

Definition at line 51 of file winternl.h.

◆ NT_SUCCESS

#define NT_SUCCESS (   Status)    (((NTSTATUS)(Status)) >= 0)

Definition at line 47 of file winternl.h.

◆ NT_WARNING

#define NT_WARNING (   Status)    ((((ULONG)(Status)) >> 30) == 2)

Definition at line 55 of file winternl.h.

◆ OBJ_CASE_INSENSITIVE

#define OBJ_CASE_INSENSITIVE   0x00000040L

Definition at line 228 of file winternl.h.

◆ OBJ_EXCLUSIVE

#define OBJ_EXCLUSIVE   0x00000020L

Definition at line 227 of file winternl.h.

◆ OBJ_FORCE_ACCESS_CHECK

#define OBJ_FORCE_ACCESS_CHECK   0x00000400L

Definition at line 232 of file winternl.h.

◆ OBJ_INHERIT

#define OBJ_INHERIT   0x00000002L

Definition at line 225 of file winternl.h.

◆ OBJ_KERNEL_HANDLE

#define OBJ_KERNEL_HANDLE   0x00000200L

Definition at line 231 of file winternl.h.

◆ OBJ_OPENIF

#define OBJ_OPENIF   0x00000080L

Definition at line 229 of file winternl.h.

◆ OBJ_OPENLINK

#define OBJ_OPENLINK   0x00000100L

Definition at line 230 of file winternl.h.

◆ OBJ_PERMANENT

#define OBJ_PERMANENT   0x00000010L

Definition at line 226 of file winternl.h.

◆ OBJ_VALID_ATTRIBUTES

#define OBJ_VALID_ATTRIBUTES   0x000007F2L

Definition at line 233 of file winternl.h.

◆ PIO_APC_ROUTINE_DEFINED

#define PIO_APC_ROUTINE_DEFINED

Definition at line 299 of file winternl.h.

◆ RtlFillMemory

#define RtlFillMemory (   Dest,
  Length,
  Fill 
)    memset((Dest),(Fill),(Length))

Definition at line 601 of file winternl.h.

◆ RtlMoveMemory

#define RtlMoveMemory (   Dest,
  Source,
  Length 
)    memmove((Dest),(Source),(Length))

Definition at line 600 of file winternl.h.

◆ RtlZeroMemory

#define RtlZeroMemory (   Dest,
  Length 
)    RtlFillMemory((Dest),(Length),0)

Definition at line 602 of file winternl.h.

◆ SERVERNAME_CURRENT

#define SERVERNAME_CURRENT   ((HANDLE)NULL)

Definition at line 166 of file winternl.h.

Typedef Documentation

◆ ANSI_STRING

Definition at line 70 of file winternl.h.

◆ FILE_INFORMATION_CLASS

◆ IO_STATUS_BLOCK

◆ KEY_SET_INFORMATION_CLASS

◆ KEY_VALUE_ENTRY

◆ LDR_DATA_TABLE_ENTRY

◆ OBJECT_ATTRIBUTES

◆ OBJECT_INFORMATION_CLASS

◆ OEM_STRING

typedef STRING OEM_STRING

Definition at line 73 of file winternl.h.

◆ PANSI_STRING

Definition at line 71 of file winternl.h.

◆ PCANSI_STRING

Definition at line 72 of file winternl.h.

◆ PCOEM_STRING

Definition at line 75 of file winternl.h.

◆ PCSZ

typedef CONST char* PCSZ

Definition at line 62 of file winternl.h.

◆ PCUNICODE_STRING

Definition at line 83 of file winternl.h.

◆ PEB

typedef struct _PEB PEB

◆ PEB_LDR_DATA

◆ PIO_APC_ROUTINE

Definition at line 293 of file winternl.h.

◆ PIO_STATUS_BLOCK

◆ PKEY_VALUE_ENTRY

◆ PLDR_DATA_TABLE_ENTRY

◆ POBJECT_ATTRIBUTES

◆ POEM_STRING

Definition at line 74 of file winternl.h.

◆ PPEB

typedef struct _PEB * PPEB

◆ PPEB_LDR_DATA

◆ PPROCESS_BASIC_INFORMATION

◆ PPS_POST_PROCESS_INIT_ROUTINE

typedef VOID(NTAPI * PPS_POST_PROCESS_INIT_ROUTINE) (VOID)

Definition at line 118 of file winternl.h.

◆ PPUBLIC_OBJECT_BASIC_INFORMATION

◆ PPUBLIC_OBJECT_TYPE_INFORMATION

◆ PROCESS_BASIC_INFORMATION

◆ PROCESSINFOCLASS

◆ PRTL_USER_PROCESS_PARAMETERS

◆ PSTRING

typedef struct _STRING * PSTRING

◆ PSYSTEM_BASIC_INFORMATION

◆ PSYSTEM_EXCEPTION_INFORMATION

◆ PSYSTEM_INTERRUPT_INFORMATION

◆ PSYSTEM_LOOKASIDE_INFORMATION

◆ PSYSTEM_PERFORMANCE_INFORMATION

◆ PSYSTEM_POLICY_INFORMATION

◆ PSYSTEM_PROCESS_INFORMATION

◆ PSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION

◆ PSYSTEM_REGISTRY_QUOTA_INFORMATION

◆ PSYSTEM_TIMEOFDAY_INFORMATION

◆ PTEB

typedef struct _TEB * PTEB

◆ PUBLIC_OBJECT_BASIC_INFORMATION

◆ PUBLIC_OBJECT_TYPE_INFORMATION

◆ PUNICODE_STRING

◆ PWINSTATIONINFORMATIONW

◆ PWINSTATIONQUERYINFORMATIONW

typedef BOOLEAN(WINAPI * PWINSTATIONQUERYINFORMATIONW) (HANDLE, ULONG, WINSTATIONINFOCLASS, PVOID, ULONG, PULONG)

Definition at line 584 of file winternl.h.

◆ RTL_USER_PROCESS_PARAMETERS

◆ STRING

◆ SYSTEM_BASIC_INFORMATION

◆ SYSTEM_EXCEPTION_INFORMATION

◆ SYSTEM_INFORMATION_CLASS

◆ SYSTEM_INTERRUPT_INFORMATION

◆ SYSTEM_LOOKASIDE_INFORMATION

◆ SYSTEM_PERFORMANCE_INFORMATION

◆ SYSTEM_POLICY_INFORMATION

◆ SYSTEM_PROCESS_INFORMATION

◆ SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION

◆ SYSTEM_REGISTRY_QUOTA_INFORMATION

◆ SYSTEM_TIMEOFDAY_INFORMATION

◆ TEB

typedef struct _TEB TEB

◆ THREADINFOCLASS

◆ UNICODE_STRING

◆ WINSTATIONINFOCLASS

◆ WINSTATIONINFORMATIONW

Enumeration Type Documentation

◆ _FILE_INFORMATION_CLASS

Enumerator
FileDirectoryInformation 
FileFullDirectoryInformation 
FileBothDirectoryInformation 
FileBasicInformation 
FileStandardInformation 
FileInternalInformation 
FileEaInformation 
FileAccessInformation 
FileNameInformation 
FileRenameInformation 
FileLinkInformation 
FileNamesInformation 
FileDispositionInformation 
FilePositionInformation 
FileFullEaInformation 
FileModeInformation 
FileAlignmentInformation 
FileAllInformation 
FileAllocationInformation 
FileEndOfFileInformation 
FileAlternateNameInformation 
FileStreamInformation 
FilePipeInformation 
FilePipeLocalInformation 
FilePipeRemoteInformation 
FileMailslotQueryInformation 
FileMailslotSetInformation 
FileCompressionInformation 
FileObjectIdInformation 
FileCompletionInformation 
FileMoveClusterInformation 
FileQuotaInformation 
FileReparsePointInformation 
FileNetworkOpenInformation 
FileAttributeTagInformation 
FileTrackingInformation 
FileIdBothDirectoryInformation 
FileIdFullDirectoryInformation 
FileValidDataLengthInformation 
FileShortNameInformation 
FileIoCompletionNotificationInformation 
FileIoStatusBlockRangeInformation 
FileIoPriorityHintInformation 
FileSfioReserveInformation 
FileSfioVolumeInformation 
FileHardLinkInformation 
FileProcessIdsUsingFileInformation 
FileNormalizedNameInformation 
FileNetworkPhysicalNameInformation 
FileIdGlobalTxDirectoryInformation 
FileMaximumInformation 
FileDirectoryInformation 
FileFullDirectoryInformation 
FileBothDirectoryInformation 
FileBasicInformation 
FileStandardInformation 
FileInternalInformation 
FileEaInformation 
FileAccessInformation 
FileNameInformation 
FileRenameInformation 
FileLinkInformation 
FileNamesInformation 
FileDispositionInformation 
FilePositionInformation 
FileFullEaInformation 
FileModeInformation 
FileAlignmentInformation 
FileAllInformation 
FileAllocationInformation 
FileEndOfFileInformation 
FileAlternateNameInformation 
FileStreamInformation 
FilePipeInformation 
FilePipeLocalInformation 
FilePipeRemoteInformation 
FileMailslotQueryInformation 
FileMailslotSetInformation 
FileCompressionInformation 
FileCopyOnWriteInformation 
FileCompletionInformation 
FileMoveClusterInformation 
FileOleClassIdInformation 
FileOleStateBitsInformation 
FileNetworkOpenInformation 
FileObjectIdInformation 
FileOleAllInformation 
FileOleDirectoryInformation 
FileContentIndexInformation 
FileInheritContentIndexInformation 
FileOleInformation 
FileMaximumInformation 
FileDirectoryInformation 
FileFullDirectoryInformation 
FileBothDirectoryInformation 
FileBasicInformation 
FileStandardInformation 
FileInternalInformation 
FileEaInformation 
FileAccessInformation 
FileNameInformation 
FileRenameInformation 
FileLinkInformation 
FileNamesInformation 
FileDispositionInformation 
FilePositionInformation 
FileFullEaInformation 
FileModeInformation 
FileAlignmentInformation 
FileAllInformation 
FileAllocationInformation 
FileEndOfFileInformation 
FileAlternateNameInformation 
FileStreamInformation 
FilePipeInformation 
FilePipeLocalInformation 
FilePipeRemoteInformation 
FileMailslotQueryInformation 
FileMailslotSetInformation 
FileCompressionInformation 
FileCopyOnWriteInformation 
FileCompletionInformation 
FileMoveClusterInformation 
FileOleClassIdInformation 
FileOleStateBitsInformation 
FileNetworkOpenInformation 
FileObjectIdInformation 
FileOleAllInformation 
FileOleDirectoryInformation 
FileContentIndexInformation 
FileInheritContentIndexInformation 
FileOleInformation 
FileMaximumInformation 
FileDirectoryInformation 
FileDirectoryInformation 
FileFullDirectoryInformation 
FileBothDirectoryInformation 
FileBasicInformation 
FileStandardInformation 
FileInternalInformation 
FileEaInformation 
FileAccessInformation 
FileNameInformation 
FileRenameInformation 
FileLinkInformation 
FileNamesInformation 
FileDispositionInformation 
FilePositionInformation 
FileFullEaInformation 
FileModeInformation 
FileAlignmentInformation 
FileAllInformation 
FileAllocationInformation 
FileEndOfFileInformation 
FileAlternateNameInformation 
FileStreamInformation 
FilePipeInformation 
FilePipeLocalInformation 
FilePipeRemoteInformation 
FileMailslotQueryInformation 
FileMailslotSetInformation 
FileCompressionInformation 
FileObjectIdInformation 
FileCompletionInformation 
FileMoveClusterInformation 
FileQuotaInformation 
FileReparsePointInformation 
FileNetworkOpenInformation 
FileAttributeTagInformation 
FileTrackingInformation 
FileIdBothDirectoryInformation 
FileIdFullDirectoryInformation 
FileValidDataLengthInformation 
FileShortNameInformation 
FileIoCompletionNotificationInformation 
FileIoStatusBlockRangeInformation 
FileIoPriorityHintInformation 
FileSfioReserveInformation 
FileSfioVolumeInformation 
FileHardLinkInformation 
FileProcessIdsUsingFileInformation 
FileNormalizedNameInformation 
FileNetworkPhysicalNameInformation 
FileIdGlobalTxDirectoryInformation 
FileIsRemoteDeviceInformation 
FileAttributeCacheInformation 
FileNumaNodeInformation 
FileStandardLinkInformation 
FileRemoteProtocolInformation 
FileRenameInformationBypassAccessCheck 
FileLinkInformationBypassAccessCheck 
FileVolumeNameInformation 
FileIdInformation 
FileIdExtdDirectoryInformation 
FileReplaceCompletionInformation 
FileHardLinkFullIdInformation 
FileIdExtdBothDirectoryInformation 
FileDispositionInformationEx 
FileRenameInformationEx 
FileRenameInformationExBypassAccessCheck 
FileDesiredStorageClassInformation 
FileStatInformation 
FileMemoryPartitionInformation 
FileStatLxInformation 
FileCaseSensitiveInformation 
FileLinkInformationEx 
FileLinkInformationExBypassAccessCheck 
FileStorageReserveIdInformation 
FileCaseSensitiveInformationForceAccessCheck 
FileKnownFolderInformation 
FileMaximumInformation 
FileDirectoryInformation 
FileFullDirectoryInformation 
FileBothDirectoryInformation 
FileBasicInformation 
FileStandardInformation 
FileInternalInformation 
FileEaInformation 
FileAccessInformation 
FileNameInformation 
FileRenameInformation 
FileLinkInformation 
FileNamesInformation 
FileDispositionInformation 
FilePositionInformation 
FileFullEaInformation 
FileModeInformation 
FileAlignmentInformation 
FileAllInformation 
FileAllocationInformation 
FileEndOfFileInformation 
FileAlternateNameInformation 
FileStreamInformation 
FilePipeInformation 
FilePipeLocalInformation 
FilePipeRemoteInformation 
FileMailslotQueryInformation 
FileMailslotSetInformation 
FileCompressionInformation 
FileObjectIdInformation 
FileCompletionInformation 
FileMoveClusterInformation 
FileQuotaInformation 
FileReparsePointInformation 
FileNetworkOpenInformation 
FileAttributeTagInformation 
FileTrackingInformation 
FileIdBothDirectoryInformation 
FileIdFullDirectoryInformation 
FileValidDataLengthInformation 
FileShortNameInformation 
FileIoCompletionNotificationInformation 
FileIoStatusBlockRangeInformation 
FileIoPriorityHintInformation 
FileSfioReserveInformation 
FileSfioVolumeInformation 
FileHardLinkInformation 
FileProcessIdsUsingFileInformation 
FileNormalizedNameInformation 
FileNetworkPhysicalNameInformation 
FileIdGlobalTxDirectoryInformation 
FileIsRemoteDeviceInformation 
FileAttributeCacheInformation 
FileNumaNodeInformation 
FileStandardLinkInformation 
FileRemoteProtocolInformation 
FileMaximumInformation 

Definition at line 159 of file winternl.h.

160{
@ FileDirectoryInformation
Definition: winternl.h:161
enum _FILE_INFORMATION_CLASS FILE_INFORMATION_CLASS

◆ _KEY_SET_INFORMATION_CLASS

Enumerator
KeyWriteTimeInformation 
KeyWriteTimeInformation 
KeyWow64FlagsInformation 
KeyControlFlagsInformation 
KeySetVirtualizationInformation 
KeySetDebugInformation 
KeySetHandleTagsInformation 
MaxKeySetInfoClass 
KeyWriteTimeInformation 
KeyWow64FlagsInformation 
KeyControlFlagsInformation 
KeySetVirtualizationInformation 
KeySetDebugInformation 
KeySetHandleTagsInformation 
MaxKeySetInfoClass 

Definition at line 372 of file winternl.h.

373{
enum _KEY_SET_INFORMATION_CLASS KEY_SET_INFORMATION_CLASS
@ KeyWriteTimeInformation
Definition: winternl.h:374
@ KeySetVirtualizationInformation
Definition: winternl.h:377
@ KeyControlFlagsInformation
Definition: winternl.h:376
@ KeySetDebugInformation
Definition: winternl.h:378
@ KeyWow64FlagsInformation
Definition: winternl.h:375
@ KeySetHandleTagsInformation
Definition: winternl.h:379
@ MaxKeySetInfoClass
Definition: winternl.h:380

◆ _OBJECT_INFORMATION_CLASS

Enumerator
ObjectBasicInformation 
ObjectNameInformation 
ObjectTypeInformation 
ObjectAllTypesInformation 
ObjectHandleInformation 
ObjectBasicInformation 
ObjectTypeInformation 
ObjectBasicInformation 
ObjectNameInformation 
ObjectTypeInformation 
ObjectTypesInformation 
ObjectHandleFlagInformation 
ObjectSessionInformation 
ObjectSessionObjectInformation 

Definition at line 439 of file winternl.h.

440{
enum _OBJECT_INFORMATION_CLASS OBJECT_INFORMATION_CLASS
@ ObjectTypeInformation
Definition: winternl.h:442
@ ObjectBasicInformation
Definition: winternl.h:441

◆ _PROCESSINFOCLASS

Enumerator
ProcessBasicInformation 
ProcessDebugPort 
ProcessWow64Information 
ProcessImageFileName 
ProcessBreakOnTermination 
ProcessBasicInformation 
ProcessDebugPort 
ProcessWow64Information 
ProcessImageFileName 
ProcessBreakOnTermination 
ProcessBasicInformation 
ProcessQuotaLimits 
ProcessIoCounters 
ProcessVmCounters 
ProcessTimes 
ProcessBasePriority 
ProcessRaisePriority 
ProcessDebugPort 
ProcessExceptionPort 
ProcessAccessToken 
ProcessLdtInformation 
ProcessLdtSize 
ProcessDefaultHardErrorMode 
ProcessIoPortHandlers 
ProcessPooledUsageAndLimits 
ProcessWorkingSetWatch 
ProcessUserModeIOPL 
ProcessEnableAlignmentFaultFixup 
ProcessPriorityClass 
ProcessWx86Information 
ProcessHandleCount 
ProcessAffinityMask 
ProcessPriorityBoost 
ProcessDeviceMap 
ProcessSessionInformation 
ProcessForegroundInformation 
ProcessWow64Information 
ProcessImageFileName 
ProcessLUIDDeviceMapsEnabled 
ProcessBreakOnTermination 
ProcessDebugObjectHandle 
ProcessDebugFlags 
ProcessHandleTracing 
ProcessIoPriority 
ProcessExecuteFlags 
ProcessTlsInformation 
ProcessCookie 
ProcessImageInformation 
ProcessCycleTime 
ProcessPagePriority 
ProcessInstrumentationCallback 
ProcessThreadStackAllocation 
ProcessWorkingSetWatchEx 
ProcessImageFileNameWin32 
ProcessImageFileMapping 
ProcessAffinityUpdateMode 
ProcessMemoryAllocationMode 
ProcessGroupInformation 
ProcessTokenVirtualizationEnabled 
ProcessConsoleHostProcess 
ProcessWindowInformation 
ProcessHandleInformation 
ProcessMitigationPolicy 
ProcessDynamicFunctionTableInformation 
ProcessHandleCheckingMode 
ProcessKeepAliveCount 
ProcessRevokeFileHandles 
ProcessWorkingSetControl 
ProcessHandleTable 
ProcessCheckStackExtentsMode 
ProcessCommandLineInformation 
ProcessProtectionInformation 
ProcessMemoryExhaustion 
ProcessFaultInformation 
ProcessTelemetryIdInformation 
ProcessCommitReleaseInformation 
ProcessDefaultCpuSetsInformation 
ProcessAllowedCpuSetsInformation 
ProcessSubsystemProcess 
ProcessJobMemoryInformation 
ProcessInPrivate 
ProcessRaiseUMExceptionOnInvalidHandleClose 
ProcessIumChallengeResponse 
ProcessChildProcessInformation 
ProcessHighGraphicsPriorityInformation 
ProcessSubsystemInformation 
ProcessEnergyValues 
ProcessPowerThrottlingState 
ProcessReserved3Information 
ProcessWin32kSyscallFilterInformation 
ProcessDisableSystemAllowedCpuSets 
ProcessWakeInformation 
ProcessEnergyTrackingState 
ProcessManageWritesToExecutableMemory 
ProcessCaptureTrustletLiveDump 
ProcessTelemetryCoverage 
ProcessEnclaveInformation 
ProcessEnableReadWriteVmLogging 
ProcessUptimeInformation 
ProcessImageSection 
ProcessDebugAuthInformation 
ProcessSystemResourceManagement 
ProcessSequenceNumber 
ProcessLoaderDetour 
ProcessSecurityDomainInformation 
ProcessCombineSecurityDomainsInformation 
ProcessEnableLogging 
ProcessLeapSecondInformation 
ProcessFiberShadowStackAllocation 
ProcessFreeFiberShadowStackAllocation 
ProcessAltSystemCallInformation 
ProcessDynamicEHContinuationTargets 
ProcessDynamicEnforcedCetCompatibleRanges 
ProcessCreateStateChange 
ProcessApplyStateChange 
ProcessEnableOptionalXStateFeatures 
ProcessAltPrefetchParam 
ProcessAssignCpuPartitions 
ProcessPriorityClassEx 
ProcessMembershipInformation 
ProcessEffectiveIoPriority 
ProcessEffectivePagePriority 
MaxProcessInfoClass 
ProcessBasicInformation 
ProcessQuotaLimits 
ProcessIoCounters 
ProcessVmCounters 
ProcessTimes 
ProcessBasePriority 
ProcessRaisePriority 
ProcessDebugPort 
ProcessExceptionPort 
ProcessAccessToken 
ProcessLdtInformation 
ProcessLdtSize 
ProcessDefaultHardErrorMode 
ProcessIoPortHandlers 
ProcessPooledUsageAndLimits 
ProcessWorkingSetWatch 
ProcessUserModeIOPL 
ProcessEnableAlignmentFaultFixup 
ProcessPriorityClass 
ProcessWx86Information 
ProcessHandleCount 
ProcessAffinityMask 
ProcessPriorityBoost 
ProcessDeviceMap 
ProcessSessionInformation 
ProcessForegroundInformation 
ProcessWow64Information 
ProcessImageFileName 
ProcessLUIDDeviceMapsEnabled 
ProcessBreakOnTermination 
ProcessDebugObjectHandle 
ProcessDebugFlags 
ProcessHandleTracing 
ProcessIoPriority 
ProcessExecuteFlags 
ProcessTlsInformation 
ProcessCookie 
ProcessImageInformation 
ProcessCycleTime 
ProcessPagePriority 
ProcessInstrumentationCallback 
ProcessThreadStackAllocation 
ProcessWorkingSetWatchEx 
ProcessImageFileNameWin32 
ProcessImageFileMapping 
ProcessAffinityUpdateMode 
ProcessMemoryAllocationMode 
ProcessGroupInformation 
ProcessTokenVirtualizationEnabled 
ProcessConsoleHostProcess 
ProcessWindowInformation 
MaxProcessInfoClass 

Definition at line 394 of file winternl.h.

395{
enum _PROCESSINFOCLASS PROCESSINFOCLASS
@ ProcessDebugPort
Definition: winternl.h:397
@ ProcessBreakOnTermination
Definition: winternl.h:400
@ ProcessBasicInformation
Definition: winternl.h:396
@ ProcessWow64Information
Definition: winternl.h:398
@ ProcessImageFileName
Definition: winternl.h:399

◆ _SYSTEM_INFORMATION_CLASS

Enumerator
SystemBasicInformation 
SystemProcessorInformation 
SystemPerformanceInformation 
SystemTimeOfDayInformation 
SystemPathInformation 
SystemProcessInformation 
SystemCallCountInformation 
SystemDeviceInformation 
SystemProcessorPerformanceInformation 
SystemFlagsInformation 
SystemCallTimeInformation 
SystemModuleInformation 
SystemLocksInformation 
SystemStackTraceInformation 
SystemPagedPoolInformation 
SystemNonPagedPoolInformation 
SystemHandleInformation 
SystemObjectInformation 
SystemPageFileInformation 
SystemVdmInstemulInformation 
SystemVdmBopInformation 
SystemFileCacheInformation 
SystemPoolTagInformation 
SystemInterruptInformation 
SystemDpcBehaviorInformation 
SystemFullMemoryInformation 
SystemLoadGdiDriverInformation 
SystemUnloadGdiDriverInformation 
SystemTimeAdjustmentInformation 
SystemSummaryMemoryInformation 
SystemNextEventIdInformation 
SystemEventIdsInformation 
SystemCrashDumpInformation 
SystemExceptionInformation 
SystemCrashDumpStateInformation 
SystemKernelDebuggerInformation 
SystemContextSwitchInformation 
SystemRegistryQuotaInformation 
SystemExtendServiceTableInformation 
SystemPrioritySeperation 
SystemPlugPlayBusInformation 
SystemDockInformation 
SystemPowerInformation 
SystemProcessorSpeedInformation 
SystemCurrentTimeZoneInformation 
SystemLookasideInformation 
SystemBasicInformation 
SystemProcessorInformation 
SystemPerformanceInformation 
SystemTimeOfDayInformation 
SystemPathInformation 
SystemProcessInformation 
SystemCallCountInformation 
SystemDeviceInformation 
SystemProcessorPerformanceInformation 
SystemFlagsInformation 
SystemCallTimeInformation 
SystemModuleInformation 
SystemLocksInformation 
SystemStackTraceInformation 
SystemPagedPoolInformation 
SystemNonPagedPoolInformation 
SystemHandleInformation 
SystemObjectInformation 
SystemPageFileInformation 
SystemVdmInstemulInformation 
SystemVdmBopInformation 
SystemFileCacheInformation 
SystemPoolTagInformation 
SystemInterruptInformation 
SystemDpcBehaviorInformation 
SystemFullMemoryInformation 
SystemLoadGdiDriverInformation 
SystemUnloadGdiDriverInformation 
SystemTimeAdjustmentInformation 
SystemSummaryMemoryInformation 
SystemNextEventIdInformation 
SystemEventIdsInformation 
SystemCrashDumpInformation 
SystemExceptionInformation 
SystemCrashDumpStateInformation 
SystemKernelDebuggerInformation 
SystemContextSwitchInformation 
SystemRegistryQuotaInformation 
SystemExtendServiceTableInformation 
SystemPrioritySeperation 
SystemPlugPlayBusInformation 
SystemDockInformation 
SystemPowerInformation 
SystemProcessorSpeedInformation 
SystemCurrentTimeZoneInformation 
SystemLookasideInformation 
SystemBasicInformation 
SystemProcessorInformation 
SystemPerformanceInformation 
SystemTimeOfDayInformation 
SystemPathInformation 
SystemProcessInformation 
SystemCallCountInformation 
SystemDeviceInformation 
SystemProcessorPerformanceInformation 
SystemFlagsInformation 
SystemCallTimeInformation 
SystemModuleInformation 
SystemLocksInformation 
SystemStackTraceInformation 
SystemPagedPoolInformation 
SystemNonPagedPoolInformation 
SystemHandleInformation 
SystemObjectInformation 
SystemPageFileInformation 
SystemVdmInstemulInformation 
SystemVdmBopInformation 
SystemFileCacheInformation 
SystemPoolTagInformation 
SystemInterruptInformation 
SystemDpcBehaviorInformation 
SystemFullMemoryInformation 
SystemLoadGdiDriverInformation 
SystemUnloadGdiDriverInformation 
SystemTimeAdjustmentInformation 
SystemSummaryMemoryInformation 
SystemMirrorMemoryInformation 
SystemPerformanceTraceInformation 
SystemObsolete0 
SystemExceptionInformation 
SystemCrashDumpStateInformation 
SystemKernelDebuggerInformation 
SystemContextSwitchInformation 
SystemRegistryQuotaInformation 
SystemExtendServiceTableInformation 
SystemPrioritySeperation 
SystemVerifierAddDriverInformation 
SystemVerifierRemoveDriverInformation 
SystemProcessorIdleInformation 
SystemLegacyDriverInformation 
SystemCurrentTimeZoneInformation 
SystemLookasideInformation 
SystemTimeSlipNotification 
SystemSessionCreate 
SystemSessionDetach 
SystemSessionInformation 
SystemRangeStartInformation 
SystemVerifierInformation 
SystemVerifierThunkExtend 
SystemSessionProcessInformation 
SystemLoadGdiDriverInSystemSpace 
SystemNumaProcessorMap 
SystemPrefetcherInformation 
SystemExtendedProcessInformation 
SystemRecommendedSharedDataAlignment 
SystemComPlusPackage 
SystemNumaAvailableMemory 
SystemProcessorPowerInformation 
SystemEmulationBasicInformation 
SystemEmulationProcessorInformation 
SystemExtendedHandleInformation 
SystemLostDelayedWriteInformation 
SystemBigPoolInformation 
SystemSessionPoolTagInformation 
SystemSessionMappedViewInformation 
SystemHotpatchInformation 
SystemObjectSecurityMode 
SystemWatchdogTimerHandler 
SystemWatchdogTimerInformation 
SystemLogicalProcessorInformation 
SystemWow64SharedInformationObsolete 
SystemRegisterFirmwareTableInformationHandler 
SystemFirmwareTableInformation 
SystemModuleInformationEx 
SystemVerifierTriageInformation 
SystemSuperfetchInformation 
SystemMemoryListInformation 
SystemFileCacheInformationEx 
SystemThreadPriorityClientIdInformation 
SystemProcessorIdleCycleTimeInformation 
SystemVerifierCancellationInformation 
SystemProcessorPowerInformationEx 
SystemRefTraceInformation 
SystemSpecialPoolInformation 
SystemProcessIdInformation 
SystemErrorPortInformation 
SystemBootEnvironmentInformation 
SystemHypervisorInformation 
SystemVerifierInformationEx 
SystemTimeZoneInformation 
SystemImageFileExecutionOptionsInformation 
SystemCoverageInformation 
SystemPrefetchPatchInformation 
SystemVerifierFaultsInformation 
SystemSystemPartitionInformation 
SystemSystemDiskInformation 
SystemProcessorPerformanceDistribution 
SystemNumaProximityNodeInformation 
SystemDynamicTimeZoneInformation 
SystemCodeIntegrityInformation 
SystemProcessorMicrocodeUpdateInformation 
SystemProcessorBrandString 
SystemVirtualAddressInformation 
SystemLogicalProcessorAndGroupInformation 
SystemProcessorCycleTimeInformation 
SystemStoreInformation 
SystemRegistryAppendString 
SystemAitSamplingValue 
SystemVhdBootInformation 
SystemCpuQuotaInformation 
SystemNativeBasicInformation 
SystemErrorPortTimeouts 
SystemLowPriorityIoInformation 
SystemBootEntropyInformation 
SystemVerifierCountersInformation 
SystemPagedPoolInformationEx 
SystemSystemPtesInformationEx 
SystemNodeDistanceInformation 
SystemAcpiAuditInformation 
SystemBasicPerformanceInformation 
SystemQueryPerformanceCounterInformation 
SystemSessionBigPoolInformation 
SystemBootGraphicsInformation 
SystemScrubPhysicalMemoryInformation 
SystemBadPageInformation 
SystemProcessorProfileControlArea 
SystemCombinePhysicalMemoryInformation 
SystemEntropyInterruptTimingInformation 
SystemConsoleInformation 
SystemPlatformBinaryInformation 
SystemThrottleNotificationInformation 
SystemPolicyInformation 
SystemHypervisorProcessorCountInformation 
SystemDeviceDataInformation 
SystemDeviceDataEnumerationInformation 
SystemMemoryTopologyInformation 
SystemMemoryChannelInformation 
SystemBootLogoInformation 
SystemProcessorPerformanceInformationEx 
SystemSpare0 
SystemCriticalProcessErrorLogInformation 
SystemSecureBootPolicyInformation 
SystemPageFileInformationEx 
SystemSecureBootInformation 
SystemEntropyInterruptTimingRawInformation 
SystemPortableWorkspaceEfiLauncherInformation 
SystemFullProcessInformation 
SystemKernelDebuggerInformationEx 
SystemBootMetadataInformation 
SystemSoftRebootInformation 
SystemElamCertificateInformation 
SystemOfflineDumpConfigInformation 
SystemProcessorFeaturesInformation 
SystemRegistryReconciliationInformation 
SystemEdidInformation 
SystemManufacturingInformation 
SystemEnergyEstimationConfigInformation 
SystemHypervisorDetailInformation 
SystemProcessorCycleStatsInformation 
SystemVmGenerationCountInformation 
SystemTrustedPlatformModuleInformation 
SystemKernelDebuggerFlags 
SystemCodeIntegrityPolicyInformation 
SystemIsolatedUserModeInformation 
SystemHardwareSecurityTestInterfaceResultsInformation 
SystemSingleModuleInformation 
SystemAllowedCpuSetsInformation 
SystemVsmProtectionInformation 
SystemInterruptCpuSetsInformation 
SystemSecureBootPolicyFullInformation 
SystemCodeIntegrityPolicyFullInformation 
SystemAffinitizedInterruptProcessorInformation 
SystemRootSiloInformation 
SystemCpuSetInformation 
SystemCpuSetTagInformation 
SystemWin32WerStartCallout 
SystemSecureKernelProfileInformation 
SystemCodeIntegrityPlatformManifestInformation 
SystemInterruptSteeringInformation 
SystemSupportedProcessorArchitectures 
SystemMemoryUsageInformation 
SystemCodeIntegrityCertificateInformation 
SystemPhysicalMemoryInformation 
SystemControlFlowTransition 
SystemKernelDebuggingAllowed 
SystemActivityModerationExeState 
SystemActivityModerationUserSettings 
SystemCodeIntegrityPoliciesFullInformation 
SystemCodeIntegrityUnlockInformation 
SystemIntegrityQuotaInformation 
SystemFlushInformation 
SystemProcessorIdleMaskInformation 
SystemSecureDumpEncryptionInformation 
SystemWriteConstraintInformation 
SystemKernelVaShadowInformation 
SystemHypervisorSharedPageInformation 
SystemFirmwareBootPerformanceInformation 
SystemCodeIntegrityVerificationInformation 
SystemFirmwarePartitionInformation 
SystemSpeculationControlInformation 
SystemDmaGuardPolicyInformation 
SystemEnclaveLaunchControlInformation 
SystemWorkloadAllowedCpuSetsInformation 
SystemCodeIntegrityUnlockModeInformation 
SystemLeapSecondInformation 
SystemFlags2Information 
SystemSecurityModelInformation 
SystemCodeIntegritySyntheticCacheInformation 
SystemFeatureConfigurationInformation 
SystemFeatureConfigurationSectionInformation 
SystemFeatureUsageSubscriptionInformation 
SystemSecureSpeculationControlInformation 
SystemSpacesBootInformation 
SystemFwRamdiskInformation 
SystemWheaIpmiHardwareInformation 
SystemDifSetRuleClassInformation 
SystemDifClearRuleClassInformation 
SystemDifApplyPluginVerificationOnDriver 
SystemDifRemovePluginVerificationOnDriver 
SystemShadowStackInformation 
SystemBuildVersionInformation 
SystemPoolLimitInformation 
SystemCodeIntegrityAddDynamicStore 
SystemCodeIntegrityClearDynamicStores 
SystemDifPoolTrackingInformation 
SystemPoolZeroingInformation 
SystemDpcWatchdogInformation 
SystemDpcWatchdogInformation2 
SystemSupportedProcessorArchitectures2 
SystemSingleProcessorRelationshipInformation 
SystemXfgCheckFailureInformation 
SystemIommuStateInformation 
SystemHypervisorMinrootInformation 
SystemHypervisorBootPagesInformation 
SystemPointerAuthInformation 
SystemSecureKernelDebuggerInformation 
SystemOriginalImageFeatureInformation 
SystemMemoryNumaInformation 
SystemMemoryNumaPerformanceInformation 
SystemCodeIntegritySignedPoliciesFullInformation 
SystemSecureSecretsInformation 
SystemTrustedAppsRuntimeInformation 
SystemBadPageInformationEx 
SystemResourceDeadlockTimeout 
SystemBreakOnContextUnwindFailureInformation 
SystemOslRamdiskInformation 
MaxSystemInfoClass 
SystemBasicInformation 
SystemPerformanceInformation 
SystemTimeOfDayInformation 
SystemProcessInformation 
SystemProcessorPerformanceInformation 
SystemInterruptInformation 
SystemExceptionInformation 
SystemRegistryQuotaInformation 
SystemLookasideInformation 
SystemPolicyInformation 
SystemBasicInformation 
SystemCpuInformation 
SystemPerformanceInformation 
SystemTimeOfDayInformation 
SystemPathInformation 
SystemProcessInformation 
SystemCallCountInformation 
SystemDeviceInformation 
SystemProcessorPerformanceInformation 
SystemFlagsInformation 
SystemCallTimeInformation 
SystemModuleInformation 
SystemLocksInformation 
SystemStackTraceInformation 
SystemPagedPoolInformation 
SystemNonPagedPoolInformation 
SystemHandleInformation 
SystemObjectInformation 
SystemPageFileInformation 
SystemVdmInstemulInformation 
SystemVdmBopInformation 
SystemFileCacheInformation 
SystemPoolTagInformation 
SystemInterruptInformation 
SystemDpcBehaviorInformation 
SystemFullMemoryInformation 
SystemNotImplemented6 
SystemLoadGdiDriverInformation 
SystemUnloadGdiDriverInformation 
SystemTimeAdjustmentInformation 
SystemTimeAdjustment 
SystemSummaryMemoryInformation 
SystemMirrorMemoryInformation 
SystemPerformanceTraceInformation 
SystemObsolete0 
SystemExceptionInformation 
SystemCrashDumpStateInformation 
SystemKernelDebuggerInformation 
SystemContextSwitchInformation 
SystemRegistryQuotaInformation 
SystemExtendServiceTableInformation 
SystemPrioritySeparation 
SystemVerifierAddDriverInformation 
SystemVerifierRemoveDriverInformation 
SystemProcessorIdleInformation 
SystemLegacyDriverInformation 
SystemCurrentTimeZoneInformation 
SystemLookasideInformation 
SystemTimeSlipNotification 
SystemSessionCreate 
SystemSessionDetach 
SystemSessionInformation 
SystemRangeStartInformation 
SystemVerifierInformation 
SystemVerifierThunkExtend 
SystemSessionProcessesInformation 
SystemLoadGdiDriverInSystemSpace 
SystemNumaProcessorMap 
SystemPrefetcherInformation 
SystemExtendedProcessInformation 
SystemRecommendedSharedDataAlignment 
SystemComPlusPackage 
SystemNumaAvailableMemory 
SystemProcessorPowerInformation 
SystemEmulationBasicInformation 
SystemEmulationProcessorInformation 
SystemExtendedHandleInformation 
SystemLostDelayedWriteInformation 
SystemBigPoolInformation 
SystemSessionPoolTagInformation 
SystemSessionMappedViewInformation 
SystemHotpatchInformation 
SystemObjectSecurityMode 
SystemWatchdogTimerHandler 
SystemWatchdogTimerInformation 
SystemLogicalProcessorInformation 
SystemWow64SharedInformationObsolete 
SystemRegisterFirmwareTableInformationHandler 
SystemFirmwareTableInformation 
SystemModuleInformationEx 
SystemVerifierTriageInformation 
SystemSuperfetchInformation 
SystemMemoryListInformation 
SystemFileCacheInformationEx 
SystemThreadPriorityClientIdInformation 
SystemProcessorIdleCycleTimeInformation 
SystemVerifierCancellationInformation 
SystemProcessorPowerInformationEx 
SystemRefTraceInformation 
SystemSpecialPoolInformation 
SystemProcessIdInformation 
SystemErrorPortInformation 
SystemBootEnvironmentInformation 
SystemHypervisorInformation 
SystemVerifierInformationEx 
SystemTimeZoneInformation 
SystemImageFileExecutionOptionsInformation 
SystemCoverageInformation 
SystemPrefetchPatchInformation 
SystemVerifierFaultsInformation 
SystemSystemPartitionInformation 
SystemSystemDiskInformation 
SystemProcessorPerformanceDistribution 
SystemNumaProximityNodeInformation 
SystemDynamicTimeZoneInformation 
SystemCodeIntegrityInformation 
SystemProcessorMicrocodeUpdateInformation 
SystemProcessorBrandString 
SystemVirtualAddressInformation 
SystemLogicalProcessorInformationEx 
SystemProcessorCycleTimeInformation 
SystemStoreInformation 
SystemRegistryAppendString 
SystemAitSamplingValue 
SystemVhdBootInformation 
SystemCpuQuotaInformation 
SystemNativeBasicInformation 
SystemErrorPortTimeouts 
SystemLowPriorityIoInformation 
SystemTpmBootEntropyInformation 
SystemVerifierCountersInformation 
SystemPagedPoolInformationEx 
SystemSystemPtesInformationEx 
SystemNodeDistanceInformation 
SystemAcpiAuditInformation 
SystemBasicPerformanceInformation 
SystemQueryPerformanceCounterInformation 
SystemSessionBigPoolInformation 
SystemBootGraphicsInformation 
SystemScrubPhysicalMemoryInformation 
SystemBadPageInformation 
SystemProcessorProfileControlArea 
SystemCombinePhysicalMemoryInformation 
SystemEntropyInterruptTimingInformation 
SystemConsoleInformation 
SystemPlatformBinaryInformation 
SystemPolicyInformation 
SystemHypervisorProcessorCountInformation 
SystemDeviceDataInformation 
SystemDeviceDataEnumerationInformation 
SystemMemoryTopologyInformation 
SystemMemoryChannelInformation 
SystemBootLogoInformation 
SystemProcessorPerformanceInformationEx 
SystemCriticalProcessErrorLogInformation 
SystemSecureBootPolicyInformation 
SystemPageFileInformationEx 
SystemSecureBootInformation 
SystemEntropyInterruptTimingRawInformation 
SystemPortableWorkspaceEfiLauncherInformation 
SystemFullProcessInformation 
SystemKernelDebuggerInformationEx 
SystemBootMetadataInformation 
SystemSoftRebootInformation 
SystemElamCertificateInformation 
SystemOfflineDumpConfigInformation 
SystemProcessorFeaturesInformation 
SystemRegistryReconciliationInformation 
SystemEdidInformation 
SystemManufacturingInformation 
SystemEnergyEstimationConfigInformation 
SystemHypervisorDetailInformation 
SystemProcessorCycleStatsInformation 
SystemVmGenerationCountInformation 
SystemTrustedPlatformModuleInformation 
SystemKernelDebuggerFlags 
SystemCodeIntegrityPolicyInformation 
SystemIsolatedUserModeInformation 
SystemHardwareSecurityTestInterfaceResultsInformation 
SystemSingleModuleInformation 
SystemAllowedCpuSetsInformation 
SystemVsmProtectionInformation 
SystemInterruptCpuSetsInformation 
SystemSecureBootPolicyFullInformation 
SystemCodeIntegrityPolicyFullInformation 
SystemAffinitizedInterruptProcessorInformation 
SystemRootSiloInformation 
SystemCpuSetInformation 
SystemCpuSetTagInformation 
SystemWin32WerStartCallout 
SystemSecureKernelProfileInformation 
SystemCodeIntegrityPlatformManifestInformation 
SystemInterruptSteeringInformation 
SystemSupportedProcessorArchitectures 
SystemMemoryUsageInformation 
SystemCodeIntegrityCertificateInformation 
SystemPhysicalMemoryInformation 
SystemControlFlowTransition 
SystemKernelDebuggingAllowed 
SystemActivityModerationExeState 
SystemActivityModerationUserSettings 
SystemCodeIntegrityPoliciesFullInformation 
SystemCodeIntegrityUnlockInformation 
SystemIntegrityQuotaInformation 
SystemFlushInformation 
SystemProcessorIdleMaskInformation 
SystemSecureDumpEncryptionInformation 
SystemWriteConstraintInformation 
SystemKernelVaShadowInformation 
SystemHypervisorSharedPageInformation 
SystemFirmwareBootPerformanceInformation 
SystemCodeIntegrityVerificationInformation 
SystemFirmwarePartitionInformation 
SystemSpeculationControlInformation 
SystemDmaGuardPolicyInformation 
SystemEnclaveLaunchControlInformation 
SystemWorkloadAllowedCpuSetsInformation 
SystemCodeIntegrityUnlockModeInformation 
SystemLeapSecondInformation 
SystemFlags2Information 
SystemSecurityModelInformation 
SystemCodeIntegritySyntheticCacheInformation 
SystemFeatureConfigurationInformation 
SystemFeatureConfigurationSectionInformation 
SystemFeatureUsageSubscriptionInformation 
SystemSecureSpeculationControlInformation 
SystemSpacesBootInformation 
SystemFwRamdiskInformation 
SystemWheaIpmiHardwareInformation 
SystemDifSetRuleClassInformation 
SystemDifClearRuleClassInformation 
SystemDifApplyPluginVerificationOnDriver 
SystemDifRemovePluginVerificationOnDriver 
SystemShadowStackInformation 
SystemBuildVersionInformation 
SystemPoolLimitInformation 
SystemCodeIntegrityAddDynamicStore 
SystemCodeIntegrityClearDynamicStores 
SystemDifPoolTrackingInformation 
SystemPoolZeroingInformation 
SystemDpcWatchdogInformation 
SystemDpcWatchdogInformation2 
SystemSupportedProcessorArchitectures2 
SystemSingleProcessorRelationshipInformation 
SystemXfgCheckFailureInformation 
SystemIommuStateInformation 
SystemHypervisorMinrootInformation 
SystemHypervisorBootPagesInformation 
SystemPointerAuthInformation 
SystemSecureKernelDebuggerInformation 
SystemOriginalImageFeatureInformation 

Definition at line 472 of file winternl.h.

473{
@ SystemTimeOfDayInformation
Definition: winternl.h:476
@ SystemExceptionInformation
Definition: winternl.h:480
@ SystemBasicInformation
Definition: winternl.h:474
@ SystemLookasideInformation
Definition: winternl.h:482
@ SystemRegistryQuotaInformation
Definition: winternl.h:481
@ SystemInterruptInformation
Definition: winternl.h:479
@ SystemPolicyInformation
Definition: winternl.h:483
@ SystemProcessInformation
Definition: winternl.h:477
@ SystemPerformanceInformation
Definition: winternl.h:475
@ SystemProcessorPerformanceInformation
Definition: winternl.h:478
enum _SYSTEM_INFORMATION_CLASS SYSTEM_INFORMATION_CLASS

◆ _THREADINFOCLASS

Enumerator
ThreadBasicInformation 
ThreadTimes 
ThreadPriority 
ThreadBasePriority 
ThreadAffinityMask 
ThreadImpersonationToken 
ThreadDescriptorTableEntry 
ThreadEnableAlignmentFaultFixup 
ThreadEventPair_Reusable 
ThreadQuerySetWin32StartAddress 
ThreadZeroTlsCell 
ThreadPerformanceCount 
ThreadAmILastThread 
ThreadIdealProcessor 
ThreadPriorityBoost 
ThreadSetTlsArrayAddress 
ThreadIsIoPending 
ThreadHideFromDebugger 
ThreadBreakOnTermination 
ThreadSwitchLegacyState 
ThreadIsTerminated 
ThreadLastSystemCall 
ThreadIoPriority 
ThreadCycleTime 
ThreadPagePriority 
ThreadActualBasePriority 
ThreadTebInformation 
ThreadCSwitchMon 
ThreadCSwitchPmu 
ThreadWow64Context 
ThreadGroupInformation 
ThreadUmsInformation 
ThreadCounterProfiling 
ThreadIdealProcessorEx 
MaxThreadInfoClass 
ThreadIsIoPending 
ThreadBasicInformation 
ThreadTimes 
ThreadPriority 
ThreadBasePriority 
ThreadAffinityMask 
ThreadImpersonationToken 
ThreadDescriptorTableEntry 
ThreadEnableAlignmentFaultFixup 
ThreadEventPair_Reusable 
ThreadQuerySetWin32StartAddress 
ThreadZeroTlsCell 
ThreadPerformanceCount 
ThreadAmILastThread 
ThreadIdealProcessor 
ThreadPriorityBoost 
ThreadSetTlsArrayAddress 
ThreadIsIoPending 
ThreadHideFromDebugger 
ThreadBreakOnTermination 
ThreadSwitchLegacyState 
ThreadIsTerminated 
ThreadLastSystemCall 
ThreadIoPriority 
ThreadCycleTime 
ThreadPagePriority 
ThreadActualBasePriority 
ThreadTebInformation 
ThreadCSwitchMon 
ThreadCSwitchPmu 
ThreadWow64Context 
ThreadGroupInformation 
ThreadUmsInformation 
ThreadCounterProfiling 
ThreadIdealProcessorEx 
ThreadCpuAccountingInformation 
ThreadSuspendCount 
ThreadHeterogeneousCpuPolicy 
ThreadContainerId 
ThreadNameInformation 
ThreadSelectedCpuSets 
ThreadSystemThreadInformation 
ThreadActualGroupAffinity 
ThreadDynamicCodePolicyInfo 
ThreadExplicitCaseSensitivity 
ThreadWorkOnBehalfTicket 
ThreadSubsystemInformation 
ThreadDbgkWerReportActive 
ThreadAttachContainer 
ThreadManageWritesToExecutableMemory 
ThreadPowerThrottlingState 
ThreadWorkloadClass 
ThreadCreateStateChange 
ThreadApplyStateChange 
ThreadStrongerBadHandleChecks 
ThreadEffectiveIoPriority 
ThreadEffectivePagePriority 
MaxThreadInfoClass 
ThreadBasicInformation 
ThreadTimes 
ThreadPriority 
ThreadBasePriority 
ThreadAffinityMask 
ThreadImpersonationToken 
ThreadDescriptorTableEntry 
ThreadEnableAlignmentFaultFixup 
ThreadEventPair_Reusable 
ThreadQuerySetWin32StartAddress 
ThreadZeroTlsCell 
ThreadPerformanceCount 
ThreadAmILastThread 
ThreadIdealProcessor 
ThreadPriorityBoost 
ThreadSetTlsArrayAddress 
ThreadIsIoPending 
ThreadHideFromDebugger 
ThreadBreakOnTermination 
ThreadSwitchLegacyState 
ThreadIsTerminated 
ThreadLastSystemCall 
ThreadIoPriority 
ThreadCycleTime 
ThreadPagePriority 
ThreadActualBasePriority 
ThreadTebInformation 
ThreadCSwitchMon 
ThreadCSwitchPmu 
ThreadWow64Context 
ThreadGroupInformation 
ThreadUmsInformation 
ThreadCounterProfiling 
ThreadIdealProcessorEx 
ThreadCpuAccountingInformation 
ThreadSuspendCount 
ThreadHeterogeneousCpuPolicy 
ThreadContainerId 
ThreadNameInformation 
ThreadSelectedCpuSets 
ThreadSystemThreadInformation 
ThreadActualGroupAffinity 
ThreadDynamicCodePolicyInfo 
ThreadExplicitCaseSensitivity 
ThreadWorkOnBehalfTicket 
ThreadSubsystemInformation 
ThreadDbgkWerReportActive 
ThreadAttachContainer 
ThreadManageWritesToExecutableMemory 
ThreadPowerThrottlingState 
ThreadWorkloadClass 
ThreadCreateStateChange 
ThreadApplyStateChange 
ThreadStrongerBadHandleChecks 
ThreadEffectiveIoPriority 
ThreadEffectivePagePriority 
MaxThreadInfoClass 

Definition at line 423 of file winternl.h.

424{
enum _THREADINFOCLASS THREADINFOCLASS
@ ThreadIsIoPending
Definition: winternl.h:425

◆ _WINSTATIONINFOCLASS

Enumerator
WinStationInformation 
WinStationInformation 

Definition at line 571 of file winternl.h.

572{
@ WinStationInformation
Definition: winternl.h:573
enum _WINSTATIONINFOCLASS WINSTATIONINFOCLASS

Function Documentation

◆ _IRQL_requires_max_()

_IRQL_requires_max_ ( PASSIVE_LEVEL  )

Queries information details about a security descriptor.

Computes the quota size of a security descriptor.

Assigns a security descriptor for a new object.

An extended function that assigns a security descriptor for a new object.

Frees a security descriptor.

An extended function that sets new information data to a security descriptor.

Modifies some information data about a security descriptor.

Parameters
[in]SecurityInformationSecurity information details to be queried from a security descriptor.
[out]SecurityDescriptorThe returned security descriptor with security information data.
[in,out]LengthThe returned length of a security descriptor.
[in,out]ObjectsSecurityDescriptorThe returned object security descriptor.
Returns
Returns STATUS_SUCCESS if the operations have been completed successfully and that the specific information about the security descriptor has been queried. STATUS_BUFFER_TOO_SMALL is returned if the buffer size is too small to contain the queried info about the security descriptor.
Parameters
[in]ObjectIf specified, the function will use this arbitrary object that points to an object security descriptor.
[in]SecurityInformationSecurity information details to be set.
[in]SecurityDescriptorA security descriptor where its info is to be changed.
[in,out]ObjectsSecurityDescriptorThe returned pointer to security descriptor objects.
[in]PoolTypePool type for the new security descriptor to allocate.
[in]GenericMappingThe generic mapping of access rights masks.
Returns
See SeSetSecurityDescriptorInfoEx.
Parameters
[in]ObjectIf specified, the function will use this arbitrary object that points to an object security descriptor.
[in]SecurityInformationSecurity information details to be set.
[in]SecurityDescriptorA security descriptor where its info is to be changed.
[in,out]ObjectsSecurityDescriptorThe returned pointer to security descriptor objects.
[in]AutoInheritFlagsFlags bitmask inheritation, influencing how the security descriptor can be inherited and if it can be in the first place.
[in]PoolTypePool type for the new security descriptor to allocate.
[in]GenericMappingThe generic mapping of access rights masks.
Returns
Returns STATUS_SUCCESS if the operations have been completed without problems and that new info has been set to the security descriptor. STATUS_NO_SECURITY_ON_OBJECT is returned if the object does not have a security descriptor. STATUS_INSUFFICIENT_RESOURCES is returned if memory pool allocation for the new security descriptor with new info set has failed.
Parameters
[in]SecurityDescriptorA security descriptor to be freed from memory.
Returns
Returns STATUS_SUCCESS.
Parameters
[in]_ParentDescriptorA security descriptor of the parent object that is being created.
[in]_ExplicitDescriptorAn explicit security descriptor that is applied to a new object.
[out]NewDescriptorThe new allocated security descriptor.
[in]ObjectTypeThe type of the new object.
[in]IsDirectoryObjectSet this to TRUE if the newly created object is a directory object, otherwise set this to FALSE.
[in]AutoInheritFlagsAutomatic inheritance flags that influence how access control entries within ACLs from security descriptors are inherited.
[in]SubjectContextSecurity subject context of the new object.
[in]GenericMappingGeneric mapping of access mask rights.
[in]PoolTypeThis parameter is unused.
Returns
Returns STATUS_SUCCESS if the operations have been completed successfully and that the security descriptor has been assigned to the new object. STATUS_NO_TOKEN is returned if the caller hasn't supplied a valid argument to a security subject context. STATUS_INVALID_OWNER is returned if the caller hasn't supplied a parent descriptor that belongs to the main user (owner). STATUS_INVALID_PRIMARY_GROUP is returned by the same reason as with the previous NTSTATUS code. The two NTSTATUS codes are returned if the calling thread stated that the owner and/or group is defaulted to the parent descriptor (SEF_DEFAULT_OWNER_FROM_PARENT and/or SEF_DEFAULT_GROUP_FROM_PARENT respectively). STATUS_INSUFFICIENT_RESOURCES is returned if memory pool allocation for the descriptor buffer has failed. A failure NTSTATUS is returned otherwise.
Parameters
[in]ParentDescriptorA security descriptor of the parent object that is being created.
[in]ExplicitDescriptorAn explicit security descriptor that is applied to a new object.
[out]NewDescriptorThe new allocated security descriptor.
[in]IsDirectoryObjectSet this to TRUE if the newly created object is a directory object, otherwise set this to FALSE.
[in]SubjectContextSecurity subject context of the new object.
[in]GenericMappingGeneric mapping of access mask rights.
[in]PoolTypeThis parameter is unused.
Returns
See SeAssignSecurityEx.
Parameters
[in]SecurityDescriptorA security descriptor.
[out]QuotaInfoSizeThe returned quota size of the given security descriptor to the caller. The function may return 0 to this parameter if the descriptor doesn't have a group or a discretionary access control list (DACL) even.
Returns
Returns STATUS_SUCCESS if the quota size of a security descriptor has been computed successfully. STATUS_UNKNOWN_REVISION is returned if the security descriptor has an invalid revision.

Definition at line 923 of file Messaging.c.

75{
76 PFLT_SERVER_PORT_OBJECT PortObject;
78
79 /* The caller must allow at least one connection */
80 if (MaxConnections == 0)
81 {
83 }
84
85 /* The request must be for a kernel handle */
86 if (!(ObjectAttributes->Attributes & OBJ_KERNEL_HANDLE))
87 {
89 }
90
91 /*
92 * Get rundown protection on the target to stop the owner
93 * from unloading whilst this port object is open. It gets
94 * removed in the FltpServerPortClose callback
95 */
97 if (!NT_SUCCESS(Status))
98 {
99 return Status;
100 }
101
102 /* Create the server port object for this filter */
107 NULL,
109 0,
110 0,
111 (PVOID *)&PortObject);
112 if (NT_SUCCESS(Status))
113 {
114 /* Zero out the struct */
115 RtlZeroMemory(PortObject, sizeof(FLT_SERVER_PORT_OBJECT));
116
117 /* Increment the ref count on the target filter */
119
120 /* Setup the filter port object */
121 PortObject->Filter = Filter;
125 PortObject->Cookie = ServerPortCookie;
126 PortObject->MaxConnections = MaxConnections;
127
128 /* Insert the object */
129 Status = ObInsertObject(PortObject,
130 NULL,
132 0,
133 NULL,
135 if (NT_SUCCESS(Status))
136 {
137 /* Lock the connection list */
139
140 /* Add the new port object to the connection list and increment the count */
143
144 /* Unlock the connection list*/
146 }
147 }
148
149 if (!NT_SUCCESS(Status))
150 {
151 /* Allow the filter to be cleaned up */
153 }
154
155 return Status;
156}
static const INTERNET_PORT ServerPort
Definition: CWebService.cpp:11
POBJECT_TYPE ServerPortObjectType
Definition: Messaging.c:24
VOID FLTAPI FltObjectDereference(_Inout_ PVOID Object)
Definition: Object.c:53
NTSTATUS FLTAPI FltObjectReference(_Inout_ PVOID Object)
Definition: Object.c:41
LONG NTSTATUS
Definition: precomp.h:26
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
Definition: conport.c:36
#define NT_SUCCESS(StatCode)
Definition: apphelp.c:33
#define InsertTailList(ListHead, Entry)
_Must_inspect_result_ _In_opt_ PFLT_FILTER Filter
Definition: fltkernel.h:1801
_Must_inspect_result_ _Outptr_ PFLT_PORT _In_ POBJECT_ATTRIBUTES _In_opt_ PVOID _In_ PFLT_CONNECT_NOTIFY _In_ PFLT_DISCONNECT_NOTIFY _In_opt_ PFLT_MESSAGE_NOTIFY MessageNotifyCallback
Definition: fltkernel.h:1877
_Must_inspect_result_ _Outptr_ PFLT_PORT _In_ POBJECT_ATTRIBUTES _In_opt_ PVOID _In_ PFLT_CONNECT_NOTIFY ConnectNotifyCallback
Definition: fltkernel.h:1875
_Must_inspect_result_ _Outptr_ PFLT_PORT _In_ POBJECT_ATTRIBUTES _In_opt_ PVOID ServerPortCookie
Definition: fltkernel.h:1874
_Must_inspect_result_ _Outptr_ PFLT_PORT _In_ POBJECT_ATTRIBUTES _In_opt_ PVOID _In_ PFLT_CONNECT_NOTIFY _In_ PFLT_DISCONNECT_NOTIFY DisconnectNotifyCallback
Definition: fltkernel.h:1876
ULONG FltpObjectPointerReference(_In_ PFLT_OBJECT Object)
Definition: Object.c:322
Status
Definition: gdiplustypes.h:25
VOID FASTCALL ExAcquireFastMutex(IN PFAST_MUTEX FastMutex)
Definition: fmutex.c:23
VOID FASTCALL ExReleaseFastMutex(IN PFAST_MUTEX FastMutex)
Definition: fmutex.c:31
#define OBJ_KERNEL_HANDLE
Definition: winternl.h:231
static LONG MaxConnections
#define KernelMode
Definition: asm.h:38
#define FILE_READ_DATA
Definition: nt_native.h:628
#define STANDARD_RIGHTS_ALL
Definition: nt_native.h:69
PVOID *typedef PHANDLE
Definition: ntsecpkg.h:455
NTSTATUS NTAPI ObInsertObject(IN PVOID Object, IN PACCESS_STATE AccessState OPTIONAL, IN ACCESS_MASK DesiredAccess, IN ULONG ObjectPointerBias, OUT PVOID *NewObject OPTIONAL, OUT PHANDLE Handle)
Definition: obhandle.c:2935
NTSTATUS NTAPI ObCreateObject(IN KPROCESSOR_MODE ProbeMode OPTIONAL, IN POBJECT_TYPE Type, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN KPROCESSOR_MODE AccessMode, IN OUT PVOID ParseContext OPTIONAL, IN ULONG ObjectSize, IN ULONG PagedPoolCharge OPTIONAL, IN ULONG NonPagedPoolCharge OPTIONAL, OUT PVOID *Object)
Definition: oblife.c:1039
FLT_MUTEX_LIST_HEAD ConnectionList
Definition: fltmgrint.h:121
LIST_ENTRY mList
Definition: fltmgrint.h:56
FAST_MUTEX mLock
Definition: fltmgrint.h:55
PFLT_DISCONNECT_NOTIFY DisconnectNotify
Definition: fltmgrint.h:192
PFLT_MESSAGE_NOTIFY MessageNotify
Definition: fltmgrint.h:193
PFLT_CONNECT_NOTIFY ConnectNotify
Definition: fltmgrint.h:191
#define RtlZeroMemory(Destination, Length)
Definition: typedefs.h:262
#define STATUS_INVALID_PARAMETER
Definition: udferr_usr.h:135

◆ _Out_range_()

_Out_range_ ( )

◆ _Out_writes_bytes_opt_()

◆ _Return_type_success_()

typedef _Return_type_success_ ( return >=  0)

◆ _When_()

_When_ ( )
pure virtual

◆ NtClose()

◆ NtCreateFile()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtCreateFile ( _Out_ PHANDLE  FileHandle,
_In_ ACCESS_MASK  DesiredAccess,
_In_ POBJECT_ATTRIBUTES  ObjectAttributes,
_Out_ PIO_STATUS_BLOCK  IoStatusBlock,
_In_opt_ PLARGE_INTEGER  AllocationSize,
_In_ ULONG  FileAttributes,
_In_ ULONG  ShareAccess,
_In_ ULONG  CreateDisposition,
_In_ ULONG  CreateOptions,
_In_reads_bytes_opt_(EaLength) PVOID  EaBuffer,
_In_ ULONG  EaLength 
)

◆ NtDeviceIoControlFile()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtDeviceIoControlFile ( _In_ HANDLE  FileHandle,
_In_opt_ HANDLE  Event,
_In_opt_ PIO_APC_ROUTINE  ApcRoutine,
_In_opt_ PVOID  ApcContext,
_Out_ PIO_STATUS_BLOCK  IoStatusBlock,
_In_ ULONG  IoControlCode,
_In_reads_bytes_opt_(InputBufferLength) PVOID  InputBuffer,
_In_ ULONG  InputBufferLength,
_Out_writes_bytes_opt_(OutputBufferLength) PVOID  OutputBuffer,
_In_ ULONG  OutputBufferLength 
)

◆ NtNotifyChangeMultipleKeys()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtNotifyChangeMultipleKeys ( _In_ HANDLE  MasterKeyHandle,
_In_opt_ ULONG  Count,
_In_reads_opt_(Count) OBJECT_ATTRIBUTES  SubordinateObjects[],
_In_opt_ HANDLE  Event,
_In_opt_ PIO_APC_ROUTINE  ApcRoutine,
_In_opt_ PVOID  ApcContext,
_Out_ PIO_STATUS_BLOCK  IoStatusBlock,
_In_ ULONG  CompletionFilter,
_In_ BOOLEAN  WatchTree,
_Out_writes_bytes_opt_(BufferSize) PVOID  Buffer,
_In_ ULONG  BufferSize,
_In_ BOOLEAN  Asynchronous 
)

◆ NtOpenFile()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtOpenFile ( _Out_ PHANDLE  FileHandle,
_In_ ACCESS_MASK  DesiredAccess,
_In_ POBJECT_ATTRIBUTES  ObjectAttributes,
_Out_ PIO_STATUS_BLOCK  IoStatusBlock,
_In_ ULONG  ShareAccess,
_In_ ULONG  OpenOptions 
)

◆ NtQueryInformationProcess()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryInformationProcess ( _In_ HANDLE  ProcessHandle,
_In_ PROCESSINFOCLASS  ProcessInformationClass,
_Out_ PVOID  ProcessInformation,
_In_ ULONG  ProcessInformationLength,
_Out_opt_ PULONG  ReturnLength 
)

Definition at line 59 of file query.c.

65{
69 ULONG Length = 0;
70
71 PAGED_CODE();
72
73 /* Validate the information class */
74 Status = DefaultQueryInfoBufferCheck(ProcessInformationClass,
78 ProcessInformation,
79 ProcessInformationLength,
81 NULL,
83 if (!NT_SUCCESS(Status))
84 {
85 DPRINT1("NtQueryInformationProcess(ProcessInformationClass: %lu): Class validation failed! (Status: 0x%lx)\n",
86 ProcessInformationClass, Status);
87 return Status;
88 }
89
90 if (((ProcessInformationClass == ProcessCookie) ||
91 (ProcessInformationClass == ProcessImageInformation)) &&
93 {
94 /*
95 * Retrieving the process cookie is only allowed for the calling process
96 * itself! XP only allows NtCurrentProcess() as process handles even if
97 * a real handle actually represents the current process.
98 */
100 }
101
102 /* Check the information class */
103 switch (ProcessInformationClass)
104 {
105 /* Basic process information */
107 {
108 PPROCESS_BASIC_INFORMATION ProcessBasicInfo = (PPROCESS_BASIC_INFORMATION)ProcessInformation;
109
110 if (ProcessInformationLength != sizeof(PROCESS_BASIC_INFORMATION))
111 {
113 break;
114 }
115
116 /* Set the return length */
118
119 /* Reference the process */
124 (PVOID*)&Process,
125 NULL);
126 if (!NT_SUCCESS(Status)) break;
127
128 /* Protect writes with SEH */
130 {
131 /* Write all the information from the EPROCESS/KPROCESS */
132 ProcessBasicInfo->ExitStatus = Process->ExitStatus;
133 ProcessBasicInfo->PebBaseAddress = Process->Peb;
134 ProcessBasicInfo->AffinityMask = Process->Pcb.Affinity;
135 ProcessBasicInfo->UniqueProcessId = (ULONG_PTR)Process->
136 UniqueProcessId;
137 ProcessBasicInfo->InheritedFromUniqueProcessId =
138 (ULONG_PTR)Process->InheritedFromUniqueProcessId;
139 ProcessBasicInfo->BasePriority = Process->Pcb.BasePriority;
140
141 }
143 {
144 /* Get exception code */
146 }
147 _SEH2_END;
148
149 /* Dereference the process */
151 break;
152 }
153
154 /* Process quota limits */
156 {
157 QUOTA_LIMITS_EX QuotaLimits;
158 BOOLEAN Extended;
159
160 if (ProcessInformationLength != sizeof(QUOTA_LIMITS) &&
161 ProcessInformationLength != sizeof(QUOTA_LIMITS_EX))
162 {
164 break;
165 }
166
167 /* Set the return length */
168 Length = ProcessInformationLength;
169 Extended = (Length == sizeof(QUOTA_LIMITS_EX));
170
171 /* Reference the process */
176 (PVOID*)&Process,
177 NULL);
178 if (!NT_SUCCESS(Status)) break;
179
180 /* Indicate success */
182
183 RtlZeroMemory(&QuotaLimits, sizeof(QuotaLimits));
184
185 /* Get max/min working set sizes */
186 QuotaLimits.MaximumWorkingSetSize =
187 Process->Vm.MaximumWorkingSetSize << PAGE_SHIFT;
188 QuotaLimits.MinimumWorkingSetSize =
189 Process->Vm.MinimumWorkingSetSize << PAGE_SHIFT;
190
191 /* Get default time limits */
192 QuotaLimits.TimeLimit.QuadPart = -1LL;
193
194 /* Is quota block a default one? */
195 if (Process->QuotaBlock == &PspDefaultQuotaBlock)
196 {
197 /* Get default pools and pagefile limits */
198 QuotaLimits.PagedPoolLimit = (SIZE_T)-1;
199 QuotaLimits.NonPagedPoolLimit = (SIZE_T)-1;
200 QuotaLimits.PagefileLimit = (SIZE_T)-1;
201 }
202 else
203 {
204 /* Get limits from non-default quota block */
205 QuotaLimits.PagedPoolLimit =
206 Process->QuotaBlock->QuotaEntry[PsPagedPool].Limit;
207 QuotaLimits.NonPagedPoolLimit =
208 Process->QuotaBlock->QuotaEntry[PsNonPagedPool].Limit;
209 QuotaLimits.PagefileLimit =
210 Process->QuotaBlock->QuotaEntry[PsPageFile].Limit;
211 }
212
213 /* Get additional information, if needed */
214 if (Extended)
215 {
216 QuotaLimits.Flags |= (Process->Vm.Flags.MaximumWorkingSetHard ?
218 QuotaLimits.Flags |= (Process->Vm.Flags.MinimumWorkingSetHard ?
220
221 /* FIXME: Get the correct information */
222 //QuotaLimits.WorkingSetLimit = (SIZE_T)-1; // Not used on Win2k3, it is set to 0
223 QuotaLimits.CpuRateLimit.RateData = 0;
224 }
225
226 /* Protect writes with SEH */
228 {
229 RtlCopyMemory(ProcessInformation, &QuotaLimits, Length);
230 }
232 {
233 /* Get exception code */
235 }
236 _SEH2_END;
237
238 /* Dereference the process */
240 break;
241 }
242
244 {
245 PIO_COUNTERS IoCounters = (PIO_COUNTERS)ProcessInformation;
246 PROCESS_VALUES ProcessValues;
247
248 if (ProcessInformationLength != sizeof(IO_COUNTERS))
249 {
251 break;
252 }
253
254 Length = sizeof(IO_COUNTERS);
255
256 /* Reference the process */
261 (PVOID*)&Process,
262 NULL);
263 if (!NT_SUCCESS(Status)) break;
264
265 /* Query IO counters from the process */
266 KeQueryValuesProcess(&Process->Pcb, &ProcessValues);
267
269 {
270 RtlCopyMemory(IoCounters, &ProcessValues.IoInfo, sizeof(IO_COUNTERS));
271 }
273 {
274 /* Ignore exception */
275 }
276 _SEH2_END;
277
278 /* Set status to success in any case */
280
281 /* Dereference the process */
283 break;
284 }
285
286 /* Timing */
287 case ProcessTimes:
288 {
289 PKERNEL_USER_TIMES ProcessTime = (PKERNEL_USER_TIMES)ProcessInformation;
290 ULONG UserTime, KernelTime;
291
292 /* Set the return length */
293 if (ProcessInformationLength != sizeof(KERNEL_USER_TIMES))
294 {
296 break;
297 }
298
299 Length = sizeof(KERNEL_USER_TIMES);
300
301 /* Reference the process */
306 (PVOID*)&Process,
307 NULL);
308 if (!NT_SUCCESS(Status)) break;
309
310 /* Protect writes with SEH */
312 {
313 /* Copy time information from EPROCESS/KPROCESS */
314 KernelTime = KeQueryRuntimeProcess(&Process->Pcb, &UserTime);
315 ProcessTime->CreateTime = Process->CreateTime;
317 ProcessTime->KernelTime.QuadPart = (LONGLONG)KernelTime * KeMaximumIncrement;
318 ProcessTime->ExitTime = Process->ExitTime;
319 }
321 {
322 /* Get exception code */
324 }
325 _SEH2_END;
326
327 /* Dereference the process */
329 break;
330 }
331
332 /* Process Debug Port */
333 case ProcessDebugPort:
334
335 if (ProcessInformationLength != sizeof(HANDLE))
336 {
338 break;
339 }
340
341 /* Set the return length */
342 Length = sizeof(HANDLE);
343
344 /* Reference the process */
349 (PVOID*)&Process,
350 NULL);
351 if (!NT_SUCCESS(Status)) break;
352
353 /* Protect write with SEH */
355 {
356 /* Return whether or not we have a debug port */
357 *(PHANDLE)ProcessInformation = (Process->DebugPort ?
358 (HANDLE)-1 : NULL);
359 }
361 {
362 /* Get exception code */
364 }
365 _SEH2_END;
366
367 /* Dereference the process */
369 break;
370
372 {
373 ULONG HandleCount;
374
375 if (ProcessInformationLength != sizeof(ULONG))
376 {
378 break;
379 }
380
381 /* Set the return length*/
382 Length = sizeof(ULONG);
383
384 /* Reference the process */
389 (PVOID*)&Process,
390 NULL);
391 if (!NT_SUCCESS(Status)) break;
392
393 /* Count the number of handles this process has */
394 HandleCount = ObGetProcessHandleCount(Process);
395
396 /* Protect write in SEH */
398 {
399 /* Return the count of handles */
400 *(PULONG)ProcessInformation = HandleCount;
401 }
403 {
404 /* Get the exception code */
406 }
407 _SEH2_END;
408
409 /* Dereference the process */
411 break;
412 }
413
414 /* Session ID for the process */
416 {
418
419 if (ProcessInformationLength != sizeof(PROCESS_SESSION_INFORMATION))
420 {
422 break;
423 }
424
425 /* Set the return length*/
427
428 /* Reference the process */
433 (PVOID*)&Process,
434 NULL);
435 if (!NT_SUCCESS(Status)) break;
436
437 /* Enter SEH for write safety */
439 {
440 /* Write back the Session ID */
442 }
444 {
445 /* Get the exception code */
447 }
448 _SEH2_END;
449
450 /* Dereference the process */
452 break;
453 }
454
455 /* Virtual Memory Statistics */
457 {
458 PVM_COUNTERS VmCounters = (PVM_COUNTERS)ProcessInformation;
459
460 /* Validate the input length */
461 if ((ProcessInformationLength != sizeof(VM_COUNTERS)) &&
462 (ProcessInformationLength != sizeof(VM_COUNTERS_EX)))
463 {
465 break;
466 }
467
468 /* Reference the process */
473 (PVOID*)&Process,
474 NULL);
475 if (!NT_SUCCESS(Status)) break;
476
477 /* Enter SEH for write safety */
479 {
480 /* Return data from EPROCESS */
481 VmCounters->PeakVirtualSize = Process->PeakVirtualSize;
482 VmCounters->VirtualSize = Process->VirtualSize;
483 VmCounters->PageFaultCount = Process->Vm.PageFaultCount;
484 VmCounters->PeakWorkingSetSize = Process->Vm.PeakWorkingSetSize;
485 VmCounters->WorkingSetSize = Process->Vm.WorkingSetSize;
486 VmCounters->QuotaPeakPagedPoolUsage = Process->QuotaPeak[PsPagedPool];
487 VmCounters->QuotaPagedPoolUsage = Process->QuotaUsage[PsPagedPool];
488 VmCounters->QuotaPeakNonPagedPoolUsage = Process->QuotaPeak[PsNonPagedPool];
489 VmCounters->QuotaNonPagedPoolUsage = Process->QuotaUsage[PsNonPagedPool];
490 VmCounters->PagefileUsage = Process->QuotaUsage[PsPageFile] << PAGE_SHIFT;
491 VmCounters->PeakPagefileUsage = Process->QuotaPeak[PsPageFile] << PAGE_SHIFT;
492 //VmCounters->PrivateUsage = Process->CommitCharge << PAGE_SHIFT;
493 //
494
495 /* Set the return length */
496 Length = ProcessInformationLength;
497 }
499 {
500 /* Get the exception code */
502 }
503 _SEH2_END;
504
505 /* Dereference the process */
507 break;
508 }
509
510 /* Hard Error Processing Mode */
512
513 if (ProcessInformationLength != sizeof(ULONG))
514 {
516 break;
517 }
518
519 /* Set the return length*/
520 Length = sizeof(ULONG);
521
522 /* Reference the process */
527 (PVOID*)&Process,
528 NULL);
529 if (!NT_SUCCESS(Status)) break;
530
531 /* Enter SEH for writing back data */
533 {
534 /* Write the current processing mode */
535 *(PULONG)ProcessInformation = Process->
536 DefaultHardErrorProcessing;
537 }
539 {
540 /* Get the exception code */
542 }
543 _SEH2_END;
544
545 /* Dereference the process */
547 break;
548
549 /* Priority Boosting status */
551
552 if (ProcessInformationLength != sizeof(ULONG))
553 {
555 break;
556 }
557
558 /* Set the return length */
559 Length = sizeof(ULONG);
560
561 /* Reference the process */
566 (PVOID*)&Process,
567 NULL);
568 if (!NT_SUCCESS(Status)) break;
569
570 /* Enter SEH for writing back data */
572 {
573 /* Return boost status */
574 *(PULONG)ProcessInformation = Process->Pcb.DisableBoost ?
575 TRUE : FALSE;
576 }
578 {
579 /* Get the exception code */
581 }
582 _SEH2_END;
583
584 /* Dereference the process */
586 break;
587
588 /* DOS Device Map */
589 case ProcessDeviceMap:
590 {
591 ULONG Flags;
592
593 if (ProcessInformationLength == sizeof(PROCESS_DEVICEMAP_INFORMATION_EX))
594 {
595 /* Protect read in SEH */
597 {
598 PPROCESS_DEVICEMAP_INFORMATION_EX DeviceMapEx = ProcessInformation;
599
600 Flags = DeviceMapEx->Flags;
601 }
603 {
604 /* Get the exception code */
606 _SEH2_YIELD(break);
607 }
608 _SEH2_END;
609
610 /* Only one flag is supported and it needs LUID mappings */
611 if ((Flags & ~PROCESS_LUID_DOSDEVICES_ONLY) != 0 ||
613 {
615 break;
616 }
617 }
618 else
619 {
620 /* This has to be the size of the Query union field for x64 compatibility! */
621 if (ProcessInformationLength != RTL_FIELD_SIZE(PROCESS_DEVICEMAP_INFORMATION, Query))
622 {
624 break;
625 }
626
627 /* No flags for standard call */
628 Flags = 0;
629 }
630
631 /* Set the return length */
632 Length = ProcessInformationLength;
633
634 /* Reference the process */
639 (PVOID*)&Process,
640 NULL);
641 if (!NT_SUCCESS(Status)) break;
642
643 /* Query the device map information */
645 ProcessInformation,
646 Flags);
647
648 /* Dereference the process */
650 break;
651 }
652
653 /* Priority class */
655 {
656 PPROCESS_PRIORITY_CLASS PsPriorityClass = (PPROCESS_PRIORITY_CLASS)ProcessInformation;
657
658 if (ProcessInformationLength != sizeof(PROCESS_PRIORITY_CLASS))
659 {
661 break;
662 }
663
664 /* Set the return length*/
666
667 /* Reference the process */
672 (PVOID*)&Process,
673 NULL);
674 if (!NT_SUCCESS(Status)) break;
675
676 /* Enter SEH for writing back data */
678 {
679 /* Return current priority class */
680 PsPriorityClass->PriorityClass = Process->PriorityClass;
681 PsPriorityClass->Foreground = FALSE;
682 }
684 {
685 /* Get the exception code */
687 }
688 _SEH2_END;
689
690 /* Dereference the process */
692 break;
693 }
694
696 {
698
699 /* Reference the process */
704 (PVOID*)&Process,
705 NULL);
706 if (!NT_SUCCESS(Status)) break;
707
708 /* Get the image path */
710 if (NT_SUCCESS(Status))
711 {
712 /* Set the return length */
713 Length = ImageName->MaximumLength +
715
716 /* Make sure it's large enough */
717 if (Length <= ProcessInformationLength)
718 {
719 /* Enter SEH to protect write */
721 {
722 /* Copy it */
723 RtlCopyMemory(ProcessInformation,
724 ImageName,
725 Length);
726
727 /* Update pointer */
728 ((PUNICODE_STRING)ProcessInformation)->Buffer =
729 (PWSTR)((PUNICODE_STRING)ProcessInformation + 1);
730 }
732 {
733 /* Get the exception code */
735 }
736 _SEH2_END;
737 }
738 else
739 {
740 /* Buffer too small */
742 }
743
744 /* Free the image path */
746 }
747 /* Dereference the process */
749 break;
750 }
751
752#if (NTDDI_VERSION >= NTDDI_VISTA) || (DLL_EXPORT_VERSION >= _WIN32_WINNT_VISTA)
754 {
757
758 /* Reference the process */
760 PROCESS_QUERY_INFORMATION, // FIXME: Use PROCESS_QUERY_LIMITED_INFORMATION if implemented
763 (PVOID*)&Process,
764 NULL);
765 if (!NT_SUCCESS(Status))
766 {
767 break;
768 }
769
770 /* Get the image path */
773 if (!NT_SUCCESS(Status))
774 {
775 break;
776 }
779 if (!NT_SUCCESS(Status))
780 {
781 break;
782 }
783
784 /* Determine return length and output */
785 Length = sizeof(UNICODE_STRING) + ObjectNameInformation->Name.MaximumLength;
786 if (Length <= ProcessInformationLength)
787 {
789 {
790 PUNICODE_STRING ImageName = (PUNICODE_STRING)ProcessInformation;
791 ImageName->Length = ObjectNameInformation->Name.Length;
792 ImageName->MaximumLength = ObjectNameInformation->Name.MaximumLength;
793 if (ObjectNameInformation->Name.MaximumLength)
794 {
795 ImageName->Buffer = (PWSTR)(ImageName + 1);
796 RtlCopyMemory(ImageName->Buffer,
797 ObjectNameInformation->Name.Buffer,
798 ObjectNameInformation->Name.MaximumLength);
799 }
800 else
801 {
802 ASSERT(ImageName->Length == 0);
803 ImageName->Buffer = NULL;
804 }
805 }
807 {
809 }
810 _SEH2_END;
811 }
812 else
813 {
815 }
817
818 break;
819 }
820#endif /* (NTDDI_VERSION >= NTDDI_VISTA) || (DLL_EXPORT_VERSION >= _WIN32_WINNT_VISTA) */
821
823
824 if (ProcessInformationLength != sizeof(ULONG))
825 {
827 break;
828 }
829
830 /* Set the return length*/
831 Length = sizeof(ULONG);
832
833 /* Reference the process */
838 (PVOID*)&Process,
839 NULL);
840 if (!NT_SUCCESS(Status)) break;
841
842 /* Enter SEH for writing back data */
844 {
845 /* Return the debug flag state */
846 *(PULONG)ProcessInformation = Process->NoDebugInherit ? 0 : 1;
847 }
849 {
850 /* Get the exception code */
852 }
853 _SEH2_END;
854
855 /* Dereference the process */
857 break;
858
860
861 if (ProcessInformationLength != sizeof(ULONG))
862 {
864 break;
865 }
866
867 /* Set the return length */
868 Length = sizeof(ULONG);
869
870 /* Reference the process */
875 (PVOID*)&Process,
876 NULL);
877 if (!NT_SUCCESS(Status)) break;
878
879 /* Enter SEH for writing back data */
881 {
882 /* Return the BreakOnTermination state */
883 *(PULONG)ProcessInformation = Process->BreakOnTermination;
884 }
886 {
887 /* Get the exception code */
889 }
890 _SEH2_END;
891
892 /* Dereference the process */
894 break;
895
896 /* Per-process security cookie */
897 case ProcessCookie:
898 {
900
901 if (ProcessInformationLength != sizeof(ULONG))
902 {
903 /* Length size wrong, bail out */
905 break;
906 }
907
908 /* Get the current process and cookie */
910 Cookie = Process->Cookie;
911 if (!Cookie)
912 {
913 LARGE_INTEGER SystemTime;
914 ULONG NewCookie;
915 PKPRCB Prcb;
916
917 /* Generate a new cookie */
918 KeQuerySystemTime(&SystemTime);
919 Prcb = KeGetCurrentPrcb();
920 NewCookie = Prcb->KeSystemCalls ^ Prcb->InterruptTime ^
921 SystemTime.u.LowPart ^ SystemTime.u.HighPart;
922
923 /* Set the new cookie or return the current one */
925 NewCookie,
926 Cookie);
927 if (!Cookie) Cookie = NewCookie;
928
929 /* Set the return length */
930 Length = sizeof(ULONG);
931 }
932
933 /* Indicate success */
935
936 /* Enter SEH to protect write */
938 {
939 /* Write back the cookie */
940 *(PULONG)ProcessInformation = Cookie;
941 }
943 {
944 /* Get the exception code */
946 }
947 _SEH2_END;
948 break;
949 }
950
952
953 if (ProcessInformationLength != sizeof(SECTION_IMAGE_INFORMATION))
954 {
955 /* Break out */
957 break;
958 }
959
960 /* Set the length required and validate it */
962
963 /* Indicate success */
965
966 /* Enter SEH to protect write */
968 {
970 }
972 {
973 /* Get the exception code */
975 }
976 _SEH2_END;
977 break;
978
980 {
981 HANDLE DebugPort = NULL;
982
983 if (ProcessInformationLength != sizeof(HANDLE))
984 {
986 break;
987 }
988
989 /* Set the return length */
990 Length = sizeof(HANDLE);
991
992 /* Reference the process */
997 (PVOID*)&Process,
998 NULL);
999 if (!NT_SUCCESS(Status)) break;
1000
1001 /* Get the debug port. Continue even if this fails. */
1003
1004 /* Let go of the process */
1006
1007 /* Protect write in SEH */
1008 _SEH2_TRY
1009 {
1010 /* Return debug port's handle */
1011 *(PHANDLE)ProcessInformation = DebugPort;
1012 }
1014 {
1015 if (DebugPort)
1016 ObCloseHandle(DebugPort, PreviousMode);
1017
1018 /* Get the exception code.
1019 * Note: This overwrites any previous failure status. */
1021 }
1022 _SEH2_END;
1023 break;
1024 }
1025
1027 DPRINT1("Handle tracing not implemented: %lu\n", ProcessInformationClass);
1029 break;
1030
1032
1033 if (ProcessInformationLength != sizeof(ULONG))
1034 {
1036 break;
1037 }
1038
1039 /* Set the return length */
1040 Length = sizeof(ULONG);
1041
1042 /* Indicate success */
1044
1045 /* Protect write in SEH */
1046 _SEH2_TRY
1047 {
1048 /* Query Ob */
1049 *(PULONG)ProcessInformation = ObIsLUIDDeviceMapsEnabled();
1050 }
1052 {
1053 /* Get the exception code */
1055 }
1056 _SEH2_END;
1057 break;
1058
1060
1061 if (ProcessInformationLength != sizeof(ULONG))
1062 {
1064 break;
1065 }
1066
1067 /* Set the return length */
1068 Length = sizeof(ULONG);
1069
1070 /* Reference the process */
1075 (PVOID*)&Process,
1076 NULL);
1077 if (!NT_SUCCESS(Status)) break;
1078
1079 /* Protect write in SEH */
1080 _SEH2_TRY
1081 {
1082 /* Return if the flag is set */
1083 *(PULONG)ProcessInformation = (ULONG)Process->VdmAllowed;
1084 }
1086 {
1087 /* Get the exception code */
1089 }
1090 _SEH2_END;
1091
1092 /* Dereference the process */
1094 break;
1095
1097 {
1098 ULONG_PTR Wow64 = 0;
1099
1100 if (ProcessInformationLength != sizeof(ULONG_PTR))
1101 {
1103 break;
1104 }
1105
1106 /* Set the return length */
1107 Length = sizeof(ULONG_PTR);
1108
1109 /* Reference the process */
1114 (PVOID*)&Process,
1115 NULL);
1116 if (!NT_SUCCESS(Status)) break;
1117
1118#ifdef _WIN64
1119 /* Make sure the process isn't dying */
1120 if (ExAcquireRundownProtection(&Process->RundownProtect))
1121 {
1122 /* Get the WOW64 process structure */
1123 Wow64 = (ULONG_PTR)Process->Wow64Process;
1124 /* Release the lock */
1125 ExReleaseRundownProtection(&Process->RundownProtect);
1126 }
1127#endif
1128
1129 /* Dereference the process */
1131
1132 /* Protect write with SEH */
1133 _SEH2_TRY
1134 {
1135 /* Return the Wow64 process information */
1136 *(PULONG_PTR)ProcessInformation = Wow64;
1137 }
1139 {
1140 /* Get exception code */
1142 }
1143 _SEH2_END;
1144 break;
1145 }
1146
1148 {
1149 ULONG ExecuteOptions = 0;
1150
1151 if (ProcessInformationLength != sizeof(ULONG))
1152 {
1154 break;
1155 }
1156
1157 /* Set the return length */
1158 Length = sizeof(ULONG);
1159
1161 {
1163 break;
1164 }
1165
1166 /* Get the options */
1167 Status = MmGetExecuteOptions(&ExecuteOptions);
1168 if (NT_SUCCESS(Status))
1169 {
1170 /* Protect write with SEH */
1171 _SEH2_TRY
1172 {
1173 /* Return them */
1174 *(PULONG)ProcessInformation = ExecuteOptions;
1175 }
1177 {
1178 /* Get exception code */
1180 }
1181 _SEH2_END;
1182 }
1183 break;
1184 }
1185
1187 DPRINT1("VDM/16-bit not implemented: %lu\n", ProcessInformationClass);
1189 break;
1190
1192 DPRINT1("WS Watch not implemented: %lu\n", ProcessInformationClass);
1194 break;
1195
1197 DPRINT1("Pool limits not implemented: %lu\n", ProcessInformationClass);
1199 break;
1200
1201 /* Not supported by Server 2003 */
1202 default:
1203 DPRINT1("Unsupported info class: %lu\n", ProcessInformationClass);
1205 }
1206
1207 /* Check if caller wants the return length and if there is one */
1208 if (ReturnLength != NULL && Length != 0)
1209 {
1210 /* Protect write with SEH */
1211 _SEH2_TRY
1212 {
1214 }
1216 {
1217 /* Get exception code.
1218 * Note: This overwrites any previous failure status. */
1220 }
1221 _SEH2_END;
1222 }
1223
1224 return Status;
1225}
#define PAGED_CODE()
@ ObjectNameInformation
Definition: DriverTester.h:55
_In_ PVOID _In_ ULONG _Out_ PVOID _In_ ULONG _Inout_ PULONG ReturnLength
_In_ PVOID _In_ ULONG _Out_ PVOID _In_ ULONG _Inout_ PULONG _In_ KPROCESSOR_MODE PreviousMode
unsigned char BOOLEAN
#define RTL_NUMBER_OF(x)
Definition: RtlRegistry.c:12
#define DPRINT1
Definition: precomp.h:8
BOOL Query(LPCTSTR *ServiceArgs, DWORD ArgCount, BOOL bExtended)
Definition: query.c:292
@ ProcessDebugPort
Definition: cicbase.cpp:64
@ ProcessBreakOnTermination
Definition: cicbase.cpp:67
@ ProcessBasicInformation
Definition: cicbase.cpp:63
@ ProcessWow64Information
Definition: cicbase.cpp:65
@ ProcessImageFileName
Definition: cicbase.cpp:66
#define STATUS_NOT_IMPLEMENTED
Definition: d3dkmdt.h:42
NTSTATUS NTAPI DbgkOpenProcessDebugPort(IN PEPROCESS Process, IN KPROCESSOR_MODE PreviousMode, OUT HANDLE *DebugHandle)
Definition: dbgkobj.c:1526
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
#define ULONG_PTR
Definition: config.h:101
UNICODE_STRING * PUNICODE_STRING
Definition: env_spec_w32.h:373
#define PAGE_SHIFT
Definition: env_spec_w32.h:45
#define KeQuerySystemTime(t)
Definition: env_spec_w32.h:570
#define ExFreePool(addr)
Definition: env_spec_w32.h:352
struct _UNICODE_STRING UNICODE_STRING
#define ExReleaseRundownProtection
Definition: ex.h:139
#define ExGetPreviousMode
Definition: ex.h:143
#define ExAcquireRundownProtection
Definition: ex.h:138
_Must_inspect_result_ _In_ PLARGE_INTEGER _In_ PLARGE_INTEGER _In_ ULONG _In_ PFILE_OBJECT _In_ PVOID Process
Definition: fsrtlfuncs.h:223
#define ICIF_PROBE_READ
Definition: icif.h:25
struct _PROCESS_PRIORITY_CLASS PROCESS_PRIORITY_CLASS
#define PROCESS_QUERY_INFORMATION
Definition: pstypes.h:167
struct _PROCESS_PRIORITY_CLASS * PPROCESS_PRIORITY_CLASS
@ PsNonPagedPool
Definition: pstypes.h:1067
@ PsPageFile
Definition: pstypes.h:1069
@ PsPagedPool
Definition: pstypes.h:1068
struct _PROCESS_BASIC_INFORMATION * PPROCESS_BASIC_INFORMATION
struct _PROCESS_BASIC_INFORMATION PROCESS_BASIC_INFORMATION
#define EXCEPTION_EXECUTE_HANDLER
Definition: excpt.h:90
struct _KERNEL_USER_TIMES KERNEL_USER_TIMES
struct _KERNEL_USER_TIMES * PKERNEL_USER_TIMES
@ ProcessLUIDDeviceMapsEnabled
Definition: winternl.h:1910
@ ProcessWx86Information
Definition: winternl.h:1901
@ ProcessDebugFlags
Definition: winternl.h:1913
@ ProcessSessionInformation
Definition: winternl.h:1906
@ ProcessVmCounters
Definition: winternl.h:1885
@ ProcessPriorityClass
Definition: winternl.h:1900
@ ProcessPriorityBoost
Definition: winternl.h:1904
@ ProcessImageInformation
Definition: winternl.h:1919
@ ProcessExecuteFlags
Definition: winternl.h:1916
@ ProcessCookie
Definition: winternl.h:1918
@ ProcessPooledUsageAndLimits
Definition: winternl.h:1896
@ ProcessIoCounters
Definition: winternl.h:1884
@ ProcessImageFileNameWin32
Definition: winternl.h:1925
@ ProcessDefaultHardErrorMode
Definition: winternl.h:1894
@ ProcessDeviceMap
Definition: winternl.h:1905
@ ProcessQuotaLimits
Definition: winternl.h:1883
@ ProcessHandleTracing
Definition: winternl.h:1914
@ ProcessTimes
Definition: winternl.h:1886
@ ProcessDebugObjectHandle
Definition: winternl.h:1912
@ ProcessWorkingSetWatch
Definition: winternl.h:1897
@ ProcessLdtInformation
Definition: winternl.h:1892
@ ProcessHandleCount
Definition: winternl.h:1902
struct _VM_COUNTERS * PVM_COUNTERS
struct _VM_COUNTERS_EX VM_COUNTERS_EX
#define QUOTA_LIMITS_HARDWS_MIN_DISABLE
#define PROCESS_LUID_DOSDEVICES_ONLY
Definition: pstypes.h:228
struct _IO_COUNTERS IO_COUNTERS
struct _PROCESS_SESSION_INFORMATION PROCESS_SESSION_INFORMATION
struct _PROCESS_SESSION_INFORMATION * PPROCESS_SESSION_INFORMATION
#define QUOTA_LIMITS_HARDWS_MAX_DISABLE
struct _QUOTA_LIMITS_EX QUOTA_LIMITS_EX
#define QUOTA_LIMITS_HARDWS_MAX_ENABLE
#define QUOTA_LIMITS_HARDWS_MIN_ENABLE
struct _IO_COUNTERS * PIO_COUNTERS
#define InterlockedCompareExchange
Definition: interlocked.h:119
#define RTL_FIELD_SIZE(type, field)
Definition: kdb_expr.c:86
if(dx< 0)
Definition: linetemp.h:194
#define ASSERT(a)
Definition: mode.c:44
#define ExFreePoolWithTag(_P, _T)
Definition: module.h:1109
static const char * ImageName
Definition: image.c:34
FORCEINLINE struct _KPRCB * KeGetCurrentPrcb(VOID)
Definition: ketypes.h:1187
_In_ HANDLE ProcessHandle
Definition: mmfuncs.h:403
struct _SECTION_IMAGE_INFORMATION SECTION_IMAGE_INFORMATION
#define NtCurrentProcess()
Definition: nt_native.h:1660
struct _OBJECT_NAME_INFORMATION OBJECT_NAME_INFORMATION
ULONG NTAPI KeQueryRuntimeProcess(IN PKPROCESS Process, OUT PULONG UserTime)
Definition: procobj.c:860
VOID NTAPI KeQueryValuesProcess(IN PKPROCESS Process, PPROCESS_VALUES Values)
Definition: procobj.c:525
VOID NTAPI MmGetImageInformation(OUT PSECTION_IMAGE_INFORMATION ImageInformation)
Definition: section.c:1617
NTSTATUS NTAPI MmGetExecuteOptions(IN PULONG ExecuteOptions)
Definition: pagfault.c:2653
static __inline NTSTATUS DefaultQueryInfoBufferCheck(_In_ ULONG Class, _In_ const INFORMATION_CLASS_INFO *ClassList, _In_ ULONG ClassListEntries, _In_ ULONG Flags, _In_opt_ PVOID Buffer, _In_ ULONG BufferLength, _In_opt_ PULONG ReturnLength, _In_opt_ PULONG_PTR ReturnLengthPtr, _In_ KPROCESSOR_MODE PreviousMode)
Probe helper that validates the provided parameters whenever a NtQuery*** system call is invoked from...
Definition: probe.h:219
NTSTATUS NTAPI IoQueryFileDosDeviceName(IN PFILE_OBJECT FileObject, OUT POBJECT_NAME_INFORMATION *ObjectNameInformation)
Definition: file.c:3664
ULONG KeMaximumIncrement
Definition: clock.c:20
POBJECT_TYPE PsProcessType
Definition: process.c:20
ULONG NTAPI PsGetProcessSessionId(IN PEPROCESS Process)
Definition: process.c:1163
NTSTATUS NTAPI PsReferenceProcessFilePointer(IN PEPROCESS Process, OUT PFILE_OBJECT *FileObject)
Definition: query.c:24
NTSTATUS NTAPI SeLocateProcessImageName(_In_ PEPROCESS Process, _Out_ PUNICODE_STRING *ProcessImageName)
Finds the process image name of a specific process.
Definition: audit.c:199
#define STATUS_INVALID_INFO_CLASS
Definition: ntstatus.h:333
ULONG NTAPI ObGetProcessHandleCount(IN PEPROCESS Process)
Definition: obhandle.c:56
ULONG NTAPI ObIsLUIDDeviceMapsEnabled(VOID)
Definition: devicemap.c:662
NTSTATUS NTAPI ObQueryDeviceMapInformation(_In_opt_ PEPROCESS Process, _Out_ PPROCESS_DEVICEMAP_INFORMATION DeviceMapInfo, _In_ ULONG Flags)
Definition: devicemap.c:539
NTSTATUS NTAPI ObCloseHandle(IN HANDLE Handle, IN KPROCESSOR_MODE AccessMode)
Definition: obhandle.c:3379
NTSTATUS NTAPI ObReferenceObjectByHandle(IN HANDLE Handle, IN ACCESS_MASK DesiredAccess, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode, OUT PVOID *Object, OUT POBJECT_HANDLE_INFORMATION HandleInformation OPTIONAL)
Definition: obref.c:494
long LONG
Definition: pedump.c:60
EPROCESS_QUOTA_BLOCK PspDefaultQuotaBlock
Definition: quota.c:16
static const INFORMATION_CLASS_INFO PsProcessInfoClass[]
Definition: ps_i.h:15
#define _SEH2_GetExceptionCode()
Definition: pseh2_64.h:181
#define _SEH2_EXCEPT(...)
Definition: pseh2_64.h:82
#define _SEH2_END
Definition: pseh2_64.h:171
#define _SEH2_TRY
Definition: pseh2_64.h:71
#define _SEH2_YIELD(__stmt)
Definition: pseh2_64.h:184
#define STATUS_SUCCESS
Definition: shellext.h:65
LARGE_INTEGER UserTime
Definition: winternl.h:2377
LARGE_INTEGER CreateTime
Definition: winternl.h:2374
LARGE_INTEGER KernelTime
Definition: winternl.h:2376
LARGE_INTEGER ExitTime
Definition: winternl.h:2375
ULONG InterruptTime
Definition: ketypes.h:834
ULONG KeSystemCalls
Definition: ketypes.h:745
ULONG_PTR InheritedFromUniqueProcessId
Definition: pstypes.h:362
IO_COUNTERS IoInfo
Definition: ke.h:48
SIZE_T MaximumWorkingSetSize
Definition: pstypes.h:71
SIZE_T PagedPoolLimit
Definition: pstypes.h:68
SIZE_T PagefileLimit
Definition: pstypes.h:72
LARGE_INTEGER TimeLimit
Definition: pstypes.h:73
RATE_QUOTA_LIMIT CpuRateLimit
Definition: pstypes.h:79
SIZE_T NonPagedPoolLimit
Definition: pstypes.h:69
SIZE_T MinimumWorkingSetSize
Definition: pstypes.h:70
SIZE_T PeakWorkingSetSize
Definition: winternl.h:3134
SIZE_T PeakPagefileUsage
Definition: winternl.h:3141
ULONG PageFaultCount
Definition: winternl.h:3133
SIZE_T QuotaPagedPoolUsage
Definition: winternl.h:3137
SIZE_T QuotaPeakPagedPoolUsage
Definition: winternl.h:3136
SIZE_T QuotaPeakNonPagedPoolUsage
Definition: winternl.h:3138
SIZE_T PeakVirtualSize
Definition: winternl.h:3131
SIZE_T VirtualSize
Definition: winternl.h:3132
SIZE_T QuotaNonPagedPoolUsage
Definition: winternl.h:3139
SIZE_T WorkingSetSize
Definition: winternl.h:3135
SIZE_T PagefileUsage
Definition: winternl.h:3140
#define TAG_SEPA
Definition: tag.h:155
uint16_t * PWSTR
Definition: typedefs.h:56
uint32_t * PULONG_PTR
Definition: typedefs.h:65
uint32_t * PULONG
Definition: typedefs.h:59
int64_t LONGLONG
Definition: typedefs.h:68
PVOID HANDLE
Definition: typedefs.h:73
ULONG_PTR SIZE_T
Definition: typedefs.h:80
#define RtlCopyMemory(Destination, Source, Length)
Definition: typedefs.h:263
uint32_t ULONG_PTR
Definition: typedefs.h:65
uint32_t ULONG
Definition: typedefs.h:59
#define STATUS_INFO_LENGTH_MISMATCH
Definition: udferr_usr.h:133
LONGLONG QuadPart
Definition: typedefs.h:114
struct _LARGE_INTEGER::@2475 u
ULONG RateData
Definition: pstypes.h:60
_In_ WDFREQUEST _In_ WDFFILEOBJECT FileObject
Definition: wdfdevice.h:550
_Must_inspect_result_ _In_ ULONG Flags
Definition: wsk.h:170
_In_opt_ PVOID _Out_ PLARGE_INTEGER Cookie
Definition: cmfuncs.h:14
* PFILE_OBJECT
Definition: iotypes.h:1998
_Out_ PULONG UserTime
Definition: kefuncs.h:759
CCHAR KPROCESSOR_MODE
Definition: ketypes.h:7
#define ObDereferenceObject
Definition: obfuncs.h:203
#define PsGetCurrentProcess
Definition: psfuncs.h:17

◆ NtQueryInformationThread()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryInformationThread ( _In_ HANDLE  ThreadHandle,
_In_ THREADINFOCLASS  ThreadInformationClass,
_Out_ PVOID  ThreadInformation,
_In_ ULONG  ThreadInformationLength,
_Out_opt_ PULONG  ReturnLength 
)

◆ NtQueryMultipleValueKey()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQueryMultipleValueKey ( _In_ HANDLE  KeyHandle,
_Inout_updates_(EntryCount) PKEY_VALUE_ENTRY  ValueEntries,
_In_ ULONG  EntryCount,
_Out_writes_bytes_ *BufferLength PVOID  ValueBuffer,
_Inout_ PULONG  BufferLength,
_Out_opt_ PULONG  RequiredBufferLength 
)

◆ NtQuerySystemInformation()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQuerySystemInformation ( _In_ SYSTEM_INFORMATION_CLASS  SystemInformationClass,
_Out_ PVOID  SystemInformation,
_In_ ULONG  InformationLength,
_Out_opt_ PULONG  ResultLength 
)

◆ NtQuerySystemTime()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtQuerySystemTime ( _Out_ PLARGE_INTEGER  SystemTime)

◆ NtRenameKey()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtRenameKey ( _In_ HANDLE  KeyHandle,
_In_ PUNICODE_STRING  NewName 
)

◆ NtSetInformationKey()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtSetInformationKey ( _In_ HANDLE  KeyHandle,
_In_ _Strict_type_match_ KEY_SET_INFORMATION_CLASS  KeySetInformationClass,
_In_reads_bytes_(KeySetInformationLength) PVOID  KeySetInformation,
_In_ ULONG  KeySetInformationLength 
)

◆ NtWaitForSingleObject()

__kernel_entry NTSYSCALLAPI NTSTATUS NTAPI NtWaitForSingleObject ( _In_ HANDLE  Object,
_In_ BOOLEAN  Alertable,
_In_opt_ PLARGE_INTEGER  Timeout 
)

◆ RtlAnsiStringToUnicodeString()

NTSTATUS NTAPI RtlAnsiStringToUnicodeString ( PUNICODE_STRING  DestinationString,
PCANSI_STRING  SourceString,
BOOLEAN  AllocateDestinationString 
)

◆ RtlCharToInteger()

NTSTATUS NTAPI RtlCharToInteger ( PCSZ  String,
ULONG  Base,
PULONG  Value 
)

Definition at line 261 of file unicode.c.

265{
266 CHAR chCurrent;
267 int digit;
268 ULONG RunningTotal = 0;
269 char bMinus = 0;
270
271 /* skip leading whitespaces */
272 while (*str != '\0' && *str <= ' ') str++;
273
274 /* Check for +/- */
275 if (*str == '+')
276 {
277 str++;
278 }
279 else if (*str == '-')
280 {
281 bMinus = 1;
282 str++;
283 }
284
285 /* base = 0 means autobase */
286 if (base == 0)
287 {
288 base = 10;
289
290 if (str[0] == '0')
291 {
292 if (str[1] == 'b')
293 {
294 str += 2;
295 base = 2;
296 }
297 else if (str[1] == 'o')
298 {
299 str += 2;
300 base = 8;
301 }
302 else if (str[1] == 'x')
303 {
304 str += 2;
305 base = 16;
306 }
307 }
308 }
309 else if (base != 2 && base != 8 && base != 10 && base != 16)
310 {
312 }
313
314 if (value == NULL) return STATUS_ACCESS_VIOLATION;
315
316 while (*str != '\0')
317 {
318 chCurrent = *str;
319
320 if (chCurrent >= '0' && chCurrent <= '9')
321 {
322 digit = chCurrent - '0';
323 }
324 else if (chCurrent >= 'A' && chCurrent <= 'Z')
325 {
326 digit = chCurrent - 'A' + 10;
327 }
328 else if (chCurrent >= 'a' && chCurrent <= 'z')
329 {
330 digit = chCurrent - 'a' + 10;
331 }
332 else
333 {
334 digit = -1;
335 }
336
337 if (digit < 0 || digit >= (int)base) break;
338
339 RunningTotal = RunningTotal * base + digit;
340 str++;
341 }
342
343 *value = bMinus ? (0 - RunningTotal) : RunningTotal;
344 return STATUS_SUCCESS;
345}
#define STATUS_ACCESS_VIOLATION
const WCHAR * str
Definition: pdh_main.c:96
char CHAR
Definition: xmlstorage.h:175

◆ RtlConvertSidToUnicodeString()

NTSTATUS NTAPI RtlConvertSidToUnicodeString ( PUNICODE_STRING  UnicodeString,
PSID  Sid,
BOOLEAN  AllocateDestinationString 
)

◆ RtlFreeAnsiString()

VOID NTAPI RtlFreeAnsiString ( PANSI_STRING  AnsiString)

◆ RtlFreeOemString()

◆ RtlFreeUnicodeString()

VOID NTAPI RtlFreeUnicodeString ( PUNICODE_STRING  UnicodeString)

◆ RtlInitAnsiString()

VOID NTAPI RtlInitAnsiString ( PANSI_STRING  DestinationString,
PCSZ  SourceString 
)

◆ RtlInitString()

VOID NTAPI RtlInitString ( PSTRING  DestinationString,
PCSZ  SourceString 
)

◆ RtlInitUnicodeString()

VOID NTAPI RtlInitUnicodeString ( PUNICODE_STRING  DestinationString,
PCWSTR  SourceString 
)

◆ RtlIsNameLegalDOS8Dot3()

◆ RtlLocalTimeToSystemTime()

NTSTATUS NTAPI RtlLocalTimeToSystemTime ( IN PLARGE_INTEGER  LocalTime,
_Out_ PLARGE_INTEGER  SystemTime 
)

◆ RtlTimeToSecondsSince1970()

◆ RtlUnicodeStringToAnsiString()

NTSTATUS NTAPI RtlUnicodeStringToAnsiString ( PANSI_STRING  DestinationString,
PCUNICODE_STRING  SourceString,
BOOLEAN  AllocateDestinationString 
)

◆ RtlUnicodeStringToOemString()

NTSTATUS NTAPI RtlUnicodeStringToOemString ( POEM_STRING  DestinationString,
PCUNICODE_STRING  SourceString,
BOOLEAN  AllocateDestinationString 
)

◆ RtlUnicodeToMultiByteSize()

NTSTATUS NTAPI RtlUnicodeToMultiByteSize ( _Out_ PULONG  BytesInMultiByteString,
_In_reads_bytes_(BytesInUnicodeString) PWCH  UnicodeString,
_In_ ULONG  BytesInUnicodeString 
)

◆ RtlUniform()

ULONG NTAPI RtlUniform ( PULONG  Seed)

Variable Documentation

◆ ObjectInformationClass

_In_ OBJECT_INFORMATION_CLASS ObjectInformationClass

Definition at line 467 of file winternl.h.

◆ ObjectInformationLength

_In_ OBJECT_INFORMATION_CLASS _In_ ULONG ObjectInformationLength

Definition at line 469 of file winternl.h.

◆ ReturnLength

Definition at line 470 of file winternl.h.