MdlAfterReqCompletedIntIoctlA-Regel (kmdf)

Die MdlAfterReqCompletedIntIoctlA-Regel gibt an, dass innerhalb der Rückruffunktion EvtIoInternalDeviceControl nicht auf die Speicherbeschreibungsliste (Memory Descriptor List, MDL) zugegriffen werden kann, nachdem die E/A-Anforderung abgeschlossen wurde.

Innerhalb der EvtIoInternalDeviceControl-Rückruffunktion des Treibers kann nicht auf die MDL zugegriffen werden, die durch Aufrufen der WdfRequestRetrieveInputWdmMdl- oder WdfRequestRetrieveOutputWdmdl-Methode abgerufen wurde, nachdem WdfRequestCompleteCompleteWithInformation oder WdfRequestCompleteWithPriorityBoost für die E/A-Anforderung aufgerufen wurde.

Diese Regel berücksichtigt die folgenden MDL-Zugriffsfunktionen:

WDF_MEMORY_DESCRIPTOR_INIT_MDLMmGetMdlByteCountMmGetSystemAddressForMdlSafeMmGetMdlVirtualAddressIoBuildPartialMdl (erster und zweiter Parameter) KeFlushIoBuffersMmGetMdlPfnArrayMmGetMdlByteOffsetMmPrepareMdlForReuseWdfDmaTransactionInitialize

Treibermodell: KMDF

So führen Sie einen Test durch

Beim Kompilieren:

Führen Sie Static Driver Verifier aus, und geben Sie die MdlAfterReqCompletedIntIoctlA-Regel an.

Gehen Sie folgendermaßen vor, um Ihren Code zu analysieren:
  1. Bereiten Sie den Code vor (verwenden Sie Rollentypdeklarationen).
  2. Führen Sie Static Driver Verifier aus.
  3. Überprüfen und analysieren Sie die Ergebnisse.

Weitere Informationen finden Sie unter Verwenden der statischen Treiberüberprüfung, um Fehler in Treibern zu finden.

Gilt für:

WDF_MEMORY_DESCRIPTOR_INIT_MDLWdfDmaTransactionInitializeWdfRequestCompleteWdfRequestCompleteWithInformationWdfRequestCompleteWithPriorityBoostWdfRequestRetrieveInputWdmMdlWdfRequestRetrievedfRequestRetrieveOutputWdmMdlIoBuildPartialMdlKeFlushIoBuffersMmGetMdlByteCountMmGetMdlByteOffsetMmGetMdlPfnArrayMmGetMdlVirtualAddressMmGetSystemAddressForMdlSafeMmPrepareMdlForReuse