IVdsLunControllerPorts::AssociateControllerPorts 方法 (vdshwprv.h)

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

相对于 LUN,将子系统控制器端口设置为活动或非活动。 此方法替换 IVdsLun::AssociateControllers

语法

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

返回代码/值 说明
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_E_OBJECT_NOT_FOUND
0x80042405L
pActiveControllerPortIdArray 或 pInactiveControllerPortIdArray 参数中指定的一个或多个数据类型VDS_OBJECT_ID GUID 不引用现有对象。
VDS_E_NOT_SUPPORTED
0x80042400L
此提供程序不支持此操作或参数组合。

要求

   
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2003 R2 [仅限桌面应用]
目标平台 Windows
标头 vdshwprv.h
可再发行组件 VDS 1.1

另请参阅

IVdsLunControllerPorts