ReactOS 0.4.16-dev-433-g6363f78
fxlibrarycommon.cpp File Reference
#include <ntddk.h>
#include "fx.hpp"
#include "fxldr.h"
#include "fxlibrarycommon.h"
#include "fxtelemetry.hpp"
#include "wdfversionlog.h"
#include "minwindef.h"
Include dependency graph for fxlibrarycommon.cpp:

Go to the source code of this file.

Macros

#define VF_FX_DYNAMICS_GENERATE_TABLE   1
 
#define EVTLOG_DDI_COUNT_ERROR_MAX_LEN   (53 + MAX_PATH)
 

Functions

VOID GetTriageInfo (VOID)
 
BOOLEAN IsClientInfoValid (_In_ PCLIENT_INFO ClientInfo)
 
VOID ReportDdiFunctionCountMismatch (_In_ PCUNICODE_STRING ServiceName, _In_ ULONG ActualFunctionCount, _In_ ULONG ExpectedFunctionCount)
 
_Must_inspect_result_ NTSTATUS FxLibraryCommonCommission (VOID)
 
_Must_inspect_result_ NTSTATUS FxLibraryCommonDecommission (VOID)
 
_Must_inspect_result_ NTSTATUS FxLibraryCommonRegisterClient (__inout PWDF_BIND_INFO Info, __deref_out PWDF_DRIVER_GLOBALS *WdfDriverGlobals, __in_opt PCLIENT_INFO ClientInfo)
 
_Must_inspect_result_ NTSTATUS FxLibraryCommonUnregisterClient (__in PWDF_BIND_INFO Info, __in PWDF_DRIVER_GLOBALS WdfDriverGlobals)
 
VOID GetEnhancedVerifierOptions (__in PCLIENT_INFO ClientInfo, __out PULONG Options)
 
VOID LibraryLogEvent (__in PDRIVER_OBJECT DriverObject, __in NTSTATUS ErrorCode, __in NTSTATUS FinalStatus, __in PWSTR ErrorInsertionString, __in_bcount(RawDataLen) PVOID RawDataBuf, __in USHORT RawDataLen)
 

Variables

static WDFOBJECT_TRIAGE_INFO _WdfObjectTriageInfo = {0}
 
static WDFCONTEXT_TRIAGE_INFO _WdfContextTriageInfo = {0}
 
static WDFCONTEXTTYPE_TRIAGE_INFO _WdfContextTypeTriageInfo = {0}
 
static WDFQUEUE_TRIAGE_INFO _WdfQueueTriageInfo = {0}
 
static WDFIRPQUEUE_TRIAGE_INFO _WdfIrpQueueTriageInfo = {0}
 
static WDFREQUEST_TRIAGE_INFO _WdfRequestTriageInfo = {0}
 
static WDFDEVICE_TRIAGE_INFO _WdfDeviceTriageInfo = {0}
 
static WDFIRP_TRIAGE_INFO _WdfIrpTriageInfo = {0}
 
static WDFFWDPROGRESS_TRIAGE_INFO _WdfFwdProgressTriageInfo = {0}
 
WDF_TRIAGE_INFO g_WdfTriageInfo
 

Macro Definition Documentation

◆ EVTLOG_DDI_COUNT_ERROR_MAX_LEN

#define EVTLOG_DDI_COUNT_ERROR_MAX_LEN   (53 + MAX_PATH)

Definition at line 18 of file fxlibrarycommon.cpp.

◆ VF_FX_DYNAMICS_GENERATE_TABLE

#define VF_FX_DYNAMICS_GENERATE_TABLE   1

Definition at line 12 of file fxlibrarycommon.cpp.

Function Documentation

◆ FxLibraryCommonCommission()

_Must_inspect_result_ NTSTATUS FxLibraryCommonCommission ( VOID  )

Definition at line 224 of file fxlibrarycommon.cpp.

