IVdsSubSystemIscsi::CreateTarget 方法 (vds.h)
[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
创建 iSCSI 目标。 可以通过通过 ppAsync 参数调用 IVdsAsync::Wait 来检索新目标对象的接口指针。 返回 VDS_ASYNC_OUTPUT 结构包含 ct.pTargetUnk 成员中的目标对象接口指针。
语法
HRESULT CreateTarget(
[in] LPWSTR pwszIscsiName,
[in] LPWSTR pwszFriendlyName,
[out] IVdsAsync **ppAsync
);
参数
[in] pwszIscsiName
指定要分配给目标的 iSCSI 名称的字符串。 目标名称在网络上可见的所有子系统中的所有目标中必须是唯一的。
如果 pwszIscsiName 为 NULL 或指向空字符串,则提供程序将生成要分配给目标的 iSCSI 名称。
[in] pwszFriendlyName
一个字符串,指定要分配给目标的友好名称。 这对应于 iSCSI 别名。
[out] ppAsync
VDS 在返回时初始化的 IVdsAsync 接口指针的地址。 调用方必须释放接口。 使用此接口可取消、等待或查询操作的状态。 如果对此方法调用 IVdsAsync::Wait 并返回成功的 HRESULT 值,则必须通过在每个接口指针上调用 IUnknown::Release 方法释放VDS_ASYNC_OUTPUT结构中返回的接口。 但是,如果 Wait 返回失败的 HRESULT 值,或者如果 Wait 的 pHrResult 参数收到失败的 HRESULT 值,则VDS_ASYNC_OUTPUT结构中的接口指针为 NULL,无需释放。 可以使用 Winerror.h 中定义的 SUCCEEDED 和 FAILED 宏测试成功或失败 HRESULT 值。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
已成功创建目标。 |
|
子系统对象不支持此方法。 这表示硬件提供程序已在子系统对象的 VDS_SUB_SYSTEM_PROP 结构的 ulFlags 成员中设置了 VDS_SF_SUPPORTS_SIMPLE_TARGET_CONFIG 标志。 |
|
提供程序的缓存已损坏。 这表示提供程序内部存在软件或通信问题,该提供程序缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,然后使用 IVdsHwProvider::Refresh 方法还原缓存。 |
|
子系统对象不再存在。 |
|
子系统处于失败状态,无法执行请求的操作。 |
|
另一个操作正在进行中。 在前面的操作完成之前,此操作无法继续。 |
|
pwszIscsiName 参数中指定了非唯一名称。 |
要求
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 R2 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |
可再发行组件 | VDS 1.1 |