WdfIoTargetCloseForQueryRemove 函数 (wdfiotarget.h)

[适用于 KMDF 和 UMDF]

WdfIoTargetCloseForQueryRemove 方法会暂时关闭指定的远程 I/O 目标,因为目标设备可能很快被删除。

语法

void WdfIoTargetCloseForQueryRemove(
  [in] WDFIOTARGET IoTarget
);

参数

[in] IoTarget

远程 I/O 目标对象的句柄,该对象是从上一次调用 WdfIoTargetCreate 获取的

返回值

备注

如果驱动程序提供无效的对象句柄,则会发生 bug 检查。

如果驱动程序确定可以安全删除目标设备,则提供 EvtIoTargetQueryRemove 回调函数的驱动程序必须从该回调函数内部调用 WdfIoTargetCloseForQueryRemove

有关 WdfIoTargetCloseForQueryRemove 的详细信息,请参阅 控制常规 I/O 目标的状态

有关 I/O 目标的详细信息,请参阅 使用 I/O 目标

示例

下面的代码示例是 Toaster 示例驱动程序中的 EvtIoTargetQueryRemove 回调函数。 函数停止计时器,确保之前提交的工作项已得到服务,然后调用 WdfIoTargetCloseForQueryRemove

NTSTATUS
ToastMon_EvtIoTargetQueryRemove(
    WDFIOTARGET IoTarget
)
{
    PTARGET_DEVICE_INFO  targetDeviceInfo = NULL;

    //
    // Get I/O target object's context space.
    //
    targetDeviceInfo = GetTargetDeviceInfo(IoTarget);

    //
    // Stop the timer and wait for any outstanding work items
    // to finish before closing the target.
    //
    WdfTimerStop(targetDeviceInfo->TimerForPostingRequests, TRUE);
    WdfWorkItemFlush(targetDeviceInfo->WorkItemForPostingRequests);

    WdfIoTargetCloseForQueryRemove(IoTarget);

    return STATUS_SUCCESS;
}

要求

要求
目标平台 通用
最低 KMDF 版本 1.0
最低 UMDF 版本 2.0
标头 wdfiotarget.h (包括 Wdf.h)
Library Wdf01000.sys (KMDF) ;WUDFx02000.dll (UMDF)
IRQL PASSIVE_LEVEL
DDI 符合性规则 DriverCreate (kmdf) KmdfIrql (kmdf) KmdfIrql2 (kmdf) 、 KmdfIrqlExplicit (kmdf)

另请参阅

EvtIoTargetQueryRemove

WdfIoTargetCreate