IrqlNtifsApcPassive 规则 (wdm)
IrqlNtifsApcPassive 规则指定驱动程序仅在 IRQL = PASSIVE_LEVEL 或 IRQL <= APC_LEVEL 执行时调用规则中列出的 DDI。
驱动程序模型:WDM
使用此规则找到的 Bug 检查 () :Bug 检查0xC4:DRIVER_VERIFIER_DETECTED_VIOLATION (0x20024)
示例
以下代码违反了此规则:
//
// KeAcquireSpinLock raises the IRQL to DISPATCH_LEVEL.
//
KeAcquireSpinLock (&Lock, &OldIrql);
//
// ERROR: ZwWriteFile can only be called at IRQL == PASSIVE_LEVEL.
//
ZwWriteFile (Handle,
NULL,
NULL,
NULL,
IoStatusBlock,
Buffer,
BufferLength,
NULL,
NULL);
KeReleaseSpinLock (&Lock, OldIrql);
有关 IRQL 级别的详细信息,请参阅 调度例程和 IRQL和管理硬件优先级。
如何测试
编译时 |
---|
运行 静态驱动程序验证程序 并指定 IrqlNtifsApcPassive 规则。 使用以下步骤运行代码分析:有关详细信息,请参阅 使用静态驱动程序验证程序查找驱动程序中的缺陷。 |
运行时 |
---|
可以使用 Verifier.exe 命令行激活一个或多个驱动程序的 DDI 符合性 - 其他 IRQL 规则。 有关详细信息,请参阅 选择驱动程序验证程序选项。 必须重新启动计算机才能激活或停用 DDI 符合性 - 其他 IRQL 规则。 在命令行中,DDI 符合性 - 附加 IRQL 检查由规则类值 35 表示。 例如:
OR
重启电脑后,其他 IRQL 检查将处于活动状态。 |
适用于
NtSetInformationFile
NtWriteFile
NtCreateFile
ZwWriteFile
CcCopyWrite
CcCopyWriteEx
CcDeferWrite
CcFastCopyWrite