EVT_UCX_USBDEVICE_ENDPOINTS_CONFIGURE funzione di callback (ucxusbdevice.h)

Implementazione del driver client che UCX chiama per configurare gli endpoint nel controller.

Sintassi

EVT_UCX_USBDEVICE_ENDPOINTS_CONFIGURE EvtUcxUsbdeviceEndpointsConfigure;

void EvtUcxUsbdeviceEndpointsConfigure(
  [in] UCXCONTROLLER UcxController,
  [in] WDFREQUEST Request
)
{...}

Parametri

[in] UcxController

Handle al controller UCX ricevuto dal driver client in una chiamata precedente al metodo UcxControllerCreate .

[in] Request

Contiene una struttura di tipo ENDPOINTS_CONFIGURE struttura.

Valore restituito

nessuno

Osservazioni

Il driver client UCX registra questa funzione di callback con l'estensione del controller host USB (UCX) chiamando il metodo UcxUsbDeviceCreate .

Nel callback, i programmi driver o degrammano gli endpoint, come descritto nella struttura ENDPOINTS_CONFIGURE .

Questo callback non abilita o disabilita l'endpoint predefinito. Lo stato predefinito dell'endpoint è associato allo stato del dispositivo. Il driver implementa e disabilita le operazioni nelle funzioni di EVT_UCX_USBDEVICE_DISABLE e EVT_UCX_USBDEVICE_ENABLE callback.

Il driver client restituisce lo stato di completamento nella richiesta. Il driver può completare in modo asincrono WDFREQUEST.

Esempio

VOID
UsbDevice_EvtUcxUsbDeviceEndpointsConfigure(
    UCXCONTROLLER      UcxController,
    WDFREQUEST         Request
)

{
    UNREFERENCED_PARAMETER(UcxController);

    DbgTrace(TL_INFO, UsbDevice, "UsbDevice_EvtUcxUsbDeviceEndpointsConfigure");

    WDF_REQUEST_PARAMETERS_INIT(&wdfRequestParams);
    WdfRequestGetParameters(WdfRequest, &wdfRequestParams);

    ...

    endpointsConfigure = (PENDPOINTS_CONFIGURE)wdfRequestParams.Parameters.Others.Arg1;

    ...

    WdfRequestComplete(Request, STATUS_SUCCESS);
}

Requisiti

Requisito Valore
Piattaforma di destinazione Windows
Versione KMDF minima 1,0
Versione UMDF minima 2,0
Intestazione ucxusbdevice.h (include Ucxclass.h)
IRQL DISPATCH_LEVEL

Vedi anche

ENDPOINTS_CONFIGURE

UcxUsbDeviceCreate