WdfIoResourceListAppendDescriptor 函数 (wdfresource.h)

[仅适用于 KMDF]

WdfIoResourceListAppendDescriptor 方法将资源描述符添加到资源要求列表的逻辑配置的末尾。

语法

NTSTATUS WdfIoResourceListAppendDescriptor(
  [in] WDFIORESLIST            ResourceList,
  [in] PIO_RESOURCE_DESCRIPTOR Descriptor
);

参数

[in] ResourceList

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

[in] Descriptor

指向描述硬件资源的 IO_RESOURCE_DESCRIPTOR 结构的指针。

返回值

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

返回代码 说明
STATUS_INVALID_PARAMETER
指定的参数无效。
STATUS_ACCESS_DENIED
不允许驱动程序将描述符添加到 ResourceList 参数指定的逻辑配置。
STATUS_INSUFFICIENT_RESOURCES
框架无法分配空间来存储描述符。
 

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

注解

框架将描述符参数指向的 IO_RESOURCE_DESCRIPTOR 结构的内容复制到内部存储中,以便调用 WdfIoResourceListAppendDescriptor 的驱动程序例程可以在本地分配结构。 驱动程序调用 WdfIoResourceListAppendDescriptor 后,驱动程序可以重复使用 IO_RESOURCE_DESCRIPTOR 结构。

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

示例

下面的代码示例创建一个空的逻辑配置,并将其添加到资源要求列表。 然后,该示例初始化一个资源描述符,并将该描述符添加到逻辑配置中。

IO_RESOURCE_DESCRIPTOR  descriptor;
NTSTATUS  status;
WDFIORESLIST  logConfig;

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

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

RtlZeroMemory(
              &descriptor,
              sizeof(descriptor)
              );

descriptor.Option = 0;
descriptor.Type = CmResourceTypePort;
descriptor.ShareDisposition = CmResourceShareDeviceExclusive;
descriptor.Flags = CM_RESOURCE_PORT_IO|CM_RESOURCE_PORT_16_BIT_DECODE;
descriptor.u.Port.Length = 1;
descriptor.u.Port.Alignment = 0x01;
descriptor.u.Port.MinimumAddress.QuadPart = 0;
descriptor.u.Port.MaximumAddress.QuadPart = 0xFFFF;

status = WdfIoResourceListAppendDescriptor(
                                           logConfig,
                                           &descriptor
                                           );

要求

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

另请参阅

IO_RESOURCE_DESCRIPTOR

WdfIoResourceListCreate

WdfIoResourceListInsertDescriptor