WdfIoResourceListAppendDescriptor 函数 (wdfresource.h)
[仅适用于 KMDF]
WdfIoResourceListAppendDescriptor 方法将资源描述符添加到资源要求列表 逻辑配置末尾。
语法
NTSTATUS WdfIoResourceListAppendDescriptor(
[in] WDFIORESLIST ResourceList,
[in] PIO_RESOURCE_DESCRIPTOR Descriptor
);
参数
[in] ResourceList
框架资源范围列表对象的句柄,该对象表示设备的硬件资源的逻辑配置。
[in] Descriptor
指向描述硬件资源的 IO_RESOURCE_DESCRIPTOR 结构的指针。
返回值
如果作成功,WdfIoResourceListAppendDescriptor 返回STATUS_SUCCESS。 否则,此方法可能会返回以下值之一:
返回代码 | 描述 |
---|---|
|
指定了无效参数。 |
|
不允许驱动程序将描述符添加到 ResourceList 参数指定的逻辑配置。 |
|
框架无法分配空间来存储描述符。 |
如果驱动程序提供无效的对象句柄,则会发生系统 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) |
库 | Wdf01000.sys(请参阅框架库版本控制。 |
IRQL | <=DISPATCH_LEVEL |
DDI 符合性规则 | DriverCreate(kmdf),KmdfIrql(kmdf),KmdfIrql2(kmdf),KmdfIrqlExplicit(kmdf) |