227{
228 DECLARE_CONST_UNICODE_STRING(usName, L"RtlGetVersion");
229 PFN_RTL_GET_VERSION pRtlGetVersion = NULL;
231
233
234 //
235 // Commission this version's DLL globals.
236 //
238
239 if (!NT_SUCCESS(status)) {
240 __Print(("FxLibraryGlobalsCommission failed %X\n", status));
241 return status;
242 }
243
244 //
245 // register telemetry provider.
246 //
248
249 //
250 // Initialize internal WPP tracing.
251 //
253 if (NT_SUCCESS(status)) {
255 }
256 else {
257 __Print(("Failed to initialize tracing for WDF\n"));
258
259 //
260 // Failure to initialize is not critical enough to fail driver load.
261 //
263 }
264
265 //
266 // Attempt to load RtlGetVersion (works for > w2k).
267 //
269 (PUNICODE_STRING) &usName
270 );
271
272 //
273 // Now attempt to get this OS's version.
274 //
275 if (pRtlGetVersion != NULL) {
276 pRtlGetVersion(&gOsVersion);
277 }
278
279 __Print(("OsVersion(%d.%d)\n",
282
283 //
284 // Init triage info for 9f bugcheck analysis.
285 //
287
288 return STATUS_SUCCESS;
289}
LONG NTSTATUS
Definition: precomp.h:26
#define NULL
Definition: types.h:112
#define TRUE
Definition: types.h:120
#define NT_SUCCESS(StatCode)
Definition: apphelp.c:33
_Must_inspect_result_ NTSTATUS FxLibraryGlobalsCommission(VOID)
Definition: globals.cpp:494
#define WDF_LIBRARY_COMMISSION
Definition: fxldr.h:110
VOID RegisterTelemetryProvider(VOID)
#define __Print(_x_)
#define LITERAL(a)
RTL_OSVERSIONINFOW gOsVersion
Definition: version.cpp:104
NTSTATUS(* PFN_RTL_GET_VERSION)(__out PRTL_OSVERSIONINFOW VersionInformation)
VOID GetTriageInfo(VOID)
#define L(x)
Definition: ntvdm.h:50
FxLibraryGlobalsType FxLibraryGlobals
Definition: globals.cpp:95
#define STATUS_SUCCESS
Definition: shellext.h:65
BOOLEAN InternalTracingInitialized
Definition: fxglobals.h:804
ULONG dwMinorVersion
Definition: rtltypes.h:248
ULONG dwMajorVersion
Definition: rtltypes.h:247
Definition: ps.c:97
PVOID NTAPI MmGetSystemRoutineAddress(IN PUNICODE_STRING SystemRoutineName)
Definition: sysldr.c:3604
_Must_inspect_result_ NTSTATUS FxTraceInitialize(VOID)
Definition: tracing.cpp:47
#define DECLARE_CONST_UNICODE_STRING(_variablename, _string)
Definition: wdfcore.h:161

◆ FxLibraryCommonDecommission()

_Must_inspect_result_ NTSTATUS FxLibraryCommonDecommission ( VOID  )

Definition at line 293 of file fxlibrarycommon.cpp.

296{
298
299 //
300 // Uninitialize WPP tracing.
301 //
305 }
306
307 //
308 // Unregister telemetry provider.
309 //
311
312 EventUnregisterMicrosoft_Windows_DriverFrameworks_KernelMode_Performance();
313
314 //
315 // Decommission this version's DLL globals.
316 //
318
319 //
320 // Note: This is the absolute last action from WDF library (dynamic or static).
321 // The image is likely to be deleted after returning.
322 //
324
325 return STATUS_SUCCESS;
326}
#define FALSE
Definition: types.h:117
VOID FxLibraryGlobalsDecommission(VOID)
Definition: globals.cpp:742
#define WDF_LIBRARY_DECOMMISSION
Definition: fxldr.h:111
VOID UnregisterTelemetryProvider(VOID)
VOID TraceUninitialize(VOID)
Definition: tracing.cpp:79

◆ FxLibraryCommonRegisterClient()

_Must_inspect_result_ NTSTATUS FxLibraryCommonRegisterClient ( __inout PWDF_BIND_INFO  Info,
__deref_out PWDF_DRIVER_GLOBALS WdfDriverGlobals,
__in_opt PCLIENT_INFO  ClientInfo 
)

Definition at line 330 of file fxlibrarycommon.cpp.

