Método IQueueCallbackRead::OnRead (wudfddi.h)

[Aviso: UMDF 2 é a versão mais recente do UMDF e substitui UMDF 1. Todos os novos drivers UMDF devem ser gravados usando UMDF 2. Nenhum novo recurso está sendo adicionado ao UMDF 1 e há suporte limitado para UMDF 1 em versões mais recentes do Windows 10. Drivers universais do Windows devem usar UMDF 2. Para obter mais informações, consulte Introdução com UMDF.]

O método OnRead é chamado para manipular uma solicitação de leitura quando um aplicativo lê informações de um dispositivo por meio da função ReadFile ou ReadFileEx do Microsoft Win32.

Sintaxe

void OnRead(
  [in] IWDFIoQueue   *pWdfQueue,
  [in] IWDFIoRequest *pWdfRequest,
  [in] SIZE_T        NumOfBytesToRead
);

Parâmetros

[in] pWdfQueue

Um ponteiro para a interface IWDFIoQueue para o objeto de fila de E/S do qual a solicitação chega.

[in] pWdfRequest

Um ponteiro para a interface IWDFIoRequest que representa o objeto de solicitação de estrutura.

[in] NumOfBytesToRead

O tamanho, em bytes, do buffer de leitura para a solicitação.

Retornar valor

Nenhum

Comentários

Um driver registra a interface IQueueCallbackRead quando o driver chama o método IWDFDevice::CreateIoQueue para criar uma fila de E/S ou para configurar a fila de E/S padrão.

Um driver pode implementar um único método OnRead para todas as filas de E/S ou métodos OnRead separados para cada fila de E/S.

O método OnRead recebe cada tipo de solicitação de leitura da fila. (O tipo de solicitação de leitura é identificado pelo valor WdfRequestRead do tipo de enumeração WDF_REQUEST_TYPE para a solicitação.) O método OnRead deve processar cada solicitação de leitura recebida. Para obter mais informações sobre como os drivers UMDF processam solicitações de E/S, consulte Processando solicitações de E/S.

O driver pode chamar os métodos IWDFIoRequest::GetReadParameters e IWDFIoRequest::GetOutputMemory para recuperar informações sobre a solicitação e o buffer de leitura.

Requisitos

Requisito Valor
Plataforma de Destino Windows
Cabeçalho wudfddi.h (include Wudfddi.h)

Confira também

IQueueCallbackRead

IWDFDevice::CreateIoQueue

IWDFIoQueue

IWDFIoRequest

WDF_REQUEST_TYPE