EVT_UFX_DEVICE_HOST_DISCONNECT回调函数 (ufxclient.h)

客户端驱动程序的实现,用于禁用函数控制器与主机的通信。

语法

EVT_UFX_DEVICE_HOST_DISCONNECT EvtUfxDeviceHostDisconnect;

void EvtUfxDeviceHostDisconnect(
  [in] UFXDEVICE unnamedParam1
)
{...}

参数

[in] unnamedParam1

客户端驱动程序在上一次调用 UfxDeviceCreate 方法时收到的 USB 设备对象的句柄。

返回值

备注

函数主机控制器的客户端驱动程序通过调用 UfxDeviceCreate 方法向 UFX () 的 USB 函数类扩展注册其EVT_UFX_DEVICE_HOST_DISCONNECT实现。

UFX 调用此事件回调,以在 USB 电缆上执行软断开连接。 在此调用之后,在 UFX 调用 EVT_UFX_DEVICE_HOST_CONNECT之前,客户端驱动程序不得启动与主机的连接。

客户端驱动程序通过调用 UfxDeviceEventComplete 方法指示此事件的完成。

示例

EVT_UFX_DEVICE_HOST_DISCONNECT UfxDevice_EvtDeviceHostDisconnect;

VOID
UfxDevice_EvtDeviceHostDisconnect (
    _In_ UFXDEVICE UfxDevice
    )
/*++

Routine Description:

    EvtDeviceHostDisconnect callback handler for UFXDEVICE object.

Arguments:

    UfxDevice - UFXDEVICE object representing the device.

--*/
{
    PCONTROLLER_CONTEXT ControllerContext;
    PUFXDEVICE_CONTEXT DeviceContext;
    BOOLEAN EventComplete;

    TraceEntry();

    DeviceContext = UfxDeviceGetContext(UfxDevice);
    ControllerContext = DeviceGetControllerContext(DeviceContext->FdoWdfDevice);

    EventComplete = TRUE;

    //
    // #### TODO: Cancel all transfers. ####
    //

    WdfSpinLockAcquire(ControllerContext->DpcLock);

    //
    // #### TODO: Insert code to clear the run state on the controller ####
    //
    
    WdfSpinLockRelease(ControllerContext->DpcLock);

    if (EventComplete) {
        UfxDeviceEventComplete(UfxDevice, STATUS_SUCCESS);
    }

    TraceExit();
}

要求

要求
目标平台 Windows
最低 KMDF 版本 1.0
最低 UMDF 版本 2.0
标头 ufxclient.h
IRQL <=DISPATCH_LEVEL

另请参阅