335{
338
340
342
343 if (Info == NULL || WdfDriverGlobals == NULL || Info->FuncTable == NULL) {
345 ": NULL parameter -- %s\n",
346 (Info == NULL) ? "PWDF_BIND_INFO" :
347 (WdfDriverGlobals == NULL) ? "PWDF_DRIVER_GLOBALS *" :
348 (Info->FuncTable == NULL) ? "PWDF_BIND_INFO->FuncTable" :
349 "unknown" ));
350 goto Done;
351 }
352
353 ASSERT(Info->FuncCount);
354
355
357
358 //
359 // WdfVersion.Count is initialized in FxDynamics.h and is never changed.
360 // Prefast is unable to make that determination.
361 //
362 __assume(WdfVersion.FuncCount == sizeof(WDFFUNCTIONS)/sizeof(PVOID));
363
364 if (Info->FuncCount > WdfVersion.FuncCount) {
366 ": version mismatch detected in function table count: client"
367 "has 0x%x, library has 0x%x\n",
368 Info->FuncCount, WdfVersion.FuncCount));
369 goto Done;
370 }
371
372 if (Info->FuncCount <= WdfFunctionTableNumEntries_V1_15) {
373 //
374 // Make sure table count matches exactly with previously
375 // released framework version table sizes.
376 //
377 switch (Info->FuncCount) {
378
383 // case WdfFunctionTableNumEntries_V1_7: // both 1.7 and 1.5 have 387 functions
387 break;
388
389 default:
391 ": Function table count 0x%x doesn't match any previously "
392 "released framework version table size\n",
393 Info->FuncCount));
394 goto Done;
395 }
396 }
397 else {
398
399
400
401
402
403
404
405
406 // Client version is same as framework version. Make
407 // sure table count is exact.
408 if (Info->FuncCount != WdfFunctionTableNumEntries) {
410
412 GetNameFromPath(ClientInfo->RegistryPath, &serviceName);
413 }
414 else {
416 }
417
418 //
419 // Report a DbgPrint message, telemetry event and an ETW event that
420 // will serve as diagnostic aid.
421 //
423 Info->FuncCount,
425
426 //
427 // If loader diagnostics are enabled and KD is connected, break-in
428 //
432 }
433 goto Done;
434 }
435 }
436
437 //
438 // Allocate an new FxDriverGlobals area for this driver.
439 //
441
442 if (*WdfDriverGlobals) {
443 BOOLEAN isFunctinTableHookingOn = FALSE;
444 BOOLEAN isPerformanceAnalysisOn = FALSE;
446
447 //
448 // Check the registry to see if Enhanced verifier is on for this driver.
449 // if registry read fails, options value remains unchanged.
450 // store enhanced verifier options in driver globals
451 //
454 isFunctinTableHookingOn = IsFxVerifierFunctionTableHooking(fxDriverGlobals);
455 isPerformanceAnalysisOn = IsFxPerformanceAnalysis(fxDriverGlobals);
456
457 //
458 // Set-up the function table. Enhanced verifier and Performance analysis is off by default.
459 //
460 if (isFunctinTableHookingOn == FALSE && isPerformanceAnalysisOn == FALSE) {
461
462 //
463 // Starting in 1.15 we reference a copy of the DDI table in WDF01000,
464 // prior to that we copy the entire table to local memory.
465 //
466 if (Info->FuncCount <= WdfFunctionTableNumEntries_V1_13) {
467 RtlCopyMemory( Info->FuncTable,
469 Info->FuncCount * sizeof(PVOID) );
470 }
471 else {
472 //
473 // FuncTable arrives with a ptr to &WdfFunctions, so we update
474 // what WdfFunctions points to.
475 //
476 *((WDFFUNC**) Info->FuncTable) = (WDFFUNC*) &WdfVersion.Functions;
477 }
478 }
479 else {
481 ": Enhanced Verification is ON \n"));
482
484
485 if (Microsoft_Windows_DriverFrameworks_KernelMode_PerformanceHandle == NULL) {
486 EventRegisterMicrosoft_Windows_DriverFrameworks_KernelMode_Performance();
487 }
488
489 //
490 // Enhanced verification is on. Return verifier function table
491 //
492 // Starting in 1.15 we reference a copy of the DDI table in WDF01000,
493 // prior to that we copy the entire table to local memory.
494 //
495 if (Info->FuncCount <= WdfFunctionTableNumEntries_V1_13) {
496 RtlCopyMemory( Info->FuncTable,
497 &VfWdfVersion.Functions,
498 Info->FuncCount * sizeof(PVOID) );
499 }
500 else {
501 //
502 // FuncTable arrives with a ptr to &WdfFunctions, so we update
503 // what WdfFunctions points to.
504 //
505 *((WDFFUNC**) Info->FuncTable) = (WDFFUNC*) &VfWdfVersion.Functions;
506 }
507 }
508
510
512 ": WdfFunctions %p\n", Info->FuncTable));
513 }
514
515Done:
517 ": exit: status %X\n", status));
518
519 return status;
520}
unsigned char BOOLEAN
PFX_DRIVER_GLOBALS fxDriverGlobals
VOID LockVerifierSection(_In_ PFX_DRIVER_GLOBALS FxDriverGlobals, _In_ PCUNICODE_STRING RegistryPath)
Definition: globals.cpp:783
__inline PFX_DRIVER_GLOBALS GetFxDriverGlobals(__in PWDF_DRIVER_GLOBALS DriverGlobals)
Definition: fxglobals.h:597
#define WDF_LIBRARY_REGISTER_CLIENT
Definition: fxldr.h:112
_Must_inspect_result_ PWDF_DRIVER_GLOBALS FxAllocateDriverGlobals(VOID)
Definition: globals.cpp:1052
VOID GetNameFromPath(_In_ PCUNICODE_STRING Path, _Out_ PUNICODE_STRING Name)
Definition: fxtelemetry.cpp:54
__inline BOOLEAN IsFxPerformanceAnalysis(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
Definition: fxverifier.h:250
__inline BOOLEAN IsFxVerifierFunctionTableHooking(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
Definition: fxverifier.h:127
NTSYSAPI void WINAPI DbgBreakPoint(void)
CLIENT_DATA ClientInfo
WDFVERSION WdfVersion
ULONG WdfLdrDbgPrintOn
Definition: version.cpp:106
BOOLEAN IsClientInfoValid(_In_ PCLIENT_INFO ClientInfo)
VOID ReportDdiFunctionCountMismatch(_In_ PCUNICODE_STRING ServiceName, _In_ ULONG ActualFunctionCount, _In_ ULONG ExpectedFunctionCount)
VOID GetEnhancedVerifierOptions(__in PCLIENT_INFO ClientInfo, __out PULONG Options)
#define __assume(x)
Definition: intrin.h:108
#define ASSERT(a)
Definition: mode.c:44
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
ULONG FxEnhancedVerifierOptions
Definition: fxglobals.h:518
ULONG FuncCount
Definition: fxdynamics.h:593
WDFFUNCTIONS Functions
Definition: fxdynamics.h:594
char serviceName[]
Definition: tftpd.cpp:34
#define RtlCopyMemory(Destination, Source, Length)
Definition: typedefs.h:263
#define RtlZeroMemory(Destination, Length)
Definition: typedefs.h:262
#define STATUS_INVALID_PARAMETER
Definition: udferr_usr.h:135
@ WdfFunctionTableNumEntries_V1_0
Definition: wdf10.h:9
@ WdfFunctionTableNumEntries_V1_11
Definition: wdf111.h:6
@ WdfFunctionTableNumEntries_V1_13
Definition: wdf113.h:6
@ WdfFunctionTableNumEntries_V1_15
Definition: wdf115.h:6
@ WdfFunctionTableNumEntries_V1_1
Definition: wdf11.h:9
@ WdfFunctionTableNumEntries_V1_5
Definition: wdf15.h:9
@ WdfFunctionTableNumEntries_V1_9
Definition: wdf19.h:9
VOID(* WDFFUNC)(VOID)
Definition: wdf.h:68
_Must_inspect_result_ _In_ WDFCHILDLIST _In_ PWDF_CHILD_LIST_ITERATOR _Out_ WDFDEVICE _Inout_opt_ PWDF_CHILD_RETRIEVE_INFO Info
Definition: wdfchildlist.h:690
PWDF_DRIVER_GLOBALS WdfDriverGlobals
@ WdfFunctionTableNumEntries
Definition: wdffuncenum.h:469
#define KD_DEBUGGER_ENABLED
Definition: kdfuncs.h:130
#define KD_DEBUGGER_NOT_PRESENT
Definition: kdfuncs.h:133

Referenced by WDF_LIBRARY_REGISTER_CLIENT().

◆ FxLibraryCommonUnregisterClient()

_Must_inspect_result_ NTSTATUS FxLibraryCommonUnregisterClient ( __in PWDF_BIND_INFO  Info,
__in PWDF_DRIVER_GLOBALS  WdfDriverGlobals 
)

Definition at line 524 of file fxlibrarycommon.cpp.

528{
530
532
533 ASSERT(Info);
535
536 if (Info != NULL && WdfDriverGlobals != NULL) {
538
540
542
543 //
544 // Destroy this FxDriver instance, if its still indicated.
545 //
546 if (pFxDriverGlobals->Driver != NULL) {
547 //
548 // Association support, we are a root with no parent
549 //
551
553 }
554
555 //
556 // Stop IFR logging
557 //
559
560 //
561 // unlock enhanced-verifier image sections
562 //
565 }
566
567 //
568 // This will free the client's FxDriverGlobals area
569 //
571 }
572 else {
574 }
575
577 ": exit: status %X\n", status));
578
579 return status;
580}
virtual VOID DeleteObject(VOID)
Definition: fxdriver.hpp:332
PFX_DRIVER_GLOBALS pFxDriverGlobals
VOID UnlockVerifierSection(_In_ PFX_DRIVER_GLOBALS FxDriverGlobals)
Definition: globals.cpp:827
VOID FxDestroy(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
Definition: globals.cpp:981
#define WDF_LIBRARY_UNREGISTER_CLIENT
Definition: fxldr.h:113
VOID FxFreeDriverGlobals(__in PWDF_DRIVER_GLOBALS DriverGlobals)
Definition: globals.cpp:1181
FxDriver * Driver
Definition: fxglobals.h:374
VOID FxIFRStop(__in PFX_DRIVER_GLOBALS FxDriverGlobals)
Definition: tracing.cpp:297
#define STATUS_UNSUCCESSFUL
Definition: udferr_usr.h:132

Referenced by WDF_LIBRARY_UNREGISTER_CLIENT().

◆ GetEnhancedVerifierOptions()

VOID GetEnhancedVerifierOptions ( __in PCLIENT_INFO  ClientInfo,
__out PULONG  Options 
)

Definition at line 583 of file fxlibrarycommon.cpp.

587{
589 ULONG value;
590 FxAutoRegKey hKey, hWdf;
591 DECLARE_CONST_UNICODE_STRING(parametersPath, L"Parameters\\Wdf");
593
594 *Options = 0;
596 Options == NULL) {
597
599 ": Invalid ClientInfo received from wdfldr \n"));
600 return;
601 }
602
603 status = FxRegKey::_OpenKey(NULL,
604 ClientInfo->RegistryPath,
605 &hWdf.m_Key,
606 KEY_READ);
607 if (!NT_SUCCESS(status)) {
608 return;
609 }
610
611 status = FxRegKey::_OpenKey(hWdf.m_Key,
612 &parametersPath,
613 &hKey.m_Key,
614 KEY_READ);
615 if (!NT_SUCCESS(status)) {
616 return;
617 }
618
619 status = FxRegKey::_QueryULong(
620 hKey.m_Key, &valueName, &value);
621
622 //
623 // Examine key values and set Options only on success.
624 //
625 if (NT_SUCCESS(status)) {
626 if (value) {
627 *Options = value;
628 }
629 }
630}
FxAutoRegKey hKey
#define WDF_ENHANCED_VERIFIER_OPTIONS_VALUE_NAME
#define KEY_READ
Definition: nt_native.h:1023
uint32_t ULONG
Definition: typedefs.h:59
Definition: pdh_main.c:94
_In_ PWDFDEVICE_INIT _In_ PWDF_REMOVE_LOCK_OPTIONS Options
Definition: wdfdevice.h:3534

Referenced by FxLibraryCommonRegisterClient().

◆ GetTriageInfo()

VOID GetTriageInfo ( VOID  )

Definition at line 75 of file fxlibrarycommon.cpp.

78{
79 // Object
80 _WdfObjectTriageInfo.RawObjectSize = sizeof(FxObject);
81 _WdfObjectTriageInfo.ObjectType = FIELD_OFFSET(FxObject, m_Type);
82 _WdfObjectTriageInfo.TotalObjectSize = FIELD_OFFSET(FxObject, m_ObjectSize);
83 _WdfObjectTriageInfo.ChildListHead = FIELD_OFFSET(FxObject, m_ChildListHead);
84 _WdfObjectTriageInfo.ChildEntry = FIELD_OFFSET(FxObject, m_ChildEntry);
85 _WdfObjectTriageInfo.Globals = FIELD_OFFSET(FxObject, m_Globals);
86 _WdfObjectTriageInfo.ParentObject = FIELD_OFFSET(FxObject, m_ParentObject);
87
88 // Context Triage Info
89 _WdfContextTriageInfo.HeaderSize = sizeof(FxContextHeader);
90 _WdfContextTriageInfo.NextHeader = FIELD_OFFSET(FxContextHeader, NextHeader);
92 _WdfContextTriageInfo.TypeInfoPtr = FIELD_OFFSET(FxContextHeader, ContextTypeInfo);
94
95 // Context type Triage info
99
100 // WdfRequest Queue
101 _WdfQueueTriageInfo.QueueSize = sizeof(FxIoQueue);
102 _WdfQueueTriageInfo.IrpQueue1 = FIELD_OFFSET(FxIoQueue, m_Queue);
103 _WdfQueueTriageInfo.IrpQueue2 = FIELD_OFFSET(FxIoQueue, m_DriverCancelable);
104 _WdfQueueTriageInfo.RequestList1 = FIELD_OFFSET(FxIoQueue, m_Cancelled);
105 _WdfQueueTriageInfo.RequestList2 = FIELD_OFFSET(FxIoQueue, m_CanceledOnQueueList);
106 _WdfQueueTriageInfo.FwdProgressContext = FIELD_OFFSET(FxIoQueue, m_FwdProgContext);
108
109 // Forward Progress
110 _WdfFwdProgressTriageInfo.ReservedRequestList =
111 FIELD_OFFSET(FXIO_FORWARD_PROGRESS_CONTEXT, m_ReservedRequestList);
112 _WdfFwdProgressTriageInfo.ReservedRequestInUseList =
113 FIELD_OFFSET(FXIO_FORWARD_PROGRESS_CONTEXT, m_ReservedRequestInUseList);
114 _WdfFwdProgressTriageInfo.PendedIrpList =
116
117 // Irp Queue
118 _WdfIrpQueueTriageInfo.IrpQueueSize = sizeof(FxIrpQueue);
119 _WdfIrpQueueTriageInfo.IrpListHeader = FIELD_OFFSET(FxIrpQueue, m_Queue);
120 _WdfIrpQueueTriageInfo.IrpListEntry = FIELD_OFFSET(IRP, Tail.Overlay.ListEntry);
122 Tail.Overlay.DriverContext[FX_IRP_QUEUE_CSQ_CONTEXT_ENTRY]);
123
124 // WdfRequest
125 _WdfRequestTriageInfo.RequestSize = sizeof(FxRequest);
126 _WdfRequestTriageInfo.CsqContext = FIELD_OFFSET(FxRequest, m_CsqContext);
128 _WdfRequestTriageInfo.ListEntryQueueOwned =
129 FIELD_OFFSET(FxRequest, m_OwnerListEntry);
130 _WdfRequestTriageInfo.ListEntryQueueOwned2 =
131 FIELD_OFFSET(FxRequest, m_OwnerListEntry2);
132 _WdfRequestTriageInfo.RequestListEntry =
133 FIELD_OFFSET(FxRequest, m_ListEntry);
134 _WdfRequestTriageInfo.FwdProgressList =
135 FIELD_OFFSET(FxRequest, m_ForwardProgressList);
136
137 // WdfDevice
138 _WdfDeviceTriageInfo.DeviceInitSize = sizeof(WDFDEVICE_INIT);
139 _WdfDeviceTriageInfo.DeviceDriver = FIELD_OFFSET(FxDevice, m_Driver);
140
141 // FxIrp
142 _WdfIrpTriageInfo.FxIrpSize = sizeof(FxIrp);
143 _WdfIrpTriageInfo.IrpPtr = FIELD_OFFSET(FxIrp, m_Irp);
144}
Definition: fxirp.hpp:28
_Must_inspect_result_ _In_ FLT_CONTEXT_TYPE _In_ SIZE_T ContextSize
Definition: fltkernel.h:1444
#define FX_IRP_QUEUE_CSQ_CONTEXT_ENTRY
Definition: fxirpqueue.hpp:47
static WDFIRPQUEUE_TRIAGE_INFO _WdfIrpQueueTriageInfo
static WDFCONTEXT_TRIAGE_INFO _WdfContextTriageInfo
static WDFDEVICE_TRIAGE_INFO _WdfDeviceTriageInfo
static WDFCONTEXTTYPE_TRIAGE_INFO _WdfContextTypeTriageInfo
static WDFREQUEST_TRIAGE_INFO _WdfRequestTriageInfo
static WDFOBJECT_TRIAGE_INFO _WdfObjectTriageInfo
static WDFFWDPROGRESS_TRIAGE_INFO _WdfFwdProgressTriageInfo
static WDFIRP_TRIAGE_INFO _WdfIrpTriageInfo
static WDFQUEUE_TRIAGE_INFO _WdfQueueTriageInfo
#define FIELD_OFFSET(t, f)
Definition: typedefs.h:255
_Must_inspect_result_ _In_ WDFCOLLECTION _In_ WDFOBJECT Object
struct _WDF_OBJECT_CONTEXT_TYPE_INFO WDF_OBJECT_CONTEXT_TYPE_INFO

