Método IWDFUsbInterface::GetNumEndPoints (wudfusb.h)
[Aviso: UMDF 2 é a versão mais recente do UMDF e substitui o UMDF 1. Todos os novos drivers UMDF devem ser gravados usando UMDF 2. Nenhum recurso novo está sendo adicionado ao UMDF 1 e há suporte limitado para UMDF 1 em versões mais recentes do Windows 10. Os drivers universais do Windows devem usar o UMDF 2. Para obter mais informações, consulte Introdução aoda UMDF .]
O método GetNumEndPoints recupera o número de pontos de extremidade (pipes) em uma interface USB.
Sintaxe
UCHAR GetNumEndPoints();
Valor de retorno
GetNumEndPoints retorna o número de pontos de extremidade na interface USB.
Observações
O método GetNumEndPoints é fornecido para conveniência porque um driver UMDF pode obter o número de pontos de extremidade do bNumEndpoints membro da estrutura de USB_INTERFACE_DESCRIPTOR que o driver recupera quando chama o método IWDFUsbInterface::GetInterfaceDescriptor.
Exemplos
O exemplo de código a seguir recupera o número de pipes em uma interface USB e recupera tipos específicos de pipes.
HRESULT hr;
UCHAR NumEndPoints;
NumEndPoints = pIUsbInterface->GetNumEndPoints();
if (NumEndPoints != NUM_OSRUSB_ENDPOINTS) {
hr = E_UNEXPECTED;
}
if (SUCCEEDED(hr)) {
for (UCHAR PipeIndex = 0; PipeIndex < NumEndPoints; PipeIndex++) {
hr = pIUsbInterface->RetrieveUsbPipeObject(PipeIndex,
&pIUsbPipe);
if (FAILED(hr)) {
// Output an error.
}
else {
if ( pIUsbPipe->IsInEndPoint() && (UsbdPipeTypeBulk == pIUsbPipe->GetType()) ) {
pIUsbInputPipe = pIUsbPipe;
}
else if ( pIUsbPipe->IsOutEndPoint() && (UsbdPipeTypeBulk == pIUsbPipe->GetType()) )
{
pIUsbOutputPipe = pIUsbPipe;
}
else
{
SAFE_RELEASE(pIUsbPipe);
}
}
Requisitos
Requisito | Valor |
---|---|
fim do suporte | Indisponível no UMDF 2.0 e posterior. |
da Plataforma de Destino | Área de trabalho |
versão mínima do UMDF | 1.5 |
cabeçalho | wudfusb.h (inclua Wudfusb.h) |
de DLL | WUDFx.dll |