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,这将检索驱动程序可以用作 WdfIoQueueRetrieveFoundRequestFoundRequest 参数的句柄。

如果驱动程序是使用 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)

另请参阅

WdfIoQueueFindRequest

WdfIoQueueRetrieveNextRequest

WdfIoQueueRetrieveRequestByFileObject