Referenced by FxLibraryCommonCommission().

◆ IsClientInfoValid()

BOOLEAN IsClientInfoValid ( _In_ PCLIENT_INFO  ClientInfo)

Definition at line 147 of file fxlibrarycommon.cpp.

150{
151 if (ClientInfo == NULL ||
152 ClientInfo->Size != sizeof(CLIENT_INFO) ||
153 ClientInfo->RegistryPath == NULL ||
154 ClientInfo->RegistryPath->Length == 0 ||
155 ClientInfo->RegistryPath->Buffer == NULL) {
156 return FALSE;
157 }
158 return TRUE;
159}

Referenced by FxLibraryCommonRegisterClient(), and GetEnhancedVerifierOptions().

◆ LibraryLogEvent()

VOID LibraryLogEvent ( __in PDRIVER_OBJECT  DriverObject,
__in NTSTATUS  ErrorCode,
__in NTSTATUS  FinalStatus,
__in PWSTR  ErrorInsertionString,
__in_bcount(RawDataLen) PVOID  RawDataBuf,
__in USHORT  RawDataLen 
)

Definition at line 633 of file fxlibrarycommon.cpp.

662{
663 PIO_ERROR_LOG_PACKET errorLogEntry;
664 size_t errorLogEntrySize; // [including null]
665 size_t errorInsertionStringByteSize = 0;
666
667 if (ErrorInsertionString) {
668 errorInsertionStringByteSize = wcslen(ErrorInsertionString) * sizeof(WCHAR);
669 errorInsertionStringByteSize += sizeof(UNICODE_NULL);
670 }
671
672 errorLogEntrySize = sizeof(IO_ERROR_LOG_PACKET) + RawDataLen + errorInsertionStringByteSize;
673
674 //
675 // Log an error.
676 //
677 //
678 // prefast complains about comparison of constant with constant here
679 //
680#pragma prefast(suppress:__WARNING_CONST_CONST_COMP, "If ErrorInsertionString is not null then this is not a constant")
681 if (errorLogEntrySize <= ERROR_LOG_MAXIMUM_SIZE) {
682
684 (UCHAR)errorLogEntrySize);
685
686 if (errorLogEntry != NULL) {
687
688 RtlZeroMemory(errorLogEntry, errorLogEntrySize);
689
690 errorLogEntry->ErrorCode = ErrorCode;
691 errorLogEntry->FinalStatus = FinalStatus;
692 errorLogEntry->NumberOfStrings = (ErrorInsertionString) ? 1 : 0;
693 errorLogEntry->DumpDataSize = RawDataLen;
694 errorLogEntry->StringOffset = (FIELD_OFFSET(IO_ERROR_LOG_PACKET, DumpData)) + errorLogEntry->DumpDataSize;
695
696 //
697 // Insertion strings follow dumpdata and since there is no dumpdata we place the
698 // insertion string at the start offset of the dumpdata.
699 //
700 if (RawDataBuf) {
701 RtlCopyMemory(errorLogEntry->DumpData,
702 RawDataBuf,
703 RawDataLen);
704 }
705
706 if (ErrorInsertionString) {
707 RtlCopyMemory(((PCHAR)errorLogEntry->DumpData) + RawDataLen,
708 ErrorInsertionString,
709 errorInsertionStringByteSize);
710 }
711
712 IoWriteErrorLogEntry(errorLogEntry);
713 }
714 }
715
716 return;
717}
_CRTIMP size_t __cdecl wcslen(_In_z_ const wchar_t *_Str)
if(dx< 0)
Definition: linetemp.h:194
_In_ NDIS_ERROR_CODE ErrorCode
Definition: ndis.h:4436
#define UNICODE_NULL
VOID NTAPI IoWriteErrorLogEntry(IN PVOID ElEntry)
Definition: error.c:628
PVOID NTAPI IoAllocateErrorLogEntry(IN PVOID IoObject, IN UCHAR EntrySize)
Definition: error.c:528
NTSTATUS ErrorCode
Definition: iotypes.h:2007
USHORT NumberOfStrings
Definition: iotypes.h:2004
NTSTATUS FinalStatus
Definition: iotypes.h:2009
char * PCHAR
Definition: typedefs.h:51
_Must_inspect_result_ _In_ PDRIVER_OBJECT DriverObject
Definition: wdfdriver.h:213
#define ERROR_LOG_MAXIMUM_SIZE
Definition: iotypes.h:2042
struct _IO_ERROR_LOG_PACKET * PIO_ERROR_LOG_PACKET
struct _IO_ERROR_LOG_PACKET IO_ERROR_LOG_PACKET
unsigned char UCHAR
Definition: xmlstorage.h:181
__wchar_t WCHAR
Definition: xmlstorage.h:180

