Поделиться через


Ошибки времени ожидания отладки NDIS/Wi-Fi — DRIVER_VERIFIER_DETECTED_VIOLATION (C4)

Если выбран параметр проверки NDIS/WIFI и средство проверки драйверов обнаруживает, что драйвер нарушает одно из правил времени ожидания NDIS/WiFi, средство проверки драйверов создает проверку ошибок 0xC4: DRIVER_VERIFIER_DETECTED_VIOLATION (с параметром 1, равным идентификатору конкретного правила времени ожидания NDIS/WiFi).

Когда средство проверки драйверов тестирует правило времени ожидания NDIS/WIFI, например NdisTimedOidComplete, механизм опроса проверяющего водителя ожидает ответ от водителя минипорта в течение нескольких циклов. Каждое правило с заданным временем определяет собственный максимальный допустимый цикл. При превышении максимального значения средство проверки драйверов создает ошибку проверка. В этом разделе описаны некоторые примеры стратегий отладки этих нарушений.

Отладка ошибок времени ожидания NDIS/WIFI

Используйте !analyze для отображения сведений об ошибке проверка

Как и в случае с любой проверка ошибок, после управления отладчиком лучше всего выполнить команду !analyze -v.

DRIVER_VERIFIER_DETECTED_VIOLATION (c4)
A device driver attempting to corrupt the system has been caught.  This is
because the driver was specified in the registry as being suspect (by the
administrator) and the kernel has enabled substantial checking of this driver.
If the driver attempts to corrupt the system, bugchecks 0xC4, 0xC1 and 0xA will
be among the most commonly seen crashes.
Arguments:
Arg1: 00092003, ID of the 'NdisTimedOidComplete' rule that was violated.
Arg2: 8521dd34, A pointer to the string describing the violated rule condition.
Arg3: 9c17b860, Address of internal rule state (second argument to !ruleinfo).
Arg4: 9c1f3480, Address of supplemental states (third argument to !ruleinfo).

В следующем разделе выходных данных !analyze -v в поле DV_VIOLATED_CONDITION отображается причина, по которой правило было нарушено в . В разделе DV_MSDN_LINK также можно найти ссылку на документацию по этому правилу.

Сведения об отладке:


*** ERROR: Module load completed but symbols could not be loaded for NdisTimedOidComplete.sys

DV_VIOLATED_CONDITION:  Timeout on completing an NDIS OID request.

DV_MSDN_LINK: https://learn.microsoft.com/windows-hardware/drivers/devtest/ndis-ndistimedoidcomplete

DRIVER_OBJECT: 98a87980

IMAGE_NAME:  NdisTimedOidComplete.sys

DEBUG_FLR_IMAGE_TIMESTAMP:  5229c857

MODULE_NAME: NdisTimedOidComplete

FAULTING_MODULE: 9fee1000 NdisTimedOidComplete

Далее вы можете щелкнуть ссылку в разделе DV_RULE_INFO для получения дополнительных описаний правил. Для правил типа тайм-аута текущий стек может не содержать релевантных сведений.

DV_RULE_INFO: 0x92003

BUGCHECK_STR:  0xc4_NdisTimedOidComplete_XDV

DEFAULT_BUCKET_ID:  WIN8_DRIVER_FAULT

PROCESS_NAME:  System

CURRENT_IRQL:  2

ANALYSIS_VERSION: 6.13.0016.1929 (debuggers(dbg).130725-1857) amd64fre

LAST_CONTROL_TRANSFER:  from 80f87fd3 to 80f0ed14

