IVdsSubSystem2::QueryMaxLunCreateSize2 方法 (vds.h)
[从Windows 8和Windows Server 2012开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
返回可以使用指定的 LUN 类型和提示创建的最大 LUN 的大小。 此方法与 IVdsSubSystem::QueryMaxLunCreateSize 方法相同,只不过 automagic 提示是使用 VDS_HINTS2 结构而不是 VDS_HINTS 结构提供的。
语法
HRESULT QueryMaxLunCreateSize2(
[in] VDS_LUN_TYPE type,
[in] VDS_OBJECT_ID *pDriveIdArray,
[in] LONG lNumberOfDrives,
[in] VDS_HINTS2 *pHints2,
[out] ULONGLONG *pullMaxLunSize
);
参数
[in] type
指定 LUN 类型的 VDS_LUN_TYPE 枚举值。
[in] pDriveIdArray
指向数组的指针,该数组包含创建 LUN 时要使用的每个驱动器的 VDS_OBJECT_ID 。 提供程序应尝试按提供的顺序使用驱动器。 如果 lNumberOfDrives 参数为零,则此参数可以为 NULL,在这种情况下,提供程序应自动选择驱动器。
[in] lNumberOfDrives
pDriveIdArray 数组中的条目数。 此参数是可选的,可以为零。
[in] pHints2
指向用于创建 LUN 的VDS_HINTS2 结构的指针。 提示的优先级始终低于前面列出的参数。 此参数是必需的,不能为 NULL。
[out] pullMaxLunSize
指向包含 LUN 最大大小(以字节为单位)的缓冲区的指针。 此参数是必需的,不能为 NULL。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
提供程序内部存在缓存有关数组的信息的软件或通信问题。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
子系统对象不再存在。 |
|
子系统处于失败状态,无法执行请求的操作。 |
|
另一个操作正在进行中:在上一个操作完成之前,此操作无法继续。 |
|
标识符不引用现有对象。 此值可以从采用 VDS_OBJECT_ID 常量的任何方法中返回。 |
|
此提供程序不支持此操作或参数组合。 |
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows 7 [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2008 R2 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |