Compartilhar via


Método IUsbTargetPipeContinuousReaderCallbackReadersFailed::OnReaderFailure (wudfusb.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.]

A função de retorno de chamada de evento OnReaderFailure de um driver informa ao driver que um leitor contínuo relatou um erro ao processar uma solicitação de leitura.

Sintaxe

BOOL OnReaderFailure(
  [in] IWDFUsbTargetPipe *pPipe,
  [in] HRESULT           hrStatus
);

Parâmetros

[in] pPipe

Um ponteiro para a interface IWDFUsbTargetPipe para o pipe USB no qual o driver habilitou um leitor contínuo.

[in] hrStatus

O hresult digitado status valor retornado pelo destino de E/S do pipe USB.

Retornar valor

A função de retorno de chamada de evento OnReaderFailure deve retornar um valor booliano. Se o valor retornado for TRUE, a estrutura redefinirá o pipe USB e reiniciará o leitor contínuo. Se a função de retorno de chamada retornar FALSE, a estrutura não redefinirá o dispositivo nem reiniciará o leitor contínuo.

Comentários

Para registrar uma função de retorno de chamada OnReaderFailure , o driver deve fornecer um ponteiro para a interface IUsbTargetPipeContinuousReaderCallbackReadersFailed do driver ao chamar IWDFUsbTargetPipe2::ConfigureContinuousReader.

Se um driver tiver criado um leitor contínuo para um pipe USB, a estrutura chamará a função de retorno de chamada OnReaderFailure do driver se o destino de E/S do driver relatar um erro quando concluir uma solicitação de leitura. (Se o destino de E/S concluir com êxito a solicitação, a estrutura chamará a função de retorno de chamada IUsbTargetPipeContinuousReaderCallbackReadComplete::OnReaderCompletion do driver.)

Antes que a estrutura chame a função de retorno de chamada OnReaderFailure de um driver, ela tenta cancelar todas as solicitações de leitura em andamento. Nenhuma solicitação de leitura está em andamento quando a estrutura chama a função de retorno de chamada OnReaderFailure . A estrutura não enfileira nenhuma solicitação de leitura adicional até que a função de retorno de chamada OnReaderFailure retorne.

Para obter informações sobre como a estrutura sincroniza chamadas para a função de retorno de chamada OnReaderFailure com chamadas para outras funções de retorno de chamada, consulte a seção Comentários de IUsbTargetPipeContinuousReaderCallbackReadComplete::OnReaderCompletion.

A função de retorno de chamada OnReaderFailure não deve chamar IWDFIoTargetStateManagement::Stop para interromper o destino USB do leitor contínuo. (Na verdade, chamar IWDFIoTargetStateManagement::Stop em uma função de retorno de chamada OnReaderFailure causa um deadlock.) Além disso, a função de retorno de chamada não deve chamar IWDFIoTargetStateManagement::Start para reiniciar o leitor contínuo. Em vez disso, a estrutura reiniciará o leitor se a função de retorno de chamada retornar TRUE. Para obter mais informações sobre quando chamar IWDFIoTargetStateManagement::Start e IWDFIoTargetStateManagement::Stop para um leitor contínuo, consulte Trabalhando com pipes USB no UMDF.

Se um driver não fornecer uma função de retorno de chamada OnReaderFailure e o destino de E/S do driver relatar um erro, a estrutura redefinirá o pipe USB e reiniciará o leitor contínuo.

Para obter mais informações sobre a função de retorno de chamada OnReaderFailure e destinos de E/S USB, consulte Manipulando um destino de E/S USB.

Requisitos

Requisito Valor
Fim do suporte Indisponível no UMDF 2.0 e posterior.
Plataforma de Destino Área de Trabalho
Versão mínima do UMDF 1,9
Cabeçalho wudfusb.h (include Wudfusb.h)

Confira também

IUsbTargetPipeContinuousReaderCallbackReadComplete::OnReaderCompletion

IUsbTargetPipeContinuousReaderCallbackReadersFailed