STACK_TEXT:  
8912380c 80f87fd3 00000003 e6c3476e 00000065 nt!RtlpBreakWithStatusInstruction
89123860 80f87aed 825a6138 89123c5c 89123cac nt!KiBugCheckDebugBreak+0x1f
89123c30 80f0d8d6 000000c4 00092003 8521dd34 nt!KeBugCheck2+0x676
89123c54 80f0d80d 000000c4 00092003 8521dd34 nt!KiBugCheck2+0xc6
89123c74 85211584 000000c4 00092003 8521dd34 nt!KeBugCheckEx+0x19
89123cac 85216d54 9c17b860 9c1f3480 9c17b8dc VerifierExt!SLIC_StatefulAbort+0x1a4
89123cd0 85216ffe 85220000 85215f5b 00000000 VerifierExt!Ndis_OnTimerExpire+0x234
89123cd8 85215f5b 00000000 80ecd56a 843d0c38 VerifierExt!CheckOnTimerExpire+0x26
89123ce0 80ecd56a 843d0c38 00000000 80ecd502 VerifierExt!XdvPassiveTimerRoutine+0x1d
89123d24 80eec133 882befd0 00000000 887debc0 nt!IopProcessWorkItem+0x68
89123d70 80ec1162 00000000 e6c342be 00000000 nt!ExpWorkerThread+0x14f
89123db0 80f23201 80eebfe4 00000000 00000000 nt!PspSystemThreadStartup+0x58
89123dbc 00000000 00000000 00000000 00000000 nt!KiThreadStartup+0x15

Использование команды расширения !ruleinfo

В поле DV_RULE_INFO: выходных данных !analyze отображается ссылка на команду, с помощью которой можно найти дополнительные сведения о нарушении этого правила. В этом примере при переходе по ссылке выполняется команда !ruleinfo с RULE_ID (0x92003) проверка проверка ошибок Arg3 и Arg 4.

kd> !ruleinfo 0x92003 0xffffffff9c17b860 0xffffffff9c1f3480

RULE_ID: 0x92003

RULE_NAME: NdisTimedOidComplete

RULE_DESCRIPTION:
This rule verifies if an NDIS miniport driver completes an OID in time.
The OID is tracked (a.k.a., TRACKED_OBJECT). Use !ndiskd.oid .

MSDN_LINK: https://learn.microsoft.com/windows-hardware/drivers/devtest/ndis-ndistimedoidcomplete

CONTEXT: Miniport 0x86BD10E8

CURRENT_TIME (Timed Rules): 168 seconds

TRACKED_OBJECT: 0x86633804

LAST_CALL_STACK: 0x9C1F3480 + 0x10

RULE_STATE: 0x9C1F3480

Определение расположения нарушения

В примере, который мы используем здесь, драйвер мини-порта, NdisTimedOidComplete.sys, имеет цикл спящего режима, внедренный в функцию MPOidRequest . Мы можем проверка, щелкнув ссылку LAST_CALL_STACK в выходных данных !ruleinfo. Это последний стек вызовов, который видел средство проверки драйверов, где мы видим, что NDIS называется ndisMInvokeOidRequest до истечения времени ожидания.

kd> dps 0x9C1F3480 + 0x10
9c1f3490  850e1e37 ndis!ndisMInvokeOidRequest+0x16641
9c1f3494  850765c8 ndis!ndisMDoOidRequest+0x24a
9c1f3498  8507552a ndis!ndisQueueOidRequest+0x2fa
9c1f349c  8507372b ndis!ndisQuerySetMiniportEx+0xd9
9c1f34a0  85073646 ndis!ndisQuerySetMiniport+0x18
9c1f34a4  850dd9c8 ndis!ndisMDoMiniportOp+0x8c
9c1f34a8  850dd916 ndis!ndisMNotifyMachineName+0xe4
9c1f34ac  85104005 ndis!ndisMInitializeAdapter+0xad7

Устранение причины нарушения времени ожидания NDIS WIFI

При создании аварийного дампа для правила, заданного по времени, существует вероятность того, что первопричину можно найти во время создания аварийного дампа. Чтобы выполнить дальнейшую отладку, попробуйте начать с команд расширения отладчика NdisKd, см. статьи Расширения NDIS (Ndiskd.dll) и Начало работы с NDISKD. Кроме того, может потребоваться просмотреть журналы трассировки событий Windows (ETW), если драйвер реализовал трассировку событий Windows. Если это правило не было включено, эта ошибка проявит себя как зависание пользовательского приложения в лучшем случае или 0x9F проверки ошибок: DRIVER_POWER_STATE_FAILURE в худшем случае.

Расширения NDIS (Ndiskd.dll)

Начало работы с NDISKD (часть 1)

NDISKD и !miniport (часть 2)

Отладка с помощью NDISKD (часть 3)