IVdsLun::Extend 方法 (vds.h)
[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
将 LUN 扩展指定的字节数。
语法
HRESULT Extend(
[in] ULONGLONG ullNumberOfBytesToAdd,
[in] VDS_OBJECT_ID *pDriveIdArray,
[in] LONG lNumberOfDrives,
[out] IVdsAsync **ppAsync
);
参数
[in] ullNumberOfBytesToAdd
扩展 LUN 所依据的字节数。 字节数不需要是驱动器块或扇区大小的偶数倍。 提供程序可以向上或向下舍入字节数,以满足对齐要求或其他限制。 在大多数情况下,提供程序会向上舍入,确保在极少数情况下,LUN 至少扩展了请求的字节数。
[in] pDriveIdArray
指向驱动器 GUID 数组的指针。 提供程序使用这些驱动器来扩展 LUN。 驱动器按指定顺序使用;在移动到下一个驱动器之前,提供程序使用一个驱动器上的所有盘区,并在 LUN 已按请求的字节数扩展时停止。
或者,调用方可以通过在此参数中传递 NULL 并在 lNumberOfDrives 参数中传递零来指示提供程序自动选择驱动器。 请注意,仅当 lNumberOfDrives 参数为零时,传递 NULL 才有效。
[in] lNumberOfDrives
pDriveIdArray 参数中指定的驱动器数。 如果调用方传递零,则提供程序选择驱动器。
[out] ppAsync
VDS 在返回时初始化的 IVdsAsync 接口指针的地址。 调用方必须释放接口。 使用此接口可取消、等待或查询操作的状态。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
此返回值表示缓存有关数组信息的提供程序中的软件或通信问题。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
LUN 对象不再存在。 |
|
LUN 处于失败状态,无法执行请求的操作。 |
|
另一项操作正在进行中;在上一个操作完成之前,此操作无法继续。 |
|
可以从采用 VDS_OBJECT_ID 常量的任何方法返回。 此返回值指示标识符不引用现有对象。 |
|
此提供程序不支持此操作或参数组合。 |
|
此操作没有足够的可用空间。 |
|
子系统中没有足够的可用驱动器来完成此操作。 |
备注
调用方可以指定供提供商用于扩展 LUN 的驱动器列表,或指示提供程序自动选择驱动器。
扩展 LUN 后,调用方应使用 IOCTL_DISK_UPDATE_PROPERTIES 控制代码,使已更新的磁盘大小在取消 LUN 屏蔽的计算机上可见。
无论调用是否启动异步操作,实现者都必须返回指向此方法的 IVdsAsync 接口的指针。
如果 ullNumberOfBytesToAdd 参数大于 pDriveIdArray 参数中指定的驱动器上的可用字节数,请先使用指定的驱动器,然后从任何其他可用的驱动器中进行选择。 如果没有足够的此类驱动器按请求的字节数扩展 LUN,则返回错误,并且不要扩展 LUN。
要求
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |