Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
dc48de25
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
dc48de25
编写于
7月 26, 2017
作者:
J
John Ferlan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
storage: Use virStoragePoolObjGetDef accessor for iSCSI backend
In preparation for privatizing the object, use the accessor.
上级
b4470515
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
23 addition
and
18 deletion
+23
-18
src/storage/storage_backend_iscsi.c
src/storage/storage_backend_iscsi.c
+23
-18
未找到文件。
src/storage/storage_backend_iscsi.c
浏览文件 @
dc48de25
...
...
@@ -83,7 +83,8 @@ static char *
virStorageBackendISCSISession
(
virStoragePoolObjPtr
pool
,
bool
probe
)
{
return
virISCSIGetSession
(
pool
->
def
->
source
.
devices
[
0
].
path
,
probe
);
virStoragePoolDefPtr
def
=
virStoragePoolObjGetDef
(
pool
);
return
virISCSIGetSession
(
def
->
source
.
devices
[
0
].
path
,
probe
);
}
...
...
@@ -235,25 +236,26 @@ static int
virStorageBackendISCSICheckPool
(
virStoragePoolObjPtr
pool
,
bool
*
isActive
)
{
virStoragePoolDefPtr
def
=
virStoragePoolObjGetDef
(
pool
);
char
*
session
=
NULL
;
int
ret
=
-
1
;
*
isActive
=
false
;
if
(
pool
->
def
->
source
.
nhost
!=
1
)
{
if
(
def
->
source
.
nhost
!=
1
)
{
virReportError
(
VIR_ERR_CONFIG_UNSUPPORTED
,
"%s"
,
_
(
"Expected exactly 1 host for the storage pool"
));
return
-
1
;
}
if
(
pool
->
def
->
source
.
hosts
[
0
].
name
==
NULL
)
{
if
(
def
->
source
.
hosts
[
0
].
name
==
NULL
)
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
"%s"
,
_
(
"missing source host"
));
return
-
1
;
}
if
(
pool
->
def
->
source
.
ndevice
!=
1
||
pool
->
def
->
source
.
devices
[
0
].
path
==
NULL
)
{
if
(
def
->
source
.
ndevice
!=
1
||
def
->
source
.
devices
[
0
].
path
==
NULL
)
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
"%s"
,
_
(
"missing source device"
));
return
-
1
;
...
...
@@ -327,44 +329,45 @@ static int
virStorageBackendISCSIStartPool
(
virConnectPtr
conn
,
virStoragePoolObjPtr
pool
)
{
virStoragePoolDefPtr
def
=
virStoragePoolObjGetDef
(
pool
);
char
*
portal
=
NULL
;
char
*
session
=
NULL
;
int
ret
=
-
1
;
if
(
pool
->
def
->
source
.
nhost
!=
1
)
{
if
(
def
->
source
.
nhost
!=
1
)
{
virReportError
(
VIR_ERR_CONFIG_UNSUPPORTED
,
"%s"
,
_
(
"Expected exactly 1 host for the storage pool"
));
return
-
1
;
}
if
(
pool
->
def
->
source
.
hosts
[
0
].
name
==
NULL
)
{
if
(
def
->
source
.
hosts
[
0
].
name
==
NULL
)
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
"%s"
,
_
(
"missing source host"
));
return
-
1
;
}
if
(
pool
->
def
->
source
.
ndevice
!=
1
||
pool
->
def
->
source
.
devices
[
0
].
path
==
NULL
)
{
if
(
def
->
source
.
ndevice
!=
1
||
def
->
source
.
devices
[
0
].
path
==
NULL
)
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
"%s"
,
_
(
"missing source device"
));
return
-
1
;
}
if
((
session
=
virStorageBackendISCSISession
(
pool
,
true
))
==
NULL
)
{
if
((
portal
=
virStorageBackendISCSIPortal
(
&
pool
->
def
->
source
))
==
NULL
)
if
((
portal
=
virStorageBackendISCSIPortal
(
&
def
->
source
))
==
NULL
)
goto
cleanup
;
/* Create a static node record for the IQN target. Must be done
* in order for login to the target */
if
(
virISCSINodeNew
(
portal
,
pool
->
def
->
source
.
devices
[
0
].
path
)
<
0
)
if
(
virISCSINodeNew
(
portal
,
def
->
source
.
devices
[
0
].
path
)
<
0
)
goto
cleanup
;
if
(
virStorageBackendISCSISetAuth
(
portal
,
conn
,
&
pool
->
def
->
source
)
<
0
)
if
(
virStorageBackendISCSISetAuth
(
portal
,
conn
,
&
def
->
source
)
<
0
)
goto
cleanup
;
if
(
virISCSIConnectionLogin
(
portal
,
pool
->
def
->
source
.
initiator
.
iqn
,
pool
->
def
->
source
.
devices
[
0
].
path
)
<
0
)
def
->
source
.
initiator
.
iqn
,
def
->
source
.
devices
[
0
].
path
)
<
0
)
goto
cleanup
;
}
ret
=
0
;
...
...
@@ -379,9 +382,10 @@ static int
virStorageBackendISCSIRefreshPool
(
virConnectPtr
conn
ATTRIBUTE_UNUSED
,
virStoragePoolObjPtr
pool
)
{
virStoragePoolDefPtr
def
=
virStoragePoolObjGetDef
(
pool
);
char
*
session
=
NULL
;
pool
->
def
->
allocation
=
pool
->
def
->
capacity
=
pool
->
def
->
available
=
0
;
def
->
allocation
=
def
->
capacity
=
def
->
available
=
0
;
if
((
session
=
virStorageBackendISCSISession
(
pool
,
false
))
==
NULL
)
goto
cleanup
;
...
...
@@ -403,6 +407,7 @@ static int
virStorageBackendISCSIStopPool
(
virConnectPtr
conn
ATTRIBUTE_UNUSED
,
virStoragePoolObjPtr
pool
)
{
virStoragePoolDefPtr
def
=
virStoragePoolObjGetDef
(
pool
);
char
*
portal
;
char
*
session
;
int
ret
=
-
1
;
...
...
@@ -411,12 +416,12 @@ virStorageBackendISCSIStopPool(virConnectPtr conn ATTRIBUTE_UNUSED,
return
0
;
VIR_FREE
(
session
);
if
((
portal
=
virStorageBackendISCSIPortal
(
&
pool
->
def
->
source
))
==
NULL
)
if
((
portal
=
virStorageBackendISCSIPortal
(
&
def
->
source
))
==
NULL
)
return
-
1
;
if
(
virISCSIConnectionLogout
(
portal
,
pool
->
def
->
source
.
initiator
.
iqn
,
pool
->
def
->
source
.
devices
[
0
].
path
)
<
0
)
def
->
source
.
initiator
.
iqn
,
def
->
source
.
devices
[
0
].
path
)
<
0
)
goto
cleanup
;
ret
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录