IVdsSubSystem::QueryMaxLunCreateSize 方法 (vdshwprv.h)

[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]

返回可以使用指定的 LUN 类型和提示创建的最大 LUN 的大小。

语法

HRESULT QueryMaxLunCreateSize(
  [in]  VDS_LUN_TYPE  type,
  [in]  VDS_OBJECT_ID *pDriveIdArray,
  [in]  LONG          lNumberOfDrives,
  [in]  VDS_HINTS     *pHints,
  [out] ULONGLONG     *pullMaxLunSize
);

参数

[in] type

VDS_LUN_TYPE枚举的 LUN 类型。

[in] pDriveIdArray

指向数组的指针,该数组包含创建 LUN 时要使用的每个驱动器的 VDS_OBJECT_ID 。 提供程序应尝试按提供的顺序使用驱动器。 如果 lNumberOfDrives 参数为 0,则此参数可以为 NULL,在这种情况下,提供程序应自动选取驱动器。

[in] lNumberOfDrives

pDriveIdArray 中的条目数。 这可以设置为 0。

[in] pHints

指向用于创建 LUN 的 VDS_HINTS 结构的指针。 提示的优先级始终低于前面列出的参数。 此参数必须为非 NULL。

[out] pullMaxLunSize

指向缓冲区的指针,该缓冲区包含 LUN 的最大大小(以字节为单位)。 此参数必须为非 NULL。

返回值

此方法可以返回标准 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
此提供程序不支持此操作或参数组合。

要求

要求
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2003 [仅限桌面应用]
目标平台 Windows
标头 vdshwprv.h
Library Uuid.lib

另请参阅

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh

IVdsSubSystem

VDS_HINTS

VDS_LUN_TYPE