IVdsSubSystem::CreateLun 方法 (vdshwprv.h)

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

CreateLun方法會建立邏輯單元編號 (LUN) 。

語法

HRESULT CreateLun(
  [in]  VDS_LUN_TYPE  type,
  [in]  ULONGLONG     ullSizeInBytes,
  [in]  VDS_OBJECT_ID *pDriveIdArray,
  [in]  LONG          lNumberOfDrives,
  [in]  LPWSTR        pwszUnmaskingList,
  [in]  VDS_HINTS     *pHints,
  [out] IVdsAsync     **ppAsync
);

參數

[in] type

指定 LUN 類型的 VDS_LUN_TYPE 列舉值。 新的 LUN 可以是自動損壞類型或特定的 RAID 類型,但不能同時是兩者。 如果呼叫端指定自動magic 類型,則應在 pHints 參數中指定一或多個自動放大提示。

您可以在ppAsync參數所傳回的介面指標上呼叫IVdsAsync::Wait方法,以擷取新LUN 物件的介面指標。 Wait所傳回的VDS_ASYNC_OUTPUT結構包含cl.pLunUnk成員中的 LUN 物件介面指標。

[in] ullSizeInBytes

新 LUN 的大小,以位元組為單位。 提供者可以四捨五入大小,以符合對齊需求或其他限制。 (在大部分情況下,提供者會四捨五入,以確保在罕見的例外狀況下,LUN 至少與 requested 一樣大。)

建立 LUN 之後,呼叫端可以呼叫 IVdsLun::GetProperties 方法來判斷 LUN 的實際大小。

[in] pDriveIdArray

陣列的指標,其中包含要用來建立 LUN 之每個磁片磁碟機 的VDS_OBJECT_ID 。 藉由指定此參數的非Null 值,呼叫端會要求提供者依提供的順序使用所有磁片磁碟機,並在移至下一個磁片磁碟機之前使用一個磁片磁碟機上的所有範圍,並在 LUN 達到要求的大小時停止。

