Función WdfIoQueuePurgeSynchronously (wdfio.h)
[Se aplica a KMDF y UMDF]
El método WdfIoQueuePurgeSynchronously hace que el marco detenga las solicitudes de E/S en cola a una cola de E/S y cancele las solicitudes no procesadas y las solicitudes cancelables propiedad del controlador.
Sintaxis
void WdfIoQueuePurgeSynchronously(
[in] WDFQUEUE Queue
);
Parámetros
[in] Queue
Identificador de un objeto de cola de marco.
Valor devuelto
None
Observaciones
Se produce una comprobación de errores si el controlador proporciona un identificador de objeto no válido.
Después de que un controlador llame a WdfIoQueuePurgeSynchronously, el marco deja de agregar solicitudes de E/S a la cola especificada. El marco cancela todas las solicitudes que no se han entregado al controlador. Si el marco recibe solicitudes adicionales para la cola, las completa con un valor de estado de finalización de STATUS_INVALID_DEVICE_STATE.
WdfIoQueuePurgeSynchronously devuelve una vez completadas o canceladas todas las solicitudes no procesadas y propiedad del controlador.
Una vez que un controlador ha purgado una cola de E/S, puede reiniciar la cola llamando a WdfIoQueueStart.
No llame a WdfIoQueuePurgeSynchronously desde las siguientes funciones de devolución de llamada de eventos de objeto de cola, independientemente de la cola con la que está asociada la función de devolución de llamada de evento:
EvtIoDefaultEvtIoDeviceControlEvtIoInternalDeviceControlEvtIoReadEvtIoWrite Para obtener más información sobre el método WdfIoQueuePurgeSynchronously , vea Administración de colas de E/S.
Ejemplos
En el ejemplo de código siguiente se purga una cola de E/S especificada.
WdfIoQueuePurgeSynchronously(ReadQueue);
Requisitos
Requisito | Value |
---|---|
Plataforma de destino | Universal |
Versión mínima de KMDF | 1.0 |
Versión mínima de UMDF | 2.0 |
Encabezado | wdfio.h (incluya Wdf.h) |
Library | Wdf01000.sys (KMDF); WUDFx02000.dll (UMDF) |
IRQL | PASSIVE_LEVEL |
Reglas de cumplimiento de DDI | ChangeQueueState(kmdf), DriverCreate(kmdf), EvtSurpriseRemoveNoSuspendQueue(kmdf), KmdfIrql(kmdf), KmdfIrql2(kmdf), KmdfIrqlExplicit(kmdf), NoCancelFromEvtSurpriseRemove(kmdf), NoIoQueuePurgeSynchronously(kmdf) |