WdfIoQueueRetrieveFoundRequest 函数 (wdfio.h)
[适用于 KMDF 和 UMDF]
WdfIoQueueRetrieveFoundRequest 方法将指定的请求传递给驱动程序,以便驱动程序可以处理该请求。
语法
NTSTATUS WdfIoQueueRetrieveFoundRequest(
[in] WDFQUEUE Queue,
[in] WDFREQUEST FoundRequest,
[out] WDFREQUEST *OutRequest
);
参数
[in] Queue
框架队列对象的句柄。
[in] FoundRequest
通过调用 WdfIoQueueFindRequest 获取的框架请求对象的句柄。
[out] OutRequest
指向接收框架请求对象的句柄的位置的指针。 处理请求时,驱动程序必须使用此句柄。
返回值
如果操作成功,WdfIoQueueRetrieveFoundRequest 将返回STATUS_SUCCESS。 否则,此方法可能会返回以下值之一:
返回代码 | 说明 |
---|---|
|
驱动程序提供的句柄无效。 |
|
在 I/O 队列中找不到 由 FoundRequest 参数标识的请求。 |
|
框架到达 I/O 队列的末尾,但找不到与搜索条件匹配的请求。 |
此方法还可能返回其他 NTSTATUS 值。
如果驱动程序提供无效的对象句柄,则会发生 bug 检查。
注解
调用 WdfIoQueueRetrieveFoundRequest 以获取 I/O 请求后,驱动程序 拥有 该请求,并且必须以某种方式 处理 I/O 请求 。
在调用 WdfIoQueueRetrieveFoundRequest 之前,驱动程序必须调用 WdfIoQueueFindRequest,这将检索驱动程序可以用作 WdfIoQueueRetrieveFoundRequest 的 FoundRequest 参数的句柄。
如果驱动程序是使用 KMDF 版本 1.11 或更高版本生成的,则驱动程序可以调用 WdfIoQueueRetrieveFoundRequest ,而无需先调用 WdfIoQueueFindRequest。 在这种情况下,驱动程序必须确保请求对象在队列中仍然有效。
如果对 WdfIoQueueRetrieveFoundRequest 的调用返回STATUS_NOT_FOUND,则之前在队列中的请求已被删除。 请求可能已取消。
有关 WdfIoQueueRetrieveFoundRequest 方法的详细信息,请参阅 管理 I/O 队列。
示例
有关使用 WdfIoQueueRetrieveFoundRequest 的代码示例,请参阅 WdfIoQueueFindRequest。
要求
要求 | 值 |
---|---|
目标平台 | 通用 |
最低 KMDF 版本 | 1.0 |
最低 UMDF 版本 | 2.0 |
标头 | wdfio.h (包括 Wdf.h) |
Library | Wdf01000.sys (KMDF) ;WUDFx02000.dll (UMDF) |
IRQL | <= DISPATCH_LEVEL |
DDI 符合性规则 | DoubleCompletion (kmdf) 、 DriverCreate (kmdf) 、 KmdfIrql (kmdf) 、 KmdfIrql2 (kmdf) 、 KmdfIrqlExplicit (kmdf) , wdfioqueuefindrequestfailed、 WdfIoQueueFindRequestFailed (kmdf) 、wdfioqueueretrievefoundrequest、 WdfIoQueueRetrieveFoundRequest (kmdf) |