WdfCmResourceListAppendDescriptor 函数 (wdfresource.h)

[仅适用于 KMDF]

WdfCmResourceListAppendDescriptor 方法将资源描述符添加到指定资源列表的末尾。

语法

NTSTATUS WdfCmResourceListAppendDescriptor(
  [in] WDFCMRESLIST                    List,
  [in] PCM_PARTIAL_RESOURCE_DESCRIPTOR Descriptor
);

参数

[in] List

框架资源列表对象的句柄,表示设备的硬件资源列表列表。

[in] Descriptor

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

返回值

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

返回代码 描述
STATUS_INVALID_PARAMETER
指定了无效参数。
STATUS_ACCESS_DENIED
不允许驱动程序将描述符添加到 List 参数指定的逻辑配置。 例如,驱动程序无法修改其 EvtDevicePrepareHardwareEvtDeviceReleaseHardware 回调函数收到的逻辑配置。
STATUS_INSUFFICIENT_RESOURCES
框架无法分配空间来存储指定 描述符 参数的描述符。
 

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

言论

框架将 CM_PARTIAL_RESOURCE_DESCRIPTOR 结构的内容复制到内部存储中,因此调用 WdfCmResourceListAppendDescriptor 的驱动程序例程可以本地分配结构。 驱动程序调用 WdfCmResourceListAppendDescriptor 它可以重复使用 CM_PARTIAL_RESOURCE_DESCRIPTOR 结构。

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

例子

下面的代码示例将资源描述符添加到 EvtDeviceResourcesQuery 回调函数接收的资源列表末尾。

NTSTATUS
PdoEvtDeviceResourcesQuery(
    IN WDFDEVICE  Device,
    IN WDFCMRESLIST  Resources
    )
{
    CM_PARTIAL_RESOURCE_DESCRIPTOR newDescriptor;
...
    newDescriptor.Type = CmResourceTypePort;
    newDescriptor.ShareDisposition = CmResourceShareDeviceExclusive;
    newDescriptor.Flags = CM_RESOURCE_PORT_IO|CM_RESOURCE_PORT_16_BIT_DECODE;
    newDescriptor.u.Port.Length = 1;
    newDescriptor.u.Port.Start = 0;

    status = WdfCmResourceListAppendDescriptor(
                                               Resources,
                                               &newDescriptor
                                               );
...

}

要求

要求 价值
目标平台 普遍
最低 KMDF 版本 1.0
标头 wdfresource.h (包括 Wdf.h)
Wdf01000.sys(请参阅框架库版本控制。
IRQL <=DISPATCH_LEVEL
DDI 符合性规则 DriverCreate(kmdf)KmdfIrql(kmdf)KmdfIrql2(kmdf),KmdfIrqlExplicit(kmdf)

另请参阅

CM_PARTIAL_RESOURCE_DESCRIPTOR

EvtDevicePrepareHardware

EvtDeviceReleaseHardware

EvtDeviceResourcesQuery

WdfCmResourceListInsertDescriptor