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) |