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。 否则,此方法可能会返回以下值之一:
返回代码 | 说明 |
---|---|
|
指定的参数无效。 |
|
指定的 resource-requirements-list 对象不拥有指定的 resource-range-list 对象。 |
|
框架无法分配空间来存储 resource-range-list 对象。 |
|
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) |