mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-12 13:25:30 +00:00
4285 lines
117 KiB
C
4285 lines
117 KiB
C
|
/*
|
||
|
* This file is part of the Process Hacker project - https://processhacker.sourceforge.io/
|
||
|
*
|
||
|
* You can redistribute this file and/or modify it under the terms of the
|
||
|
* Attribution 4.0 International (CC BY 4.0) license.
|
||
|
*
|
||
|
* You must give appropriate credit, provide a link to the license, and
|
||
|
* indicate if changes were made. You may do so in any reasonable manner, but
|
||
|
* not in any way that suggests the licensor endorses you or your use.
|
||
|
*/
|
||
|
|
||
|
#ifndef _NTEXAPI_H
|
||
|
#define _NTEXAPI_H
|
||
|
|
||
|
#include <ntkeapi.h>
|
||
|
|
||
|
#if (PHNT_MODE != PHNT_MODE_KERNEL)
|
||
|
|
||
|
// Thread execution
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDelayExecution(
|
||
|
_In_ BOOLEAN Alertable,
|
||
|
_In_opt_ PLARGE_INTEGER DelayInterval
|
||
|
);
|
||
|
|
||
|
// Environment values
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySystemEnvironmentValue(
|
||
|
_In_ PUNICODE_STRING VariableName,
|
||
|
_Out_writes_bytes_(ValueLength) PWSTR VariableValue,
|
||
|
_In_ USHORT ValueLength,
|
||
|
_Out_opt_ PUSHORT ReturnLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetSystemEnvironmentValue(
|
||
|
_In_ PUNICODE_STRING VariableName,
|
||
|
_In_ PUNICODE_STRING VariableValue
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySystemEnvironmentValueEx(
|
||
|
_In_ PUNICODE_STRING VariableName,
|
||
|
_In_ LPGUID VendorGuid,
|
||
|
_Out_writes_bytes_opt_(*ValueLength) PVOID Value,
|
||
|
_Inout_ PULONG ValueLength,
|
||
|
_Out_opt_ PULONG Attributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetSystemEnvironmentValueEx(
|
||
|
_In_ PUNICODE_STRING VariableName,
|
||
|
_In_ LPGUID VendorGuid,
|
||
|
_In_reads_bytes_opt_(ValueLength) PVOID Value,
|
||
|
_In_ ULONG ValueLength,
|
||
|
_In_ ULONG Attributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtEnumerateSystemEnvironmentValuesEx(
|
||
|
_In_ ULONG InformationClass,
|
||
|
_Out_ PVOID Buffer,
|
||
|
_Inout_ PULONG BufferLength
|
||
|
);
|
||
|
|
||
|
// EFI
|
||
|
|
||
|
// private
|
||
|
typedef struct _BOOT_ENTRY
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG Length;
|
||
|
ULONG Id;
|
||
|
ULONG Attributes;
|
||
|
ULONG FriendlyNameOffset;
|
||
|
ULONG BootFilePathOffset;
|
||
|
ULONG OsOptionsLength;
|
||
|
UCHAR OsOptions[1];
|
||
|
} BOOT_ENTRY, *PBOOT_ENTRY;
|
||
|
|
||
|
// private
|
||
|
typedef struct _BOOT_ENTRY_LIST
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
BOOT_ENTRY BootEntry;
|
||
|
} BOOT_ENTRY_LIST, *PBOOT_ENTRY_LIST;
|
||
|
|
||
|
// private
|
||
|
typedef struct _BOOT_OPTIONS
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG Length;
|
||
|
ULONG Timeout;
|
||
|
ULONG CurrentBootEntryId;
|
||
|
ULONG NextBootEntryId;
|
||
|
WCHAR HeadlessRedirection[1];
|
||
|
} BOOT_OPTIONS, *PBOOT_OPTIONS;
|
||
|
|
||
|
// private
|
||
|
typedef struct _FILE_PATH
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG Length;
|
||
|
ULONG Type;
|
||
|
UCHAR FilePath[1];
|
||
|
} FILE_PATH, *PFILE_PATH;
|
||
|
|
||
|
// private
|
||
|
typedef struct _EFI_DRIVER_ENTRY
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG Length;
|
||
|
ULONG Id;
|
||
|
ULONG FriendlyNameOffset;
|
||
|
ULONG DriverFilePathOffset;
|
||
|
} EFI_DRIVER_ENTRY, *PEFI_DRIVER_ENTRY;
|
||
|
|
||
|
// private
|
||
|
typedef struct _EFI_DRIVER_ENTRY_LIST
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
EFI_DRIVER_ENTRY DriverEntry;
|
||
|
} EFI_DRIVER_ENTRY_LIST, *PEFI_DRIVER_ENTRY_LIST;
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAddBootEntry(
|
||
|
_In_ PBOOT_ENTRY BootEntry,
|
||
|
_Out_opt_ PULONG Id
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDeleteBootEntry(
|
||
|
_In_ ULONG Id
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtModifyBootEntry(
|
||
|
_In_ PBOOT_ENTRY BootEntry
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtEnumerateBootEntries(
|
||
|
_Out_writes_bytes_opt_(*BufferLength) PVOID Buffer,
|
||
|
_Inout_ PULONG BufferLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryBootEntryOrder(
|
||
|
_Out_writes_opt_(*Count) PULONG Ids,
|
||
|
_Inout_ PULONG Count
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetBootEntryOrder(
|
||
|
_In_reads_(Count) PULONG Ids,
|
||
|
_In_ ULONG Count
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryBootOptions(
|
||
|
_Out_writes_bytes_opt_(*BootOptionsLength) PBOOT_OPTIONS BootOptions,
|
||
|
_Inout_ PULONG BootOptionsLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetBootOptions(
|
||
|
_In_ PBOOT_OPTIONS BootOptions,
|
||
|
_In_ ULONG FieldsToChange
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtTranslateFilePath(
|
||
|
_In_ PFILE_PATH InputFilePath,
|
||
|
_In_ ULONG OutputType,
|
||
|
_Out_writes_bytes_opt_(*OutputFilePathLength) PFILE_PATH OutputFilePath,
|
||
|
_Inout_opt_ PULONG OutputFilePathLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAddDriverEntry(
|
||
|
_In_ PEFI_DRIVER_ENTRY DriverEntry,
|
||
|
_Out_opt_ PULONG Id
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDeleteDriverEntry(
|
||
|
_In_ ULONG Id
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtModifyDriverEntry(
|
||
|
_In_ PEFI_DRIVER_ENTRY DriverEntry
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtEnumerateDriverEntries(
|
||
|
_Out_writes_bytes_opt_(*BufferLength) PVOID Buffer,
|
||
|
_Inout_ PULONG BufferLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryDriverEntryOrder(
|
||
|
_Out_writes_opt_(*Count) PULONG Ids,
|
||
|
_Inout_ PULONG Count
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetDriverEntryOrder(
|
||
|
_In_reads_(Count) PULONG Ids,
|
||
|
_In_ ULONG Count
|
||
|
);
|
||
|
|
||
|
typedef enum _FILTER_BOOT_OPTION_OPERATION
|
||
|
{
|
||
|
FilterBootOptionOperationOpenSystemStore,
|
||
|
FilterBootOptionOperationSetElement,
|
||
|
FilterBootOptionOperationDeleteElement,
|
||
|
FilterBootOptionOperationMax
|
||
|
} FILTER_BOOT_OPTION_OPERATION;
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_THRESHOLD)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtFilterBootOption(
|
||
|
_In_ FILTER_BOOT_OPTION_OPERATION FilterOperation,
|
||
|
_In_ ULONG ObjectType,
|
||
|
_In_ ULONG ElementType,
|
||
|
_In_reads_bytes_opt_(DataSize) PVOID Data,
|
||
|
_In_ ULONG DataSize
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// Event
|
||
|
|
||
|
#ifndef EVENT_QUERY_STATE
|
||
|
#define EVENT_QUERY_STATE 0x0001
|
||
|
#endif
|
||
|
|
||
|
typedef enum _EVENT_INFORMATION_CLASS
|
||
|
{
|
||
|
EventBasicInformation
|
||
|
} EVENT_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _EVENT_BASIC_INFORMATION
|
||
|
{
|
||
|
EVENT_TYPE EventType;
|
||
|
LONG EventState;
|
||
|
} EVENT_BASIC_INFORMATION, *PEVENT_BASIC_INFORMATION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateEvent(
|
||
|
_Out_ PHANDLE EventHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ EVENT_TYPE EventType,
|
||
|
_In_ BOOLEAN InitialState
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenEvent(
|
||
|
_Out_ PHANDLE EventHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetEvent(
|
||
|
_In_ HANDLE EventHandle,
|
||
|
_Out_opt_ PLONG PreviousState
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetEventBoostPriority(
|
||
|
_In_ HANDLE EventHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtClearEvent(
|
||
|
_In_ HANDLE EventHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtResetEvent(
|
||
|
_In_ HANDLE EventHandle,
|
||
|
_Out_opt_ PLONG PreviousState
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtPulseEvent(
|
||
|
_In_ HANDLE EventHandle,
|
||
|
_Out_opt_ PLONG PreviousState
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryEvent(
|
||
|
_In_ HANDLE EventHandle,
|
||
|
_In_ EVENT_INFORMATION_CLASS EventInformationClass,
|
||
|
_Out_writes_bytes_(EventInformationLength) PVOID EventInformation,
|
||
|
_In_ ULONG EventInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
// Event Pair
|
||
|
|
||
|
#define EVENT_PAIR_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateEventPair(
|
||
|
_Out_ PHANDLE EventPairHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenEventPair(
|
||
|
_Out_ PHANDLE EventPairHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetLowEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetHighEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtWaitLowEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtWaitHighEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetLowWaitHighEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetHighWaitLowEventPair(
|
||
|
_In_ HANDLE EventPairHandle
|
||
|
);
|
||
|
|
||
|
// Mutant
|
||
|
|
||
|
typedef enum _MUTANT_INFORMATION_CLASS
|
||
|
{
|
||
|
MutantBasicInformation,
|
||
|
MutantOwnerInformation
|
||
|
} MUTANT_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _MUTANT_BASIC_INFORMATION
|
||
|
{
|
||
|
LONG CurrentCount;
|
||
|
BOOLEAN OwnedByCaller;
|
||
|
BOOLEAN AbandonedState;
|
||
|
} MUTANT_BASIC_INFORMATION, *PMUTANT_BASIC_INFORMATION;
|
||
|
|
||
|
typedef struct _MUTANT_OWNER_INFORMATION
|
||
|
{
|
||
|
CLIENT_ID ClientId;
|
||
|
} MUTANT_OWNER_INFORMATION, *PMUTANT_OWNER_INFORMATION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateMutant(
|
||
|
_Out_ PHANDLE MutantHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ BOOLEAN InitialOwner
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenMutant(
|
||
|
_Out_ PHANDLE MutantHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReleaseMutant(
|
||
|
_In_ HANDLE MutantHandle,
|
||
|
_Out_opt_ PLONG PreviousCount
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryMutant(
|
||
|
_In_ HANDLE MutantHandle,
|
||
|
_In_ MUTANT_INFORMATION_CLASS MutantInformationClass,
|
||
|
_Out_writes_bytes_(MutantInformationLength) PVOID MutantInformation,
|
||
|
_In_ ULONG MutantInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
// Semaphore
|
||
|
|
||
|
#ifndef SEMAPHORE_QUERY_STATE
|
||
|
#define SEMAPHORE_QUERY_STATE 0x0001
|
||
|
#endif
|
||
|
|
||
|
typedef enum _SEMAPHORE_INFORMATION_CLASS
|
||
|
{
|
||
|
SemaphoreBasicInformation
|
||
|
} SEMAPHORE_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _SEMAPHORE_BASIC_INFORMATION
|
||
|
{
|
||
|
LONG CurrentCount;
|
||
|
LONG MaximumCount;
|
||
|
} SEMAPHORE_BASIC_INFORMATION, *PSEMAPHORE_BASIC_INFORMATION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateSemaphore(
|
||
|
_Out_ PHANDLE SemaphoreHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ LONG InitialCount,
|
||
|
_In_ LONG MaximumCount
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenSemaphore(
|
||
|
_Out_ PHANDLE SemaphoreHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReleaseSemaphore(
|
||
|
_In_ HANDLE SemaphoreHandle,
|
||
|
_In_ LONG ReleaseCount,
|
||
|
_Out_opt_ PLONG PreviousCount
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySemaphore(
|
||
|
_In_ HANDLE SemaphoreHandle,
|
||
|
_In_ SEMAPHORE_INFORMATION_CLASS SemaphoreInformationClass,
|
||
|
_Out_writes_bytes_(SemaphoreInformationLength) PVOID SemaphoreInformation,
|
||
|
_In_ ULONG SemaphoreInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
// Timer
|
||
|
|
||
|
typedef enum _TIMER_INFORMATION_CLASS
|
||
|
{
|
||
|
TimerBasicInformation
|
||
|
} TIMER_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _TIMER_BASIC_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER RemainingTime;
|
||
|
BOOLEAN TimerState;
|
||
|
} TIMER_BASIC_INFORMATION, *PTIMER_BASIC_INFORMATION;
|
||
|
|
||
|
typedef VOID (NTAPI *PTIMER_APC_ROUTINE)(
|
||
|
_In_ PVOID TimerContext,
|
||
|
_In_ ULONG TimerLowValue,
|
||
|
_In_ LONG TimerHighValue
|
||
|
);
|
||
|
|
||
|
typedef enum _TIMER_SET_INFORMATION_CLASS
|
||
|
{
|
||
|
TimerSetCoalescableTimer,
|
||
|
MaxTimerInfoClass
|
||
|
} TIMER_SET_INFORMATION_CLASS;
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
struct _COUNTED_REASON_CONTEXT;
|
||
|
|
||
|
typedef struct _TIMER_SET_COALESCABLE_TIMER_INFO
|
||
|
{
|
||
|
_In_ LARGE_INTEGER DueTime;
|
||
|
_In_opt_ PTIMER_APC_ROUTINE TimerApcRoutine;
|
||
|
_In_opt_ PVOID TimerContext;
|
||
|
_In_opt_ struct _COUNTED_REASON_CONTEXT *WakeContext;
|
||
|
_In_opt_ ULONG Period;
|
||
|
_In_ ULONG TolerableDelay;
|
||
|
_Out_opt_ PBOOLEAN PreviousState;
|
||
|
} TIMER_SET_COALESCABLE_TIMER_INFO, *PTIMER_SET_COALESCABLE_TIMER_INFO;
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateTimer(
|
||
|
_Out_ PHANDLE TimerHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ TIMER_TYPE TimerType
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenTimer(
|
||
|
_Out_ PHANDLE TimerHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetTimer(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_ PLARGE_INTEGER DueTime,
|
||
|
_In_opt_ PTIMER_APC_ROUTINE TimerApcRoutine,
|
||
|
_In_opt_ PVOID TimerContext,
|
||
|
_In_ BOOLEAN ResumeTimer,
|
||
|
_In_opt_ LONG Period,
|
||
|
_Out_opt_ PBOOLEAN PreviousState
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetTimerEx(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_ TIMER_SET_INFORMATION_CLASS TimerSetInformationClass,
|
||
|
_Inout_updates_bytes_opt_(TimerSetInformationLength) PVOID TimerSetInformation,
|
||
|
_In_ ULONG TimerSetInformationLength
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCancelTimer(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_Out_opt_ PBOOLEAN CurrentState
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryTimer(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_ TIMER_INFORMATION_CLASS TimerInformationClass,
|
||
|
_Out_writes_bytes_(TimerInformationLength) PVOID TimerInformation,
|
||
|
_In_ ULONG TimerInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN8)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateIRTimer(
|
||
|
_Out_ PHANDLE TimerHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetIRTimer(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_opt_ PLARGE_INTEGER DueTime
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
typedef struct _T2_SET_PARAMETERS_V0
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG Reserved;
|
||
|
LONGLONG NoWakeTolerance;
|
||
|
} T2_SET_PARAMETERS, *PT2_SET_PARAMETERS;
|
||
|
|
||
|
typedef PVOID PT2_CANCEL_PARAMETERS;
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_THRESHOLD)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateTimer2(
|
||
|
_Out_ PHANDLE TimerHandle,
|
||
|
_In_opt_ PVOID Reserved1,
|
||
|
_In_opt_ PVOID Reserved2,
|
||
|
_In_ ULONG Attributes,
|
||
|
_In_ ACCESS_MASK DesiredAccess
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetTimer2(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_ PLARGE_INTEGER DueTime,
|
||
|
_In_opt_ PLARGE_INTEGER Period,
|
||
|
_In_ PT2_SET_PARAMETERS Parameters
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCancelTimer2(
|
||
|
_In_ HANDLE TimerHandle,
|
||
|
_In_ PT2_CANCEL_PARAMETERS Parameters
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// Profile
|
||
|
|
||
|
#define PROFILE_CONTROL 0x0001
|
||
|
#define PROFILE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | PROFILE_CONTROL)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateProfile(
|
||
|
_Out_ PHANDLE ProfileHandle,
|
||
|
_In_opt_ HANDLE Process,
|
||
|
_In_ PVOID ProfileBase,
|
||
|
_In_ SIZE_T ProfileSize,
|
||
|
_In_ ULONG BucketSize,
|
||
|
_In_reads_bytes_(BufferSize) PULONG Buffer,
|
||
|
_In_ ULONG BufferSize,
|
||
|
_In_ KPROFILE_SOURCE ProfileSource,
|
||
|
_In_ KAFFINITY Affinity
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateProfileEx(
|
||
|
_Out_ PHANDLE ProfileHandle,
|
||
|
_In_opt_ HANDLE Process,
|
||
|
_In_ PVOID ProfileBase,
|
||
|
_In_ SIZE_T ProfileSize,
|
||
|
_In_ ULONG BucketSize,
|
||
|
_In_reads_bytes_(BufferSize) PULONG Buffer,
|
||
|
_In_ ULONG BufferSize,
|
||
|
_In_ KPROFILE_SOURCE ProfileSource,
|
||
|
_In_ USHORT GroupCount,
|
||
|
_In_reads_(GroupCount) PGROUP_AFFINITY GroupAffinity
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtStartProfile(
|
||
|
_In_ HANDLE ProfileHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtStopProfile(
|
||
|
_In_ HANDLE ProfileHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryIntervalProfile(
|
||
|
_In_ KPROFILE_SOURCE ProfileSource,
|
||
|
_Out_ PULONG Interval
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetIntervalProfile(
|
||
|
_In_ ULONG Interval,
|
||
|
_In_ KPROFILE_SOURCE Source
|
||
|
);
|
||
|
|
||
|
// Keyed Event
|
||
|
|
||
|
#define KEYEDEVENT_WAIT 0x0001
|
||
|
#define KEYEDEVENT_WAKE 0x0002
|
||
|
#define KEYEDEVENT_ALL_ACCESS \
|
||
|
(STANDARD_RIGHTS_REQUIRED | KEYEDEVENT_WAIT | KEYEDEVENT_WAKE)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateKeyedEvent(
|
||
|
_Out_ PHANDLE KeyedEventHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ ULONG Flags
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtOpenKeyedEvent(
|
||
|
_Out_ PHANDLE KeyedEventHandle,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_ POBJECT_ATTRIBUTES ObjectAttributes
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReleaseKeyedEvent(
|
||
|
_In_ HANDLE KeyedEventHandle,
|
||
|
_In_ PVOID KeyValue,
|
||
|
_In_ BOOLEAN Alertable,
|
||
|
_In_opt_ PLARGE_INTEGER Timeout
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtWaitForKeyedEvent(
|
||
|
_In_ HANDLE KeyedEventHandle,
|
||
|
_In_ PVOID KeyValue,
|
||
|
_In_ BOOLEAN Alertable,
|
||
|
_In_opt_ PLARGE_INTEGER Timeout
|
||
|
);
|
||
|
|
||
|
// UMS
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtUmsThreadYield(
|
||
|
_In_ PVOID SchedulerParam
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
// WNF
|
||
|
|
||
|
// begin_private
|
||
|
|
||
|
typedef struct _WNF_STATE_NAME
|
||
|
{
|
||
|
ULONG Data[2];
|
||
|
} WNF_STATE_NAME, *PWNF_STATE_NAME;
|
||
|
|
||
|
typedef const WNF_STATE_NAME *PCWNF_STATE_NAME;
|
||
|
|
||
|
typedef enum _WNF_STATE_NAME_LIFETIME
|
||
|
{
|
||
|
WnfWellKnownStateName,
|
||
|
WnfPermanentStateName,
|
||
|
WnfPersistentStateName,
|
||
|
WnfTemporaryStateName
|
||
|
} WNF_STATE_NAME_LIFETIME;
|
||
|
|
||
|
typedef enum _WNF_STATE_NAME_INFORMATION
|
||
|
{
|
||
|
WnfInfoStateNameExist,
|
||
|
WnfInfoSubscribersPresent,
|
||
|
WnfInfoIsQuiescent
|
||
|
} WNF_STATE_NAME_INFORMATION;
|
||
|
|
||
|
typedef enum _WNF_DATA_SCOPE
|
||
|
{
|
||
|
WnfDataScopeSystem,
|
||
|
WnfDataScopeSession,
|
||
|
WnfDataScopeUser,
|
||
|
WnfDataScopeProcess,
|
||
|
WnfDataScopeMachine // REDSTONE3
|
||
|
} WNF_DATA_SCOPE;
|
||
|
|
||
|
typedef struct _WNF_TYPE_ID
|
||
|
{
|
||
|
GUID TypeId;
|
||
|
} WNF_TYPE_ID, *PWNF_TYPE_ID;
|
||
|
|
||
|
typedef const WNF_TYPE_ID *PCWNF_TYPE_ID;
|
||
|
|
||
|
// rev
|
||
|
typedef ULONG WNF_CHANGE_STAMP, *PWNF_CHANGE_STAMP;
|
||
|
|
||
|
typedef struct _WNF_DELIVERY_DESCRIPTOR
|
||
|
{
|
||
|
ULONGLONG SubscriptionId;
|
||
|
WNF_STATE_NAME StateName;
|
||
|
WNF_CHANGE_STAMP ChangeStamp;
|
||
|
ULONG StateDataSize;
|
||
|
ULONG EventMask;
|
||
|
WNF_TYPE_ID TypeId;
|
||
|
ULONG StateDataOffset;
|
||
|
} WNF_DELIVERY_DESCRIPTOR, *PWNF_DELIVERY_DESCRIPTOR;
|
||
|
|
||
|
// end_private
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN8)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateWnfStateName(
|
||
|
_Out_ PWNF_STATE_NAME StateName,
|
||
|
_In_ WNF_STATE_NAME_LIFETIME NameLifetime,
|
||
|
_In_ WNF_DATA_SCOPE DataScope,
|
||
|
_In_ BOOLEAN PersistData,
|
||
|
_In_opt_ PCWNF_TYPE_ID TypeId,
|
||
|
_In_ ULONG MaximumStateSize,
|
||
|
_In_ PSECURITY_DESCRIPTOR SecurityDescriptor
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDeleteWnfStateName(
|
||
|
_In_ PCWNF_STATE_NAME StateName
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtUpdateWnfStateData(
|
||
|
_In_ PCWNF_STATE_NAME StateName,
|
||
|
_In_reads_bytes_opt_(Length) const VOID *Buffer,
|
||
|
_In_opt_ ULONG Length,
|
||
|
_In_opt_ PCWNF_TYPE_ID TypeId,
|
||
|
_In_opt_ const VOID *ExplicitScope,
|
||
|
_In_ WNF_CHANGE_STAMP MatchingChangeStamp,
|
||
|
_In_ LOGICAL CheckStamp
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDeleteWnfStateData(
|
||
|
_In_ PCWNF_STATE_NAME StateName,
|
||
|
_In_opt_ const VOID *ExplicitScope
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryWnfStateData(
|
||
|
_In_ PCWNF_STATE_NAME StateName,
|
||
|
_In_opt_ PCWNF_TYPE_ID TypeId,
|
||
|
_In_opt_ const VOID *ExplicitScope,
|
||
|
_Out_ PWNF_CHANGE_STAMP ChangeStamp,
|
||
|
_Out_writes_bytes_to_opt_(*BufferSize, *BufferSize) PVOID Buffer,
|
||
|
_Inout_ PULONG BufferSize
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryWnfStateNameInformation(
|
||
|
_In_ PCWNF_STATE_NAME StateName,
|
||
|
_In_ WNF_STATE_NAME_INFORMATION NameInfoClass,
|
||
|
_In_opt_ const VOID *ExplicitScope,
|
||
|
_Out_writes_bytes_(InfoBufferSize) PVOID InfoBuffer,
|
||
|
_In_ ULONG InfoBufferSize
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSubscribeWnfStateChange(
|
||
|
_In_ PCWNF_STATE_NAME StateName,
|
||
|
_In_opt_ WNF_CHANGE_STAMP ChangeStamp,
|
||
|
_In_ ULONG EventMask,
|
||
|
_Out_opt_ PULONG64 SubscriptionId
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtUnsubscribeWnfStateChange(
|
||
|
_In_ PCWNF_STATE_NAME StateName
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_THRESHOLD)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtGetCompleteWnfStateSubscription(
|
||
|
_In_opt_ PWNF_STATE_NAME OldDescriptorStateName,
|
||
|
_In_opt_ ULONG64 *OldSubscriptionId,
|
||
|
_In_opt_ ULONG OldDescriptorEventMask,
|
||
|
_In_opt_ ULONG OldDescriptorStatus,
|
||
|
_Out_writes_bytes_(DescriptorSize) PWNF_DELIVERY_DESCRIPTOR NewDeliveryDescriptor,
|
||
|
_In_ ULONG DescriptorSize
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetWnfProcessNotificationEvent(
|
||
|
_In_ HANDLE NotificationEvent
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// Worker factory
|
||
|
|
||
|
// begin_rev
|
||
|
|
||
|
#define WORKER_FACTORY_RELEASE_WORKER 0x0001
|
||
|
#define WORKER_FACTORY_WAIT 0x0002
|
||
|
#define WORKER_FACTORY_SET_INFORMATION 0x0004
|
||
|
#define WORKER_FACTORY_QUERY_INFORMATION 0x0008
|
||
|
#define WORKER_FACTORY_READY_WORKER 0x0010
|
||
|
#define WORKER_FACTORY_SHUTDOWN 0x0020
|
||
|
|
||
|
#define WORKER_FACTORY_ALL_ACCESS ( \
|
||
|
STANDARD_RIGHTS_REQUIRED | \
|
||
|
WORKER_FACTORY_RELEASE_WORKER | \
|
||
|
WORKER_FACTORY_WAIT | \
|
||
|
WORKER_FACTORY_SET_INFORMATION | \
|
||
|
WORKER_FACTORY_QUERY_INFORMATION | \
|
||
|
WORKER_FACTORY_READY_WORKER | \
|
||
|
WORKER_FACTORY_SHUTDOWN \
|
||
|
)
|
||
|
|
||
|
// end_rev
|
||
|
|
||
|
// begin_private
|
||
|
|
||
|
typedef enum _WORKERFACTORYINFOCLASS
|
||
|
{
|
||
|
WorkerFactoryTimeout, // q; s: LARGE_INTEGER
|
||
|
WorkerFactoryRetryTimeout, // q; s: LARGE_INTEGER
|
||
|
WorkerFactoryIdleTimeout, // q; s: LARGE_INTEGER
|
||
|
WorkerFactoryBindingCount,
|
||
|
WorkerFactoryThreadMinimum, // q; s: ULONG
|
||
|
WorkerFactoryThreadMaximum, // q; s: ULONG
|
||
|
WorkerFactoryPaused, // ULONG or BOOLEAN
|
||
|
WorkerFactoryBasicInformation, // WORKER_FACTORY_BASIC_INFORMATION
|
||
|
WorkerFactoryAdjustThreadGoal,
|
||
|
WorkerFactoryCallbackType,
|
||
|
WorkerFactoryStackInformation, // 10
|
||
|
WorkerFactoryThreadBasePriority,
|
||
|
WorkerFactoryTimeoutWaiters, // since THRESHOLD
|
||
|
WorkerFactoryFlags,
|
||
|
WorkerFactoryThreadSoftMaximum,
|
||
|
WorkerFactoryThreadCpuSets, // since REDSTONE5
|
||
|
MaxWorkerFactoryInfoClass
|
||
|
} WORKERFACTORYINFOCLASS, *PWORKERFACTORYINFOCLASS;
|
||
|
|
||
|
typedef struct _WORKER_FACTORY_BASIC_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER Timeout;
|
||
|
LARGE_INTEGER RetryTimeout;
|
||
|
LARGE_INTEGER IdleTimeout;
|
||
|
BOOLEAN Paused;
|
||
|
BOOLEAN TimerSet;
|
||
|
BOOLEAN QueuedToExWorker;
|
||
|
BOOLEAN MayCreate;
|
||
|
BOOLEAN CreateInProgress;
|
||
|
BOOLEAN InsertedIntoQueue;
|
||
|
BOOLEAN Shutdown;
|
||
|
ULONG BindingCount;
|
||
|
ULONG ThreadMinimum;
|
||
|
ULONG ThreadMaximum;
|
||
|
ULONG PendingWorkerCount;
|
||
|
ULONG WaitingWorkerCount;
|
||
|
ULONG TotalWorkerCount;
|
||
|
ULONG ReleaseCount;
|
||
|
LONGLONG InfiniteWaitGoal;
|
||
|
PVOID StartRoutine;
|
||
|
PVOID StartParameter;
|
||
|
HANDLE ProcessId;
|
||
|
SIZE_T StackReserve;
|
||
|
SIZE_T StackCommit;
|
||
|
NTSTATUS LastThreadCreationStatus;
|
||
|
} WORKER_FACTORY_BASIC_INFORMATION, *PWORKER_FACTORY_BASIC_INFORMATION;
|
||
|
|
||
|
// end_private
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtCreateWorkerFactory(
|
||
|
_Out_ PHANDLE WorkerFactoryHandleReturn,
|
||
|
_In_ ACCESS_MASK DesiredAccess,
|
||
|
_In_opt_ POBJECT_ATTRIBUTES ObjectAttributes,
|
||
|
_In_ HANDLE CompletionPortHandle,
|
||
|
_In_ HANDLE WorkerProcessHandle,
|
||
|
_In_ PVOID StartRoutine,
|
||
|
_In_opt_ PVOID StartParameter,
|
||
|
_In_opt_ ULONG MaxThreadCount,
|
||
|
_In_opt_ SIZE_T StackReserve,
|
||
|
_In_opt_ SIZE_T StackCommit
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryInformationWorkerFactory(
|
||
|
_In_ HANDLE WorkerFactoryHandle,
|
||
|
_In_ WORKERFACTORYINFOCLASS WorkerFactoryInformationClass,
|
||
|
_Out_writes_bytes_(WorkerFactoryInformationLength) PVOID WorkerFactoryInformation,
|
||
|
_In_ ULONG WorkerFactoryInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetInformationWorkerFactory(
|
||
|
_In_ HANDLE WorkerFactoryHandle,
|
||
|
_In_ WORKERFACTORYINFOCLASS WorkerFactoryInformationClass,
|
||
|
_In_reads_bytes_(WorkerFactoryInformationLength) PVOID WorkerFactoryInformation,
|
||
|
_In_ ULONG WorkerFactoryInformationLength
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtShutdownWorkerFactory(
|
||
|
_In_ HANDLE WorkerFactoryHandle,
|
||
|
_Inout_ volatile LONG *PendingWorkerCount
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReleaseWorkerFactoryWorker(
|
||
|
_In_ HANDLE WorkerFactoryHandle
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtWorkerFactoryWorkerReady(
|
||
|
_In_ HANDLE WorkerFactoryHandle
|
||
|
);
|
||
|
|
||
|
struct _FILE_IO_COMPLETION_INFORMATION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtWaitForWorkViaWorkerFactory(
|
||
|
_In_ HANDLE WorkerFactoryHandle,
|
||
|
_Out_ struct _FILE_IO_COMPLETION_INFORMATION *MiniPacket
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// Time
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySystemTime(
|
||
|
_Out_ PLARGE_INTEGER SystemTime
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetSystemTime(
|
||
|
_In_opt_ PLARGE_INTEGER SystemTime,
|
||
|
_Out_opt_ PLARGE_INTEGER PreviousTime
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryTimerResolution(
|
||
|
_Out_ PULONG MaximumTime,
|
||
|
_Out_ PULONG MinimumTime,
|
||
|
_Out_ PULONG CurrentTime
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetTimerResolution(
|
||
|
_In_ ULONG DesiredTime,
|
||
|
_In_ BOOLEAN SetResolution,
|
||
|
_Out_ PULONG ActualTime
|
||
|
);
|
||
|
|
||
|
// Performance Counter
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryPerformanceCounter(
|
||
|
_Out_ PLARGE_INTEGER PerformanceCounter,
|
||
|
_Out_opt_ PLARGE_INTEGER PerformanceFrequency
|
||
|
);
|
||
|
|
||
|
// LUIDs
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAllocateLocallyUniqueId(
|
||
|
_Out_ PLUID Luid
|
||
|
);
|
||
|
|
||
|
// UUIDs
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetUuidSeed(
|
||
|
_In_ PCHAR Seed
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAllocateUuids(
|
||
|
_Out_ PULARGE_INTEGER Time,
|
||
|
_Out_ PULONG Range,
|
||
|
_Out_ PULONG Sequence,
|
||
|
_Out_ PCHAR Seed
|
||
|
);
|
||
|
|
||
|
// System Information
|
||
|
|
||
|
#endif // (PHNT_MODE != PHNT_MODE_KERNEL)
|
||
|
|
||
|
// rev
|
||
|
// private
|
||
|
typedef enum _SYSTEM_INFORMATION_CLASS
|
||
|
{
|
||
|
SystemBasicInformation, // q: SYSTEM_BASIC_INFORMATION
|
||
|
SystemProcessorInformation, // q: SYSTEM_PROCESSOR_INFORMATION
|
||
|
SystemPerformanceInformation, // q: SYSTEM_PERFORMANCE_INFORMATION
|
||
|
SystemTimeOfDayInformation, // q: SYSTEM_TIMEOFDAY_INFORMATION
|
||
|
SystemPathInformation, // not implemented
|
||
|
SystemProcessInformation, // q: SYSTEM_PROCESS_INFORMATION
|
||
|
SystemCallCountInformation, // q: SYSTEM_CALL_COUNT_INFORMATION
|
||
|
SystemDeviceInformation, // q: SYSTEM_DEVICE_INFORMATION
|
||
|
SystemProcessorPerformanceInformation, // q: SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION
|
||
|
SystemFlagsInformation, // q: SYSTEM_FLAGS_INFORMATION
|
||
|
SystemCallTimeInformation, // not implemented // SYSTEM_CALL_TIME_INFORMATION // 10
|
||
|
SystemModuleInformation, // q: RTL_PROCESS_MODULES
|
||
|
SystemLocksInformation, // q: RTL_PROCESS_LOCKS
|
||
|
SystemStackTraceInformation, // q: RTL_PROCESS_BACKTRACES
|
||
|
SystemPagedPoolInformation, // not implemented
|
||
|
SystemNonPagedPoolInformation, // not implemented
|
||
|
SystemHandleInformation, // q: SYSTEM_HANDLE_INFORMATION
|
||
|
SystemObjectInformation, // q: SYSTEM_OBJECTTYPE_INFORMATION mixed with SYSTEM_OBJECT_INFORMATION
|
||
|
SystemPageFileInformation, // q: SYSTEM_PAGEFILE_INFORMATION
|
||
|
SystemVdmInstemulInformation, // q
|
||
|
SystemVdmBopInformation, // not implemented // 20
|
||
|
SystemFileCacheInformation, // q: SYSTEM_FILECACHE_INFORMATION; s (requires SeIncreaseQuotaPrivilege) (info for WorkingSetTypeSystemCache)
|
||
|
SystemPoolTagInformation, // q: SYSTEM_POOLTAG_INFORMATION
|
||
|
SystemInterruptInformation, // q: SYSTEM_INTERRUPT_INFORMATION
|
||
|
SystemDpcBehaviorInformation, // q: SYSTEM_DPC_BEHAVIOR_INFORMATION; s: SYSTEM_DPC_BEHAVIOR_INFORMATION (requires SeLoadDriverPrivilege)
|
||
|
SystemFullMemoryInformation, // not implemented
|
||
|
SystemLoadGdiDriverInformation, // s (kernel-mode only)
|
||
|
SystemUnloadGdiDriverInformation, // s (kernel-mode only)
|
||
|
SystemTimeAdjustmentInformation, // q: SYSTEM_QUERY_TIME_ADJUST_INFORMATION; s: SYSTEM_SET_TIME_ADJUST_INFORMATION (requires SeSystemtimePrivilege)
|
||
|
SystemSummaryMemoryInformation, // not implemented
|
||
|
SystemMirrorMemoryInformation, // s (requires license value "Kernel-MemoryMirroringSupported") (requires SeShutdownPrivilege) // 30
|
||
|
SystemPerformanceTraceInformation, // q; s: (type depends on EVENT_TRACE_INFORMATION_CLASS)
|
||
|
SystemObsolete0, // not implemented
|
||
|
SystemExceptionInformation, // q: SYSTEM_EXCEPTION_INFORMATION
|
||
|
SystemCrashDumpStateInformation, // s (requires SeDebugPrivilege)
|
||
|
SystemKernelDebuggerInformation, // q: SYSTEM_KERNEL_DEBUGGER_INFORMATION
|
||
|
SystemContextSwitchInformation, // q: SYSTEM_CONTEXT_SWITCH_INFORMATION
|
||
|
SystemRegistryQuotaInformation, // q: SYSTEM_REGISTRY_QUOTA_INFORMATION; s (requires SeIncreaseQuotaPrivilege)
|
||
|
SystemExtendServiceTableInformation, // s (requires SeLoadDriverPrivilege) // loads win32k only
|
||
|
SystemPrioritySeperation, // s (requires SeTcbPrivilege)
|
||
|
SystemVerifierAddDriverInformation, // s (requires SeDebugPrivilege) // 40
|
||
|
SystemVerifierRemoveDriverInformation, // s (requires SeDebugPrivilege)
|
||
|
SystemProcessorIdleInformation, // q: SYSTEM_PROCESSOR_IDLE_INFORMATION
|
||
|
SystemLegacyDriverInformation, // q: SYSTEM_LEGACY_DRIVER_INFORMATION
|
||
|
SystemCurrentTimeZoneInformation, // q; s: RTL_TIME_ZONE_INFORMATION
|
||
|
SystemLookasideInformation, // q: SYSTEM_LOOKASIDE_INFORMATION
|
||
|
SystemTimeSlipNotification, // s (requires SeSystemtimePrivilege)
|
||
|
SystemSessionCreate, // not implemented
|
||
|
SystemSessionDetach, // not implemented
|
||
|
SystemSessionInformation, // not implemented (SYSTEM_SESSION_INFORMATION)
|
||
|
SystemRangeStartInformation, // q: SYSTEM_RANGE_START_INFORMATION // 50
|
||
|
SystemVerifierInformation, // q: SYSTEM_VERIFIER_INFORMATION; s (requires SeDebugPrivilege)
|
||
|
SystemVerifierThunkExtend, // s (kernel-mode only)
|
||
|
SystemSessionProcessInformation, // q: SYSTEM_SESSION_PROCESS_INFORMATION
|
||
|
SystemLoadGdiDriverInSystemSpace, // s (kernel-mode only) (same as SystemLoadGdiDriverInformation)
|
||
|
SystemNumaProcessorMap, // q
|
||
|
SystemPrefetcherInformation, // q: PREFETCHER_INFORMATION; s: PREFETCHER_INFORMATION // PfSnQueryPrefetcherInformation
|
||
|
SystemExtendedProcessInformation, // q: SYSTEM_PROCESS_INFORMATION
|
||
|
SystemRecommendedSharedDataAlignment, // q
|
||
|
SystemComPlusPackage, // q; s
|
||
|
SystemNumaAvailableMemory, // 60
|
||
|
SystemProcessorPowerInformation, // q: SYSTEM_PROCESSOR_POWER_INFORMATION
|
||
|
SystemEmulationBasicInformation,
|
||
|
SystemEmulationProcessorInformation,
|
||
|
SystemExtendedHandleInformation, // q: SYSTEM_HANDLE_INFORMATION_EX
|
||
|
SystemLostDelayedWriteInformation, // q: ULONG
|
||
|
SystemBigPoolInformation, // q: SYSTEM_BIGPOOL_INFORMATION
|
||
|
SystemSessionPoolTagInformation, // q: SYSTEM_SESSION_POOLTAG_INFORMATION
|
||
|
SystemSessionMappedViewInformation, // q: SYSTEM_SESSION_MAPPED_VIEW_INFORMATION
|
||
|
SystemHotpatchInformation, // q; s: SYSTEM_HOTPATCH_CODE_INFORMATION
|
||
|
SystemObjectSecurityMode, // q: ULONG // 70
|
||
|
SystemWatchdogTimerHandler, // s (kernel-mode only)
|
||
|
SystemWatchdogTimerInformation, // q (kernel-mode only); s (kernel-mode only)
|
||
|
SystemLogicalProcessorInformation, // q: SYSTEM_LOGICAL_PROCESSOR_INFORMATION
|
||
|
SystemWow64SharedInformationObsolete, // not implemented
|
||
|
SystemRegisterFirmwareTableInformationHandler, // s (kernel-mode only)
|
||
|
SystemFirmwareTableInformation, // SYSTEM_FIRMWARE_TABLE_INFORMATION
|
||
|
SystemModuleInformationEx, // q: RTL_PROCESS_MODULE_INFORMATION_EX
|
||
|
SystemVerifierTriageInformation, // not implemented
|
||
|
SystemSuperfetchInformation, // q; s: SUPERFETCH_INFORMATION // PfQuerySuperfetchInformation
|
||
|
SystemMemoryListInformation, // q: SYSTEM_MEMORY_LIST_INFORMATION; s: SYSTEM_MEMORY_LIST_COMMAND (requires SeProfileSingleProcessPrivilege) // 80
|
||
|
SystemFileCacheInformationEx, // q: SYSTEM_FILECACHE_INFORMATION; s (requires SeIncreaseQuotaPrivilege) (same as SystemFileCacheInformation)
|
||
|
SystemThreadPriorityClientIdInformation, // s: SYSTEM_THREAD_CID_PRIORITY_INFORMATION (requires SeIncreaseBasePriorityPrivilege)
|
||
|
SystemProcessorIdleCycleTimeInformation, // q: SYSTEM_PROCESSOR_IDLE_CYCLE_TIME_INFORMATION[]
|
||
|
SystemVerifierCancellationInformation, // not implemented // name:wow64:whNT32QuerySystemVerifierCancellationInformation
|
||
|
SystemProcessorPowerInformationEx, // not implemented
|
||
|
SystemRefTraceInformation, // q; s: SYSTEM_REF_TRACE_INFORMATION // ObQueryRefTraceInformation
|
||
|
SystemSpecialPoolInformation, // q; s (requires SeDebugPrivilege) // MmSpecialPoolTag, then MmSpecialPoolCatchOverruns != 0
|
||
|
SystemProcessIdInformation, // q: SYSTEM_PROCESS_ID_INFORMATION
|
||
|
SystemErrorPortInformation, // s (requires SeTcbPrivilege)
|
||
|
SystemBootEnvironmentInformation, // q: SYSTEM_BOOT_ENVIRONMENT_INFORMATION // 90
|
||
|
SystemHypervisorInformation, // q; s (kernel-mode only)
|
||
|
SystemVerifierInformationEx, // q; s: SYSTEM_VERIFIER_INFORMATION_EX
|
||
|
SystemTimeZoneInformation, // s (requires SeTimeZonePrivilege)
|
||
|
SystemImageFileExecutionOptionsInformation, // s: SYSTEM_IMAGE_FILE_EXECUTION_OPTIONS_INFORMATION (requires SeTcbPrivilege)
|
||
|
SystemCoverageInformation, // q; s // name:wow64:whNT32QuerySystemCoverageInformation; ExpCovQueryInformation
|
||
|
SystemPrefetchPatchInformation, // not implemented
|
||
|
SystemVerifierFaultsInformation, // s (requires SeDebugPrivilege)
|
||
|
SystemSystemPartitionInformation, // q: SYSTEM_SYSTEM_PARTITION_INFORMATION
|
||
|
SystemSystemDiskInformation, // q: SYSTEM_SYSTEM_DISK_INFORMATION
|
||
|
SystemProcessorPerformanceDistribution, // q: SYSTEM_PROCESSOR_PERFORMANCE_DISTRIBUTION // 100
|
||
|
SystemNumaProximityNodeInformation,
|
||
|
SystemDynamicTimeZoneInformation, // q; s (requires SeTimeZonePrivilege)
|
||
|
SystemCodeIntegrityInformation, // q: SYSTEM_CODEINTEGRITY_INFORMATION // SeCodeIntegrityQueryInformation
|
||
|
SystemProcessorMicrocodeUpdateInformation, // s
|
||
|
SystemProcessorBrandString, // q // HaliQuerySystemInformation -> HalpGetProcessorBrandString, info class 23
|
||
|
SystemVirtualAddressInformation, // q: SYSTEM_VA_LIST_INFORMATION[]; s: SYSTEM_VA_LIST_INFORMATION[] (requires SeIncreaseQuotaPrivilege) // MmQuerySystemVaInformation
|
||
|
SystemLogicalProcessorAndGroupInformation, // q: SYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX // since WIN7 // KeQueryLogicalProcessorRelationship
|
||
|
SystemProcessorCycleTimeInformation, // q: SYSTEM_PROCESSOR_CYCLE_TIME_INFORMATION[]
|
||
|
SystemStoreInformation, // q; s: SYSTEM_STORE_INFORMATION // SmQueryStoreInformation
|
||
|
SystemRegistryAppendString, // s: SYSTEM_REGISTRY_APPEND_STRING_PARAMETERS // 110
|
||
|
SystemAitSamplingValue, // s: ULONG (requires SeProfileSingleProcessPrivilege)
|
||
|
SystemVhdBootInformation, // q: SYSTEM_VHD_BOOT_INFORMATION
|
||
|
SystemCpuQuotaInformation, // q; s // PsQueryCpuQuotaInformation
|
||
|
SystemNativeBasicInformation, // not implemented
|
||
|
SystemSpare1, // not implemented
|
||
|
SystemLowPriorityIoInformation, // q: SYSTEM_LOW_PRIORITY_IO_INFORMATION
|
||
|
SystemTpmBootEntropyInformation, // q: TPM_BOOT_ENTROPY_NT_RESULT // ExQueryTpmBootEntropyInformation
|
||
|
SystemVerifierCountersInformation, // q: SYSTEM_VERIFIER_COUNTERS_INFORMATION
|
||
|
SystemPagedPoolInformationEx, // q: SYSTEM_FILECACHE_INFORMATION; s (requires SeIncreaseQuotaPrivilege) (info for WorkingSetTypePagedPool)
|
||
|
SystemSystemPtesInformationEx, // q: SYSTEM_FILECACHE_INFORMATION; s (requires SeIncreaseQuotaPrivilege) (info for WorkingSetTypeSystemPtes) // 120
|
||
|
SystemNodeDistanceInformation,
|
||
|
SystemAcpiAuditInformation, // q: SYSTEM_ACPI_AUDIT_INFORMATION // HaliQuerySystemInformation -> HalpAuditQueryResults, info class 26
|
||
|
SystemBasicPerformanceInformation, // q: SYSTEM_BASIC_PERFORMANCE_INFORMATION // name:wow64:whNtQuerySystemInformation_SystemBasicPerformanceInformation
|
||
|
SystemQueryPerformanceCounterInformation, // q: SYSTEM_QUERY_PERFORMANCE_COUNTER_INFORMATION // since WIN7 SP1
|
||
|
SystemSessionBigPoolInformation, // q: SYSTEM_SESSION_POOLTAG_INFORMATION // since WIN8
|
||
|
SystemBootGraphicsInformation, // q; s: SYSTEM_BOOT_GRAPHICS_INFORMATION (kernel-mode only)
|
||
|
SystemScrubPhysicalMemoryInformation, // q; s: MEMORY_SCRUB_INFORMATION
|
||
|
SystemBadPageInformation,
|
||
|
SystemProcessorProfileControlArea, // q; s: SYSTEM_PROCESSOR_PROFILE_CONTROL_AREA
|
||
|
SystemCombinePhysicalMemoryInformation, // s: MEMORY_COMBINE_INFORMATION, MEMORY_COMBINE_INFORMATION_EX, MEMORY_COMBINE_INFORMATION_EX2 // 130
|
||
|
SystemEntropyInterruptTimingCallback,
|
||
|
SystemConsoleInformation, // q: SYSTEM_CONSOLE_INFORMATION
|
||
|
SystemPlatformBinaryInformation, // q: SYSTEM_PLATFORM_BINARY_INFORMATION
|
||
|
SystemThrottleNotificationInformation,
|
||
|
SystemHypervisorProcessorCountInformation, // q: SYSTEM_HYPERVISOR_PROCESSOR_COUNT_INFORMATION
|
||
|
SystemDeviceDataInformation, // q: SYSTEM_DEVICE_DATA_INFORMATION
|
||
|
SystemDeviceDataEnumerationInformation,
|
||
|
SystemMemoryTopologyInformation, // q: SYSTEM_MEMORY_TOPOLOGY_INFORMATION
|
||
|
SystemMemoryChannelInformation, // q: SYSTEM_MEMORY_CHANNEL_INFORMATION
|
||
|
SystemBootLogoInformation, // q: SYSTEM_BOOT_LOGO_INFORMATION // 140
|
||
|
SystemProcessorPerformanceInformationEx, // q: SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION_EX // since WINBLUE
|
||
|
SystemSpare0,
|
||
|
SystemSecureBootPolicyInformation, // q: SYSTEM_SECUREBOOT_POLICY_INFORMATION
|
||
|
SystemPageFileInformationEx, // q: SYSTEM_PAGEFILE_INFORMATION_EX
|
||
|
SystemSecureBootInformation, // q: SYSTEM_SECUREBOOT_INFORMATION
|
||
|
SystemEntropyInterruptTimingRawInformation,
|
||
|
SystemPortableWorkspaceEfiLauncherInformation, // q: SYSTEM_PORTABLE_WORKSPACE_EFI_LAUNCHER_INFORMATION
|
||
|
SystemFullProcessInformation, // q: SYSTEM_PROCESS_INFORMATION with SYSTEM_PROCESS_INFORMATION_EXTENSION (requires admin)
|
||
|
SystemKernelDebuggerInformationEx, // q: SYSTEM_KERNEL_DEBUGGER_INFORMATION_EX
|
||
|
SystemBootMetadataInformation, // 150
|
||
|
SystemSoftRebootInformation, // q: ULONG
|
||
|
SystemElamCertificateInformation, // s: SYSTEM_ELAM_CERTIFICATE_INFORMATION
|
||
|
SystemOfflineDumpConfigInformation,
|
||
|
SystemProcessorFeaturesInformation, // q: SYSTEM_PROCESSOR_FEATURES_INFORMATION
|
||
|
SystemRegistryReconciliationInformation,
|
||
|
SystemEdidInformation,
|
||
|
SystemManufacturingInformation, // q: SYSTEM_MANUFACTURING_INFORMATION // since THRESHOLD
|
||
|
SystemEnergyEstimationConfigInformation, // q: SYSTEM_ENERGY_ESTIMATION_CONFIG_INFORMATION
|
||
|
SystemHypervisorDetailInformation, // q: SYSTEM_HYPERVISOR_DETAIL_INFORMATION
|
||
|
SystemProcessorCycleStatsInformation, // q: SYSTEM_PROCESSOR_CYCLE_STATS_INFORMATION // 160
|
||
|
SystemVmGenerationCountInformation,
|
||
|
SystemTrustedPlatformModuleInformation, // q: SYSTEM_TPM_INFORMATION
|
||
|
SystemKernelDebuggerFlags, // SYSTEM_KERNEL_DEBUGGER_FLAGS
|
||
|
SystemCodeIntegrityPolicyInformation, // q: SYSTEM_CODEINTEGRITYPOLICY_INFORMATION
|
||
|
SystemIsolatedUserModeInformation, // q: SYSTEM_ISOLATED_USER_MODE_INFORMATION
|
||
|
SystemHardwareSecurityTestInterfaceResultsInformation,
|
||
|
SystemSingleModuleInformation, // q: SYSTEM_SINGLE_MODULE_INFORMATION
|
||
|
SystemAllowedCpuSetsInformation,
|
||
|
SystemVsmProtectionInformation, // q: SYSTEM_VSM_PROTECTION_INFORMATION (previously SystemDmaProtectionInformation)
|
||
|
SystemInterruptCpuSetsInformation, // q: SYSTEM_INTERRUPT_CPU_SET_INFORMATION // 170
|
||
|
SystemSecureBootPolicyFullInformation, // q: SYSTEM_SECUREBOOT_POLICY_FULL_INFORMATION
|
||
|
SystemCodeIntegrityPolicyFullInformation,
|
||
|
SystemAffinitizedInterruptProcessorInformation,
|
||
|
SystemRootSiloInformation, // q: SYSTEM_ROOT_SILO_INFORMATION
|
||
|
SystemCpuSetInformation, // q: SYSTEM_CPU_SET_INFORMATION // since THRESHOLD2
|
||
|
SystemCpuSetTagInformation, // q: SYSTEM_CPU_SET_TAG_INFORMATION
|
||
|
SystemWin32WerStartCallout,
|
||
|
SystemSecureKernelProfileInformation, // q: SYSTEM_SECURE_KERNEL_HYPERGUARD_PROFILE_INFORMATION
|
||
|
SystemCodeIntegrityPlatformManifestInformation, // q: SYSTEM_SECUREBOOT_PLATFORM_MANIFEST_INFORMATION // since REDSTONE
|
||
|
SystemInterruptSteeringInformation, // 180
|
||
|
SystemSupportedProcessorArchitectures,
|
||
|
SystemMemoryUsageInformation, // q: SYSTEM_MEMORY_USAGE_INFORMATION
|
||
|
SystemCodeIntegrityCertificateInformation, // q: SYSTEM_CODEINTEGRITY_CERTIFICATE_INFORMATION
|
||
|
SystemPhysicalMemoryInformation, // q: SYSTEM_PHYSICAL_MEMORY_INFORMATION // since REDSTONE2
|
||
|
SystemControlFlowTransition,
|
||
|
SystemKernelDebuggingAllowed, // s: ULONG
|
||
|
SystemActivityModerationExeState, // SYSTEM_ACTIVITY_MODERATION_EXE_STATE
|
||
|
SystemActivityModerationUserSettings, // SYSTEM_ACTIVITY_MODERATION_USER_SETTINGS
|
||
|
SystemCodeIntegrityPoliciesFullInformation,
|
||
|
SystemCodeIntegrityUnlockInformation, // SYSTEM_CODEINTEGRITY_UNLOCK_INFORMATION // 190
|
||
|
SystemIntegrityQuotaInformation,
|
||
|
SystemFlushInformation, // q: SYSTEM_FLUSH_INFORMATION
|
||
|
SystemProcessorIdleMaskInformation, // q: ULONG_PTR // since REDSTONE3
|
||
|
SystemSecureDumpEncryptionInformation,
|
||
|
SystemWriteConstraintInformation, // SYSTEM_WRITE_CONSTRAINT_INFORMATION
|
||
|
SystemKernelVaShadowInformation, // SYSTEM_KERNEL_VA_SHADOW_INFORMATION
|
||
|
SystemHypervisorSharedPageInformation, // SYSTEM_HYPERVISOR_SHARED_PAGE_INFORMATION // since REDSTONE4
|
||
|
SystemFirmwareBootPerformanceInformation,
|
||
|
SystemCodeIntegrityVerificationInformation, // SYSTEM_CODEINTEGRITYVERIFICATION_INFORMATION
|
||
|
SystemFirmwarePartitionInformation, // SYSTEM_FIRMWARE_PARTITION_INFORMATION // 200
|
||
|
SystemSpeculationControlInformation, // SYSTEM_SPECULATION_CONTROL_INFORMATION // (CVE-2017-5715) REDSTONE3 and above.
|
||
|
SystemDmaGuardPolicyInformation, // SYSTEM_DMA_GUARD_POLICY_INFORMATION
|
||
|
SystemEnclaveLaunchControlInformation, // SYSTEM_ENCLAVE_LAUNCH_CONTROL_INFORMATION
|
||
|
SystemWorkloadAllowedCpuSetsInformation, // SYSTEM_WORKLOAD_ALLOWED_CPU_SET_INFORMATION // since REDSTONE5
|
||
|
SystemCodeIntegrityUnlockModeInformation,
|
||
|
SystemLeapSecondInformation, // SYSTEM_LEAP_SECOND_INFORMATION
|
||
|
SystemFlags2Information, // q: SYSTEM_FLAGS_INFORMATION
|
||
|
SystemSecurityModelInformation, // SYSTEM_SECURITY_MODEL_INFORMATION // since 19H1
|
||
|
SystemCodeIntegritySyntheticCacheInformation,
|
||
|
MaxSystemInfoClass
|
||
|
} SYSTEM_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _SYSTEM_BASIC_INFORMATION
|
||
|
{
|
||
|
ULONG Reserved;
|
||
|
ULONG TimerResolution;
|
||
|
ULONG PageSize;
|
||
|
ULONG NumberOfPhysicalPages;
|
||
|
ULONG LowestPhysicalPageNumber;
|
||
|
ULONG HighestPhysicalPageNumber;
|
||
|
ULONG AllocationGranularity;
|
||
|
ULONG_PTR MinimumUserModeAddress;
|
||
|
ULONG_PTR MaximumUserModeAddress;
|
||
|
ULONG_PTR ActiveProcessorsAffinityMask;
|
||
|
CCHAR NumberOfProcessors;
|
||
|
} SYSTEM_BASIC_INFORMATION, *PSYSTEM_BASIC_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PROCESSOR_INFORMATION
|
||
|
{
|
||
|
USHORT ProcessorArchitecture;
|
||
|
USHORT ProcessorLevel;
|
||
|
USHORT ProcessorRevision;
|
||
|
USHORT MaximumProcessors;
|
||
|
ULONG ProcessorFeatureBits;
|
||
|
} SYSTEM_PROCESSOR_INFORMATION, *PSYSTEM_PROCESSOR_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PERFORMANCE_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER IdleProcessTime;
|
||
|
LARGE_INTEGER IoReadTransferCount;
|
||
|
LARGE_INTEGER IoWriteTransferCount;
|
||
|
LARGE_INTEGER IoOtherTransferCount;
|
||
|
ULONG IoReadOperationCount;
|
||
|
ULONG IoWriteOperationCount;
|
||
|
ULONG IoOtherOperationCount;
|
||
|
ULONG AvailablePages;
|
||
|
ULONG CommittedPages;
|
||
|
ULONG CommitLimit;
|
||
|
ULONG PeakCommitment;
|
||
|
ULONG PageFaultCount;
|
||
|
ULONG CopyOnWriteCount;
|
||
|
ULONG TransitionCount;
|
||
|
ULONG CacheTransitionCount;
|
||
|
ULONG DemandZeroCount;
|
||
|
ULONG PageReadCount;
|
||
|
ULONG PageReadIoCount;
|
||
|
ULONG CacheReadCount;
|
||
|
ULONG CacheIoCount;
|
||
|
ULONG DirtyPagesWriteCount;
|
||
|
ULONG DirtyWriteIoCount;
|
||
|
ULONG MappedPagesWriteCount;
|
||
|
ULONG MappedWriteIoCount;
|
||
|
ULONG PagedPoolPages;
|
||
|
ULONG NonPagedPoolPages;
|
||
|
ULONG PagedPoolAllocs;
|
||
|
ULONG PagedPoolFrees;
|
||
|
ULONG NonPagedPoolAllocs;
|
||
|
ULONG NonPagedPoolFrees;
|
||
|
ULONG FreeSystemPtes;
|
||
|
ULONG ResidentSystemCodePage;
|
||
|
ULONG TotalSystemDriverPages;
|
||
|
ULONG TotalSystemCodePages;
|
||
|
ULONG NonPagedPoolLookasideHits;
|
||
|
ULONG PagedPoolLookasideHits;
|
||
|
ULONG AvailablePagedPoolPages;
|
||
|
ULONG ResidentSystemCachePage;
|
||
|
ULONG ResidentPagedPoolPage;
|
||
|
ULONG ResidentSystemDriverPage;
|
||
|
ULONG CcFastReadNoWait;
|
||
|
ULONG CcFastReadWait;
|
||
|
ULONG CcFastReadResourceMiss;
|
||
|
ULONG CcFastReadNotPossible;
|
||
|
ULONG CcFastMdlReadNoWait;
|
||
|
ULONG CcFastMdlReadWait;
|
||
|
ULONG CcFastMdlReadResourceMiss;
|
||
|
ULONG CcFastMdlReadNotPossible;
|
||
|
ULONG CcMapDataNoWait;
|
||
|
ULONG CcMapDataWait;
|
||
|
ULONG CcMapDataNoWaitMiss;
|
||
|
ULONG CcMapDataWaitMiss;
|
||
|
ULONG CcPinMappedDataCount;
|
||
|
ULONG CcPinReadNoWait;
|
||
|
ULONG CcPinReadWait;
|
||
|
ULONG CcPinReadNoWaitMiss;
|
||
|
ULONG CcPinReadWaitMiss;
|
||
|
ULONG CcCopyReadNoWait;
|
||
|
ULONG CcCopyReadWait;
|
||
|
ULONG CcCopyReadNoWaitMiss;
|
||
|
ULONG CcCopyReadWaitMiss;
|
||
|
ULONG CcMdlReadNoWait;
|
||
|
ULONG CcMdlReadWait;
|
||
|
ULONG CcMdlReadNoWaitMiss;
|
||
|
ULONG CcMdlReadWaitMiss;
|
||
|
ULONG CcReadAheadIos;
|
||
|
ULONG CcLazyWriteIos;
|
||
|
ULONG CcLazyWritePages;
|
||
|
ULONG CcDataFlushes;
|
||
|
ULONG CcDataPages;
|
||
|
ULONG ContextSwitches;
|
||
|
ULONG FirstLevelTbFills;
|
||
|
ULONG SecondLevelTbFills;
|
||
|
ULONG SystemCalls;
|
||
|
ULONGLONG CcTotalDirtyPages; // since THRESHOLD
|
||
|
ULONGLONG CcDirtyPageThreshold; // since THRESHOLD
|
||
|
LONGLONG ResidentAvailablePages; // since THRESHOLD
|
||
|
ULONGLONG SharedCommittedPages; // since THRESHOLD
|
||
|
} SYSTEM_PERFORMANCE_INFORMATION, *PSYSTEM_PERFORMANCE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_TIMEOFDAY_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER BootTime;
|
||
|
LARGE_INTEGER CurrentTime;
|
||
|
LARGE_INTEGER TimeZoneBias;
|
||
|
ULONG TimeZoneId;
|
||
|
ULONG Reserved;
|
||
|
ULONGLONG BootTimeBias;
|
||
|
ULONGLONG SleepTimeBias;
|
||
|
} SYSTEM_TIMEOFDAY_INFORMATION, *PSYSTEM_TIMEOFDAY_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_THREAD_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER KernelTime;
|
||
|
LARGE_INTEGER UserTime;
|
||
|
LARGE_INTEGER CreateTime;
|
||
|
ULONG WaitTime;
|
||
|
PVOID StartAddress;
|
||
|
CLIENT_ID ClientId;
|
||
|
KPRIORITY Priority;
|
||
|
LONG BasePriority;
|
||
|
ULONG ContextSwitches;
|
||
|
KTHREAD_STATE ThreadState;
|
||
|
KWAIT_REASON WaitReason;
|
||
|
} SYSTEM_THREAD_INFORMATION, *PSYSTEM_THREAD_INFORMATION;
|
||
|
|
||
|
typedef struct _TEB *PTEB;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_EXTENDED_THREAD_INFORMATION
|
||
|
{
|
||
|
SYSTEM_THREAD_INFORMATION ThreadInfo;
|
||
|
PVOID StackBase;
|
||
|
PVOID StackLimit;
|
||
|
PVOID Win32StartAddress;
|
||
|
PTEB TebBase; // since VISTA
|
||
|
ULONG_PTR Reserved2;
|
||
|
ULONG_PTR Reserved3;
|
||
|
ULONG_PTR Reserved4;
|
||
|
} SYSTEM_EXTENDED_THREAD_INFORMATION, *PSYSTEM_EXTENDED_THREAD_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PROCESS_INFORMATION
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG NumberOfThreads;
|
||
|
LARGE_INTEGER WorkingSetPrivateSize; // since VISTA
|
||
|
ULONG HardFaultCount; // since WIN7
|
||
|
ULONG NumberOfThreadsHighWatermark; // since WIN7
|
||
|
ULONGLONG CycleTime; // since WIN7
|
||
|
LARGE_INTEGER CreateTime;
|
||
|
LARGE_INTEGER UserTime;
|
||
|
LARGE_INTEGER KernelTime;
|
||
|
UNICODE_STRING ImageName;
|
||
|
KPRIORITY BasePriority;
|
||
|
HANDLE UniqueProcessId;
|
||
|
HANDLE InheritedFromUniqueProcessId;
|
||
|
ULONG HandleCount;
|
||
|
ULONG SessionId;
|
||
|
ULONG_PTR UniqueProcessKey; // since VISTA (requires SystemExtendedProcessInformation)
|
||
|
SIZE_T PeakVirtualSize;
|
||
|
SIZE_T VirtualSize;
|
||
|
ULONG PageFaultCount;
|
||
|
SIZE_T PeakWorkingSetSize;
|
||
|
SIZE_T WorkingSetSize;
|
||
|
SIZE_T QuotaPeakPagedPoolUsage;
|
||
|
SIZE_T QuotaPagedPoolUsage;
|
||
|
SIZE_T QuotaPeakNonPagedPoolUsage;
|
||
|
SIZE_T QuotaNonPagedPoolUsage;
|
||
|
SIZE_T PagefileUsage;
|
||
|
SIZE_T PeakPagefileUsage;
|
||
|
SIZE_T PrivatePageCount;
|
||
|
LARGE_INTEGER ReadOperationCount;
|
||
|
LARGE_INTEGER WriteOperationCount;
|
||
|
LARGE_INTEGER OtherOperationCount;
|
||
|
LARGE_INTEGER ReadTransferCount;
|
||
|
LARGE_INTEGER WriteTransferCount;
|
||
|
LARGE_INTEGER OtherTransferCount;
|
||
|
SYSTEM_THREAD_INFORMATION Threads[1]; // SystemProcessInformation
|
||
|
// SYSTEM_EXTENDED_THREAD_INFORMATION Threads[1]; // SystemExtendedProcessinformation
|
||
|
// SYSTEM_EXTENDED_THREAD_INFORMATION + SYSTEM_PROCESS_INFORMATION_EXTENSION // SystemFullProcessInformation
|
||
|
} SYSTEM_PROCESS_INFORMATION, *PSYSTEM_PROCESS_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_CALL_COUNT_INFORMATION
|
||
|
{
|
||
|
ULONG Length;
|
||
|
ULONG NumberOfTables;
|
||
|
} SYSTEM_CALL_COUNT_INFORMATION, *PSYSTEM_CALL_COUNT_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_DEVICE_INFORMATION
|
||
|
{
|
||
|
ULONG NumberOfDisks;
|
||
|
ULONG NumberOfFloppies;
|
||
|
ULONG NumberOfCdRoms;
|
||
|
ULONG NumberOfTapes;
|
||
|
ULONG NumberOfSerialPorts;
|
||
|
ULONG NumberOfParallelPorts;
|
||
|
} SYSTEM_DEVICE_INFORMATION, *PSYSTEM_DEVICE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER IdleTime;
|
||
|
LARGE_INTEGER KernelTime;
|
||
|
LARGE_INTEGER UserTime;
|
||
|
LARGE_INTEGER DpcTime;
|
||
|
LARGE_INTEGER InterruptTime;
|
||
|
ULONG InterruptCount;
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION, *PSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_FLAGS_INFORMATION
|
||
|
{
|
||
|
ULONG Flags; // NtGlobalFlag
|
||
|
} SYSTEM_FLAGS_INFORMATION, *PSYSTEM_FLAGS_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CALL_TIME_INFORMATION
|
||
|
{
|
||
|
ULONG Length;
|
||
|
ULONG TotalCalls;
|
||
|
LARGE_INTEGER TimeOfCalls[1];
|
||
|
} SYSTEM_CALL_TIME_INFORMATION, *PSYSTEM_CALL_TIME_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _RTL_PROCESS_LOCK_INFORMATION
|
||
|
{
|
||
|
PVOID Address;
|
||
|
USHORT Type;
|
||
|
USHORT CreatorBackTraceIndex;
|
||
|
HANDLE OwningThread;
|
||
|
LONG LockCount;
|
||
|
ULONG ContentionCount;
|
||
|
ULONG EntryCount;
|
||
|
LONG RecursionCount;
|
||
|
ULONG NumberOfWaitingShared;
|
||
|
ULONG NumberOfWaitingExclusive;
|
||
|
} RTL_PROCESS_LOCK_INFORMATION, *PRTL_PROCESS_LOCK_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _RTL_PROCESS_LOCKS
|
||
|
{
|
||
|
ULONG NumberOfLocks;
|
||
|
RTL_PROCESS_LOCK_INFORMATION Locks[1];
|
||
|
} RTL_PROCESS_LOCKS, *PRTL_PROCESS_LOCKS;
|
||
|
|
||
|
// private
|
||
|
typedef struct _RTL_PROCESS_BACKTRACE_INFORMATION
|
||
|
{
|
||
|
PCHAR SymbolicBackTrace;
|
||
|
ULONG TraceCount;
|
||
|
USHORT Index;
|
||
|
USHORT Depth;
|
||
|
PVOID BackTrace[32];
|
||
|
} RTL_PROCESS_BACKTRACE_INFORMATION, *PRTL_PROCESS_BACKTRACE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _RTL_PROCESS_BACKTRACES
|
||
|
{
|
||
|
ULONG CommittedMemory;
|
||
|
ULONG ReservedMemory;
|
||
|
ULONG NumberOfBackTraceLookups;
|
||
|
ULONG NumberOfBackTraces;
|
||
|
RTL_PROCESS_BACKTRACE_INFORMATION BackTraces[1];
|
||
|
} RTL_PROCESS_BACKTRACES, *PRTL_PROCESS_BACKTRACES;
|
||
|
|
||
|
typedef struct _SYSTEM_HANDLE_TABLE_ENTRY_INFO
|
||
|
{
|
||
|
USHORT UniqueProcessId;
|
||
|
USHORT CreatorBackTraceIndex;
|
||
|
UCHAR ObjectTypeIndex;
|
||
|
UCHAR HandleAttributes;
|
||
|
USHORT HandleValue;
|
||
|
PVOID Object;
|
||
|
ULONG GrantedAccess;
|
||
|
} SYSTEM_HANDLE_TABLE_ENTRY_INFO, *PSYSTEM_HANDLE_TABLE_ENTRY_INFO;
|
||
|
|
||
|
typedef struct _SYSTEM_HANDLE_INFORMATION
|
||
|
{
|
||
|
ULONG NumberOfHandles;
|
||
|
SYSTEM_HANDLE_TABLE_ENTRY_INFO Handles[1];
|
||
|
} SYSTEM_HANDLE_INFORMATION, *PSYSTEM_HANDLE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_OBJECTTYPE_INFORMATION
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG NumberOfObjects;
|
||
|
ULONG NumberOfHandles;
|
||
|
ULONG TypeIndex;
|
||
|
ULONG InvalidAttributes;
|
||
|
GENERIC_MAPPING GenericMapping;
|
||
|
ULONG ValidAccessMask;
|
||
|
ULONG PoolType;
|
||
|
BOOLEAN SecurityRequired;
|
||
|
BOOLEAN WaitableObject;
|
||
|
UNICODE_STRING TypeName;
|
||
|
} SYSTEM_OBJECTTYPE_INFORMATION, *PSYSTEM_OBJECTTYPE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_OBJECT_INFORMATION
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
PVOID Object;
|
||
|
HANDLE CreatorUniqueProcess;
|
||
|
USHORT CreatorBackTraceIndex;
|
||
|
USHORT Flags;
|
||
|
LONG PointerCount;
|
||
|
LONG HandleCount;
|
||
|
ULONG PagedPoolCharge;
|
||
|
ULONG NonPagedPoolCharge;
|
||
|
HANDLE ExclusiveProcessId;
|
||
|
PVOID SecurityDescriptor;
|
||
|
UNICODE_STRING NameInfo;
|
||
|
} SYSTEM_OBJECT_INFORMATION, *PSYSTEM_OBJECT_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PAGEFILE_INFORMATION
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG TotalSize;
|
||
|
ULONG TotalInUse;
|
||
|
ULONG PeakUsage;
|
||
|
UNICODE_STRING PageFileName;
|
||
|
} SYSTEM_PAGEFILE_INFORMATION, *PSYSTEM_PAGEFILE_INFORMATION;
|
||
|
|
||
|
#define MM_WORKING_SET_MAX_HARD_ENABLE 0x1
|
||
|
#define MM_WORKING_SET_MAX_HARD_DISABLE 0x2
|
||
|
#define MM_WORKING_SET_MIN_HARD_ENABLE 0x4
|
||
|
#define MM_WORKING_SET_MIN_HARD_DISABLE 0x8
|
||
|
|
||
|
typedef struct _SYSTEM_FILECACHE_INFORMATION
|
||
|
{
|
||
|
SIZE_T CurrentSize;
|
||
|
SIZE_T PeakSize;
|
||
|
ULONG PageFaultCount;
|
||
|
SIZE_T MinimumWorkingSet;
|
||
|
SIZE_T MaximumWorkingSet;
|
||
|
SIZE_T CurrentSizeIncludingTransitionInPages;
|
||
|
SIZE_T PeakSizeIncludingTransitionInPages;
|
||
|
ULONG TransitionRePurposeCount;
|
||
|
ULONG Flags;
|
||
|
} SYSTEM_FILECACHE_INFORMATION, *PSYSTEM_FILECACHE_INFORMATION;
|
||
|
|
||
|
// Can be used instead of SYSTEM_FILECACHE_INFORMATION
|
||
|
typedef struct _SYSTEM_BASIC_WORKING_SET_INFORMATION
|
||
|
{
|
||
|
SIZE_T CurrentSize;
|
||
|
SIZE_T PeakSize;
|
||
|
ULONG PageFaultCount;
|
||
|
} SYSTEM_BASIC_WORKING_SET_INFORMATION, *PSYSTEM_BASIC_WORKING_SET_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_POOLTAG
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
UCHAR Tag[4];
|
||
|
ULONG TagUlong;
|
||
|
};
|
||
|
ULONG PagedAllocs;
|
||
|
ULONG PagedFrees;
|
||
|
SIZE_T PagedUsed;
|
||
|
ULONG NonPagedAllocs;
|
||
|
ULONG NonPagedFrees;
|
||
|
SIZE_T NonPagedUsed;
|
||
|
} SYSTEM_POOLTAG, *PSYSTEM_POOLTAG;
|
||
|
|
||
|
typedef struct _SYSTEM_POOLTAG_INFORMATION
|
||
|
{
|
||
|
ULONG Count;
|
||
|
SYSTEM_POOLTAG TagInfo[1];
|
||
|
} SYSTEM_POOLTAG_INFORMATION, *PSYSTEM_POOLTAG_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_INTERRUPT_INFORMATION
|
||
|
{
|
||
|
ULONG ContextSwitches;
|
||
|
ULONG DpcCount;
|
||
|
ULONG DpcRate;
|
||
|
ULONG TimeIncrement;
|
||
|
ULONG DpcBypassCount;
|
||
|
ULONG ApcBypassCount;
|
||
|
} SYSTEM_INTERRUPT_INFORMATION, *PSYSTEM_INTERRUPT_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_DPC_BEHAVIOR_INFORMATION
|
||
|
{
|
||
|
ULONG Spare;
|
||
|
ULONG DpcQueueDepth;
|
||
|
ULONG MinimumDpcRate;
|
||
|
ULONG AdjustDpcThreshold;
|
||
|
ULONG IdealDpcRate;
|
||
|
} SYSTEM_DPC_BEHAVIOR_INFORMATION, *PSYSTEM_DPC_BEHAVIOR_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_QUERY_TIME_ADJUST_INFORMATION
|
||
|
{
|
||
|
ULONG TimeAdjustment;
|
||
|
ULONG TimeIncrement;
|
||
|
BOOLEAN Enable;
|
||
|
} SYSTEM_QUERY_TIME_ADJUST_INFORMATION, *PSYSTEM_QUERY_TIME_ADJUST_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_QUERY_TIME_ADJUST_INFORMATION_PRECISE
|
||
|
{
|
||
|
ULONGLONG TimeAdjustment;
|
||
|
ULONGLONG TimeIncrement;
|
||
|
BOOLEAN Enable;
|
||
|
} SYSTEM_QUERY_TIME_ADJUST_INFORMATION_PRECISE, *PSYSTEM_QUERY_TIME_ADJUST_INFORMATION_PRECISE;
|
||
|
|
||
|
typedef struct _SYSTEM_SET_TIME_ADJUST_INFORMATION
|
||
|
{
|
||
|
ULONG TimeAdjustment;
|
||
|
BOOLEAN Enable;
|
||
|
} SYSTEM_SET_TIME_ADJUST_INFORMATION, *PSYSTEM_SET_TIME_ADJUST_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_SET_TIME_ADJUST_INFORMATION_PRECISE
|
||
|
{
|
||
|
ULONGLONG TimeAdjustment;
|
||
|
BOOLEAN Enable;
|
||
|
} SYSTEM_SET_TIME_ADJUST_INFORMATION_PRECISE, *PSYSTEM_SET_TIME_ADJUST_INFORMATION_PRECISE;
|
||
|
|
||
|
typedef enum _EVENT_TRACE_INFORMATION_CLASS
|
||
|
{
|
||
|
EventTraceKernelVersionInformation, // EVENT_TRACE_VERSION_INFORMATION
|
||
|
EventTraceGroupMaskInformation, // EVENT_TRACE_GROUPMASK_INFORMATION
|
||
|
EventTracePerformanceInformation, // EVENT_TRACE_PERFORMANCE_INFORMATION
|
||
|
EventTraceTimeProfileInformation, // EVENT_TRACE_TIME_PROFILE_INFORMATION
|
||
|
EventTraceSessionSecurityInformation, // EVENT_TRACE_SESSION_SECURITY_INFORMATION
|
||
|
EventTraceSpinlockInformation, // EVENT_TRACE_SPINLOCK_INFORMATION
|
||
|
EventTraceStackTracingInformation, // EVENT_TRACE_SYSTEM_EVENT_INFORMATION
|
||
|
EventTraceExecutiveResourceInformation, // EVENT_TRACE_EXECUTIVE_RESOURCE_INFORMATION
|
||
|
EventTraceHeapTracingInformation, // EVENT_TRACE_HEAP_TRACING_INFORMATION
|
||
|
EventTraceHeapSummaryTracingInformation, // EVENT_TRACE_HEAP_TRACING_INFORMATION
|
||
|
EventTracePoolTagFilterInformation, // EVENT_TRACE_TAG_FILTER_INFORMATION
|
||
|
EventTracePebsTracingInformation, // EVENT_TRACE_SYSTEM_EVENT_INFORMATION
|
||
|
EventTraceProfileConfigInformation, // EVENT_TRACE_PROFILE_COUNTER_INFORMATION
|
||
|
EventTraceProfileSourceListInformation, // EVENT_TRACE_PROFILE_LIST_INFORMATION
|
||
|
EventTraceProfileEventListInformation, // EVENT_TRACE_SYSTEM_EVENT_INFORMATION
|
||
|
EventTraceProfileCounterListInformation, // EVENT_TRACE_PROFILE_COUNTER_INFORMATION
|
||
|
EventTraceStackCachingInformation, // EVENT_TRACE_STACK_CACHING_INFORMATION
|
||
|
EventTraceObjectTypeFilterInformation, // EVENT_TRACE_TAG_FILTER_INFORMATION
|
||
|
EventTraceSoftRestartInformation, // EVENT_TRACE_SOFT_RESTART_INFORMATION
|
||
|
EventTraceLastBranchConfigurationInformation, // REDSTONE3
|
||
|
EventTraceLastBranchEventListInformation,
|
||
|
EventTraceProfileSourceAddInformation, // EVENT_TRACE_PROFILE_ADD_INFORMATION // REDSTONE4
|
||
|
EventTraceProfileSourceRemoveInformation, // EVENT_TRACE_PROFILE_REMOVE_INFORMATION
|
||
|
EventTraceProcessorTraceConfigurationInformation,
|
||
|
EventTraceProcessorTraceEventListInformation,
|
||
|
EventTraceCoverageSamplerInformation, // EVENT_TRACE_COVERAGE_SAMPLER_INFORMATION
|
||
|
MaxEventTraceInfoClass
|
||
|
} EVENT_TRACE_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_VERSION_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG EventTraceKernelVersion;
|
||
|
} EVENT_TRACE_VERSION_INFORMATION, *PEVENT_TRACE_VERSION_INFORMATION;
|
||
|
|
||
|
typedef struct _PERFINFO_GROUPMASK
|
||
|
{
|
||
|
ULONG Masks[8];
|
||
|
} PERFINFO_GROUPMASK, *PPERFINFO_GROUPMASK;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_GROUPMASK_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
PERFINFO_GROUPMASK EventTraceGroupMasks;
|
||
|
} EVENT_TRACE_GROUPMASK_INFORMATION, *PEVENT_TRACE_GROUPMASK_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_PERFORMANCE_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
LARGE_INTEGER LogfileBytesWritten;
|
||
|
} EVENT_TRACE_PERFORMANCE_INFORMATION, *PEVENT_TRACE_PERFORMANCE_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_TIME_PROFILE_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG ProfileInterval;
|
||
|
} EVENT_TRACE_TIME_PROFILE_INFORMATION, *PEVENT_TRACE_TIME_PROFILE_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_SESSION_SECURITY_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG SecurityInformation;
|
||
|
HANDLE TraceHandle;
|
||
|
UCHAR SecurityDescriptor[1];
|
||
|
} EVENT_TRACE_SESSION_SECURITY_INFORMATION, *PEVENT_TRACE_SESSION_SECURITY_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_SPINLOCK_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG SpinLockSpinThreshold;
|
||
|
ULONG SpinLockAcquireSampleRate;
|
||
|
ULONG SpinLockContentionSampleRate;
|
||
|
ULONG SpinLockHoldThreshold;
|
||
|
} EVENT_TRACE_SPINLOCK_INFORMATION, *PEVENT_TRACE_SPINLOCK_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_SYSTEM_EVENT_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
ULONG HookId[1];
|
||
|
} EVENT_TRACE_SYSTEM_EVENT_INFORMATION, *PEVENT_TRACE_SYSTEM_EVENT_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_EXECUTIVE_RESOURCE_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG ReleaseSamplingRate;
|
||
|
ULONG ContentionSamplingRate;
|
||
|
ULONG NumberOfExcessiveTimeouts;
|
||
|
} EVENT_TRACE_EXECUTIVE_RESOURCE_INFORMATION, *PEVENT_TRACE_EXECUTIVE_RESOURCE_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_HEAP_TRACING_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG ProcessId;
|
||
|
} EVENT_TRACE_HEAP_TRACING_INFORMATION, *PEVENT_TRACE_HEAP_TRACING_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_TAG_FILTER_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
ULONG Filter[1];
|
||
|
} EVENT_TRACE_TAG_FILTER_INFORMATION, *PEVENT_TRACE_TAG_FILTER_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_PROFILE_COUNTER_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
ULONG ProfileSource[1];
|
||
|
} EVENT_TRACE_PROFILE_COUNTER_INFORMATION, *PEVENT_TRACE_PROFILE_COUNTER_INFORMATION;
|
||
|
|
||
|
//typedef struct _PROFILE_SOURCE_INFO
|
||
|
//{
|
||
|
// ULONG NextEntryOffset;
|
||
|
// ULONG Source;
|
||
|
// ULONG MinInterval;
|
||
|
// ULONG MaxInterval;
|
||
|
// PVOID Reserved;
|
||
|
// WCHAR Description[1];
|
||
|
//} PROFILE_SOURCE_INFO, *PPROFILE_SOURCE_INFO;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_PROFILE_LIST_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
ULONG Spare;
|
||
|
struct _PROFILE_SOURCE_INFO* Profile[1];
|
||
|
} EVENT_TRACE_PROFILE_LIST_INFORMATION, *PEVENT_TRACE_PROFILE_LIST_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_STACK_CACHING_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
BOOLEAN Enabled;
|
||
|
UCHAR Reserved[3];
|
||
|
ULONG CacheSize;
|
||
|
ULONG BucketCount;
|
||
|
} EVENT_TRACE_STACK_CACHING_INFORMATION, *PEVENT_TRACE_STACK_CACHING_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_SOFT_RESTART_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
HANDLE TraceHandle;
|
||
|
BOOLEAN PersistTraceBuffers;
|
||
|
WCHAR FileName[1];
|
||
|
} EVENT_TRACE_SOFT_RESTART_INFORMATION, *PEVENT_TRACE_SOFT_RESTART_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_PROFILE_ADD_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
BOOLEAN PerfEvtEventSelect;
|
||
|
BOOLEAN PerfEvtUnitSelect;
|
||
|
ULONG PerfEvtType;
|
||
|
ULONG CpuInfoHierarchy[0x3];
|
||
|
ULONG InitialInterval;
|
||
|
BOOLEAN AllowsHalt;
|
||
|
BOOLEAN Persist;
|
||
|
WCHAR ProfileSourceDescription[0x1];
|
||
|
} EVENT_TRACE_PROFILE_ADD_INFORMATION, *PEVENT_TRACE_PROFILE_ADD_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_PROFILE_REMOVE_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
KPROFILE_SOURCE ProfileSource;
|
||
|
ULONG CpuInfoHierarchy[0x3];
|
||
|
} EVENT_TRACE_PROFILE_REMOVE_INFORMATION, *PEVENT_TRACE_PROFILE_REMOVE_INFORMATION;
|
||
|
|
||
|
typedef struct _EVENT_TRACE_COVERAGE_SAMPLER_INFORMATION
|
||
|
{
|
||
|
EVENT_TRACE_INFORMATION_CLASS EventTraceInformationClass;
|
||
|
BOOLEAN CoverageSamplerInformationClass;
|
||
|
UCHAR MajorVersion;
|
||
|
UCHAR MinorVersion;
|
||
|
UCHAR Reserved;
|
||
|
HANDLE SamplerHandle;
|
||
|
} EVENT_TRACE_COVERAGE_SAMPLER_INFORMATION, *PEVENT_TRACE_COVERAGE_SAMPLER_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_EXCEPTION_INFORMATION
|
||
|
{
|
||
|
ULONG AlignmentFixupCount;
|
||
|
ULONG ExceptionDispatchCount;
|
||
|
ULONG FloatingEmulationCount;
|
||
|
ULONG ByteWordEmulationCount;
|
||
|
} SYSTEM_EXCEPTION_INFORMATION, *PSYSTEM_EXCEPTION_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_KERNEL_DEBUGGER_INFORMATION
|
||
|
{
|
||
|
BOOLEAN KernelDebuggerEnabled;
|
||
|
BOOLEAN KernelDebuggerNotPresent;
|
||
|
} SYSTEM_KERNEL_DEBUGGER_INFORMATION, *PSYSTEM_KERNEL_DEBUGGER_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_CONTEXT_SWITCH_INFORMATION
|
||
|
{
|
||
|
ULONG ContextSwitches;
|
||
|
ULONG FindAny;
|
||
|
ULONG FindLast;
|
||
|
ULONG FindIdeal;
|
||
|
ULONG IdleAny;
|
||
|
ULONG IdleCurrent;
|
||
|
ULONG IdleLast;
|
||
|
ULONG IdleIdeal;
|
||
|
ULONG PreemptAny;
|
||
|
ULONG PreemptCurrent;
|
||
|
ULONG PreemptLast;
|
||
|
ULONG SwitchToIdle;
|
||
|
} SYSTEM_CONTEXT_SWITCH_INFORMATION, *PSYSTEM_CONTEXT_SWITCH_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_REGISTRY_QUOTA_INFORMATION
|
||
|
{
|
||
|
ULONG RegistryQuotaAllowed;
|
||
|
ULONG RegistryQuotaUsed;
|
||
|
SIZE_T PagedPoolSize;
|
||
|
} SYSTEM_REGISTRY_QUOTA_INFORMATION, *PSYSTEM_REGISTRY_QUOTA_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PROCESSOR_IDLE_INFORMATION
|
||
|
{
|
||
|
ULONGLONG IdleTime;
|
||
|
ULONGLONG C1Time;
|
||
|
ULONGLONG C2Time;
|
||
|
ULONGLONG C3Time;
|
||
|
ULONG C1Transitions;
|
||
|
ULONG C2Transitions;
|
||
|
ULONG C3Transitions;
|
||
|
ULONG Padding;
|
||
|
} SYSTEM_PROCESSOR_IDLE_INFORMATION, *PSYSTEM_PROCESSOR_IDLE_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_LEGACY_DRIVER_INFORMATION
|
||
|
{
|
||
|
ULONG VetoType;
|
||
|
UNICODE_STRING VetoList;
|
||
|
} SYSTEM_LEGACY_DRIVER_INFORMATION, *PSYSTEM_LEGACY_DRIVER_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_LOOKASIDE_INFORMATION
|
||
|
{
|
||
|
USHORT CurrentDepth;
|
||
|
USHORT MaximumDepth;
|
||
|
ULONG TotalAllocates;
|
||
|
ULONG AllocateMisses;
|
||
|
ULONG TotalFrees;
|
||
|
ULONG FreeMisses;
|
||
|
ULONG Type;
|
||
|
ULONG Tag;
|
||
|
ULONG Size;
|
||
|
} SYSTEM_LOOKASIDE_INFORMATION, *PSYSTEM_LOOKASIDE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_RANGE_START_INFORMATION
|
||
|
{
|
||
|
PVOID SystemRangeStart;
|
||
|
} SYSTEM_RANGE_START_INFORMATION, *PSYSTEM_RANGE_START_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_VERIFIER_INFORMATION_LEGACY // pre-19H1
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG Level;
|
||
|
UNICODE_STRING DriverName;
|
||
|
|
||
|
ULONG RaiseIrqls;
|
||
|
ULONG AcquireSpinLocks;
|
||
|
ULONG SynchronizeExecutions;
|
||
|
ULONG AllocationsAttempted;
|
||
|
|
||
|
ULONG AllocationsSucceeded;
|
||
|
ULONG AllocationsSucceededSpecialPool;
|
||
|
ULONG AllocationsWithNoTag;
|
||
|
ULONG TrimRequests;
|
||
|
|
||
|
ULONG Trims;
|
||
|
ULONG AllocationsFailed;
|
||
|
ULONG AllocationsFailedDeliberately;
|
||
|
ULONG Loads;
|
||
|
|
||
|
ULONG Unloads;
|
||
|
ULONG UnTrackedPool;
|
||
|
ULONG CurrentPagedPoolAllocations;
|
||
|
ULONG CurrentNonPagedPoolAllocations;
|
||
|
|
||
|
ULONG PeakPagedPoolAllocations;
|
||
|
ULONG PeakNonPagedPoolAllocations;
|
||
|
|
||
|
SIZE_T PagedPoolUsageInBytes;
|
||
|
SIZE_T NonPagedPoolUsageInBytes;
|
||
|
SIZE_T PeakPagedPoolUsageInBytes;
|
||
|
SIZE_T PeakNonPagedPoolUsageInBytes;
|
||
|
} SYSTEM_VERIFIER_INFORMATION_LEGACY, *PSYSTEM_VERIFIER_INFORMATION_LEGACY;
|
||
|
|
||
|
typedef struct _SYSTEM_VERIFIER_INFORMATION
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG Level;
|
||
|
ULONG RuleClasses[2];
|
||
|
ULONG TriageContext;
|
||
|
ULONG AreAllDriversBeingVerified;
|
||
|
|
||
|
UNICODE_STRING DriverName;
|
||
|
|
||
|
ULONG RaiseIrqls;
|
||
|
ULONG AcquireSpinLocks;
|
||
|
ULONG SynchronizeExecutions;
|
||
|
ULONG AllocationsAttempted;
|
||
|
|
||
|
ULONG AllocationsSucceeded;
|
||
|
ULONG AllocationsSucceededSpecialPool;
|
||
|
ULONG AllocationsWithNoTag;
|
||
|
ULONG TrimRequests;
|
||
|
|
||
|
ULONG Trims;
|
||
|
ULONG AllocationsFailed;
|
||
|
ULONG AllocationsFailedDeliberately;
|
||
|
ULONG Loads;
|
||
|
|
||
|
ULONG Unloads;
|
||
|
ULONG UnTrackedPool;
|
||
|
ULONG CurrentPagedPoolAllocations;
|
||
|
ULONG CurrentNonPagedPoolAllocations;
|
||
|
|
||
|
ULONG PeakPagedPoolAllocations;
|
||
|
ULONG PeakNonPagedPoolAllocations;
|
||
|
|
||
|
SIZE_T PagedPoolUsageInBytes;
|
||
|
SIZE_T NonPagedPoolUsageInBytes;
|
||
|
SIZE_T PeakPagedPoolUsageInBytes;
|
||
|
SIZE_T PeakNonPagedPoolUsageInBytes;
|
||
|
} SYSTEM_VERIFIER_INFORMATION, *PSYSTEM_VERIFIER_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_SESSION_PROCESS_INFORMATION
|
||
|
{
|
||
|
ULONG SessionId;
|
||
|
ULONG SizeOfBuf;
|
||
|
PVOID Buffer;
|
||
|
} SYSTEM_SESSION_PROCESS_INFORMATION, *PSYSTEM_SESSION_PROCESS_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_PROCESSOR_POWER_INFORMATION
|
||
|
{
|
||
|
UCHAR CurrentFrequency;
|
||
|
UCHAR ThermalLimitFrequency;
|
||
|
UCHAR ConstantThrottleFrequency;
|
||
|
UCHAR DegradedThrottleFrequency;
|
||
|
UCHAR LastBusyFrequency;
|
||
|
UCHAR LastC3Frequency;
|
||
|
UCHAR LastAdjustedBusyFrequency;
|
||
|
UCHAR ProcessorMinThrottle;
|
||
|
UCHAR ProcessorMaxThrottle;
|
||
|
ULONG NumberOfFrequencies;
|
||
|
ULONG PromotionCount;
|
||
|
ULONG DemotionCount;
|
||
|
ULONG ErrorCount;
|
||
|
ULONG RetryCount;
|
||
|
ULONGLONG CurrentFrequencyTime;
|
||
|
ULONGLONG CurrentProcessorTime;
|
||
|
ULONGLONG CurrentProcessorIdleTime;
|
||
|
ULONGLONG LastProcessorTime;
|
||
|
ULONGLONG LastProcessorIdleTime;
|
||
|
ULONGLONG Energy;
|
||
|
} SYSTEM_PROCESSOR_POWER_INFORMATION, *PSYSTEM_PROCESSOR_POWER_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_HANDLE_TABLE_ENTRY_INFO_EX
|
||
|
{
|
||
|
PVOID Object;
|
||
|
ULONG_PTR UniqueProcessId;
|
||
|
ULONG_PTR HandleValue;
|
||
|
ULONG GrantedAccess;
|
||
|
USHORT CreatorBackTraceIndex;
|
||
|
USHORT ObjectTypeIndex;
|
||
|
ULONG HandleAttributes;
|
||
|
ULONG Reserved;
|
||
|
} SYSTEM_HANDLE_TABLE_ENTRY_INFO_EX, *PSYSTEM_HANDLE_TABLE_ENTRY_INFO_EX;
|
||
|
|
||
|
typedef struct _SYSTEM_HANDLE_INFORMATION_EX
|
||
|
{
|
||
|
ULONG_PTR NumberOfHandles;
|
||
|
ULONG_PTR Reserved;
|
||
|
SYSTEM_HANDLE_TABLE_ENTRY_INFO_EX Handles[1];
|
||
|
} SYSTEM_HANDLE_INFORMATION_EX, *PSYSTEM_HANDLE_INFORMATION_EX;
|
||
|
|
||
|
typedef struct _SYSTEM_BIGPOOL_ENTRY
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
PVOID VirtualAddress;
|
||
|
ULONG_PTR NonPaged : 1;
|
||
|
};
|
||
|
SIZE_T SizeInBytes;
|
||
|
union
|
||
|
{
|
||
|
UCHAR Tag[4];
|
||
|
ULONG TagUlong;
|
||
|
};
|
||
|
} SYSTEM_BIGPOOL_ENTRY, *PSYSTEM_BIGPOOL_ENTRY;
|
||
|
|
||
|
typedef struct _SYSTEM_BIGPOOL_INFORMATION
|
||
|
{
|
||
|
ULONG Count;
|
||
|
SYSTEM_BIGPOOL_ENTRY AllocatedInfo[1];
|
||
|
} SYSTEM_BIGPOOL_INFORMATION, *PSYSTEM_BIGPOOL_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_POOL_ENTRY
|
||
|
{
|
||
|
BOOLEAN Allocated;
|
||
|
BOOLEAN Spare0;
|
||
|
USHORT AllocatorBackTraceIndex;
|
||
|
ULONG Size;
|
||
|
union
|
||
|
{
|
||
|
UCHAR Tag[4];
|
||
|
ULONG TagUlong;
|
||
|
PVOID ProcessChargedQuota;
|
||
|
};
|
||
|
} SYSTEM_POOL_ENTRY, *PSYSTEM_POOL_ENTRY;
|
||
|
|
||
|
typedef struct _SYSTEM_POOL_INFORMATION
|
||
|
{
|
||
|
SIZE_T TotalSize;
|
||
|
PVOID FirstEntry;
|
||
|
USHORT EntryOverhead;
|
||
|
BOOLEAN PoolTagPresent;
|
||
|
BOOLEAN Spare0;
|
||
|
ULONG NumberOfEntries;
|
||
|
SYSTEM_POOL_ENTRY Entries[1];
|
||
|
} SYSTEM_POOL_INFORMATION, *PSYSTEM_POOL_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_SESSION_POOLTAG_INFORMATION
|
||
|
{
|
||
|
SIZE_T NextEntryOffset;
|
||
|
ULONG SessionId;
|
||
|
ULONG Count;
|
||
|
SYSTEM_POOLTAG TagInfo[1];
|
||
|
} SYSTEM_SESSION_POOLTAG_INFORMATION, *PSYSTEM_SESSION_POOLTAG_INFORMATION;
|
||
|
|
||
|
typedef struct _SYSTEM_SESSION_MAPPED_VIEW_INFORMATION
|
||
|
{
|
||
|
SIZE_T NextEntryOffset;
|
||
|
ULONG SessionId;
|
||
|
ULONG ViewFailures;
|
||
|
SIZE_T NumberOfBytesAvailable;
|
||
|
SIZE_T NumberOfBytesAvailableContiguous;
|
||
|
} SYSTEM_SESSION_MAPPED_VIEW_INFORMATION, *PSYSTEM_SESSION_MAPPED_VIEW_INFORMATION;
|
||
|
|
||
|
#if (PHNT_MODE != PHNT_MODE_KERNEL)
|
||
|
// private
|
||
|
typedef enum _SYSTEM_FIRMWARE_TABLE_ACTION
|
||
|
{
|
||
|
SystemFirmwareTableEnumerate,
|
||
|
SystemFirmwareTableGet,
|
||
|
SystemFirmwareTableMax
|
||
|
} SYSTEM_FIRMWARE_TABLE_ACTION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_FIRMWARE_TABLE_INFORMATION
|
||
|
{
|
||
|
ULONG ProviderSignature; // (same as the GetSystemFirmwareTable function)
|
||
|
SYSTEM_FIRMWARE_TABLE_ACTION Action;
|
||
|
ULONG TableID;
|
||
|
ULONG TableBufferLength;
|
||
|
UCHAR TableBuffer[1];
|
||
|
} SYSTEM_FIRMWARE_TABLE_INFORMATION, *PSYSTEM_FIRMWARE_TABLE_INFORMATION;
|
||
|
#endif
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_MEMORY_LIST_INFORMATION
|
||
|
{
|
||
|
ULONG_PTR ZeroPageCount;
|
||
|
ULONG_PTR FreePageCount;
|
||
|
ULONG_PTR ModifiedPageCount;
|
||
|
ULONG_PTR ModifiedNoWritePageCount;
|
||
|
ULONG_PTR BadPageCount;
|
||
|
ULONG_PTR PageCountByPriority[8];
|
||
|
ULONG_PTR RepurposedPagesByPriority[8];
|
||
|
ULONG_PTR ModifiedPageCountPageFile;
|
||
|
} SYSTEM_MEMORY_LIST_INFORMATION, *PSYSTEM_MEMORY_LIST_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSTEM_MEMORY_LIST_COMMAND
|
||
|
{
|
||
|
MemoryCaptureAccessedBits,
|
||
|
MemoryCaptureAndResetAccessedBits,
|
||
|
MemoryEmptyWorkingSets,
|
||
|
MemoryFlushModifiedList,
|
||
|
MemoryPurgeStandbyList,
|
||
|
MemoryPurgeLowPriorityStandbyList,
|
||
|
MemoryCommandMax
|
||
|
} SYSTEM_MEMORY_LIST_COMMAND;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_THREAD_CID_PRIORITY_INFORMATION
|
||
|
{
|
||
|
CLIENT_ID ClientId;
|
||
|
KPRIORITY Priority;
|
||
|
} SYSTEM_THREAD_CID_PRIORITY_INFORMATION, *PSYSTEM_THREAD_CID_PRIORITY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_IDLE_CYCLE_TIME_INFORMATION
|
||
|
{
|
||
|
ULONGLONG CycleTime;
|
||
|
} SYSTEM_PROCESSOR_IDLE_CYCLE_TIME_INFORMATION, *PSYSTEM_PROCESSOR_IDLE_CYCLE_TIME_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_REF_TRACE_INFORMATION
|
||
|
{
|
||
|
BOOLEAN TraceEnable;
|
||
|
BOOLEAN TracePermanent;
|
||
|
UNICODE_STRING TraceProcessName;
|
||
|
UNICODE_STRING TracePoolTags;
|
||
|
} SYSTEM_REF_TRACE_INFORMATION, *PSYSTEM_REF_TRACE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESS_ID_INFORMATION
|
||
|
{
|
||
|
HANDLE ProcessId;
|
||
|
UNICODE_STRING ImageName;
|
||
|
} SYSTEM_PROCESS_ID_INFORMATION, *PSYSTEM_PROCESS_ID_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_BOOT_ENVIRONMENT_INFORMATION
|
||
|
{
|
||
|
GUID BootIdentifier;
|
||
|
FIRMWARE_TYPE FirmwareType;
|
||
|
union
|
||
|
{
|
||
|
ULONGLONG BootFlags;
|
||
|
struct
|
||
|
{
|
||
|
ULONGLONG DbgMenuOsSelection : 1; // REDSTONE4
|
||
|
ULONGLONG DbgHiberBoot : 1;
|
||
|
ULONGLONG DbgSoftBoot : 1;
|
||
|
ULONGLONG DbgMeasuredLaunch : 1;
|
||
|
ULONGLONG DbgMeasuredLaunchCapable : 1; // 19H1
|
||
|
ULONGLONG DbgSystemHiveReplace : 1;
|
||
|
ULONGLONG DbgMeasuredLaunchSmmProtections : 1;
|
||
|
};
|
||
|
};
|
||
|
} SYSTEM_BOOT_ENVIRONMENT_INFORMATION, *PSYSTEM_BOOT_ENVIRONMENT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_IMAGE_FILE_EXECUTION_OPTIONS_INFORMATION
|
||
|
{
|
||
|
ULONG FlagsToEnable;
|
||
|
ULONG FlagsToDisable;
|
||
|
} SYSTEM_IMAGE_FILE_EXECUTION_OPTIONS_INFORMATION, *PSYSTEM_IMAGE_FILE_EXECUTION_OPTIONS_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_VERIFIER_INFORMATION_EX
|
||
|
{
|
||
|
ULONG VerifyMode;
|
||
|
ULONG OptionChanges;
|
||
|
UNICODE_STRING PreviousBucketName;
|
||
|
ULONG IrpCancelTimeoutMsec;
|
||
|
ULONG VerifierExtensionEnabled;
|
||
|
#ifdef _WIN64
|
||
|
ULONG Reserved[1];
|
||
|
#else
|
||
|
ULONG Reserved[3];
|
||
|
#endif
|
||
|
} SYSTEM_VERIFIER_INFORMATION_EX, *PSYSTEM_VERIFIER_INFORMATION_EX;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SYSTEM_PARTITION_INFORMATION
|
||
|
{
|
||
|
UNICODE_STRING SystemPartition;
|
||
|
} SYSTEM_SYSTEM_PARTITION_INFORMATION, *PSYSTEM_SYSTEM_PARTITION_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SYSTEM_DISK_INFORMATION
|
||
|
{
|
||
|
UNICODE_STRING SystemDisk;
|
||
|
} SYSTEM_SYSTEM_DISK_INFORMATION, *PSYSTEM_SYSTEM_DISK_INFORMATION;
|
||
|
|
||
|
// private (Windows 8.1 and above)
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT
|
||
|
{
|
||
|
ULONGLONG Hits;
|
||
|
UCHAR PercentFrequency;
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT, *PSYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT;
|
||
|
|
||
|
// private (Windows 7 and Windows 8)
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT_WIN8
|
||
|
{
|
||
|
ULONG Hits;
|
||
|
UCHAR PercentFrequency;
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT_WIN8, *PSYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT_WIN8;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_STATE_DISTRIBUTION
|
||
|
{
|
||
|
ULONG ProcessorNumber;
|
||
|
ULONG StateCount;
|
||
|
SYSTEM_PROCESSOR_PERFORMANCE_HITCOUNT States[1];
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_STATE_DISTRIBUTION, *PSYSTEM_PROCESSOR_PERFORMANCE_STATE_DISTRIBUTION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_DISTRIBUTION
|
||
|
{
|
||
|
ULONG ProcessorCount;
|
||
|
ULONG Offsets[1];
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_DISTRIBUTION, *PSYSTEM_PROCESSOR_PERFORMANCE_DISTRIBUTION;
|
||
|
|
||
|
#define CODEINTEGRITY_OPTION_ENABLED 0x01
|
||
|
#define CODEINTEGRITY_OPTION_TESTSIGN 0x02
|
||
|
#define CODEINTEGRITY_OPTION_UMCI_ENABLED 0x04
|
||
|
#define CODEINTEGRITY_OPTION_UMCI_AUDITMODE_ENABLED 0x08
|
||
|
#define CODEINTEGRITY_OPTION_UMCI_EXCLUSIONPATHS_ENABLED 0x10
|
||
|
#define CODEINTEGRITY_OPTION_TEST_BUILD 0x20
|
||
|
#define CODEINTEGRITY_OPTION_PREPRODUCTION_BUILD 0x40
|
||
|
#define CODEINTEGRITY_OPTION_DEBUGMODE_ENABLED 0x80
|
||
|
#define CODEINTEGRITY_OPTION_FLIGHT_BUILD 0x100
|
||
|
#define CODEINTEGRITY_OPTION_FLIGHTING_ENABLED 0x200
|
||
|
#define CODEINTEGRITY_OPTION_HVCI_KMCI_ENABLED 0x400
|
||
|
#define CODEINTEGRITY_OPTION_HVCI_KMCI_AUDITMODE_ENABLED 0x800
|
||
|
#define CODEINTEGRITY_OPTION_HVCI_KMCI_STRICTMODE_ENABLED 0x1000
|
||
|
#define CODEINTEGRITY_OPTION_HVCI_IUM_ENABLED 0x2000
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CODEINTEGRITY_INFORMATION
|
||
|
{
|
||
|
ULONG Length;
|
||
|
ULONG CodeIntegrityOptions;
|
||
|
} SYSTEM_CODEINTEGRITY_INFORMATION, *PSYSTEM_CODEINTEGRITY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSTEM_VA_TYPE
|
||
|
{
|
||
|
SystemVaTypeAll,
|
||
|
SystemVaTypeNonPagedPool,
|
||
|
SystemVaTypePagedPool,
|
||
|
SystemVaTypeSystemCache,
|
||
|
SystemVaTypeSystemPtes,
|
||
|
SystemVaTypeSessionSpace,
|
||
|
SystemVaTypeMax
|
||
|
} SYSTEM_VA_TYPE, *PSYSTEM_VA_TYPE;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_VA_LIST_INFORMATION
|
||
|
{
|
||
|
SIZE_T VirtualSize;
|
||
|
SIZE_T VirtualPeak;
|
||
|
SIZE_T VirtualLimit;
|
||
|
SIZE_T AllocationFailures;
|
||
|
} SYSTEM_VA_LIST_INFORMATION, *PSYSTEM_VA_LIST_INFORMATION;
|
||
|
|
||
|
// rev
|
||
|
typedef enum _SYSTEM_STORE_INFORMATION_CLASS
|
||
|
{
|
||
|
SystemStoreCompressionInformation = 22 // q: SYSTEM_STORE_COMPRESSION_INFORMATION
|
||
|
} SYSTEM_STORE_INFORMATION_CLASS;
|
||
|
|
||
|
// rev
|
||
|
#define SYSTEM_STORE_INFORMATION_VERSION 1
|
||
|
|
||
|
// rev
|
||
|
typedef struct _SYSTEM_STORE_INFORMATION
|
||
|
{
|
||
|
_In_ ULONG Version;
|
||
|
_In_ SYSTEM_STORE_INFORMATION_CLASS StoreInformationClass;
|
||
|
_Inout_ PVOID Data;
|
||
|
_Inout_ ULONG Length;
|
||
|
} SYSTEM_STORE_INFORMATION, *PSYSTEM_STORE_INFORMATION;
|
||
|
|
||
|
// rev
|
||
|
#define SYSTEM_STORE_COMPRESSION_INFORMATION_VERSION 3
|
||
|
|
||
|
// rev
|
||
|
typedef struct _SYSTEM_STORE_COMPRESSION_INFORMATION
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG CompressionPid;
|
||
|
ULONGLONG CompressionWorkingSetSize;
|
||
|
ULONGLONG CompressSize;
|
||
|
ULONGLONG CompressedSize;
|
||
|
ULONGLONG NonCompressedSize;
|
||
|
} SYSTEM_STORE_COMPRESSION_INFORMATION, *PSYSTEM_STORE_COMPRESSION_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_REGISTRY_APPEND_STRING_PARAMETERS
|
||
|
{
|
||
|
HANDLE KeyHandle;
|
||
|
PUNICODE_STRING ValueNamePointer;
|
||
|
PULONG RequiredLengthPointer;
|
||
|
PUCHAR Buffer;
|
||
|
ULONG BufferLength;
|
||
|
ULONG Type;
|
||
|
PUCHAR AppendBuffer;
|
||
|
ULONG AppendBufferLength;
|
||
|
BOOLEAN CreateIfDoesntExist;
|
||
|
BOOLEAN TruncateExistingValue;
|
||
|
} SYSTEM_REGISTRY_APPEND_STRING_PARAMETERS, *PSYSTEM_REGISTRY_APPEND_STRING_PARAMETERS;
|
||
|
|
||
|
// msdn
|
||
|
typedef struct _SYSTEM_VHD_BOOT_INFORMATION
|
||
|
{
|
||
|
BOOLEAN OsDiskIsVhd;
|
||
|
ULONG OsVhdFilePathOffset;
|
||
|
WCHAR OsVhdParentVolume[ANYSIZE_ARRAY];
|
||
|
} SYSTEM_VHD_BOOT_INFORMATION, *PSYSTEM_VHD_BOOT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_LOW_PRIORITY_IO_INFORMATION
|
||
|
{
|
||
|
ULONG LowPriReadOperations;
|
||
|
ULONG LowPriWriteOperations;
|
||
|
ULONG KernelBumpedToNormalOperations;
|
||
|
ULONG LowPriPagingReadOperations;
|
||
|
ULONG KernelPagingReadsBumpedToNormal;
|
||
|
ULONG LowPriPagingWriteOperations;
|
||
|
ULONG KernelPagingWritesBumpedToNormal;
|
||
|
ULONG BoostedIrpCount;
|
||
|
ULONG BoostedPagingIrpCount;
|
||
|
ULONG BlanketBoostCount;
|
||
|
} SYSTEM_LOW_PRIORITY_IO_INFORMATION, *PSYSTEM_LOW_PRIORITY_IO_INFORMATION;
|
||
|
|
||
|
// symbols
|
||
|
typedef enum _TPM_BOOT_ENTROPY_RESULT_CODE
|
||
|
{
|
||
|
TpmBootEntropyStructureUninitialized,
|
||
|
TpmBootEntropyDisabledByPolicy,
|
||
|
TpmBootEntropyNoTpmFound,
|
||
|
TpmBootEntropyTpmError,
|
||
|
TpmBootEntropySuccess
|
||
|
} TPM_BOOT_ENTROPY_RESULT_CODE;
|
||
|
|
||
|
// Contents of KeLoaderBlock->Extension->TpmBootEntropyResult (TPM_BOOT_ENTROPY_LDR_RESULT).
|
||
|
// EntropyData is truncated to 40 bytes.
|
||
|
|
||
|
// private
|
||
|
typedef struct _TPM_BOOT_ENTROPY_NT_RESULT
|
||
|
{
|
||
|
ULONGLONG Policy;
|
||
|
TPM_BOOT_ENTROPY_RESULT_CODE ResultCode;
|
||
|
NTSTATUS ResultStatus;
|
||
|
ULONGLONG Time;
|
||
|
ULONG EntropyLength;
|
||
|
UCHAR EntropyData[40];
|
||
|
} TPM_BOOT_ENTROPY_NT_RESULT, *PTPM_BOOT_ENTROPY_NT_RESULT;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_VERIFIER_COUNTERS_INFORMATION
|
||
|
{
|
||
|
SYSTEM_VERIFIER_INFORMATION Legacy;
|
||
|
ULONG RaiseIrqls;
|
||
|
ULONG AcquireSpinLocks;
|
||
|
ULONG SynchronizeExecutions;
|
||
|
ULONG AllocationsWithNoTag;
|
||
|
ULONG AllocationsFailed;
|
||
|
ULONG AllocationsFailedDeliberately;
|
||
|
SIZE_T LockedBytes;
|
||
|
SIZE_T PeakLockedBytes;
|
||
|
SIZE_T MappedLockedBytes;
|
||
|
SIZE_T PeakMappedLockedBytes;
|
||
|
SIZE_T MappedIoSpaceBytes;
|
||
|
SIZE_T PeakMappedIoSpaceBytes;
|
||
|
SIZE_T PagesForMdlBytes;
|
||
|
SIZE_T PeakPagesForMdlBytes;
|
||
|
SIZE_T ContiguousMemoryBytes;
|
||
|
SIZE_T PeakContiguousMemoryBytes;
|
||
|
ULONG ExecutePoolTypes; // REDSTONE2
|
||
|
ULONG ExecutePageProtections;
|
||
|
ULONG ExecutePageMappings;
|
||
|
ULONG ExecuteWriteSections;
|
||
|
ULONG SectionAlignmentFailures;
|
||
|
ULONG UnsupportedRelocs;
|
||
|
ULONG IATInExecutableSection;
|
||
|
} SYSTEM_VERIFIER_COUNTERS_INFORMATION, *PSYSTEM_VERIFIER_COUNTERS_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ACPI_AUDIT_INFORMATION
|
||
|
{
|
||
|
ULONG RsdpCount;
|
||
|
ULONG SameRsdt : 1;
|
||
|
ULONG SlicPresent : 1;
|
||
|
ULONG SlicDifferent : 1;
|
||
|
} SYSTEM_ACPI_AUDIT_INFORMATION, *PSYSTEM_ACPI_AUDIT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_BASIC_PERFORMANCE_INFORMATION
|
||
|
{
|
||
|
SIZE_T AvailablePages;
|
||
|
SIZE_T CommittedPages;
|
||
|
SIZE_T CommitLimit;
|
||
|
SIZE_T PeakCommitment;
|
||
|
} SYSTEM_BASIC_PERFORMANCE_INFORMATION, *PSYSTEM_BASIC_PERFORMANCE_INFORMATION;
|
||
|
|
||
|
// begin_msdn
|
||
|
|
||
|
typedef struct _QUERY_PERFORMANCE_COUNTER_FLAGS
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
ULONG KernelTransition : 1;
|
||
|
ULONG Reserved : 31;
|
||
|
};
|
||
|
ULONG ul;
|
||
|
};
|
||
|
} QUERY_PERFORMANCE_COUNTER_FLAGS;
|
||
|
|
||
|
typedef struct _SYSTEM_QUERY_PERFORMANCE_COUNTER_INFORMATION
|
||
|
{
|
||
|
ULONG Version;
|
||
|
QUERY_PERFORMANCE_COUNTER_FLAGS Flags;
|
||
|
QUERY_PERFORMANCE_COUNTER_FLAGS ValidFlags;
|
||
|
} SYSTEM_QUERY_PERFORMANCE_COUNTER_INFORMATION, *PSYSTEM_QUERY_PERFORMANCE_COUNTER_INFORMATION;
|
||
|
|
||
|
// end_msdn
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSTEM_PIXEL_FORMAT
|
||
|
{
|
||
|
SystemPixelFormatUnknown,
|
||
|
SystemPixelFormatR8G8B8,
|
||
|
SystemPixelFormatR8G8B8X8,
|
||
|
SystemPixelFormatB8G8R8,
|
||
|
SystemPixelFormatB8G8R8X8
|
||
|
} SYSTEM_PIXEL_FORMAT;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_BOOT_GRAPHICS_INFORMATION
|
||
|
{
|
||
|
LARGE_INTEGER FrameBuffer;
|
||
|
ULONG Width;
|
||
|
ULONG Height;
|
||
|
ULONG PixelStride;
|
||
|
ULONG Flags;
|
||
|
SYSTEM_PIXEL_FORMAT Format;
|
||
|
ULONG DisplayRotation;
|
||
|
} SYSTEM_BOOT_GRAPHICS_INFORMATION, *PSYSTEM_BOOT_GRAPHICS_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _MEMORY_SCRUB_INFORMATION
|
||
|
{
|
||
|
HANDLE Handle;
|
||
|
ULONG PagesScrubbed;
|
||
|
} MEMORY_SCRUB_INFORMATION, *PMEMORY_SCRUB_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _PEBS_DS_SAVE_AREA32
|
||
|
{
|
||
|
ULONG BtsBufferBase;
|
||
|
ULONG BtsIndex;
|
||
|
ULONG BtsAbsoluteMaximum;
|
||
|
ULONG BtsInterruptThreshold;
|
||
|
ULONG PebsBufferBase;
|
||
|
ULONG PebsIndex;
|
||
|
ULONG PebsAbsoluteMaximum;
|
||
|
ULONG PebsInterruptThreshold;
|
||
|
ULONG PebsGpCounterReset[8];
|
||
|
ULONG PebsFixedCounterReset[4];
|
||
|
} PEBS_DS_SAVE_AREA32, *PPEBS_DS_SAVE_AREA32;
|
||
|
|
||
|
// private
|
||
|
typedef struct _PEBS_DS_SAVE_AREA64
|
||
|
{
|
||
|
ULONGLONG BtsBufferBase;
|
||
|
ULONGLONG BtsIndex;
|
||
|
ULONGLONG BtsAbsoluteMaximum;
|
||
|
ULONGLONG BtsInterruptThreshold;
|
||
|
ULONGLONG PebsBufferBase;
|
||
|
ULONGLONG PebsIndex;
|
||
|
ULONGLONG PebsAbsoluteMaximum;
|
||
|
ULONGLONG PebsInterruptThreshold;
|
||
|
ULONGLONG PebsGpCounterReset[8];
|
||
|
ULONGLONG PebsFixedCounterReset[4];
|
||
|
} PEBS_DS_SAVE_AREA64, *PPEBS_DS_SAVE_AREA64;
|
||
|
|
||
|
// private
|
||
|
typedef union _PEBS_DS_SAVE_AREA
|
||
|
{
|
||
|
PEBS_DS_SAVE_AREA32 As32Bit;
|
||
|
PEBS_DS_SAVE_AREA64 As64Bit;
|
||
|
} PEBS_DS_SAVE_AREA, *PPEBS_DS_SAVE_AREA;
|
||
|
|
||
|
// private
|
||
|
typedef struct _PROCESSOR_PROFILE_CONTROL_AREA
|
||
|
{
|
||
|
PEBS_DS_SAVE_AREA PebsDsSaveArea;
|
||
|
} PROCESSOR_PROFILE_CONTROL_AREA, *PPROCESSOR_PROFILE_CONTROL_AREA;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_PROFILE_CONTROL_AREA
|
||
|
{
|
||
|
PROCESSOR_PROFILE_CONTROL_AREA ProcessorProfileControlArea;
|
||
|
BOOLEAN Allocate;
|
||
|
} SYSTEM_PROCESSOR_PROFILE_CONTROL_AREA, *PSYSTEM_PROCESSOR_PROFILE_CONTROL_AREA;
|
||
|
|
||
|
// private
|
||
|
typedef struct _MEMORY_COMBINE_INFORMATION
|
||
|
{
|
||
|
HANDLE Handle;
|
||
|
ULONG_PTR PagesCombined;
|
||
|
} MEMORY_COMBINE_INFORMATION, *PMEMORY_COMBINE_INFORMATION;
|
||
|
|
||
|
// rev
|
||
|
#define MEMORY_COMBINE_FLAGS_COMMON_PAGES_ONLY 0x4
|
||
|
|
||
|
// private
|
||
|
typedef struct _MEMORY_COMBINE_INFORMATION_EX
|
||
|
{
|
||
|
HANDLE Handle;
|
||
|
ULONG_PTR PagesCombined;
|
||
|
ULONG Flags;
|
||
|
} MEMORY_COMBINE_INFORMATION_EX, *PMEMORY_COMBINE_INFORMATION_EX;
|
||
|
|
||
|
// private
|
||
|
typedef struct _MEMORY_COMBINE_INFORMATION_EX2
|
||
|
{
|
||
|
HANDLE Handle;
|
||
|
ULONG_PTR PagesCombined;
|
||
|
ULONG Flags;
|
||
|
HANDLE ProcessHandle;
|
||
|
} MEMORY_COMBINE_INFORMATION_EX2, *PMEMORY_COMBINE_INFORMATION_EX2;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CONSOLE_INFORMATION
|
||
|
{
|
||
|
ULONG DriverLoaded : 1;
|
||
|
ULONG Spare : 31;
|
||
|
} SYSTEM_CONSOLE_INFORMATION, *PSYSTEM_CONSOLE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PLATFORM_BINARY_INFORMATION
|
||
|
{
|
||
|
ULONG64 PhysicalAddress;
|
||
|
PVOID HandoffBuffer;
|
||
|
PVOID CommandLineBuffer;
|
||
|
ULONG HandoffBufferSize;
|
||
|
ULONG CommandLineBufferSize;
|
||
|
} SYSTEM_PLATFORM_BINARY_INFORMATION, *PSYSTEM_PLATFORM_BINARY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_HYPERVISOR_PROCESSOR_COUNT_INFORMATION
|
||
|
{
|
||
|
ULONG NumberOfLogicalProcessors;
|
||
|
ULONG NumberOfCores;
|
||
|
} SYSTEM_HYPERVISOR_PROCESSOR_COUNT_INFORMATION, *PSYSTEM_HYPERVISOR_PROCESSOR_COUNT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_DEVICE_DATA_INFORMATION
|
||
|
{
|
||
|
UNICODE_STRING DeviceId;
|
||
|
UNICODE_STRING DataName;
|
||
|
ULONG DataType;
|
||
|
ULONG DataBufferLength;
|
||
|
PVOID DataBuffer;
|
||
|
} SYSTEM_DEVICE_DATA_INFORMATION, *PSYSTEM_DEVICE_DATA_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _PHYSICAL_CHANNEL_RUN
|
||
|
{
|
||
|
ULONG NodeNumber;
|
||
|
ULONG ChannelNumber;
|
||
|
ULONGLONG BasePage;
|
||
|
ULONGLONG PageCount;
|
||
|
ULONG Flags;
|
||
|
} PHYSICAL_CHANNEL_RUN, *PPHYSICAL_CHANNEL_RUN;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_MEMORY_TOPOLOGY_INFORMATION
|
||
|
{
|
||
|
ULONGLONG NumberOfRuns;
|
||
|
ULONG NumberOfNodes;
|
||
|
ULONG NumberOfChannels;
|
||
|
PHYSICAL_CHANNEL_RUN Run[1];
|
||
|
} SYSTEM_MEMORY_TOPOLOGY_INFORMATION, *PSYSTEM_MEMORY_TOPOLOGY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_MEMORY_CHANNEL_INFORMATION
|
||
|
{
|
||
|
ULONG ChannelNumber;
|
||
|
ULONG ChannelHeatIndex;
|
||
|
ULONGLONG TotalPageCount;
|
||
|
ULONGLONG ZeroPageCount;
|
||
|
ULONGLONG FreePageCount;
|
||
|
ULONGLONG StandbyPageCount;
|
||
|
} SYSTEM_MEMORY_CHANNEL_INFORMATION, *PSYSTEM_MEMORY_CHANNEL_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_BOOT_LOGO_INFORMATION
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
ULONG BitmapOffset;
|
||
|
} SYSTEM_BOOT_LOGO_INFORMATION, *PSYSTEM_BOOT_LOGO_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION_EX
|
||
|
{
|
||
|
LARGE_INTEGER IdleTime;
|
||
|
LARGE_INTEGER KernelTime;
|
||
|
LARGE_INTEGER UserTime;
|
||
|
LARGE_INTEGER DpcTime;
|
||
|
LARGE_INTEGER InterruptTime;
|
||
|
ULONG InterruptCount;
|
||
|
ULONG Spare0;
|
||
|
LARGE_INTEGER AvailableTime;
|
||
|
LARGE_INTEGER Spare1;
|
||
|
LARGE_INTEGER Spare2;
|
||
|
} SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION_EX, *PSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION_EX;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECUREBOOT_POLICY_INFORMATION
|
||
|
{
|
||
|
GUID PolicyPublisher;
|
||
|
ULONG PolicyVersion;
|
||
|
ULONG PolicyOptions;
|
||
|
} SYSTEM_SECUREBOOT_POLICY_INFORMATION, *PSYSTEM_SECUREBOOT_POLICY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PAGEFILE_INFORMATION_EX
|
||
|
{
|
||
|
union // HACK union declaration for convenience (dmex)
|
||
|
{
|
||
|
SYSTEM_PAGEFILE_INFORMATION Info;
|
||
|
struct
|
||
|
{
|
||
|
ULONG NextEntryOffset;
|
||
|
ULONG TotalSize;
|
||
|
ULONG TotalInUse;
|
||
|
ULONG PeakUsage;
|
||
|
UNICODE_STRING PageFileName;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
ULONG MinimumSize;
|
||
|
ULONG MaximumSize;
|
||
|
} SYSTEM_PAGEFILE_INFORMATION_EX, *PSYSTEM_PAGEFILE_INFORMATION_EX;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECUREBOOT_INFORMATION
|
||
|
{
|
||
|
BOOLEAN SecureBootEnabled;
|
||
|
BOOLEAN SecureBootCapable;
|
||
|
} SYSTEM_SECUREBOOT_INFORMATION, *PSYSTEM_SECUREBOOT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _PROCESS_DISK_COUNTERS
|
||
|
{
|
||
|
ULONGLONG BytesRead;
|
||
|
ULONGLONG BytesWritten;
|
||
|
ULONGLONG ReadOperationCount;
|
||
|
ULONGLONG WriteOperationCount;
|
||
|
ULONGLONG FlushOperationCount;
|
||
|
} PROCESS_DISK_COUNTERS, *PPROCESS_DISK_COUNTERS;
|
||
|
|
||
|
// private
|
||
|
typedef union _ENERGY_STATE_DURATION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
ULONGLONG Value;
|
||
|
ULONG LastChangeTime;
|
||
|
};
|
||
|
|
||
|
ULONG Duration : 31;
|
||
|
ULONG IsInState : 1;
|
||
|
} ENERGY_STATE_DURATION, *PENERGY_STATE_DURATION;
|
||
|
|
||
|
typedef struct _PROCESS_ENERGY_VALUES
|
||
|
{
|
||
|
ULONGLONG Cycles[4][2];
|
||
|
ULONGLONG DiskEnergy;
|
||
|
ULONGLONG NetworkTailEnergy;
|
||
|
ULONGLONG MBBTailEnergy;
|
||
|
ULONGLONG NetworkTxRxBytes;
|
||
|
ULONGLONG MBBTxRxBytes;
|
||
|
union
|
||
|
{
|
||
|
ENERGY_STATE_DURATION Durations[3];
|
||
|
struct
|
||
|
{
|
||
|
ENERGY_STATE_DURATION ForegroundDuration;
|
||
|
ENERGY_STATE_DURATION DesktopVisibleDuration;
|
||
|
ENERGY_STATE_DURATION PSMForegroundDuration;
|
||
|
};
|
||
|
};
|
||
|
ULONG CompositionRendered;
|
||
|
ULONG CompositionDirtyGenerated;
|
||
|
ULONG CompositionDirtyPropagated;
|
||
|
ULONG Reserved1;
|
||
|
ULONGLONG AttributedCycles[4][2];
|
||
|
ULONGLONG WorkOnBehalfCycles[4][2];
|
||
|
} PROCESS_ENERGY_VALUES, *PPROCESS_ENERGY_VALUES;
|
||
|
|
||
|
typedef struct _TIMELINE_BITMAP
|
||
|
{
|
||
|
ULONGLONG Value;
|
||
|
ULONG EndTime;
|
||
|
ULONG Bitmap;
|
||
|
} TIMELINE_BITMAP, *PTIMELINE_BITMAP;
|
||
|
|
||
|
typedef struct _PROCESS_ENERGY_VALUES_EXTENSION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
TIMELINE_BITMAP Timelines[14]; // 9 for REDSTONE2, 14 for REDSTONE3/4/5
|
||
|
struct
|
||
|
{
|
||
|
TIMELINE_BITMAP CpuTimeline;
|
||
|
TIMELINE_BITMAP DiskTimeline;
|
||
|
TIMELINE_BITMAP NetworkTimeline;
|
||
|
TIMELINE_BITMAP MBBTimeline;
|
||
|
TIMELINE_BITMAP ForegroundTimeline;
|
||
|
TIMELINE_BITMAP DesktopVisibleTimeline;
|
||
|
TIMELINE_BITMAP CompositionRenderedTimeline;
|
||
|
TIMELINE_BITMAP CompositionDirtyGeneratedTimeline;
|
||
|
TIMELINE_BITMAP CompositionDirtyPropagatedTimeline;
|
||
|
TIMELINE_BITMAP InputTimeline; // REDSTONE3
|
||
|
TIMELINE_BITMAP AudioInTimeline;
|
||
|
TIMELINE_BITMAP AudioOutTimeline;
|
||
|
TIMELINE_BITMAP DisplayRequiredTimeline;
|
||
|
TIMELINE_BITMAP KeyboardInputTimeline;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
union // REDSTONE3
|
||
|
{
|
||
|
ENERGY_STATE_DURATION Durations[5];
|
||
|
struct
|
||
|
{
|
||
|
ENERGY_STATE_DURATION InputDuration;
|
||
|
ENERGY_STATE_DURATION AudioInDuration;
|
||
|
ENERGY_STATE_DURATION AudioOutDuration;
|
||
|
ENERGY_STATE_DURATION DisplayRequiredDuration;
|
||
|
ENERGY_STATE_DURATION PSMBackgroundDuration;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
ULONG KeyboardInput;
|
||
|
ULONG MouseInput;
|
||
|
} PROCESS_ENERGY_VALUES_EXTENSION, *PPROCESS_ENERGY_VALUES_EXTENSION;
|
||
|
|
||
|
typedef struct _PROCESS_EXTENDED_ENERGY_VALUES
|
||
|
{
|
||
|
PROCESS_ENERGY_VALUES Base;
|
||
|
PROCESS_ENERGY_VALUES_EXTENSION Extension;
|
||
|
} PROCESS_EXTENDED_ENERGY_VALUES, *PPROCESS_EXTENDED_ENERGY_VALUES;
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSTEM_PROCESS_CLASSIFICATION
|
||
|
{
|
||
|
SystemProcessClassificationNormal,
|
||
|
SystemProcessClassificationSystem,
|
||
|
SystemProcessClassificationSecureSystem,
|
||
|
SystemProcessClassificationMemCompression,
|
||
|
SystemProcessClassificationRegistry, // REDSTONE4
|
||
|
SystemProcessClassificationMaximum
|
||
|
} SYSTEM_PROCESS_CLASSIFICATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESS_INFORMATION_EXTENSION
|
||
|
{
|
||
|
PROCESS_DISK_COUNTERS DiskCounters;
|
||
|
ULONGLONG ContextSwitches;
|
||
|
union
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG HasStrongId : 1;
|
||
|
ULONG Classification : 4; // SYSTEM_PROCESS_CLASSIFICATION
|
||
|
ULONG BackgroundActivityModerated : 1;
|
||
|
ULONG Spare : 26;
|
||
|
};
|
||
|
};
|
||
|
ULONG UserSidOffset;
|
||
|
ULONG PackageFullNameOffset; // since THRESHOLD
|
||
|
PROCESS_ENERGY_VALUES EnergyValues; // since THRESHOLD
|
||
|
ULONG AppIdOffset; // since THRESHOLD
|
||
|
SIZE_T SharedCommitCharge; // since THRESHOLD2
|
||
|
ULONG JobObjectId; // since REDSTONE
|
||
|
ULONG SpareUlong; // since REDSTONE
|
||
|
ULONGLONG ProcessSequenceNumber;
|
||
|
} SYSTEM_PROCESS_INFORMATION_EXTENSION, *PSYSTEM_PROCESS_INFORMATION_EXTENSION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PORTABLE_WORKSPACE_EFI_LAUNCHER_INFORMATION
|
||
|
{
|
||
|
BOOLEAN EfiLauncherEnabled;
|
||
|
} SYSTEM_PORTABLE_WORKSPACE_EFI_LAUNCHER_INFORMATION, *PSYSTEM_PORTABLE_WORKSPACE_EFI_LAUNCHER_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_KERNEL_DEBUGGER_INFORMATION_EX
|
||
|
{
|
||
|
BOOLEAN DebuggerAllowed;
|
||
|
BOOLEAN DebuggerEnabled;
|
||
|
BOOLEAN DebuggerPresent;
|
||
|
} SYSTEM_KERNEL_DEBUGGER_INFORMATION_EX, *PSYSTEM_KERNEL_DEBUGGER_INFORMATION_EX;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ELAM_CERTIFICATE_INFORMATION
|
||
|
{
|
||
|
HANDLE ElamDriverFile;
|
||
|
} SYSTEM_ELAM_CERTIFICATE_INFORMATION, *PSYSTEM_ELAM_CERTIFICATE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_FEATURES_INFORMATION
|
||
|
{
|
||
|
ULONGLONG ProcessorFeatureBits;
|
||
|
ULONGLONG Reserved[3];
|
||
|
} SYSTEM_PROCESSOR_FEATURES_INFORMATION, *PSYSTEM_PROCESSOR_FEATURES_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_MANUFACTURING_INFORMATION
|
||
|
{
|
||
|
ULONG Options;
|
||
|
UNICODE_STRING ProfileName;
|
||
|
} SYSTEM_MANUFACTURING_INFORMATION, *PSYSTEM_MANUFACTURING_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ENERGY_ESTIMATION_CONFIG_INFORMATION
|
||
|
{
|
||
|
BOOLEAN Enabled;
|
||
|
} SYSTEM_ENERGY_ESTIMATION_CONFIG_INFORMATION, *PSYSTEM_ENERGY_ESTIMATION_CONFIG_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _HV_DETAILS
|
||
|
{
|
||
|
ULONG Data[4];
|
||
|
} HV_DETAILS, *PHV_DETAILS;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_HYPERVISOR_DETAIL_INFORMATION
|
||
|
{
|
||
|
HV_DETAILS HvVendorAndMaxFunction;
|
||
|
HV_DETAILS HypervisorInterface;
|
||
|
HV_DETAILS HypervisorVersion;
|
||
|
HV_DETAILS HvFeatures;
|
||
|
HV_DETAILS HwFeatures;
|
||
|
HV_DETAILS EnlightenmentInfo;
|
||
|
HV_DETAILS ImplementationLimits;
|
||
|
} SYSTEM_HYPERVISOR_DETAIL_INFORMATION, *PSYSTEM_HYPERVISOR_DETAIL_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PROCESSOR_CYCLE_STATS_INFORMATION
|
||
|
{
|
||
|
ULONGLONG Cycles[4][2];
|
||
|
} SYSTEM_PROCESSOR_CYCLE_STATS_INFORMATION, *PSYSTEM_PROCESSOR_CYCLE_STATS_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_TPM_INFORMATION
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
} SYSTEM_TPM_INFORMATION, *PSYSTEM_TPM_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_VSM_PROTECTION_INFORMATION
|
||
|
{
|
||
|
BOOLEAN DmaProtectionsAvailable;
|
||
|
BOOLEAN DmaProtectionsInUse;
|
||
|
BOOLEAN HardwareMbecAvailable; // REDSTONE4 (CVE-2018-3639)
|
||
|
} SYSTEM_VSM_PROTECTION_INFORMATION, *PSYSTEM_VSM_PROTECTION_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_KERNEL_DEBUGGER_FLAGS
|
||
|
{
|
||
|
UCHAR KernelDebuggerIgnoreUmExceptions;
|
||
|
} SYSTEM_KERNEL_DEBUGGER_FLAGS, *PSYSTEM_KERNEL_DEBUGGER_FLAGS;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CODEINTEGRITYPOLICY_INFORMATION
|
||
|
{
|
||
|
ULONG Options;
|
||
|
ULONG HVCIOptions;
|
||
|
ULONGLONG Version;
|
||
|
GUID PolicyGuid;
|
||
|
} SYSTEM_CODEINTEGRITYPOLICY_INFORMATION, *PSYSTEM_CODEINTEGRITYPOLICY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ISOLATED_USER_MODE_INFORMATION
|
||
|
{
|
||
|
BOOLEAN SecureKernelRunning : 1;
|
||
|
BOOLEAN HvciEnabled : 1;
|
||
|
BOOLEAN HvciStrictMode : 1;
|
||
|
BOOLEAN DebugEnabled : 1;
|
||
|
BOOLEAN FirmwarePageProtection : 1;
|
||
|
BOOLEAN EncryptionKeyAvailable : 1;
|
||
|
BOOLEAN SpareFlags : 2;
|
||
|
BOOLEAN TrustletRunning : 1;
|
||
|
BOOLEAN HvciDisableAllowed : 1;
|
||
|
BOOLEAN SpareFlags2 : 6;
|
||
|
BOOLEAN Spare0[6];
|
||
|
ULONGLONG Spare1;
|
||
|
} SYSTEM_ISOLATED_USER_MODE_INFORMATION, *PSYSTEM_ISOLATED_USER_MODE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SINGLE_MODULE_INFORMATION
|
||
|
{
|
||
|
PVOID TargetModuleAddress;
|
||
|
RTL_PROCESS_MODULE_INFORMATION_EX ExInfo;
|
||
|
} SYSTEM_SINGLE_MODULE_INFORMATION, *PSYSTEM_SINGLE_MODULE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_INTERRUPT_CPU_SET_INFORMATION
|
||
|
{
|
||
|
ULONG Gsiv;
|
||
|
USHORT Group;
|
||
|
ULONGLONG CpuSets;
|
||
|
} SYSTEM_INTERRUPT_CPU_SET_INFORMATION, *PSYSTEM_INTERRUPT_CPU_SET_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECUREBOOT_POLICY_FULL_INFORMATION
|
||
|
{
|
||
|
SYSTEM_SECUREBOOT_POLICY_INFORMATION PolicyInformation;
|
||
|
ULONG PolicySize;
|
||
|
UCHAR Policy[1];
|
||
|
} SYSTEM_SECUREBOOT_POLICY_FULL_INFORMATION, *PSYSTEM_SECUREBOOT_POLICY_FULL_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ROOT_SILO_INFORMATION
|
||
|
{
|
||
|
ULONG NumberOfSilos;
|
||
|
ULONG SiloIdList[1];
|
||
|
} SYSTEM_ROOT_SILO_INFORMATION, *PSYSTEM_ROOT_SILO_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CPU_SET_TAG_INFORMATION
|
||
|
{
|
||
|
ULONGLONG Tag;
|
||
|
ULONGLONG CpuSets[1];
|
||
|
} SYSTEM_CPU_SET_TAG_INFORMATION, *PSYSTEM_CPU_SET_TAG_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECURE_KERNEL_HYPERGUARD_PROFILE_INFORMATION
|
||
|
{
|
||
|
ULONG ExtentCount;
|
||
|
ULONG ValidStructureSize;
|
||
|
ULONG NextExtentIndex;
|
||
|
ULONG ExtentRestart;
|
||
|
ULONG CycleCount;
|
||
|
ULONG TimeoutCount;
|
||
|
ULONGLONG CycleTime;
|
||
|
ULONGLONG CycleTimeMax;
|
||
|
ULONGLONG ExtentTime;
|
||
|
ULONG ExtentTimeIndex;
|
||
|
ULONG ExtentTimeMaxIndex;
|
||
|
ULONGLONG ExtentTimeMax;
|
||
|
ULONGLONG HyperFlushTimeMax;
|
||
|
ULONGLONG TranslateVaTimeMax;
|
||
|
ULONGLONG DebugExemptionCount;
|
||
|
ULONGLONG TbHitCount;
|
||
|
ULONGLONG TbMissCount;
|
||
|
ULONGLONG VinaPendingYield;
|
||
|
ULONGLONG HashCycles;
|
||
|
ULONG HistogramOffset;
|
||
|
ULONG HistogramBuckets;
|
||
|
ULONG HistogramShift;
|
||
|
ULONG Reserved1;
|
||
|
ULONGLONG PageNotPresentCount;
|
||
|
} SYSTEM_SECURE_KERNEL_HYPERGUARD_PROFILE_INFORMATION, *PSYSTEM_SECURE_KERNEL_HYPERGUARD_PROFILE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECUREBOOT_PLATFORM_MANIFEST_INFORMATION
|
||
|
{
|
||
|
ULONG PlatformManifestSize;
|
||
|
UCHAR PlatformManifest[1];
|
||
|
} SYSTEM_SECUREBOOT_PLATFORM_MANIFEST_INFORMATION, *PSYSTEM_SECUREBOOT_PLATFORM_MANIFEST_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_MEMORY_USAGE_INFORMATION
|
||
|
{
|
||
|
ULONGLONG TotalPhysicalBytes;
|
||
|
ULONGLONG AvailableBytes;
|
||
|
LONGLONG ResidentAvailableBytes;
|
||
|
ULONGLONG CommittedBytes;
|
||
|
ULONGLONG SharedCommittedBytes;
|
||
|
ULONGLONG CommitLimitBytes;
|
||
|
ULONGLONG PeakCommitmentBytes;
|
||
|
} SYSTEM_MEMORY_USAGE_INFORMATION, *PSYSTEM_MEMORY_USAGE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CODEINTEGRITY_CERTIFICATE_INFORMATION
|
||
|
{
|
||
|
HANDLE ImageFile;
|
||
|
ULONG Type; // REDSTONE4
|
||
|
} SYSTEM_CODEINTEGRITY_CERTIFICATE_INFORMATION, *PSYSTEM_CODEINTEGRITY_CERTIFICATE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_PHYSICAL_MEMORY_INFORMATION
|
||
|
{
|
||
|
ULONGLONG TotalPhysicalBytes;
|
||
|
ULONGLONG LowestPhysicalAddress;
|
||
|
ULONGLONG HighestPhysicalAddress;
|
||
|
} SYSTEM_PHYSICAL_MEMORY_INFORMATION, *PSYSTEM_PHYSICAL_MEMORY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSTEM_ACTIVITY_MODERATION_STATE
|
||
|
{
|
||
|
SystemActivityModerationStateSystemManaged,
|
||
|
SystemActivityModerationStateUserManagedAllowThrottling,
|
||
|
SystemActivityModerationStateUserManagedDisableThrottling,
|
||
|
MaxSystemActivityModerationState
|
||
|
} SYSTEM_ACTIVITY_MODERATION_STATE;
|
||
|
|
||
|
// private - REDSTONE2
|
||
|
typedef struct _SYSTEM_ACTIVITY_MODERATION_EXE_STATE // REDSTONE3: Renamed SYSTEM_ACTIVITY_MODERATION_INFO
|
||
|
{
|
||
|
UNICODE_STRING ExePathNt;
|
||
|
SYSTEM_ACTIVITY_MODERATION_STATE ModerationState;
|
||
|
} SYSTEM_ACTIVITY_MODERATION_EXE_STATE, *PSYSTEM_ACTIVITY_MODERATION_EXE_STATE;
|
||
|
|
||
|
typedef enum _SYSTEM_ACTIVITY_MODERATION_APP_TYPE
|
||
|
{
|
||
|
SystemActivityModerationAppTypeClassic,
|
||
|
SystemActivityModerationAppTypePackaged,
|
||
|
MaxSystemActivityModerationAppType
|
||
|
} SYSTEM_ACTIVITY_MODERATION_APP_TYPE;
|
||
|
|
||
|
// private - REDSTONE3
|
||
|
typedef struct _SYSTEM_ACTIVITY_MODERATION_INFO
|
||
|
{
|
||
|
UNICODE_STRING Identifier;
|
||
|
SYSTEM_ACTIVITY_MODERATION_STATE ModerationState;
|
||
|
SYSTEM_ACTIVITY_MODERATION_APP_TYPE AppType;
|
||
|
} SYSTEM_ACTIVITY_MODERATION_INFO, *PSYSTEM_ACTIVITY_MODERATION_INFO;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ACTIVITY_MODERATION_USER_SETTINGS
|
||
|
{
|
||
|
HANDLE UserKeyHandle;
|
||
|
} SYSTEM_ACTIVITY_MODERATION_USER_SETTINGS, *PSYSTEM_ACTIVITY_MODERATION_USER_SETTINGS;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CODEINTEGRITY_UNLOCK_INFORMATION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG Locked : 1;
|
||
|
ULONG UnlockApplied : 1; // Unlockable field removed 19H1
|
||
|
ULONG UnlockIdValid : 1;
|
||
|
ULONG Reserved : 29;
|
||
|
};
|
||
|
};
|
||
|
UCHAR UnlockId[32]; // REDSTONE4
|
||
|
} SYSTEM_CODEINTEGRITY_UNLOCK_INFORMATION, *PSYSTEM_CODEINTEGRITY_UNLOCK_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_FLUSH_INFORMATION
|
||
|
{
|
||
|
ULONG SupportedFlushMethods;
|
||
|
ULONG ProcessorCacheFlushSize;
|
||
|
ULONGLONG SystemFlushCapabilities;
|
||
|
ULONGLONG Reserved[2];
|
||
|
} SYSTEM_FLUSH_INFORMATION, *PSYSTEM_FLUSH_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_WRITE_CONSTRAINT_INFORMATION
|
||
|
{
|
||
|
ULONG WriteConstraintPolicy;
|
||
|
ULONG Reserved;
|
||
|
} SYSTEM_WRITE_CONSTRAINT_INFORMATION, *PSYSTEM_WRITE_CONSTRAINT_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_KERNEL_VA_SHADOW_INFORMATION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG KvaShadowEnabled : 1;
|
||
|
ULONG KvaShadowUserGlobal : 1;
|
||
|
ULONG KvaShadowPcid : 1;
|
||
|
ULONG KvaShadowInvpcid : 1;
|
||
|
ULONG KvaShadowRequired : 1; // REDSTONE4
|
||
|
ULONG KvaShadowRequiredAvailable : 1;
|
||
|
ULONG InvalidPteBit : 6;
|
||
|
ULONG L1DataCacheFlushSupported : 1;
|
||
|
ULONG L1TerminalFaultMitigationPresent : 1;
|
||
|
ULONG Reserved : 18;
|
||
|
};
|
||
|
};
|
||
|
} SYSTEM_KERNEL_VA_SHADOW_INFORMATION, *PSYSTEM_KERNEL_VA_SHADOW_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_CODEINTEGRITYVERIFICATION_INFORMATION
|
||
|
{
|
||
|
HANDLE FileHandle;
|
||
|
ULONG ImageSize;
|
||
|
PVOID Image;
|
||
|
} SYSTEM_CODEINTEGRITYVERIFICATION_INFORMATION, *PSYSTEM_CODEINTEGRITYVERIFICATION_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_HYPERVISOR_SHARED_PAGE_INFORMATION
|
||
|
{
|
||
|
PVOID HypervisorSharedUserVa;
|
||
|
} SYSTEM_HYPERVISOR_SHARED_PAGE_INFORMATION, *PSYSTEM_HYPERVISOR_SHARED_PAGE_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_FIRMWARE_PARTITION_INFORMATION
|
||
|
{
|
||
|
UNICODE_STRING FirmwarePartition;
|
||
|
} SYSTEM_FIRMWARE_PARTITION_INFORMATION, *PSYSTEM_FIRMWARE_PARTITION_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SPECULATION_CONTROL_INFORMATION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG BpbEnabled : 1;
|
||
|
ULONG BpbDisabledSystemPolicy : 1;
|
||
|
ULONG BpbDisabledNoHardwareSupport : 1;
|
||
|
ULONG SpecCtrlEnumerated : 1;
|
||
|
ULONG SpecCmdEnumerated : 1;
|
||
|
ULONG IbrsPresent : 1;
|
||
|
ULONG StibpPresent : 1;
|
||
|
ULONG SmepPresent : 1;
|
||
|
ULONG SpeculativeStoreBypassDisableAvailable : 1; // REDSTONE4 (CVE-2018-3639)
|
||
|
ULONG SpeculativeStoreBypassDisableSupported : 1;
|
||
|
ULONG SpeculativeStoreBypassDisabledSystemWide : 1;
|
||
|
ULONG SpeculativeStoreBypassDisabledKernel : 1;
|
||
|
ULONG SpeculativeStoreBypassDisableRequired : 1;
|
||
|
ULONG BpbDisabledKernelToUser : 1;
|
||
|
ULONG SpecCtrlRetpolineEnabled : 1;
|
||
|
ULONG SpecCtrlImportOptimizationEnabled : 1;
|
||
|
ULONG EnhancedIbrs : 1; // since 19H1
|
||
|
ULONG HvL1tfStatusAvailable : 1;
|
||
|
ULONG HvL1tfProcessorNotAffected : 1;
|
||
|
ULONG HvL1tfMigitationEnabled : 1;
|
||
|
ULONG HvL1tfMigitationNotEnabled_Hardware : 1;
|
||
|
ULONG HvL1tfMigitationNotEnabled_LoadOption : 1;
|
||
|
ULONG HvL1tfMigitationNotEnabled_CoreScheduler : 1;
|
||
|
ULONG EnhancedIbrsReported : 1;
|
||
|
ULONG MdsHardwareProtected : 1; // since 19H2
|
||
|
ULONG MbClearEnabled : 1;
|
||
|
ULONG MbClearReported : 1;
|
||
|
ULONG Reserved : 5;
|
||
|
};
|
||
|
};
|
||
|
} SYSTEM_SPECULATION_CONTROL_INFORMATION, *PSYSTEM_SPECULATION_CONTROL_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_DMA_GUARD_POLICY_INFORMATION
|
||
|
{
|
||
|
BOOLEAN DmaGuardPolicyEnabled;
|
||
|
} SYSTEM_DMA_GUARD_POLICY_INFORMATION, *PSYSTEM_DMA_GUARD_POLICY_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_ENCLAVE_LAUNCH_CONTROL_INFORMATION
|
||
|
{
|
||
|
UCHAR EnclaveLaunchSigner[32];
|
||
|
} SYSTEM_ENCLAVE_LAUNCH_CONTROL_INFORMATION, *PSYSTEM_ENCLAVE_LAUNCH_CONTROL_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_WORKLOAD_ALLOWED_CPU_SET_INFORMATION
|
||
|
{
|
||
|
ULONGLONG WorkloadClass;
|
||
|
ULONGLONG CpuSets[1];
|
||
|
} SYSTEM_WORKLOAD_ALLOWED_CPU_SET_INFORMATION, *PSYSTEM_WORKLOAD_ALLOWED_CPU_SET_INFORMATION;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSTEM_SECURITY_MODEL_INFORMATION
|
||
|
{
|
||
|
union
|
||
|
{
|
||
|
ULONG SecurityModelFlags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG SModeAdminlessEnabled : 1;
|
||
|
ULONG AllowDeviceOwnerProtectionDowngrade : 1;
|
||
|
ULONG Reserved : 30;
|
||
|
};
|
||
|
};
|
||
|
} SYSTEM_SECURITY_MODEL_INFORMATION, *PSYSTEM_SECURITY_MODEL_INFORMATION;
|
||
|
|
||
|
#if (PHNT_MODE != PHNT_MODE_KERNEL)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySystemInformation(
|
||
|
_In_ SYSTEM_INFORMATION_CLASS SystemInformationClass,
|
||
|
_Out_writes_bytes_opt_(SystemInformationLength) PVOID SystemInformation,
|
||
|
_In_ ULONG SystemInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQuerySystemInformationEx(
|
||
|
_In_ SYSTEM_INFORMATION_CLASS SystemInformationClass,
|
||
|
_In_reads_bytes_(InputBufferLength) PVOID InputBuffer,
|
||
|
_In_ ULONG InputBufferLength,
|
||
|
_Out_writes_bytes_opt_(SystemInformationLength) PVOID SystemInformation,
|
||
|
_In_ ULONG SystemInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetSystemInformation(
|
||
|
_In_ SYSTEM_INFORMATION_CLASS SystemInformationClass,
|
||
|
_In_reads_bytes_opt_(SystemInformationLength) PVOID SystemInformation,
|
||
|
_In_ ULONG SystemInformationLength
|
||
|
);
|
||
|
|
||
|
// SysDbg APIs
|
||
|
|
||
|
// private
|
||
|
typedef enum _SYSDBG_COMMAND
|
||
|
{
|
||
|
SysDbgQueryModuleInformation,
|
||
|
SysDbgQueryTraceInformation,
|
||
|
SysDbgSetTracepoint,
|
||
|
SysDbgSetSpecialCall,
|
||
|
SysDbgClearSpecialCalls,
|
||
|
SysDbgQuerySpecialCalls,
|
||
|
SysDbgBreakPoint,
|
||
|
SysDbgQueryVersion,
|
||
|
SysDbgReadVirtual,
|
||
|
SysDbgWriteVirtual,
|
||
|
SysDbgReadPhysical,
|
||
|
SysDbgWritePhysical,
|
||
|
SysDbgReadControlSpace,
|
||
|
SysDbgWriteControlSpace,
|
||
|
SysDbgReadIoSpace,
|
||
|
SysDbgWriteIoSpace,
|
||
|
SysDbgReadMsr,
|
||
|
SysDbgWriteMsr,
|
||
|
SysDbgReadBusData,
|
||
|
SysDbgWriteBusData,
|
||
|
SysDbgCheckLowMemory,
|
||
|
SysDbgEnableKernelDebugger,
|
||
|
SysDbgDisableKernelDebugger,
|
||
|
SysDbgGetAutoKdEnable,
|
||
|
SysDbgSetAutoKdEnable,
|
||
|
SysDbgGetPrintBufferSize,
|
||
|
SysDbgSetPrintBufferSize,
|
||
|
SysDbgGetKdUmExceptionEnable,
|
||
|
SysDbgSetKdUmExceptionEnable,
|
||
|
SysDbgGetTriageDump,
|
||
|
SysDbgGetKdBlockEnable,
|
||
|
SysDbgSetKdBlockEnable,
|
||
|
SysDbgRegisterForUmBreakInfo,
|
||
|
SysDbgGetUmBreakPid,
|
||
|
SysDbgClearUmBreakPid,
|
||
|
SysDbgGetUmAttachPid,
|
||
|
SysDbgClearUmAttachPid,
|
||
|
SysDbgGetLiveKernelDump
|
||
|
} SYSDBG_COMMAND, *PSYSDBG_COMMAND;
|
||
|
|
||
|
typedef struct _SYSDBG_VIRTUAL
|
||
|
{
|
||
|
PVOID Address;
|
||
|
PVOID Buffer;
|
||
|
ULONG Request;
|
||
|
} SYSDBG_VIRTUAL, *PSYSDBG_VIRTUAL;
|
||
|
|
||
|
typedef struct _SYSDBG_PHYSICAL
|
||
|
{
|
||
|
PHYSICAL_ADDRESS Address;
|
||
|
PVOID Buffer;
|
||
|
ULONG Request;
|
||
|
} SYSDBG_PHYSICAL, *PSYSDBG_PHYSICAL;
|
||
|
|
||
|
typedef struct _SYSDBG_CONTROL_SPACE
|
||
|
{
|
||
|
ULONG64 Address;
|
||
|
PVOID Buffer;
|
||
|
ULONG Request;
|
||
|
ULONG Processor;
|
||
|
} SYSDBG_CONTROL_SPACE, *PSYSDBG_CONTROL_SPACE;
|
||
|
|
||
|
enum _INTERFACE_TYPE;
|
||
|
|
||
|
typedef struct _SYSDBG_IO_SPACE
|
||
|
{
|
||
|
ULONG64 Address;
|
||
|
PVOID Buffer;
|
||
|
ULONG Request;
|
||
|
enum _INTERFACE_TYPE InterfaceType;
|
||
|
ULONG BusNumber;
|
||
|
ULONG AddressSpace;
|
||
|
} SYSDBG_IO_SPACE, *PSYSDBG_IO_SPACE;
|
||
|
|
||
|
typedef struct _SYSDBG_MSR
|
||
|
{
|
||
|
ULONG Msr;
|
||
|
ULONG64 Data;
|
||
|
} SYSDBG_MSR, *PSYSDBG_MSR;
|
||
|
|
||
|
enum _BUS_DATA_TYPE;
|
||
|
|
||
|
typedef struct _SYSDBG_BUS_DATA
|
||
|
{
|
||
|
ULONG Address;
|
||
|
PVOID Buffer;
|
||
|
ULONG Request;
|
||
|
enum _BUS_DATA_TYPE BusDataType;
|
||
|
ULONG BusNumber;
|
||
|
ULONG SlotNumber;
|
||
|
} SYSDBG_BUS_DATA, *PSYSDBG_BUS_DATA;
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSDBG_TRIAGE_DUMP
|
||
|
{
|
||
|
ULONG Flags;
|
||
|
ULONG BugCheckCode;
|
||
|
ULONG_PTR BugCheckParam1;
|
||
|
ULONG_PTR BugCheckParam2;
|
||
|
ULONG_PTR BugCheckParam3;
|
||
|
ULONG_PTR BugCheckParam4;
|
||
|
ULONG ProcessHandles;
|
||
|
ULONG ThreadHandles;
|
||
|
PHANDLE Handles;
|
||
|
} SYSDBG_TRIAGE_DUMP, *PSYSDBG_TRIAGE_DUMP;
|
||
|
|
||
|
// private
|
||
|
typedef union _SYSDBG_LIVEDUMP_CONTROL_FLAGS
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
ULONG UseDumpStorageStack : 1;
|
||
|
ULONG CompressMemoryPagesData : 1;
|
||
|
ULONG IncludeUserSpaceMemoryPages : 1;
|
||
|
ULONG AbortIfMemoryPressure : 1; // REDSTONE4
|
||
|
ULONG Reserved : 28;
|
||
|
};
|
||
|
ULONG AsUlong;
|
||
|
} SYSDBG_LIVEDUMP_CONTROL_FLAGS, *PSYSDBG_LIVEDUMP_CONTROL_FLAGS;
|
||
|
|
||
|
// private
|
||
|
typedef union _SYSDBG_LIVEDUMP_CONTROL_ADDPAGES
|
||
|
{
|
||
|
struct
|
||
|
{
|
||
|
ULONG HypervisorPages : 1;
|
||
|
ULONG Reserved : 31;
|
||
|
};
|
||
|
ULONG AsUlong;
|
||
|
} SYSDBG_LIVEDUMP_CONTROL_ADDPAGES, *PSYSDBG_LIVEDUMP_CONTROL_ADDPAGES;
|
||
|
|
||
|
#define SYSDBG_LIVEDUMP_CONTROL_VERSION 1
|
||
|
|
||
|
// private
|
||
|
typedef struct _SYSDBG_LIVEDUMP_CONTROL
|
||
|
{
|
||
|
ULONG Version;
|
||
|
ULONG BugCheckCode;
|
||
|
ULONG_PTR BugCheckParam1;
|
||
|
ULONG_PTR BugCheckParam2;
|
||
|
ULONG_PTR BugCheckParam3;
|
||
|
ULONG_PTR BugCheckParam4;
|
||
|
HANDLE DumpFileHandle;
|
||
|
HANDLE CancelEventHandle;
|
||
|
SYSDBG_LIVEDUMP_CONTROL_FLAGS Flags;
|
||
|
SYSDBG_LIVEDUMP_CONTROL_ADDPAGES AddPagesControl;
|
||
|
} SYSDBG_LIVEDUMP_CONTROL, *PSYSDBG_LIVEDUMP_CONTROL;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSystemDebugControl(
|
||
|
_In_ SYSDBG_COMMAND Command,
|
||
|
_Inout_updates_bytes_opt_(InputBufferLength) PVOID InputBuffer,
|
||
|
_In_ ULONG InputBufferLength,
|
||
|
_Out_writes_bytes_opt_(OutputBufferLength) PVOID OutputBuffer,
|
||
|
_In_ ULONG OutputBufferLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
// Hard errors
|
||
|
|
||
|
typedef enum _HARDERROR_RESPONSE_OPTION
|
||
|
{
|
||
|
OptionAbortRetryIgnore,
|
||
|
OptionOk,
|
||
|
OptionOkCancel,
|
||
|
OptionRetryCancel,
|
||
|
OptionYesNo,
|
||
|
OptionYesNoCancel,
|
||
|
OptionShutdownSystem,
|
||
|
OptionOkNoWait,
|
||
|
OptionCancelTryContinue
|
||
|
} HARDERROR_RESPONSE_OPTION;
|
||
|
|
||
|
typedef enum _HARDERROR_RESPONSE
|
||
|
{
|
||
|
ResponseReturnToCaller,
|
||
|
ResponseNotHandled,
|
||
|
ResponseAbort,
|
||
|
ResponseCancel,
|
||
|
ResponseIgnore,
|
||
|
ResponseNo,
|
||
|
ResponseOk,
|
||
|
ResponseRetry,
|
||
|
ResponseYes,
|
||
|
ResponseTryAgain,
|
||
|
ResponseContinue
|
||
|
} HARDERROR_RESPONSE;
|
||
|
|
||
|
#define HARDERROR_OVERRIDE_ERRORMODE 0x10000000
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtRaiseHardError(
|
||
|
_In_ NTSTATUS ErrorStatus,
|
||
|
_In_ ULONG NumberOfParameters,
|
||
|
_In_ ULONG UnicodeStringParameterMask,
|
||
|
_In_reads_(NumberOfParameters) PULONG_PTR Parameters,
|
||
|
_In_ ULONG ValidResponseOptions,
|
||
|
_Out_ PULONG Response
|
||
|
);
|
||
|
|
||
|
// Kernel-user shared data
|
||
|
|
||
|
typedef enum _ALTERNATIVE_ARCHITECTURE_TYPE
|
||
|
{
|
||
|
StandardDesign,
|
||
|
NEC98x86,
|
||
|
EndAlternatives
|
||
|
} ALTERNATIVE_ARCHITECTURE_TYPE;
|
||
|
|
||
|
#define PROCESSOR_FEATURE_MAX 64
|
||
|
|
||
|
#define MAX_WOW64_SHARED_ENTRIES 16
|
||
|
|
||
|
#define NX_SUPPORT_POLICY_ALWAYSOFF 0
|
||
|
#define NX_SUPPORT_POLICY_ALWAYSON 1
|
||
|
#define NX_SUPPORT_POLICY_OPTIN 2
|
||
|
#define NX_SUPPORT_POLICY_OPTOUT 3
|
||
|
|
||
|
#include <pshpack4.h>
|
||
|
typedef struct _KUSER_SHARED_DATA
|
||
|
{
|
||
|
ULONG TickCountLowDeprecated;
|
||
|
ULONG TickCountMultiplier;
|
||
|
|
||
|
volatile KSYSTEM_TIME InterruptTime;
|
||
|
volatile KSYSTEM_TIME SystemTime;
|
||
|
volatile KSYSTEM_TIME TimeZoneBias;
|
||
|
|
||
|
USHORT ImageNumberLow;
|
||
|
USHORT ImageNumberHigh;
|
||
|
|
||
|
WCHAR NtSystemRoot[260];
|
||
|
|
||
|
ULONG MaxStackTraceDepth;
|
||
|
|
||
|
ULONG CryptoExponent;
|
||
|
|
||
|
ULONG TimeZoneId;
|
||
|
ULONG LargePageMinimum;
|
||
|
ULONG AitSamplingValue;
|
||
|
ULONG AppCompatFlag;
|
||
|
ULONGLONG RNGSeedVersion;
|
||
|
ULONG GlobalValidationRunlevel;
|
||
|
LONG TimeZoneBiasStamp;
|
||
|
|
||
|
ULONG NtBuildNumber;
|
||
|
NT_PRODUCT_TYPE NtProductType;
|
||
|
BOOLEAN ProductTypeIsValid;
|
||
|
UCHAR Reserved0[1];
|
||
|
USHORT NativeProcessorArchitecture;
|
||
|
|
||
|
ULONG NtMajorVersion;
|
||
|
ULONG NtMinorVersion;
|
||
|
|
||
|
BOOLEAN ProcessorFeatures[PROCESSOR_FEATURE_MAX];
|
||
|
|
||
|
ULONG Reserved1;
|
||
|
ULONG Reserved3;
|
||
|
|
||
|
volatile ULONG TimeSlip;
|
||
|
|
||
|
ALTERNATIVE_ARCHITECTURE_TYPE AlternativeArchitecture;
|
||
|
ULONG BootId;
|
||
|
|
||
|
LARGE_INTEGER SystemExpirationDate;
|
||
|
|
||
|
ULONG SuiteMask;
|
||
|
|
||
|
BOOLEAN KdDebuggerEnabled;
|
||
|
union
|
||
|
{
|
||
|
UCHAR MitigationPolicies;
|
||
|
struct
|
||
|
{
|
||
|
UCHAR NXSupportPolicy : 2;
|
||
|
UCHAR SEHValidationPolicy : 2;
|
||
|
UCHAR CurDirDevicesSkippedForDlls : 2;
|
||
|
UCHAR Reserved : 2;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
USHORT CyclesPerYield;
|
||
|
|
||
|
volatile ULONG ActiveConsoleId;
|
||
|
|
||
|
volatile ULONG DismountCount;
|
||
|
|
||
|
ULONG ComPlusPackage;
|
||
|
|
||
|
ULONG LastSystemRITEventTickCount;
|
||
|
|
||
|
ULONG NumberOfPhysicalPages;
|
||
|
|
||
|
BOOLEAN SafeBootMode;
|
||
|
UCHAR VirtualizationFlags;
|
||
|
UCHAR Reserved12[2];
|
||
|
|
||
|
union
|
||
|
{
|
||
|
ULONG SharedDataFlags;
|
||
|
struct
|
||
|
{
|
||
|
ULONG DbgErrorPortPresent : 1;
|
||
|
ULONG DbgElevationEnabled : 1;
|
||
|
ULONG DbgVirtEnabled : 1;
|
||
|
ULONG DbgInstallerDetectEnabled : 1;
|
||
|
ULONG DbgLkgEnabled : 1;
|
||
|
ULONG DbgDynProcessorEnabled : 1;
|
||
|
ULONG DbgConsoleBrokerEnabled : 1;
|
||
|
ULONG DbgSecureBootEnabled : 1;
|
||
|
ULONG DbgMultiSessionSku : 1;
|
||
|
ULONG DbgMultiUsersInSessionSku : 1;
|
||
|
ULONG DbgStateSeparationEnabled : 1;
|
||
|
ULONG SpareBits : 21;
|
||
|
};
|
||
|
};
|
||
|
ULONG DataFlagsPad[1];
|
||
|
|
||
|
ULONGLONG TestRetInstruction;
|
||
|
LONGLONG QpcFrequency;
|
||
|
ULONG SystemCall;
|
||
|
ULONG SystemCallPad0;
|
||
|
ULONGLONG SystemCallPad[2];
|
||
|
|
||
|
union
|
||
|
{
|
||
|
volatile KSYSTEM_TIME TickCount;
|
||
|
volatile ULONG64 TickCountQuad;
|
||
|
ULONG ReservedTickCountOverlay[3];
|
||
|
};
|
||
|
ULONG TickCountPad[1];
|
||
|
|
||
|
ULONG Cookie;
|
||
|
ULONG CookiePad[1];
|
||
|
|
||
|
LONGLONG ConsoleSessionForegroundProcessId;
|
||
|
ULONGLONG TimeUpdateLock;
|
||
|
ULONGLONG BaselineSystemTimeQpc;
|
||
|
ULONGLONG BaselineInterruptTimeQpc;
|
||
|
ULONGLONG QpcSystemTimeIncrement;
|
||
|
ULONGLONG QpcInterruptTimeIncrement;
|
||
|
UCHAR QpcSystemTimeIncrementShift;
|
||
|
UCHAR QpcInterruptTimeIncrementShift;
|
||
|
|
||
|
USHORT UnparkedProcessorCount;
|
||
|
ULONG EnclaveFeatureMask[4];
|
||
|
|
||
|
ULONG TelemetryCoverageRound;
|
||
|
|
||
|
USHORT UserModeGlobalLogger[16];
|
||
|
ULONG ImageFileExecutionOptions;
|
||
|
|
||
|
ULONG LangGenerationCount;
|
||
|
ULONGLONG Reserved4;
|
||
|
volatile ULONG64 InterruptTimeBias;
|
||
|
volatile ULONG64 QpcBias;
|
||
|
|
||
|
ULONG ActiveProcessorCount;
|
||
|
volatile UCHAR ActiveGroupCount;
|
||
|
UCHAR Reserved9;
|
||
|
union
|
||
|
{
|
||
|
USHORT QpcData;
|
||
|
struct
|
||
|
{
|
||
|
UCHAR QpcBypassEnabled : 1;
|
||
|
UCHAR QpcShift : 1;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
LARGE_INTEGER TimeZoneBiasEffectiveStart;
|
||
|
LARGE_INTEGER TimeZoneBiasEffectiveEnd;
|
||
|
XSTATE_CONFIGURATION XState;
|
||
|
} KUSER_SHARED_DATA, *PKUSER_SHARED_DATA;
|
||
|
#include <poppack.h>
|
||
|
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, TickCountMultiplier) == 0x4);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, InterruptTime) == 0x8);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, SystemTime) == 0x14);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, NtSystemRoot) == 0x30);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, LargePageMinimum) == 0x244);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, NtProductType) == 0x264);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, NtMajorVersion) == 0x26c);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, NtMinorVersion) == 0x270);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, ProcessorFeatures) == 0x274);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, KdDebuggerEnabled) == 0x2d4);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, ActiveConsoleId) == 0x2d8);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, NumberOfPhysicalPages) == 0x2e8);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, SafeBootMode) == 0x2ec);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, TickCount) == 0x320);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, TickCountQuad) == 0x320);
|
||
|
C_ASSERT(FIELD_OFFSET(KUSER_SHARED_DATA, XState) == 0x3d8);
|
||
|
//C_ASSERT(sizeof(KUSER_SHARED_DATA) == 0x70C); // VS2017 has some weird issue with this.
|
||
|
|
||
|
#define USER_SHARED_DATA ((KUSER_SHARED_DATA * const)0x7ffe0000)
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WS03)
|
||
|
|
||
|
FORCEINLINE ULONGLONG NtGetTickCount64()
|
||
|
{
|
||
|
ULARGE_INTEGER tickCount;
|
||
|
|
||
|
#ifdef _WIN64
|
||
|
|
||
|
tickCount.QuadPart = USER_SHARED_DATA->TickCountQuad;
|
||
|
|
||
|
#else
|
||
|
|
||
|
while (TRUE)
|
||
|
{
|
||
|
tickCount.HighPart = (ULONG)USER_SHARED_DATA->TickCount.High1Time;
|
||
|
tickCount.LowPart = USER_SHARED_DATA->TickCount.LowPart;
|
||
|
|
||
|
if (tickCount.HighPart == (ULONG)USER_SHARED_DATA->TickCount.High2Time)
|
||
|
break;
|
||
|
|
||
|
YieldProcessor();
|
||
|
}
|
||
|
|
||
|
#endif
|
||
|
|
||
|
return (UInt32x32To64(tickCount.LowPart, USER_SHARED_DATA->TickCountMultiplier) >> 24) +
|
||
|
(UInt32x32To64(tickCount.HighPart, USER_SHARED_DATA->TickCountMultiplier) << 8);
|
||
|
}
|
||
|
|
||
|
FORCEINLINE ULONG NtGetTickCount()
|
||
|
{
|
||
|
#ifdef _WIN64
|
||
|
|
||
|
return (ULONG)((USER_SHARED_DATA->TickCountQuad * USER_SHARED_DATA->TickCountMultiplier) >> 24);
|
||
|
|
||
|
#else
|
||
|
|
||
|
ULARGE_INTEGER tickCount;
|
||
|
|
||
|
while (TRUE)
|
||
|
{
|
||
|
tickCount.HighPart = (ULONG)USER_SHARED_DATA->TickCount.High1Time;
|
||
|
tickCount.LowPart = USER_SHARED_DATA->TickCount.LowPart;
|
||
|
|
||
|
if (tickCount.HighPart == (ULONG)USER_SHARED_DATA->TickCount.High2Time)
|
||
|
break;
|
||
|
|
||
|
YieldProcessor();
|
||
|
}
|
||
|
|
||
|
return (ULONG)((UInt32x32To64(tickCount.LowPart, USER_SHARED_DATA->TickCountMultiplier) >> 24) +
|
||
|
UInt32x32To64((tickCount.HighPart << 8) & 0xffffffff, USER_SHARED_DATA->TickCountMultiplier));
|
||
|
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// Locale
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryDefaultLocale(
|
||
|
_In_ BOOLEAN UserProfile,
|
||
|
_Out_ PLCID DefaultLocaleId
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetDefaultLocale(
|
||
|
_In_ BOOLEAN UserProfile,
|
||
|
_In_ LCID DefaultLocaleId
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryInstallUILanguage(
|
||
|
_Out_ LANGID *InstallUILanguageId
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
// private
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtFlushInstallUILanguage(
|
||
|
_In_ LANGID InstallUILanguage,
|
||
|
_In_ ULONG SetComittedFlag
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryDefaultUILanguage(
|
||
|
_Out_ LANGID *DefaultUILanguageId
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetDefaultUILanguage(
|
||
|
_In_ LANGID DefaultUILanguageId
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
// private
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtIsUILanguageComitted(
|
||
|
VOID
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
// NLS
|
||
|
|
||
|
// begin_private
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_VISTA)
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtInitializeNlsFiles(
|
||
|
_Out_ PVOID *BaseAddress,
|
||
|
_Out_ PLCID DefaultLocaleId,
|
||
|
_Out_ PLARGE_INTEGER DefaultCasingTableSize
|
||
|
);
|
||
|
#else
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtInitializeNlsFiles(
|
||
|
_Out_ PVOID *BaseAddress,
|
||
|
_Out_ PLCID DefaultLocaleId,
|
||
|
_Out_ PLARGE_INTEGER DefaultCasingTableSize,
|
||
|
_Out_opt_ PULONG CurrentNLSVersion
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtGetNlsSectionPtr(
|
||
|
_In_ ULONG SectionType,
|
||
|
_In_ ULONG SectionData,
|
||
|
_In_ PVOID ContextData,
|
||
|
_Out_ PVOID *SectionPointer,
|
||
|
_Out_ PULONG SectionSize
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION < PHNT_WIN7)
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAcquireCMFViewOwnership(
|
||
|
_Out_ PULONGLONG TimeStamp,
|
||
|
_Out_ PBOOLEAN tokenTaken,
|
||
|
_In_ BOOLEAN replaceExisting
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtReleaseCMFViewOwnership(
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtMapCMFModule(
|
||
|
_In_ ULONG What,
|
||
|
_In_ ULONG Index,
|
||
|
_Out_opt_ PULONG CacheIndexOut,
|
||
|
_Out_opt_ PULONG CacheFlagsOut,
|
||
|
_Out_opt_ PULONG ViewSizeOut,
|
||
|
_Out_opt_ PVOID *BaseAddress
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtGetMUIRegistryInfo(
|
||
|
_In_ ULONG Flags,
|
||
|
_Inout_ PULONG DataSize,
|
||
|
_Out_ PVOID Data
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
// end_private
|
||
|
|
||
|
// Global atoms
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAddAtom(
|
||
|
_In_reads_bytes_opt_(Length) PWSTR AtomName,
|
||
|
_In_ ULONG Length,
|
||
|
_Out_opt_ PRTL_ATOM Atom
|
||
|
);
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN8)
|
||
|
|
||
|
#define ATOM_FLAG_GLOBAL 0x2
|
||
|
|
||
|
// rev
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtAddAtomEx(
|
||
|
_In_reads_bytes_opt_(Length) PWSTR AtomName,
|
||
|
_In_ ULONG Length,
|
||
|
_Out_opt_ PRTL_ATOM Atom,
|
||
|
_In_ ULONG Flags
|
||
|
);
|
||
|
|
||
|
#endif
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtFindAtom(
|
||
|
_In_reads_bytes_opt_(Length) PWSTR AtomName,
|
||
|
_In_ ULONG Length,
|
||
|
_Out_opt_ PRTL_ATOM Atom
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDeleteAtom(
|
||
|
_In_ RTL_ATOM Atom
|
||
|
);
|
||
|
|
||
|
typedef enum _ATOM_INFORMATION_CLASS
|
||
|
{
|
||
|
AtomBasicInformation,
|
||
|
AtomTableInformation
|
||
|
} ATOM_INFORMATION_CLASS;
|
||
|
|
||
|
typedef struct _ATOM_BASIC_INFORMATION
|
||
|
{
|
||
|
USHORT UsageCount;
|
||
|
USHORT Flags;
|
||
|
USHORT NameLength;
|
||
|
WCHAR Name[1];
|
||
|
} ATOM_BASIC_INFORMATION, *PATOM_BASIC_INFORMATION;
|
||
|
|
||
|
typedef struct _ATOM_TABLE_INFORMATION
|
||
|
{
|
||
|
ULONG NumberOfAtoms;
|
||
|
RTL_ATOM Atoms[1];
|
||
|
} ATOM_TABLE_INFORMATION, *PATOM_TABLE_INFORMATION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryInformationAtom(
|
||
|
_In_ RTL_ATOM Atom,
|
||
|
_In_ ATOM_INFORMATION_CLASS AtomInformationClass,
|
||
|
_Out_writes_bytes_(AtomInformationLength) PVOID AtomInformation,
|
||
|
_In_ ULONG AtomInformationLength,
|
||
|
_Out_opt_ PULONG ReturnLength
|
||
|
);
|
||
|
|
||
|
// Global flags
|
||
|
|
||
|
#define FLG_STOP_ON_EXCEPTION 0x00000001 // uk
|
||
|
#define FLG_SHOW_LDR_SNAPS 0x00000002 // uk
|
||
|
#define FLG_DEBUG_INITIAL_COMMAND 0x00000004 // k
|
||
|
#define FLG_STOP_ON_HUNG_GUI 0x00000008 // k
|
||
|
|
||
|
#define FLG_HEAP_ENABLE_TAIL_CHECK 0x00000010 // u
|
||
|
#define FLG_HEAP_ENABLE_FREE_CHECK 0x00000020 // u
|
||
|
#define FLG_HEAP_VALIDATE_PARAMETERS 0x00000040 // u
|
||
|
#define FLG_HEAP_VALIDATE_ALL 0x00000080 // u
|
||
|
|
||
|
#define FLG_APPLICATION_VERIFIER 0x00000100 // u
|
||
|
#define FLG_POOL_ENABLE_TAGGING 0x00000400 // k
|
||
|
#define FLG_HEAP_ENABLE_TAGGING 0x00000800 // u
|
||
|
|
||
|
#define FLG_USER_STACK_TRACE_DB 0x00001000 // u,32
|
||
|
#define FLG_KERNEL_STACK_TRACE_DB 0x00002000 // k,32
|
||
|
#define FLG_MAINTAIN_OBJECT_TYPELIST 0x00004000 // k
|
||
|
#define FLG_HEAP_ENABLE_TAG_BY_DLL 0x00008000 // u
|
||
|
|
||
|
#define FLG_DISABLE_STACK_EXTENSION 0x00010000 // u
|
||
|
#define FLG_ENABLE_CSRDEBUG 0x00020000 // k
|
||
|
#define FLG_ENABLE_KDEBUG_SYMBOL_LOAD 0x00040000 // k
|
||
|
#define FLG_DISABLE_PAGE_KERNEL_STACKS 0x00080000 // k
|
||
|
|
||
|
#define FLG_ENABLE_SYSTEM_CRIT_BREAKS 0x00100000 // u
|
||
|
#define FLG_HEAP_DISABLE_COALESCING 0x00200000 // u
|
||
|
#define FLG_ENABLE_CLOSE_EXCEPTIONS 0x00400000 // k
|
||
|
#define FLG_ENABLE_EXCEPTION_LOGGING 0x00800000 // k
|
||
|
|
||
|
#define FLG_ENABLE_HANDLE_TYPE_TAGGING 0x01000000 // k
|
||
|
#define FLG_HEAP_PAGE_ALLOCS 0x02000000 // u
|
||
|
#define FLG_DEBUG_INITIAL_COMMAND_EX 0x04000000 // k
|
||
|
#define FLG_DISABLE_DBGPRINT 0x08000000 // k
|
||
|
|
||
|
#define FLG_CRITSEC_EVENT_CREATION 0x10000000 // u
|
||
|
#define FLG_LDR_TOP_DOWN 0x20000000 // u,64
|
||
|
#define FLG_ENABLE_HANDLE_EXCEPTIONS 0x40000000 // k
|
||
|
#define FLG_DISABLE_PROTDLLS 0x80000000 // u
|
||
|
|
||
|
#define FLG_VALID_BITS 0xfffffdff
|
||
|
|
||
|
#define FLG_USERMODE_VALID_BITS (FLG_STOP_ON_EXCEPTION | \
|
||
|
FLG_SHOW_LDR_SNAPS | \
|
||
|
FLG_HEAP_ENABLE_TAIL_CHECK | \
|
||
|
FLG_HEAP_ENABLE_FREE_CHECK | \
|
||
|
FLG_HEAP_VALIDATE_PARAMETERS | \
|
||
|
FLG_HEAP_VALIDATE_ALL | \
|
||
|
FLG_APPLICATION_VERIFIER | \
|
||
|
FLG_HEAP_ENABLE_TAGGING | \
|
||
|
FLG_USER_STACK_TRACE_DB | \
|
||
|
FLG_HEAP_ENABLE_TAG_BY_DLL | \
|
||
|
FLG_DISABLE_STACK_EXTENSION | \
|
||
|
FLG_ENABLE_SYSTEM_CRIT_BREAKS | \
|
||
|
FLG_HEAP_DISABLE_COALESCING | \
|
||
|
FLG_DISABLE_PROTDLLS | \
|
||
|
FLG_HEAP_PAGE_ALLOCS | \
|
||
|
FLG_CRITSEC_EVENT_CREATION | \
|
||
|
FLG_LDR_TOP_DOWN)
|
||
|
|
||
|
#define FLG_BOOTONLY_VALID_BITS (FLG_KERNEL_STACK_TRACE_DB | \
|
||
|
FLG_MAINTAIN_OBJECT_TYPELIST | \
|
||
|
FLG_ENABLE_CSRDEBUG | \
|
||
|
FLG_DEBUG_INITIAL_COMMAND | \
|
||
|
FLG_DEBUG_INITIAL_COMMAND_EX | \
|
||
|
FLG_DISABLE_PAGE_KERNEL_STACKS)
|
||
|
|
||
|
#define FLG_KERNELMODE_VALID_BITS (FLG_STOP_ON_EXCEPTION | \
|
||
|
FLG_SHOW_LDR_SNAPS | \
|
||
|
FLG_STOP_ON_HUNG_GUI | \
|
||
|
FLG_POOL_ENABLE_TAGGING | \
|
||
|
FLG_ENABLE_KDEBUG_SYMBOL_LOAD | \
|
||
|
FLG_ENABLE_CLOSE_EXCEPTIONS | \
|
||
|
FLG_ENABLE_EXCEPTION_LOGGING | \
|
||
|
FLG_ENABLE_HANDLE_TYPE_TAGGING | \
|
||
|
FLG_DISABLE_DBGPRINT | \
|
||
|
FLG_ENABLE_HANDLE_EXCEPTIONS)
|
||
|
|
||
|
// Licensing
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtQueryLicenseValue(
|
||
|
_In_ PUNICODE_STRING ValueName,
|
||
|
_Out_opt_ PULONG Type,
|
||
|
_Out_writes_bytes_to_opt_(DataSize, *ResultDataSize) PVOID Data,
|
||
|
_In_ ULONG DataSize,
|
||
|
_Out_ PULONG ResultDataSize
|
||
|
);
|
||
|
|
||
|
// Misc.
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtSetDefaultHardErrorPort(
|
||
|
_In_ HANDLE DefaultHardErrorPort
|
||
|
);
|
||
|
|
||
|
typedef enum _SHUTDOWN_ACTION
|
||
|
{
|
||
|
ShutdownNoReboot,
|
||
|
ShutdownReboot,
|
||
|
ShutdownPowerOff
|
||
|
} SHUTDOWN_ACTION;
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtShutdownSystem(
|
||
|
_In_ SHUTDOWN_ACTION Action
|
||
|
);
|
||
|
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDisplayString(
|
||
|
_In_ PUNICODE_STRING String
|
||
|
);
|
||
|
|
||
|
// Boot graphics
|
||
|
|
||
|
#if (PHNT_VERSION >= PHNT_WIN7)
|
||
|
// rev
|
||
|
NTSYSCALLAPI
|
||
|
NTSTATUS
|
||
|
NTAPI
|
||
|
NtDrawText(
|
||
|
_In_ PUNICODE_STRING Text
|
||
|
);
|
||
|
#endif
|
||
|
|
||
|
#endif // (PHNT_MODE != PHNT_MODE_KERNEL)
|
||
|
|
||
|
#endif
|