IVdsSubSystem::QueryLuns 方法 (vdshwprv.h)
[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
返回子系统中显示的 LUN 的枚举。 此方法仅适用于硬件提供程序对象。
语法
HRESULT QueryLuns(
[out] IEnumVdsObject **ppEnum
);
参数
[out] ppEnum
可用于将 LUN 枚举为 LUN 对象的IEnumVdsObject 接口指针的地址。 有关详细信息,请参阅 使用枚举对象。 当不再需要接口和每个 LUN 对象时,调用方必须通过调用 IUnknown::Release 方法释放这些对象。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
返回子系统中 LUN 的枚举。 如果子系统没有 LUN,则枚举为空。 |
|
此返回值表示缓存有关数组信息的提供程序中的软件或通信问题。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
子系统对象不再存在。 |
|
子系统处于失败状态,无法执行请求的操作。 |
|
另一项操作正在进行中;在上一个操作完成之前,此操作无法继续。 |
注解
无论 LUN 掩码如何, IEnumVdsObject 接口都包含子系统中的所有 LUN。
对于具有零 LUN 的每个子系统,实现者必须返回一个空枚举对象。
如果在同时运行的两个单独的线程中调用此方法,则结果可能不一致。 如果在同时运行的另一个线程中调用 IVdsLun::D elete 等方法时在一个线程中调用,则结果可能是提供程序访问冲突。 硬件提供程序负责根据需要序列化此查询操作,以最大程度地减少此类同步问题。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | vdshwprv.h |
Library | Uuid.lib |