44 #if defined(EVENT_TRACING) 45 #include "globals.tmh" 51 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 57 #pragma alloc_text(WDF_FX_VF_SECTION_NAME, VerifierPageLockHandle) 109 #pragma comment(linker, "/include:_FxObjectsInfoCount") 111 #pragma comment(linker, "/include:FxObjectsInfoCount") 173 if (*HandleNameList ==
NULL) {
185 FxDriverGlobals->Tag);
225 objectName.
Buffer = ubuffer;
243 pCur = HandleNameList;
288 if (pExtension ==
NULL) {
300 FxDriverGlobals->DebugExtension = pExtension;
310 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 392 ASSERTMSG(
"FxObjectsInfo table is not in sorted order\n",
436 if (pRtlVerifyVersionInfo ==
NULL) {
447 info.dwOSVersionInfoSize =
sizeof(
info);
448 info.dwMajorVersion = 6;
449 info.dwMinorVersion = 2;
472 ULONG ifrDisabled = 0;
479 status = FxRegKey::_QueryULong(hWdf.
m_Key, &ifrDisabledName, &ifrDisabled);
484 if (ifrDisabled == 1) {
520 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 536 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 645 #endif //((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 676 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 681 #ifdef EVENT_TRACING // __REACTOS__ 705 sizeof(PWMI_WDF_NOTIFY_ROUTINES),
715 sizeof(WMI_WDF_NOTIFY_ROUTINES));
717 sizeof(WMI_WDF_NOTIFY_ROUTINES);
730 sizeof(WMI_WDF_NOTIFY_ROUTINES));
733 #endif // EVENT_TRACING 751 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 768 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 795 % __alignof(
LONG)) == 0);
808 "First time Locking (%d) in Verifier Paged Memory " 809 "from %!wZ! from driver globals %p",
820 "Increment Lock counter (%d) for Verifier Paged Memory " 821 "from %!wZ! from driver globals %p",
839 "Decrement UnLock counter (%d) for Verifier Paged Memory " 840 "with driver globals %p",
841 count, FxDriverGlobals);
926 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 943 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 944 if(FxDriverGlobals->FxVerifierOn){
959 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 977 return windowsVerifierOn;
1012 Mx::MxEnterCriticalRegion();
1014 Mx::MxLeaveCriticalRegion();
1026 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 1038 #if ((FX_CORE_MODE)==(FX_CORE_KERNEL_MODE)) 1042 if(FxDriverGlobals->FxVerifierOn){
1072 #if (FX_CORE_MODE==FX_CORE_USER_MODE) 1146 #if (FX_CORE_MODE==FX_CORE_KERNEL_MODE) 1155 #if (FX_CORE_MODE==FX_CORE_KERNEL_MODE) 1171 #ifdef EVENT_TRACING // __REACTOS__ 1172 if (TraceLoggingProviderEnabled(g_TelemetryProvider, 0 ,0)) {
1258 status = FxRegKey::_QueryValue(FxDriverGlobals,
1286 status = FxRegKey::_QueryValue(FxDriverGlobals,
1304 #pragma prefast(push) 1305 #pragma prefast(suppress:__WARNING_PRECONDITION_NULLTERMINATION_VIOLATION, "FxRegKey::_VerifyMultiSzString makes sure the string is NULL-terminated") 1307 #pragma prefast(pop) 1351 *OverrideValue =
TRUE;
1353 *OverrideValue =
FALSE;
1385 ULONG verifierOnValue;
1386 ULONG verifyDownlevelValue;
1388 ULONG allocateFailValue;
1389 ULONG forceLogsInMiniDump;
1390 ULONG trackDriverForMiniDumpLog;
1391 ULONG requestParentOptimizationOn;
1393 ULONG removeLockOptionFlags;
1398 ULONG timeoutValue = 0;
1407 #if (FX_CORE_MODE==FX_CORE_KERNEL_MODE) 1431 if (FxDriverGlobals->IsVersionGreaterThanOrEqualTo(1,9)) {
1436 FxDriverGlobals->SetVerifierState(WindowsVerifierOn);
1437 if (FxDriverGlobals->FxVerifierOn) {
1451 paramTable[
i].
Name =
L"VerboseOn";
1457 allocateFailValue = (
ULONG) -1;
1461 paramTable[
i].
Name =
L"VerifierAllocateFailCount";
1467 verifierOnValue = 0;
1474 if (FxDriverGlobals->IsVersionGreaterThanOrEqualTo(1,9)) {
1475 verifierOnValue = WindowsVerifierOn;
1481 paramTable[
i].
Name =
L"VerifierOn";
1487 verifyDownlevelValue = 0;
1491 paramTable[
i].
Name =
L"VerifyDownLevel";
1497 forceLogsInMiniDump = 0;
1501 paramTable[
i].
Name =
L"ForceLogsInMiniDump";
1512 #if (FX_CORE_MODE==FX_CORE_KERNEL_MODE) 1513 trackDriverForMiniDumpLog = (
ULONG)
TRUE;
1515 trackDriverForMiniDumpLog = 0;
1520 paramTable[
i].
Name =
L"TrackDriverForMiniDumpLog";
1523 #if (FX_CORE_MODE==FX_CORE_KERNEL_MODE) 1530 requestParentOptimizationOn = (
ULONG)
TRUE;
1534 paramTable[
i].
Name =
L"RequestParentOptimizationOn";
1544 paramTable[
i].
Name =
L"DsfOn";
1550 removeLockOptionFlags = 0;
1554 paramTable[
i].
Name =
L"RemoveLockOptionFlags";
1560 ASSERT(
i <
sizeof(paramTable) /
sizeof(paramTable[0]));
1562 #if (FX_CORE_MODE==FX_CORE_USER_MODE) 1566 "RtlQueryRegistryValuesEx" 1573 #pragma warning(push) 1574 #pragma warning(disable: 4055) 1578 #pragma warning(pop) 1582 if (queryFn ==
NULL) {
1600 FxDriverGlobals->FxVerboseOn =
TRUE;
1603 FxDriverGlobals->FxVerboseOn =
FALSE;
1606 if (allocateFailValue != (
ULONG) -1) {
1607 FxDriverGlobals->WdfVerifierAllocateFailCount = (
LONG) allocateFailValue;
1610 FxDriverGlobals->WdfVerifierAllocateFailCount = -1;
1617 FxDriverGlobals->SetVerifierState(verifierOnValue ?
TRUE :
FALSE);
1619 if (FxDriverGlobals->FxVerifierOn) {
1627 if (verifyDownlevelValue) {
1628 FxDriverGlobals->FxVerifyDownlevel =
TRUE;
1631 FxDriverGlobals->FxVerifyDownlevel =
FALSE;
1642 &FxDriverGlobals->FxVerifyOn);
1644 if (FxDriverGlobals->FxVerifyOn) {
1645 FxDriverGlobals->Public.DriverFlags |=
WdfVerifyOn;
1650 &FxDriverGlobals->FxVerifierDbgBreakOnError);
1653 L"DbgBreakOnDeviceStateError",
1654 &FxDriverGlobals->FxVerifierDbgBreakOnDeviceStateError);
1656 if (FxDriverGlobals->FxVerifierDbgBreakOnError) {
1667 FxDriverGlobals->FxVerifierDbgWaitForSignalTimeoutInSec = timeoutValue;
1679 if (FxDriverGlobals->IsVersionGreaterThanOrEqualTo(1,13) &&
1684 FxDriverGlobals->DbgWaitForWakeInterruptIsrTimeoutInSec = timeoutValue;
1687 FxDriverGlobals->FxForceLogsInMiniDump =
1690 FxDriverGlobals->FxTrackDriverForMiniDumpLog =
1691 (trackDriverForMiniDumpLog) ?
TRUE :
FALSE;
1693 FxDriverGlobals->FxRequestParentOptimizationOn =
1694 (requestParentOptimizationOn) ?
TRUE :
FALSE;
1696 FxDriverGlobals->FxDsfOn = (dsfValue) ?
TRUE :
FALSE;
1698 FxDriverGlobals->RemoveLockOptionFlags = removeLockOptionFlags;
1727 DbgPrint(
"Thread 0x%p is %s 0x%p\n",
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble * u
VOID LockVerifierSection(_In_ PFX_DRIVER_GLOBALS FxDriverGlobals, _In_ PCUNICODE_STRING RegistryPath)
__inline VOID Uninitialize()
PFN_KE_SET_COALESCABLE_TIMER KeSetCoalescableTimer
ULONG dwOSVersionInfoSize
VOID(STDCALL * PFN_VF_CHECK_NX_POOL_TYPE)(_In_ POOL_TYPE PoolType, _In_ PVOID CallingAddress, _In_ ULONG PoolTag)
PFN_POX_UNREGISTER_DEVICE PoxUnregisterDevice
_Must_inspect_result_ PWDF_DRIVER_GLOBALS FxAllocateDriverGlobals(VOID)
BOOLEAN FxTrackDriverForMiniDumpLog
#define FLAG_TO_BOOL(_Flags, _FlagMask)
static VOID MxGlobalInit(VOID)
FxObjectDebugInfo * ObjectDebugInfo
BOOLEAN FxRequestParentOptimizationOn
VOID UnlockVerifierSection(_In_ PFX_DRIVER_GLOBALS FxDriverGlobals)
NTSYSAPI NTSTATUS WINAPI RtlQueryRegistryValues(ULONG, PCWSTR, PRTL_QUERY_REGISTRY_TABLE, PVOID, PVOID)
VOID(STDCALL * PFN_POX_START_DEVICE_POWER_MANAGEMENT)(__in POHANDLE Handle)
const FX_OBJECT_INFO FxObjectsInfo[]
#define UNREFERENCED_PARAMETER(P)
PFN_POX_REGISTER_DEVICE PoxRegisterDevice
FORCEINLINE VOID InsertHeadList(_Inout_ PLIST_ENTRY ListHead, _Inout_ __drv_aliasesMem PLIST_ENTRY Entry)
GLuint GLuint GLsizei count
#define WDF_GLOBAL_VALUE_IFRDISABLED
VOID SetVerifierState(__in BOOLEAN State)
BOOLEAN IsWindowsVerifierOn(_In_ MdDriverObject DriverObject)
_Must_inspect_result_ _In_ PDRIVER_OBJECT _In_ PCUNICODE_STRING RegistryPath
VOID(STDCALL * PFN_POX_REPORT_DEVICE_POWERED_ON)(__in POHANDLE Handle)
VOID FxFreeAllocatedMdlsDebugInfo(__in FxDriverGlobalsDebugExtension *DebugExtension)
LONG WdfVerifierAllocateFailCount
_In_ LPWSTR _In_ ULONG _In_ ULONG _In_ ULONG _Out_ DEVINFO _In_ HDEV _In_ LPWSTR _In_ HANDLE hDriver
ULONG DbgWaitForWakeInterruptIsrTimeoutInSec
VOID FxDestroy(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
BOOLEAN IsUserModeFramework
union FxObjectDebugInfo::@4549 u
FxDriverGlobalsDebugExtension * DebugExtension
VOID WaitForSignal(__in MxEvent *Event, __in PCSTR ReasonForWaiting, __in PVOID Handle, __in ULONG WarningTimeoutInSec, __in ULONG WaitSignalFlags)
VOID FxInitializeBugCheckDriverInfo()
RTL_OSVERSIONINFOEXW OsVersionInfo
LIST_ENTRY AllocatedTagTrackersListHead
PFN_POX_SET_DEVICE_IDLE_TIMEOUT PoxSetDeviceIdleTimeout
#define TRACE_LEVEL_INFORMATION
PFN_POX_COMPLETE_DEVICE_POWER_NOT_REQUIRED PoxCompleteDevicePowerNotRequired
VOID(STDCALL * PFN_POX_UNREGISTER_DEVICE)(__in POHANDLE Handle)
_Must_inspect_result_ FORCEINLINE BOOLEAN IsListEmpty(_In_ const LIST_ENTRY *ListHead)
BOOLEAN PassiveLevelInterruptSupport
FxTrackPowerOption TrackPower
VOID FxPurgeBugCheckDriverInfo(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
KSPIN_LOCK AllocatedMdlsLock
#define STATUS_BUFFER_TOO_SMALL
KAFFINITY(STDCALL * PFN_KE_QUERY_ACTIVE_PROCESSORS)(VOID)
OSVERSIONINFOW VersionInfo
NTSYSAPI VOID NTAPI RtlInitAnsiString(PANSI_STRING DestinationString, PCSZ SourceString)
static __inline VOID MxFreePool(__in PVOID Ptr)
FORCEINLINE BOOLEAN RemoveEntryList(_In_ PLIST_ENTRY Entry)
FX_DRIVER_TRACKER_CACHE_AWARE DriverTracker
VOID FxLibraryGlobalsVerifyVersion(VOID)
VOID FxFreeDriverGlobals(__in PWDF_DRIVER_GLOBALS DriverGlobals)
PVOID VerifierSectionHandle
CHECK_RETURN_IF_USER_MODE __inline NTSTATUS Initialize(__in EVENT_TYPE Type, __in BOOLEAN InitialState)
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
VOID NTAPI DbgBreakPoint(VOID)
#define TRACE_LEVEL_VERBOSE
_Must_inspect_result_ BOOLEAN FxVerifierGetTrackReferences(__in FxObjectDebugInfo *DebugInfo, __in WDFTYPE ObjectType)
PFN_POX_ACTIVATE_COMPONENT PoxActivateComponent
PFN_POX_COMPLETE_IDLE_STATE PoxCompleteIdleState
PVOID NTAPI MmGetSystemRoutineAddress(IN PUNICODE_STRING SystemRoutineName)
static __inline PVOID MxAllocatePoolWithTag(__in POOL_TYPE PoolType, __in SIZE_T NumberOfBytes, __in ULONG Tag)
PFN_POX_REPORT_DEVICE_POWERED_ON PoxReportDevicePoweredOn
VOID(STDCALL * PFN_IO_REPORT_INTERRUPT_INACTIVE)(_In_ PIO_REPORT_INTERRUPT_ACTIVE_STATE_PARAMETERS Parameters)
VOID(STDCALL * PFN_POX_COMPLETE_DEVICE_POWER_NOT_REQUIRED)(__in POHANDLE Handle)
#define ASSERTMSG(msg, exp)
static struct _test_info info[]
GLenum GLuint GLenum GLsizei length
ULONG FxEnhancedVerifierOptions
FORCEINLINE VOID KeInitializeSpinLock(_Out_ PKSPIN_LOCK SpinLock)
#define PAGED_CODE_LOCKED()
_Must_inspect_result_ NTSTATUS FxPoolPackageInitialize(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
static __inline PVOID MxGetSystemRoutineAddress(__in MxFuncName FuncName)
MxLock AllocatedTagTrackersLock
#define RTL_REGISTRY_OPTIONAL
IN ULONG IN UCHAR Condition
DECLSPEC_SELECTANY const ULONG_PTR FxHandleValueMask
NTSTATUS(* PFN_RTL_VERIFY_VERSION_INFO)(__in PRTL_OSVERSIONINFOEXW VersionInfo, __in ULONG TypeMask, __in ULONGLONG ConditionMask)
PFN_IO_UNREGISTER_PLUGPLAY_NOTIFICATION_EX IoUnregisterPlugPlayNotificationEx
_Must_inspect_result_ _In_ PDRIVER_OBJECT DriverObject
VOID FxVerifyObjectTableIsSorted(VOID)
PCSTR FxObjectTypeToHandleName(__in WDFTYPE ObjectType)
void FxVerifierLockInitialize(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
VOID FxCacheBugCheckDriverInfo(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
NTSTATUS(* PFN_RTL_GET_VERSION)(__out PRTL_OSVERSIONINFOW VersionInformation)
PFX_DRIVER_GLOBALS pFxDriverGlobals
VOID(STDCALL * PFN_POX_IDLE_COMPONENT)(__in POHANDLE Handle, __in ULONG Component, __in ULONG Flags)
#define MmLockPagableCodeSection(Address)
#define NT_SUCCESS(StatCode)
BOOLEAN MachineSleepStates[FxMachineSleepStatesMax]
VOID AllocAndInitializeTelemetryContext(_In_ PFX_TELEMETRY_CONTEXT *TelemetryContext)
VOID FxUninitializeBugCheckDriverInfo()
#define DECLARE_CONST_UNICODE_STRING(_variablename, _string)
PFN_KE_SET_TARGET_PROCESSOR_DPC KeSetTargetProcessorDpc
__inline VOID Uninitialize()
static __inline KIRQL MxGetCurrentIrql()
_Must_inspect_result_ NTSTATUS FxLibraryGlobalsCommission(VOID)
PFN_VF_CHECK_NX_POOL_TYPE VfCheckNxPoolType
NTSTATUS NTAPI WmiQueryTraceInformation(IN TRACE_INFORMATION_CLASS TraceInformationClass, OUT PVOID TraceInformation, IN ULONG TraceInformationLength, OUT PULONG RequiredLength OPTIONAL, IN PVOID Buffer OPTIONAL)
BOOLEAN ProcessorGroupSupport
PVOID DummyPerfTraceRoutines
_Must_inspect_result_ FxObjectDebugInfo * FxVerifierGetObjectDebugInfo(__in HANDLE Key, __in PFX_DRIVER_GLOBALS FxDriverGlobals)
ULONG RtlCompareUnicodeString(PUNICODE_STRING s1, PUNICODE_STRING s2, BOOLEAN UpCase)
#define InterlockedDecrement
_Must_inspect_result_ NTSTATUS Initialize()
VOID(STDCALL * PFN_POX_ACTIVATE_COMPONENT)(__in POHANDLE Handle, __in ULONG Component, __in ULONG Flags)
#define RTL_REGISTRY_HANDLE
_Must_inspect_result_ NTSTATUS FxInitialize(__inout PFX_DRIVER_GLOBALS FxDriverGlobals, __in MdDriverObject DriverObject, __in PCUNICODE_STRING RegistryPath, __in_opt PWDF_DRIVER_CONFIG DriverConfig)
NTSTATUS(STDCALL * PFN_IO_CONNECT_INTERRUPT_EX)(__inout PIO_CONNECT_INTERRUPT_PARAMETERS Parameters)
VOID(STDCALL * PFN_IO_REPORT_INTERRUPT_ACTIVE)(_In_ PIO_REPORT_INTERRUPT_ACTIVE_STATE_PARAMETERS Parameters)
VOID VerifierPageLockHandle(VOID)
VOID FxRegisterBugCheckCallback(__inout PFX_DRIVER_GLOBALS FxDriverGlobals, __in PDRIVER_OBJECT DriverObject)
#define _Must_inspect_result_
BOOLEAN FxVerifierDbgBreakOnError
VOID FxLibraryGlobalsDecommission(VOID)
#define VER_GREATER_EQUAL
#define MAKE_MX_FUNC_NAME(x)
FORCEINLINE LONGLONG WDF_REL_TIMEOUT_IN_SEC(_In_ ULONGLONG Time)
_Must_inspect_result_ BOOLEAN IsDebuggerAttached(VOID)
static __inline MxThread MxGetCurrentThread()
ULONGLONG(* PFN_VER_SET_CONDITION_MASK)(__in ULONGLONG ConditionMask, __in ULONG TypeMask, __in UCHAR Condition)
#define InterlockedIncrement
#define STATUS_BUFFER_OVERFLOW
PFX_TELEMETRY_CONTEXT TelemetryContext
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
ULONG FxVerifierDbgWaitForSignalTimeoutInSec
NTSYSAPI NTSTATUS NTAPI RtlAnsiStringToUnicodeString(PUNICODE_STRING DestinationString, PANSI_STRING SourceString, BOOLEAN AllocateDestinationString)
FxLibraryGlobalsType FxLibraryGlobals
#define InitializeListHead(ListHead)
FxLibraryGlobalsType * LibraryGlobals
PFN_IO_DISCONNECT_INTERRUPT_EX IoDisconnectInterruptEx
LOGICAL NTAPI MmIsDriverVerifying(IN PDRIVER_OBJECT DriverObject)
DoTraceLevelMessage(pFxDriverGlobals, TRACE_LEVEL_VERBOSE, TRACINGPNP, "Enter, WDFDEVICE %p", Device)
#define FIELD_OFFSET(t, f)
NTSTATUS(STDCALL * PFN_POX_REGISTER_DEVICE)(__in MdDeviceObject Pdo, __in PPO_FX_DEVICE PoxDevice, __out POHANDLE *Handle)
PFN_IO_REPORT_INTERRUPT_ACTIVE IoReportInterruptActive
BOOLEAN(STDCALL * PFN_KE_SET_COALESCABLE_TIMER)(__inout PKTIMER Timer, __in LARGE_INTEGER DueTime, __in ULONG Period, __in ULONG TolerableDelay, __in_opt PKDPC Dpc)
VOID FxUnregisterBugCheckCallback(__inout PFX_DRIVER_GLOBALS FxDriverGlobals)
VOID FxDriverGlobalsInitializeDebugExtension(__inout PFX_DRIVER_GLOBALS FxDriverGlobals, __in_opt HANDLE Key)
PFN_KE_QUERY_ACTIVE_PROCESSORS KeQueryActiveProcessors
_In_ ULONG _In_ ULONGLONG ConditionMask
VOID FxLibraryGlobalsQueryRegistrySettings(VOID)
ACPI_BUFFER *RetBuffer ACPI_BUFFER *RetBuffer char ACPI_WALK_RESOURCE_CALLBACK void *Context ACPI_BUFFER *RetBuffer UINT16 ACPI_RESOURCE **ResourcePtr ACPI_GENERIC_ADDRESS *Reg UINT32 *ReturnValue UINT8 UINT8 *Slp_TypB ACPI_PHYSICAL_ADDRESS PhysicalAddress64 UINT32 UINT32 *TimeElapsed UINT32 ACPI_STATUS const char UINT32 ACPI_STATUS const char UINT32 const char * FunctionName
VOID FxPoolPackageDestroy(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
BOOLEAN FxVerifyDownlevel
VOID FxRegistrySettingsInitialize(__inout PFX_DRIVER_GLOBALS FxDriverGlobals, __in PCUNICODE_STRING RegistryPath, __in BOOLEAN WindowsVerifierOn)
static _Must_inspect_result_ NTSTATUS _VerifyMultiSzString(__in PFX_DRIVER_GLOBALS FxDriverGlobals, __in PCUNICODE_STRING RegValueName, __in_bcount(DataLength) PWCHAR DataString, __in ULONG DataLength)
VOID FxVerifierQueryTrackPower(__in HANDLE Key, __out FxTrackPowerOption *TrackPower)
HMODULE WINAPI GetModuleHandleW(LPCWSTR lpModuleName)
VOID(STDCALL * PFN_POX_COMPLETE_IDLE_STATE)(__in POHANDLE Handle, __in ULONG Component)
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
#define RtlZeroMemory(Destination, Length)
volatile LONG VerifierSectionHandleRefCount
#define GetProcAddress(x, y)
VOID FxOverrideDefaultVerifierSettings(__in HANDLE Key, __in LPWSTR Name, __out PBOOLEAN OverrideValue)
PFN_IO_CONNECT_INTERRUPT_EX IoConnectInterruptEx
NTSTATUS(STDCALL * PFN_IO_DISCONNECT_INTERRUPT_EX)(__in PIO_DISCONNECT_INTERRUPT_PARAMETERS Parameters)
GLuint GLuint GLsizei GLenum type
__inline PFX_DRIVER_GLOBALS GetFxDriverGlobals(__in PWDF_DRIVER_GLOBALS DriverGlobals)
VOID(STDCALL * PFN_POX_SET_DEVICE_IDLE_TIMEOUT)(__in POHANDLE Handle, __in ULONGLONG IdleTimeout)
__inline VOID Initialize()
#define WDF_REGISTRY_BASE_PATH
NTSTATUS(STDCALL * PFN_IO_UNREGISTER_PLUGPLAY_NOTIFICATION_EX)(__in PVOID NotificationEntry)
PFN_POX_IDLE_COMPONENT PoxIdleComponent
VOID(STDCALL * PFN_KE_SET_TARGET_PROCESSOR_DPC)(__in PRKDPC Dpc, __in CCHAR Number)
static SERVICE_STATUS status
struct _FX_DRIVER_GLOBALS * PFX_DRIVER_GLOBALS
PFN_IO_REPORT_INTERRUPT_INACTIVE IoReportInterruptInactive
void FxVerifierLockDestroy(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
VOID(STDCALL * PFN_POX_COMPLETE_IDLE_CONDITION)(__in POHANDLE Handle, __in ULONG Component)
#define RTL_QUERY_REGISTRY_DIRECT
_Must_inspect_result_ _In_ PDRIVER_OBJECT _In_ PCUNICODE_STRING _In_opt_ PWDF_OBJECT_ATTRIBUTES _In_ PWDF_DRIVER_CONFIG DriverConfig
_Must_inspect_result_ BOOLEAN FxVerifyObjectTypeInTable(__in USHORT ObjectType)
PFN_POX_COMPLETE_IDLE_CONDITION PoxCompleteIdleCondition
PFN_POX_START_DEVICE_POWER_MANAGEMENT PoxStartDevicePowerManagement
ULONG BugCheckDriverInfoIndex
BOOLEAN FxForceLogsInMiniDump
LIST_ENTRY FxDriverGlobalsList
MxLockNoDynam FxDriverGlobalsListLock
_Must_inspect_result_ FxObjectDebugInfo * FxVerifyAllocateDebugInfo(__in LPWSTR HandleNameList, __in PFX_DRIVER_GLOBALS FxDriverGlobals)