Referenced by ReportDdiFunctionCountMismatch(), and WDF_LIBRARY_REGISTER_CLIENT().

◆ ReportDdiFunctionCountMismatch()

VOID ReportDdiFunctionCountMismatch ( _In_ PCUNICODE_STRING  ServiceName,
_In_ ULONG  ActualFunctionCount,
_In_ ULONG  ExpectedFunctionCount 
)

Definition at line 162 of file fxlibrarycommon.cpp.

167{
168 WCHAR insertString[EVTLOG_DDI_COUNT_ERROR_MAX_LEN] = { 0 };
170
171 //
172 // NOTE: Any single call to DbgPrintEx will only transmit 512 bytes of
173 // information.
174 //
176 "\n\n************************* \n"
177 "* DDI function table mismatch detected in KMDF driver. The \n"
178 "* driver will not load until it is re-compiled using a \n"
179 "* newer version of the Windows Driver Kit (WDK). \n"
180 );
181
183 "* Service name : %wZ\n"
184 "* Actual function table count : %d \n"
185 "* Expected function table count: %d \n"
186 "*************************** \n\n",
188 ActualFunctionCount,
189 ExpectedFunctionCount
190 );
191
192 //
193 // Report a warning level ETW event to the system event log. "Wdf01000" is
194 // the listed event provider.
195 //
196 status = RtlStringCchPrintfW(insertString,
197 RTL_NUMBER_OF(insertString),
198 L"Service:%wZ Count:Actual %d Expected %d",
200 ActualFunctionCount,
201 ExpectedFunctionCount);
202 if (NT_SUCCESS(status)) {
204 WDFVER_CLIENT_INVALID_DDI_COUNT,
206 insertString,
207 NULL,
208 0);
209 }
210
211 //
212 // Report a telemetry event that can be used to proactively fix drivers
213 //
214 TraceLoggingWrite(g_TelemetryProvider,
215 "KmdfClientFunctionCountMismatch",
217 TraceLoggingUnicodeString(ServiceName, "ServiceName"),
218 TraceLoggingUInt32(ActualFunctionCount, "FunctionCount"),
219 TraceLoggingUInt32(ExpectedFunctionCount, "ExpectedCount"));
220}
#define RTL_NUMBER_OF(x)
Definition: RtlRegistry.c:12
#define DPFLTR_ERROR_LEVEL
Definition: main.cpp:32
static WCHAR ServiceName[]
Definition: browser.c:19
@ DPFLTR_DEFAULT_ID
Definition: dpfilter.h:129
#define WDF_TELEMETRY_EVT_KEYWORDS
#define DbgPrintEx(cmpid, lvl, fmt,...)
Definition: kdinit.c:24
VOID LibraryLogEvent(__in PDRIVER_OBJECT DriverObject, __in NTSTATUS ErrorCode, __in NTSTATUS FinalStatus, __in PWSTR ErrorInsertionString, __in_bcount(RawDataLen) PVOID RawDataBuf, __in USHORT RawDataLen)
#define EVTLOG_DDI_COUNT_ERROR_MAX_LEN
NTSTRSAFEVAPI RtlStringCchPrintfW(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
Definition: ntstrsafe.h:1110
PDRIVER_OBJECT DriverObject
Definition: fxglobals.h:719

Referenced by FxLibraryCommonRegisterClient().

Variable Documentation

◆ _WdfContextTriageInfo

WDFCONTEXT_TRIAGE_INFO _WdfContextTriageInfo = {0}
static

Definition at line 32 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfContextTypeTriageInfo

WDFCONTEXTTYPE_TRIAGE_INFO _WdfContextTypeTriageInfo = {0}
static

Definition at line 33 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfDeviceTriageInfo

WDFDEVICE_TRIAGE_INFO _WdfDeviceTriageInfo = {0}
static

Definition at line 37 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfFwdProgressTriageInfo

WDFFWDPROGRESS_TRIAGE_INFO _WdfFwdProgressTriageInfo = {0}
static

Definition at line 39 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfIrpQueueTriageInfo

WDFIRPQUEUE_TRIAGE_INFO _WdfIrpQueueTriageInfo = {0}
static

Definition at line 35 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfIrpTriageInfo

WDFIRP_TRIAGE_INFO _WdfIrpTriageInfo = {0}
static

Definition at line 38 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfObjectTriageInfo

WDFOBJECT_TRIAGE_INFO _WdfObjectTriageInfo = {0}
static

Definition at line 31 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfQueueTriageInfo

WDFQUEUE_TRIAGE_INFO _WdfQueueTriageInfo = {0}
static

Definition at line 34 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ _WdfRequestTriageInfo

WDFREQUEST_TRIAGE_INFO _WdfRequestTriageInfo = {0}
static

Definition at line 36 of file fxlibrarycommon.cpp.

Referenced by GetTriageInfo().

◆ g_WdfTriageInfo

WDF_TRIAGE_INFO g_WdfTriageInfo

Definition at line 41 of file fxlibrarycommon.cpp.