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。 否则,此方法可能会返回以下值之一:

返回代码 说明
STATUS_INVALID_PARAMETER
驱动程序提供了无效句柄。
STATUS_NOT_FOUND
在 I/O 队列中找不到由 FoundRequest 参数标识的请求。
STATUS_NO_MORE_ENTRIES
框架到达 I/O 队列的末尾,但没有找到与搜索条件匹配的请求。
 

此方法还可以 返回其他NTSTATUS 值。

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

注解

调用 WdfIoQueueRetrieveFoundRequest 以获取 I/O 请求后,驱动程序 拥有 请求,并且必须以某种方式 处理 I/O 请求

在调用 WdfIoQueueRetrieveFoundRequest之前,驱动程序必须调用 WdfIoQueueFindRequest,该句柄检索驱动程序可以用作 foundRequest 参数的 句柄,以 WdfIoQueueRetrieveFoundRequest

如果驱动程序是使用 KMDF 版本 1.11 或更高版本生成的,驱动程序可以调用 WdfIoQueueRetrieveFoundRequest,而无需先调用 WdfIoQueueFindRequest。 在这种情况下,驱动程序必须确保请求对象仍然有效且在队列中。

如果调用 WdfIoQueueRetrieveFoundRequest 将返回STATUS_NOT_FOUND,则会删除以前在队列中的请求。 请求可能已被取消。

有关 WdfIoQueueRetrieveFoundRequest 方法的详细信息,请参阅 管理 I/O 队列

例子

有关使用 WdfIoQueueRetrieveFoundRequest的代码示例,请参阅 WdfIoQueueFindRequest

要求

要求 价值
目标平台 普遍
最低 KMDF 版本 1.0
最低 UMDF 版本 2.0
标头 wdfio.h (包括 Wdf.h)
图书馆 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)

另请参阅

WdfIoQueueFindRequest

WdfIoQueueRetrieveNextRequest

WdfIoQueueRetrieveRequestByFileObject