共用方式為


EVT_WDF_CHILD_LIST_ADDRESS_DESCRIPTION_DUPLICATE回呼函式 (wdfchildlist.h)

[僅適用於 KMDF]

驅動程式的 EvtChildListAddressDescriptionDuplicate 事件回呼函式會複製子位址描述。

語法

EVT_WDF_CHILD_LIST_ADDRESS_DESCRIPTION_DUPLICATE EvtWdfChildListAddressDescriptionDuplicate;

NTSTATUS EvtWdfChildListAddressDescriptionDuplicate(
  [in]  WDFCHILDLIST ChildList,
  [in]  PWDF_CHILD_ADDRESS_DESCRIPTION_HEADER SourceAddressDescription,
  [out] PWDF_CHILD_ADDRESS_DESCRIPTION_HEADER DestinationAddressDescription
)
{...}

參數

[in] ChildList

架構子清單物件的句柄。

[in] SourceAddressDescription

識別子位址描述來源位置 之WDF_CHILD_ADDRESS_DESCRIPTION_HEADER 結構的指標。

[out] DestinationAddressDescription

識別子位址描述目的地位置之WDF_CHILD_ADDRESS_DESCRIPTION_HEADER結構的指標。

傳回值

EvtChildListAddressDescriptionDuplicate 回呼函式必須傳回STATUS_SUCCESS,如果作業成功,NT_SUCCESS (狀態 ) 等於 TRUE 的另一個狀態值。 否則,此函式必須傳回狀態值,NT_SUCCESS (狀態) 等於 FALSE

備註

如果總線驅動程式使用動態列舉,它可以藉由呼叫 WdfFdoInitSetDefaultChildListConfigWdfChildListCreate 來註冊 EvtChildListAddressDescriptionDuplicate 回呼函式。

架構會複製驅動程式提供的位址描述,使其可以有描述的內部複本。

EvtChildListAddressDescriptionDuplicate 回呼函式必須建立位址描述的重複複本。 如果驅動程式的子裝置需要位址描述,而且架構無法呼叫 RtlCopyMemory 來複製位址描述,驅動程式必須提供此回呼函式。 (如果描述包含其他記憶體的指標,架構就無法呼叫 RtlCopyMemory 。)

如果您的驅動程式提供位址描述,但未提供 EvtChildListAddressDescriptionDuplicate 回呼函式,架構會藉由呼叫 RtlCopyMemory 來複製位址描述。

下列步驟描述一般案例:

  1. 驅動程式會判斷子裝置是否存在。
  2. 驅動程式會填入包含 WDF_CHILD_ADDRESS_DESCRIPTION_HEADER 結構的驅動程式定義結構,並透過動態配置額外的記憶體來儲存具有裝置特定大小的位址資訊,以建立位址描述。
  3. 驅動程式會呼叫 WdfChildListAddOrUpdateChildDescriptionAsPresent 來報告子裝置,並提供位址描述的指標。
  4. 架構會呼叫 EvtChildListAddressDescriptionDuplicate 回呼函式, (如果存在) 或 RtlCopyMemory 來複製位址描述,讓它可以有描述的內部複本。
架構可以使用 RtlCopyMemory 來複製位址描述,如果描述是由WDF_CHILD_ADDRESS_DESCRIPTION_HEADER結構的 AddressDescriptionSize 成員所指定之預先決定大小的單一結構所組成。 不過,有時候描述也必須包含儲存在動態配置記憶體中的其他資訊。 在此情況下,您通常會定義描述結構,讓成員指向動態配置的記憶體,而您的驅動程序必須提供 EvtChildListAddressDescriptionDuplicate 回呼函式。 回呼函式必須執行下列動作:
  1. 通常藉由呼叫 ExAllocatePool 來配置額外的記憶體。
  2. 將配置的記憶體位址儲存在驅動程式定義的位址描述結構 (,也就是回呼函式的 DestinationAddressDescription 結構) 。
  3. 將其他結構成員從回調函式的 SourceAddressDescription 結構複製到回呼函式的 DestinationAddressDescription 結構。
驅動程式的 EvtChildListAddressDescriptionDuplicate 回呼函式可以呼叫的唯一架構子清單物件方法WdfChildListGetDevice

架構會先取得內部子清單對象鎖定,再呼叫 EvtChildListAddressDescriptionDuplicate 回呼函式。 回呼函式只能執行與描述重複作業相關的作業,例如呼叫架構記憶體物件方法和存取物件內容空間。 它不得呼叫存取其他驅動程式的方法。

如果您的驅動程式提供 EvtChildListAddressDescriptionDuplicate 回呼函式,可能也需要 EvtChildListAddressDescriptionCopyEvtChildListAddressDescriptionCleanup 回呼函式。

如需動態列舉的詳細資訊,請參閱 列舉總線上的裝置

規格需求

需求
目標平台 Universal
最低 KMDF 版本 1.0
標頭 wdfchildlist.h (包含 Wdf.h)
IRQL <= DISPATCH_LEVEL

另請參閱

EvtChildListAddressDescriptionCleanup

ExAllocatePool

RtlCopyMemory

WDF_CHILD_ADDRESS_DESCRIPTION_HEADER

WdfChildListAddOrUpdateChildDescriptionAsPresent

WdfChildListCreate

WdfChildListGetDevice

WdfFdoInitSetDefaultChildListConfig