EVT_WDF_CHILD_LIST_ADDRESS_DESCRIPTION_COPY回呼函式 (wdfchildlist.h)
[僅適用於 KMDF]
驅動程式的 EvtChildListAddressDescriptionCopy 事件回呼函式會將子位址描述從一個指定的位置複製到另一個位置。
語法
EVT_WDF_CHILD_LIST_ADDRESS_DESCRIPTION_COPY EvtWdfChildListAddressDescriptionCopy;
void EvtWdfChildListAddressDescriptionCopy(
[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結構的指標。
傳回值
沒有
言論
如果總線驅動程式使用 動態列舉,則可以呼叫 WdfFdoInitSetDefaultChildListConfig 或 WdfChildListCreate來註冊 EvtChildListAddressDescriptionCopy 回呼函式。
架構會將資訊從一個驅動程式提供的位址描述複製到另一個驅動程式,當它需要以新資訊更新現有的描述,或當它需要將位址描述的內容傳遞給驅動程式時。
EvtChildListAddressDescriptionCopy 回呼函式必須將來源描述的內容複製到目的地描述。 驅動程式必須在其子裝置需要位址描述時提供此回呼函式,如果架構無法呼叫 RtlCopyMemory 來複製位址描述。 (如果描述包含其他記憶體的指標,則架構無法呼叫 RtlCopyMemory。
如果您的驅動程式提供位址描述,但沒有提供 EvtChildListAddressDescriptionCopy 回呼函式,架構會呼叫 RtlCopyMemory來複製位址描述。
下列步驟描述一般案例:
- 驅動程式會判斷子裝置是否存在。
- 驅動程式會填入包含 WDF_CHILD_ADDRESS_DESCRIPTION_HEADER 結構的驅動程式定義結構,並可能藉由動態配置額外的記憶體來儲存具有裝置特定大小的地址資訊,以建立位址描述。
- 驅動程式會呼叫 WdfChildListAddOrUpdateChildDescriptionAsPresent 來報告子裝置,並提供位址描述的指標。
- 架構會判斷驅動程式先前已回報裝置,因此架構可以使用新資訊來更新裝置的舊位址描述。
- 架構會呼叫 EvtChildListAddressDescriptionCopy 回呼函式(如果存在),或 RtlCopyMemory,將新的位址描述資訊複製到現有的位址描述中。
- 在回呼函式的 SourceAddressDescription 和 DestinationAddressDescription 結構中,尋找動態配置記憶體的指標。
- 使用指標,將動態配置的記憶體從來源複製到目的地。
- 將回呼函式 SourceAddressDescription 結構的其他結構成員複製到回呼函式的 DestinationAddressDescription 結構。
架構會先取得內部子清單對象鎖定,再呼叫 EvtChildListAddressDescriptionCopy 回呼函式。 回呼函式只能執行與所述複製作業相關的作業,例如呼叫架構記憶體物件方法和存取物件內容空間。 它不得呼叫存取其他驅動程式的方法。
如果您的驅動程式提供 EvtChildListAddressDescriptionCopy 回呼函式,它可能需要 EvtChildListAddressDescriptionDuplicate 和 EvtChildListAddressDescriptionCleanup 回呼函式。
如需動態列舉的詳細資訊,請參閱 列舉總線上的裝置。
要求
要求 | 價值 |
---|---|
目標平臺 | 普遍 |
最低 KMDF 版本 | 1.0 |
標頭 | wdfchildlist.h (包括 Wdf.h) |
IRQL | <= DISPATCH_LEVEL |
另請參閱
EvtChildListAddressDescriptionCleanup
EvtChildListAddressDescriptionDuplicate
WDF_CHILD_ADDRESS_DESCRIPTION_HEADER