WdfFdoAddStaticChild 函数 (wdffdo.h)

[仅适用于 KMDF]

WdfFdoAddStaticChild 方法将指定的设备添加到函数驱动程序的子设备列表中,这些子设备已被静态枚举标识。

语法

NTSTATUS WdfFdoAddStaticChild(
  [in] WDFDEVICE Fdo,
  [in] WDFDEVICE Child
);

参数

[in] Fdo

表示父设备的框架设备对象的句柄。

[in] Child

表示子设备的框架设备对象的句柄。

返回值

如果作成功,该方法将返回STATUS_SUCCESS。 其他返回值包括:

返回代码 说明
STATUS_INVALID_PARAMETER
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)

另请参阅

WdfChildListAddOrUpdateChildDescriptionAsPresent

WdfDeviceCreate

WdfPdoInitAllocate