Partilhar via


IOCTL_HID_SET_OUTPUT_REPORT IOCTL (hidclass.h)

A solicitação IOCTL_HID_SET_OUTPUT_REPORT envia um relatório de saída para uma coleção de nível superior.

Para obter informações gerais sobre dispositivos HIDClass, consulte Coleções HID.

Código principal

IRP_MJ_DEVICE_CONTROL

Buffer de entrada

O Parameters.DeviceIoControl.InputBufferLength membro é definido como o tamanho, em bytes, de um buffer de entrada alocado pelo solicitante que contém um relatório de saída de classe HID.

O tamanho do buffer de entrada em bytes. O buffer deve ser grande o suficiente para manter o relatório de saída mais um byte adicional que especifica uma ID de relatório diferente de zero. Se a ID do relatório não for usada, o valor da ID será zero.

O Irp->AssociatedIrp.SystemBuffer membro aponta para o buffer de entrada que contém um relatório de saída. Se a coleção incluir IDs de relatório, o solicitante deverá definir o primeiro byte do buffer como uma ID de relatório diferente de zero. Caso contrário, o solicitante deve definir o primeiro byte como zero. O relatório de saída está localizado em ((PUCHAR)ReportBuffer + 1).

Manipulação de minidriver

Irp->UserBuffer aponta para uma estrutura HID_XFER_PACKET que o driver de classe HID usa para inserir os seguintes membros:

Comprimento do buffer de entrada

O tamanho do buffer de entrada em bytes. O buffer deve ser grande o suficiente para manter o relatório de saída mais um byte adicional que especifica uma ID de relatório diferente de zero. Se a ID do relatório não for usada, o valor da ID será zero.

Manipulação de minidriver

O tamanho de uma estrutura HID_XFER_PACKET .

Buffer de saída

Nenhum.

Comprimento do buffer de saída

Nenhum.

Bloco de status

O driver de classe HID define os seguintes campos de Irp->IoStatus:

  • As informações são definidas como zero.
  • O status será definido como STATUS_SUCCESS se a transferência for concluída sem erros. Caso contrário, ele será definido como um código de erro NTSTATUS apropriado.

Manipulação de minidriver

Os minidrivers HID que executam a E/S para o dispositivo definem os seguintes campos de Irp->IoStatus:

  • As informações são definidas como o número de bytes transferidos para o dispositivo.
  • O status será definido como STATUS_SUCCESS se a transferência for concluída sem erros. Caso contrário, ele será definido como um código de erro NTSTATUS apropriado.

Os minidrivers HID que chamam outros drivers com esse IOCTL para realizar a E/S devem garantir que o campo Informações do bloco status esteja correto e não altere o conteúdo do campo Status.

Requisitos

Requisito Valor
Cabeçalho hidclass.h (inclua Hidclass.h)

Confira também