共用方式為


IVdsLun::AssociateControllers 方法 (vds.h)

[從 Windows 8 和 Windows Server 2012 開始,虛擬磁碟服務 COM 介面會由 Windows 記憶體管理 API 取代。

將子系統控制器設定為與 LUN 相關的使用中或非使用中。

語法

HRESULT AssociateControllers(
  [in] VDS_OBJECT_ID *pActiveControllerIdArray,
  [in] LONG          lNumberOfActiveControllers,
  [in] VDS_OBJECT_ID *pInactiveControllerIdArray,
  [in] LONG          lNumberOfInactiveControllers
);

參數

[in] pActiveControllerIdArray

控制器 GUID 陣列的指標。 提供者會將這些控制器設定為作用中。 此陣列包含已設定為作用中的控制器,以保持作用中狀態。

[in] lNumberOfActiveControllers

pActiveControllerArray 參數中指定的控制器數目。

[in] pInactiveControllerIdArray

控制器 GUID 陣列的指標。 提供者會將這些控制器設定為非使用中。 此陣列包含已設定為非作用中的控制器,以維持不變。

[in] lNumberOfInactiveControllers

pInactiveControllerIdArray 參數中指定的控制器數目。

傳回值

這個方法可以傳回標準 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 VDS 特定的傳回值。 它也可以使用 HRESULT_FROM_WIN32 宏傳回已轉換的系統錯誤碼。 錯誤可能源自 VDS 本身,或來自正在使用的基礎 VDS 提供者 。 可能的傳回值包括下列專案。

傳回碼/值 Description
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
這個傳回值會向提供者內快取數位相關信息的軟體或通訊問題發出訊號。 使用 IVdsHwProvider::Reenumerate 方法,後面接著 IVdsHwProvider::Refresh 方法來還原快取。
VDS_E_OBJECT_DELETED
0x8004240BL
LUN 物件已不存在。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
LUN 處於失敗狀態,無法執行要求的作業。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一項作業正在進行中。 此作業無法繼續,直到先前的作業或作業完成為止。
VDS_E_OBJECT_NOT_FOUND
0x80042405L
使用中或非使用中陣列中指定的一或多個 GUID 不會參考現有的物件。
VDS_E_NOT_SUPPORTED
0x80042400L
這個提供者不支援此作業或參數組合。

備註

呼叫端必須在每個方法呼叫的 pActiveControllerIdArray 參數或 pInactiveControllerIdArray 參數中只包含每個子系統控制器。 pActiveControllerIdArraypInactiveControllerIdArray 參數的組合可以針對每個子系統 LUN 不同。 大部分子系統只會實作一個主動控制器,但有些則允許多個主動控制器。

注意E_INVALIDARG傳回值可以指出呼叫端未指定子系統中的所有控制器。 AssociateControllers 方法要求子系統中的所有控制器都存在於提供的兩個陣列之一中。
 
使用 IVdsLun::QueryActiveControllers 方法來查詢控制器關聯。 使用 IVdsController::QueryAssociatedLuns 方法來查詢與特定控制器相關聯的 LUN。

規格需求

需求
最低支援的用戶端 Windows Vista [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限桌面應用程式]
目標平台 Windows
標頭 vds.h
程式庫 Uuid.lib

另請參閱

IVdsController::QueryAssociatedLuns

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh

IVdsLun

IVdsLun::QueryActiveControllers