IVdsLunMpio::GetPathInfo 方法 (vds.h)
[从Windows 8和Windows Server 2012开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
返回 VDS_PATH_INFO 结构的数组,每个指向 LUN 的路径各一个。
语法
HRESULT GetPathInfo(
[out] VDS_PATH_INFO **ppPaths,
[out] LONG *plNumberOfPaths
);
参数
[out] ppPaths
接收 VDS_PATH_INFO 结构的数组的变量的地址。 调用方必须使用 CoTaskMemFree 函数释放数组中的每个元素以及数组本身。
[out] plNumberOfPaths
变量的地址,该变量接收 ppPaths 参数中返回的数组中的元素数。
此方法返回的路径数将与 IVdsLunMpio::GetLoadBalancePolicy 方法返回的路径数匹配。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
已成功返回路径信息。 |
|
提供程序的缓存已损坏。 这表示提供程序内部存在软件或通信问题,该提供程序缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,然后使用 IVdsHwProvider::Refresh 方法还原缓存。 |
|
LUN 对象不再存在。 |
|
LUN 处于失败状态,无法执行请求的操作。 |
|
另一个操作正在进行中。 在完成以前的操作之前,此操作无法继续。 |
注解
硬件提供程序不需要在 VDS_PATH_INFO hbaPortProp.id 返回 VDS_OBJECT_ID ,只需将此设置为 GUID_NULL。 当此调用传回应用程序时,系统将填充此 ID。 如果服务找不到相应的 HBA 端口,将使用 GUID_NULL 。 应用程序会将此解释为表示 HBA 端口对 VDS 未知。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 R2 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |
可再发行组件 | VDS 1.1 |