MdlAfterReqCompletedIntIoctlA 规则 (kmdf)

MdlAfterReqCompletedIntIoctlA 规则指定在 EvtIoInternalDeviceControl 回调函数内,I/O 请求完成后无法访问内存描述符列表 (MDL) 。

在驱动程序的 EvtIoInternalDeviceControl 回调函数中, 在 I/O 请求上调用 WdfRequestComplete、WdfRequestCompleteWithInformationWdfRequestCompleteWithInformation 或 WdfRequestCompleteWithPriorityBoost 后,无法访问通过调用 WdfRequestRetrieveInputWdmMdl 或 WdfRequestRetrieveOutputWdmMdl 方法检索到的 MDL

此规则考虑以下 MDL 访问函数:

WDF_MEMORY_DESCRIPTOR_INIT_MDLMmGetMdlByteCountMmGetSystemAddressForMdlSafeMmGetMdlVirtualAddressIoBuildPartialMdl () keFlushIoBuffersmmGetMdlPfnArrayMmGetMdlByteOffsetMmPrepareMdlForReuseWdfDmaTransactionInitialize

驱动程序模型:KMDF

如何测试

编译时

运行 静态驱动程序验证程序 并指定 MdlAfterReqCompletedIntIoctlA 规则。

使用以下步骤运行代码分析:
  1. 准备代码 (使用角色类型声明) 。
  2. 运行静态驱动程序验证程序。
  3. 查看和分析结果。

有关详细信息,请参阅 使用静态驱动程序验证程序查找驱动程序中的缺陷

适用于

WDF_MEMORY_DESCRIPTOR_INIT_MDLWdfDmaTransactionInitializeWdfRequestCompleteWdfRequestCompleteWithInformationWdfRequestCompleteWithPriorityBoostWdfRequestRetrieveInputWdmMdlWdfRequestRetrieveOutputWdmMdlIoBuildPartialMdlkeFlushIoBuffersmmGetMdlByteCountmmGetMdlByteOffsetMmGetMdlPfnArrayMmGetMdlVirtualAddressMmGetSystemAddressForMdlSafeMmPrepareMdlForReuse