[适用于 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,该句柄检索驱动程序可以用作 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) |