或者,呼叫端也可以指示提供者在此參數中傳遞 Null,並在lNumberOfDrives中傳遞Null,以自動選取磁片磁碟機。 只有在lNumberOfDrives為 0.) 時,才 (傳遞Null

如果 類型 參數指定自動損壞類型,這個參數應該是 Null

[in] lNumberOfDrives

pDriveIdArray中指定的磁片磁碟機數目。 如果呼叫端通過 0,提供者會選取磁片磁碟機。

如果 類型 參數指定自動損壞類型,則此參數應該是 0。

建立 LUN 之後,呼叫端可以呼叫 IVdsLunPlex::QueryExtents 方法來判斷正在使用中的磁片磁碟機。

[in] pwszUnmaskingList

清單,指定要授與 LUN 存取權的電腦。 此清單是以分號分隔、 以 Null結束、人類可讀取的字串。

如果值為 「 」,則所有連結至儲存體子系統之 HBA 埠的電腦都會被授與 LUN 的存取權。 如果值為 「」,則不會將任何電腦授與 LUN 的存取權。

注意 實際上,如果值為 「 」,大部分的硬體提供者只會授與本機電腦對 LUN 存取權的埠和啟動器。

 

如果指定了 「*」 或 「」,則無法指定任何其他值。

針對光纖通道網路和序列連結的 SCSI (SAS) 網路,每個專案都是 64 位全球名稱 (WWN) ,其中 LUN 未遮罩的每個埠,格式為十六進位字串, (16 個字元長) ,最重要的位元組優先。 例如,01:23:45:67:89:AB:CD:EF 的 WWN 位址會以 「0123456789ABCDEF」 表示。 如需詳細資訊,請參閱 光纖通道SAS的 T10 規格。

針對 iSCSI 網路,每個專案都是 iSCSI 限定名稱, (IQN) LUN 解除遮罩的每個啟動器。 未遮罩到特定啟動器的 LUN 會被視為與該啟動器相關聯。

注意 取消遮罩清單可以多次包含相同的 WWN 或 IQN。 呼叫端不預期會從清單中移除重複專案,或驗證 WWN 或 IQN 的格式。
 
建立 LUN 之後,呼叫端可以呼叫 IVdsLun::GetProperties 方法來判斷實際的取消遮罩清單。

[in] pHints

VDS_HINTS結構的指標,指定要用於建立 LUN 的提示。 提供者不需要將提示套用至 LUN。 VDS_HINTS 結構中指定的提示只是提供者的要求。

建立 LUN 之後,呼叫端可以呼叫 IVdsLun::QueryHints 方法或 IVdsLunPlex::QueryHints 方法來判斷提供者所套用的提示。

如果 類型 參數指定非自動損壞類型,則此參數應該是 Null

[out] ppAsync

IVdsAsync介面指標的位址,VDS 會在傳回時初始化。 呼叫端必須釋放 介面。 使用此介面來取消、等候或查詢作業的狀態。

如果在傳回的介面指標上呼叫IVdsAsync::Wait,並傳回成功的 HRESULT 值,則必須在每個介面指標上呼叫IUnknown::Release方法,以釋放VDS_ASYNC_OUTPUT結構中傳回的介面。 不過,如果Wait傳回失敗 HRESULT 值,或WaitpHrResult參數收到失敗 HRESULT 值,則VDS_ASYNC_OUTPUT結構中的介面指標為Null且不需要釋放。 您可以使用 Winerror.h 中定義的 SUCCEEDEDFAILED 宏來測試成功或失敗 HRESULT 值。

傳回值

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

傳回碼/值 描述
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
這個傳回值會向提供者內快取陣列相關資訊的軟體或通訊問題發出訊號。 使用 IVdsHwProvider::Reenumerate 方法,後面接著 IVdsHwProvider::Refresh 方法來還原快取。
VDS_E_OBJECT_DELETED
0x8004240BL
子系統物件已不存在。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
子系統處於失敗狀態,無法執行要求的作業。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一項作業正在進行中;此作業無法繼續,直到先前的作業或作業完成為止。
VDS_E_OBJECT_NOT_FOUND
0x80042405L
可以從接受 VDS_OBJECT_ID 常數的任何方法傳回。 這個傳回值表示識別碼不會參考現有的物件。
VDS_E_NOT_SUPPORTED
0x80042400L
此提供者不支援此作業或參數組合。
VDS_E_NOT_ENOUGH_SPACE
0x8004240FL
此作業沒有足夠的可用空間。
VDS_E_NOT_ENOUGH_DRIVE
0x80042410L
子系統中存在太少的可用磁片磁碟機,無法完成這項作業。

備註

藉由為 類型和pHints 參數選擇適當的值,呼叫端可以完全、部分或最少地指定 LUN 的屬性。 提供者可以根據pHints參數指向之VDS_HINTS結構中指定的自動magic 提示,自動包含未指定的屬性。

如果 VDS 提供者只支援簡單的目標群組態,子系統應該會自動將新建立的 LUN 物件與 iSCSI 目標物件產生關聯。 請參閱 VDS_SUB_SYSTEM_FLAG 列舉的 VDS_SF_SUPPORTS_SIMPLE_TARGET_CONFIG 值。

pwszUnmaskingList參數中的 WWN 和 IQN 清單可能包含重複的名稱。 提供者必須負責驗證清單中的所有名稱,並視需要移除重複專案。

硬體提供者負責移除 LUN 的資料分割資訊,以便重複使用 LUN。 如果 LUN 是 MBR 磁碟,這可藉由將零寫入磁片的第一個和最後一個 1 MB 來完成。 針對 GPT 磁片,零必須寫入磁片的第一個和最後 16 KB。

E_INVALIDARGVDS_E_NOT_SUPPORTED傳回值之間有細微的差異。 提供者不預期會實作 VDS API 可以呈現給用戶端的每個功能。 例如, CreateLun 方法會公開建立許多不同類型的 (LUN 的能力,例如簡單、鏡像、等量和同位) 。 不過,不需要提供者才能支援所有類型的 LUN。 如果呼叫端針對不是有效VDS_LUN_TYPE列舉值的別參數指定值,提供者應該傳回E_INVALIDARG。 如果呼叫端指定提供者不支援的有效 型別 值,提供者應該傳回VDS_E_NOT_SUPPORTED。

實作者的注意事項:提供者必須在ppAsync參數中傳回IVdsAsync介面指標,即使呼叫這個方法不會起始非同步作業也一樣。

規格需求

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

另請參閱

IVdsAsync

IVdsAsync::Wait

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh

IVdsLun

IVdsLun::GetProperties

IVdsLun::QueryHints

IVdsLunPlex::QueryExtents

IVdsLunPlex::QueryHints

IVdsSubSystem

IVdsSubSystem::QueryLuns

VDS_ASYNC_OUTPUT

VDS_HINTS

VDS_LUN_TYPE