[仅适用于 KMDF]
WdfFdoAddStaticChild 方法将指定的设备添加到函数驱动程序的子设备列表中,这些子设备已被静态枚举标识。
语法
NTSTATUS WdfFdoAddStaticChild(
[in] WDFDEVICE Fdo,
[in] WDFDEVICE Child
);
参数
[in] Fdo
表示父设备的框架设备对象的句柄。
[in] Child
表示子设备的框架设备对象的句柄。
返回值
如果作成功,该方法将返回STATUS_SUCCESS。 其他返回值包括:
| 返回代码 | 说明 |
|---|---|
|
Fdo 不是函数驱动程序的设备对象的句柄。 |
此方法还可以返回其他 NTSTATUS 值。
如果驱动程序提供无效的对象句柄,则会发生系统 bug 检查。
注解
使用静态总线枚举的驱动程序可以调用 WdfFdoAddStaticChild。 有关静态子列表的详细信息,请参阅 枚举总线上的设备。
如果 WdfFdoAddStaticChild 返回 NTSTATUS 值,NT_SUCCESS 计算为 FALSE,驱动程序必须调用 WdfObjectDelete 来删除表示子设备的框架设备对象。 WdfFdoAddStaticChild 返回STATUS_SUCCESS后,驱动程序不得删除框架设备对象。
例子
下面的代码示例创建一个框架设备对象,该对象表示新的子设备,并将子设备添加到父设备的子设备列表中。 有关完整的代码示例,请参阅 KbFiltr 示例驱动程序。
NTSTATUS status;
PWDFDEVICE_INIT pDeviceInit = NULL;
WDFDEVICE hChild = NULL;
WDF_OBJECT_ATTRIBUTES pdoAttributes;
pDeviceInit = WdfPdoInitAllocate(Device);
if (pDeviceInit == NULL) {
status = STATUS_INSUFFICIENT_RESOURCES;
goto Cleanup;
}
...
status = WdfDeviceCreate(
&pDeviceInit,
&pdoAttributes,
&hChild
);
if (!NT_SUCCESS(status)) {
WdfDeviceInitFree(pDeviceInit);
pDeviceInit = NULL;
goto Cleanup;
}
...
status = WdfFdoAddStaticChild(
Device,
hChild
);
if (!NT_SUCCESS(status)) {
goto Cleanup;
}
要求
| 要求 | 价值 |
|---|---|
| 目标平台 | 普遍 |
| 最低 KMDF 版本 | 1.0 |
| 标头 | wdffdo.h (包括 Wdf.h) |
| 图书馆 | Wdf01000.sys(请参阅框架库版本控制。 |
| IRQL | <= DISPATCH_LEVEL |
| DDI 符合性规则 | AddPdoToStaticChildList(kmdf), DriverCreate(kmdf), KmdfIrql(kmdf), KmdfIrql2(kmdf), KmdfIrqlExplicit(kmdf) |