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 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
此返回值表示提供程序内部存在软件或通信问题,该提供程序缓存有关数组的信息。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
LUN 对象不再存在。 |
|
LUN 处于失败状态,无法执行请求的操作。 |
|
另一个操作正在进行中。 在上一个操作完成之前,此操作无法继续。 |
|
活动或非活动数组中指定的一个或多个 GUID 不引用现有对象。 |
|
此提供程序不支持此操作或参数组合。 |
注解
调用方必须在每个方法调用的 pActiveControllerIdArray 参数或 pInactiveControllerIdArray 参数之一中包含每个子系统控制器。 对于每个子系统 LUN,pActiveControllerIdArray 和 pInactiveControllerIdArray 参数的组合可能不同。 大多数子系统只实现一个主动控制器,但有些子系统允许多个主动控制器。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |