EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION Rückruffunktion (sercx.h)
Die EvtSerCx2SystemDmaTransmitCleanupTransaction Ereignisrückruffunktion wird von Version 2 der seriellen Framework-Erweiterung (SerCx2) aufgerufen, um den seriellen Controllerzustand zu bereinigen, nachdem eine Transaktion mit system-DMA-transmission beendet wurde.
Syntax
EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION EvtSercx2SystemDmaTransmitCleanupTransaction;
void EvtSercx2SystemDmaTransmitCleanupTransaction(
[in] SERCX2SYSTEMDMATRANSMIT SystemDmaTransmit
)
{...}
Parameter
[in] SystemDmaTransmit
Ein SERCX2SYSTEMDMATRANSMIT Handle zu einem System-DMA-Transmissionsobjekt. Der serielle Controllertreiber hat zuvor den SerCx2SystemDmaTransmitCreate Methode aufgerufen, um dieses Objekt zu erstellen.
Rückgabewert
Nichts
Bemerkungen
Ihr serieller Controllertreiber kann diese Funktion als Option implementieren. Falls implementiert, registriert der Treiber die Funktion im SerCx2SystemDmaTransmitCreate Aufruf, der das System-DMA-übertragungsobjekt erstellt.
Ihr serieller Controllertreiber sollte einen EvtSerCx2SystemDmaTransmitCleanupTransaction Funktion implementieren, wenn der serielle Controllerzustand am Ende einer System-DMA-Übertragungstransaktion bereinigt werden muss. SerCx2 ruft diese Funktion auf, wenn sie implementiert ist, nachdem eine System-DMA-Übertragungstransaktion beendet wurde. Als Reaktion auf den EvtSerCx2SystemDmaTransmitCleanupTransaction Aufruf muss der serielle Controllertreiber die SerCx2SystemDmaTransmitCleanupTransactionComplete Methode aufrufen, um SerCx2 nach Abschluss der Bereinigung zu benachrichtigen.
Weitere Informationen finden Sie unter SerCx2 System-DMA-Transmit Transactions.
Beispiele
Um eine EvtSerCx2SystemDmaTransmitCleanupTransaction Rückruffunktion zu definieren, müssen Sie zuerst eine Funktionsdeklaration bereitstellen, die den Typ der rückruffunktion identifiziert, die Sie definieren. Windows stellt eine Reihe von Rückruffunktionstypen für Treiber bereit. Durch das Deklarieren einer Funktion mithilfe der Rückruffunktionstypen können Codeanalyse für Treiber, statische Treiberüberprüfung (SDV) und andere Überprüfungstools Fehler finden, und es ist eine Anforderung zum Schreiben von Treibern für das Windows-Betriebssystem.
Um beispielsweise eine EvtSerCx2SystemDmaTransmitCleanupTransactiontransaction Rückruffunktion zu definieren, die MySystemDmaTransmitCleanupTransaction
benannt ist, verwenden Sie den funktionstyp EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION, wie in diesem Codebeispiel gezeigt:
EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION MySystemDmaTransmitCleanupTransaction;
Implementieren Sie dann die Rückruffunktion wie folgt:
_Use_decl_annotations_
VOID
MySystemDmaTransmitCleanupTransaction(
SERCX2SYSTEMDMATRANSMIT SystemDmaTransmit
)
{...}
Der EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION Funktionstyp wird in der Headerdatei Sercx.h definiert. Um Fehler genauer zu identifizieren, wenn Sie die Codeanalysetools ausführen, müssen Sie der Funktionsdefinition die Use_decl_annotations Anmerkung hinzufügen. Die Use_decl_annotations Anmerkung stellt sicher, dass die Anmerkungen, die auf den funktionstyp EVT_SERCX2_SYSTEM_DMA_TRANSMIT_CLEANUP_TRANSACTION in der Headerdatei angewendet werden, verwendet werden. Weitere Informationen zu den Anforderungen für Funktionsdeklarationen finden Sie unter Deklarieren von Funktionen mithilfe von Funktionsrollentypen für KMDF-Treiber. Weitere Informationen zu Use_decl_annotationsfinden Sie unter Annotating Function Behavior.
Anforderungen
Anforderung | Wert |
---|---|
mindestens unterstützte Client- | Verfügbar ab Windows 8.1. |
Zielplattform- | Desktop |
Header- | sercx.h |
IRQL- | Wird bei IRQL <= DISPATCH_LEVEL aufgerufen. |