SerCxProgressReceive-Funktion (sercx.h)
Die SerCxProgressReceive Methode meldet den Fortschritt des aktuellen Lesevorgangs (Empfangsvorgang).
NTSTATUS SerCxProgressReceive(
[in] WDFDEVICE Device,
[in] ULONG BytesReceived,
[in] SERCX_STATUS ReceiveStatus
);
[in] Device
Ein WDFDEVICE-Handle für das Framework-Geräteobjekt, das den seriellen Controller darstellt.
[in] BytesReceived
Die Anzahl der Daten, die der Aufrufer in den Empfangspuffer geladen hat, der vom letzten Aufruf der SerCxRetrieveReceiveBuffer-Methode abgerufen wurde.
[in] ReceiveStatus
Der aktuelle Status des Empfangsvorgangs. Legen Sie diesen Parameter auf einen der folgenden Werte fest:
- SerCxStatusSuccess
- SerCxStatusCancelled
- SerCxStatusTimeout-
SerCxProgressReceive gibt bei erfolgreicher Ausführung STATUS_SUCCESS zurück. Mögliche Fehlerrückgabewerte sind die folgenden Statuscodes.
Rückgabecode | Beschreibung |
---|---|
|
Der BytesReceived Wert überschreitet die verfügbare Pufferlänge; oder der ReceiveStatus- Wert ist ungültig. |
|
Die Methode wurde beim falschen IRQL aufgerufen; oder der WDFDEVICE-Handle ist ungültig; oder der Treiber hat keinen Eingabepuffer für diesen Empfangsvorgang erhalten. |
|
Der Empfangsvorgang wurde bereits abgebrochen. |
Der serielle Controllertreiber ruft diese Methode auf, um den Fortschritt eines ausstehenden Lesevorgangs zu melden. In der Regel ruft der serielle Controllertreiber diese Methode aus dem DMA-Abschlussrückruf auf (wenn der Treiber DMA zum Lesen der Daten verwendet) oder von der Übertragungs-/Empfangs-DPC-Funktion (wenn PIO verwendet wird).
Wenn die SerCxProgressReceive nicht alle ausstehenden Arbeiten für den Lesevorgang abgeschlossen hat, muss der Aufrufer die SerCxRetrieveReceiveBuffer Methode erneut aufrufen, um einen neuen Pufferdeskriptor abzurufen und weiterhin Daten zu empfangen.
Anforderung | Wert |
---|---|
mindestens unterstützte Client- | Verfügbar ab Windows 8. |
Zielplattform- | Universal |
Header- | sercx.h |
IRQL- | <= DISPATCH_LEVEL |