IVdsLunMpio::GetPathInfo 方法 (vds.h)

[从 Windows 8 和 Windows Server 2012 开始, 虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。

返回一个由 VDS_PATH_INFO 结构构成的数组,其中一个用于 LUN 的每个路径。

Syntax

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 提供程序 。 可能的返回值包括以下内容。

返回代码/值 Description
S_OK
已成功返回路径信息。
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
提供程序的缓存已损坏。 这表示提供程序内的软件或通信问题,用于缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。
VDS_E_OBJECT_DELETED
0x8004240BL
LUN 对象不再存在。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
LUN 处于失败状态,无法执行请求的作。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一个作正在进行中。 在前面的作完成之前,此作无法继续。

注解

硬件提供程序无需在VDS_PATH_INFO的 hbaPortProp.id 处返回 VDS_OBJECT_ID ,并且应仅将此设置为 GUID_NULL。 将此调用传回应用程序时,系统将填充此 ID。 如果服务找不到相应的 HBA 端口,将使用 GUID_NULL 。 应用程序将解释这一点,这意味着 HBA 端口对 VDS 未知。

要求

Requirement 价值
最低支持的客户端 Windows Vista [仅限桌面应用]
支持的最低服务器 Windows Server 2003 R2 [仅限桌面应用]
目标平台 Windows操作系统
Header vds.h
Library Uuid.lib
可再发行组件 VDS 1.1

另请参阅

IVdsLunMpio

VDS_PATH_INFO