[从 Windows 8 和 Windows Server 2012 开始, 虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。
将子系统控制器端口设置为与 LUN 相关的活动或非活动端口。 此方法替换 IVdsLun::AssociateControllers。
Syntax
HRESULT AssociateControllerPorts(
VDS_OBJECT_ID *pActiveControllerPortIdArray,
LONG lNumberOfActiveControllerPorts,
VDS_OBJECT_ID *pInactiveControllerPortIdArray,
LONG lNumberOfInactiveControllerPorts
);
参数
pActiveControllerPortIdArray
指向控制器端口 GUID 数组的指针。 提供程序将这些控制器端口设置为活动端口。 此数组包括已设置为活动的控制器端口,这些端口将保持活动状态。
lNumberOfActiveControllerPorts
pActiveControllerPortIdArray 参数中指定的控制器端口数。
pInactiveControllerPortIdArray
指向控制器端口 GUID 数组的指针。 提供程序将这些控制器端口设置为非活动状态。 此数组包括已设置为非活动状态的控制器端口,这些端口将保持非活动状态。
lNumberOfInactiveControllerPorts
pInactiveControllerPortIdArray 参数中指定的控制器端口数。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用HRESULT_FROM_WIN32宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
| 返回代码/值 | Description |
|---|---|
|
已成功设置关联名称。 |
|
提供程序的缓存已损坏。 这表示提供程序内的软件或通信问题,用于缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
LUN 对象不再存在。 |
|
LUN 处于失败状态,无法执行请求的作。 |
|
另一个作正在进行中。 在前面的作完成之前,此作无法继续。 |
|
pActiveControllerPortIdArray 或 pInactiveControllerPortIdArray 参数中指定的数据类型 VDS_OBJECT_ID的一个或多个 GUID 不引用现有对象。 |
|
此提供程序不支持此作或参数组合。 |
要求
| Requirement | 价值 |
|---|---|
| 最低支持的客户端 | Windows Vista [仅限桌面应用] |
| 支持的最低服务器 | Windows Server 2003 R2 [仅限桌面应用] |
| 目标平台 | Windows操作系统 |
| Header | vds.h |
| 可再发行组件 | VDS 1.1 |