WdfIoResourceRequirementsListInsertIoResList 函数 (wdfresource.h)

[仅适用于 KMDF]

WdfIoResourceRequirementsListInsertIoResList 方法将逻辑配置插入到资源要求列表中。

语法

NTSTATUS WdfIoResourceRequirementsListInsertIoResList(
  [in] WDFIORESREQLIST RequirementsList,
  [in] WDFIORESLIST    IoResList,
  [in] ULONG           Index
);

参数

[in] RequirementsList

表示设备资源要求列表的框架 resource-requirements-list 对象的句柄。

[in] IoResList

表示设备硬件资源的逻辑配置的框架 resource-range-list 对象的句柄。

[in] Index

一个从零开始的值,该值用作一组逻辑配置中的索引,这些配置已在 RequirementsList 指定的资源要求列表中。 若要将配置添加到列表末尾,请指定WDF_INSERT_AT_END或 WdfIoResourceRequirementsListGetCount 中的返回值。

返回值

如果操作成功,WdfIoResourceRequirementsListInsertIoResList 将返回STATUS_SUCCESS。 否则,此方法可能会返回以下值之一:

返回代码 说明
STATUS_INVALID_PARAMETER
指定的参数无效。
STATUS_INVALID_DEVICE_REQUEST
指定的 resource-requirements-list 对象不拥有指定的 resource-range-list 对象。
STATUS_INSUFFICIENT_RESOURCES
框架无法分配空间来存储 resource-range-list 对象。
STATUS_ARRAY_BOUNDS_EXCEEDED
Index 参数的指定值太大。
 

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

注解

WdfIoResourceRequirementsListInsertIoResList 方法将 IoResList 参数指定的逻辑配置插入 RequirementsList 参数指定的资源要求列表中,位于 Index 值标识的逻辑配置前面。

若要将逻辑配置添加到资源要求列表的末尾,请使用 WDF_INSERT_AT_END 或 WdfIoResourceRequirementsListGetCount 中的返回值作为 Index 值。 或者,使用 WdfIoResourceRequirementsListAppendIoResList 方法。

有关资源要求列表的详细信息,请参阅 Framework-Based 驱动程序的硬件资源

示例

下面的代码示例演示 EvtDeviceResourceRequirementsQuery 回调函数如何创建两个空的逻辑配置并将其添加到资源要求列表。

NTSTATUS
Example_EvtDeviceResourceRequirementsQuery(
    IN WDFDEVICE Device,
    IN WDFIORESREQLIST RequirementsList
    )
{
    NTSTATUS  status;
    WDFIORESLIST  logConfig1;
    WDFIORESLIST  logConfig2;

    status = WdfIoResourceListCreate(
                                     RequirementsList,
                                     WDF_NO_OBJECT_ATTRIBUTES,
                                     &logConfig1
                                     );
    if (!NT_SUCCESS(status)) {
        return status;
    }

    status = WdfIoResourceRequirementsListAppendIoResList(
                                             RequirementsList,
                                             logConfig1
                                             );
    if (!NT_SUCCESS(status)) {
        return status;
    }

    status = WdfIoResourceListCreate(
                                     RequirementsList,
                                     WDF_NO_OBJECT_ATTRIBUTES,
                                     &logConfig2
                                     );
    if (!NT_SUCCESS(status)) {
        return status;
    }
    status = WdfIoResourceRequirementsListInsertIoResList(
                                             RequirementsList,
                                             logConfig2,
                                             WDF_INSERT_AT_END
                                             );
    if (!NT_SUCCESS(status)) {
        return status;
    }
...
}

要求

要求
目标平台 通用
最低 KMDF 版本 1.0
标头 wdfresource.h (包括 Wdf.h)
Library Wdf01000.sys (请参阅框架库 Versioning.)
IRQL <=DISPATCH_LEVEL
DDI 符合性规则 DriverCreate (kmdf) KmdfIrql (kmdf) KmdfIrql2 (kmdf) 、 KmdfIrqlExplicit (kmdf)

另请参阅

WdfIoResourceListCreate

WdfIoResourceRequirementsListAppendIoResList