IVdsLun::QueryActiveControllers 方法 (vds.h)
[从Windows 8和Windows Server 2012开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
返回当前活动控制器的枚举,即可访问 LUN 的控制器。
语法
HRESULT QueryActiveControllers(
[out] IEnumVdsObject **ppEnum
);
参数
[out] ppEnum
可用于将子系统中的控制器枚举为控制器对象的IEnumVdsObject 接口指针的地址。 有关详细信息,请参阅 使用枚举对象。 当不再需要接口和每个控制器对象时,调用方必须通过调用 IUnknown::Release 方法释放它们。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
返回活动控制器的枚举。 如果 LUN 没有活动控制器,则枚举为空。 |
|
此返回值表示提供程序内部存在软件或通信问题,该提供程序缓存有关数组的信息。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
LUN 对象不再存在。 |
|
LUN 处于失败状态,无法执行请求的操作。 |
|
另一个操作正在进行中:在上一个操作完成之前,此操作无法继续。 |
备注
使用 IVdsLun::AssociateControllers 方法设置控制器。 使用 IVdsController::QueryAssociatedLuns 方法查询与特定控制器关联的 LUN。
大多数子系统仅为一个 LUN 提供一个活动控制器,使其他控制器处于待机模式。 但是,某些子系统制造商确实允许多个同时活动的控制器。
要求
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |