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)

Consulte también

WdfIoQueuePurge