Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
8f03c6e8
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
8f03c6e8
编写于
4月 14, 2011
作者:
E
Eric Blake
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
phyp: avoid memory leak on failure
* src/phyp/phyp_driver.c (phypUUIDTable_Init): Avoid memory leak on error.
上级
ef6147c4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
27 addition
and
19 deletion
+27
-19
src/phyp/phyp_driver.c
src/phyp/phyp_driver.c
+27
-19
未找到文件。
src/phyp/phyp_driver.c
浏览文件 @
8f03c6e8
...
...
@@ -807,31 +807,35 @@ phypUUIDTable_Pull(virConnectPtr conn)
static
int
phypUUIDTable_Init
(
virConnectPtr
conn
)
{
uuid_tablePtr
uuid_table
;
uuid_tablePtr
uuid_table
=
NULL
;
phyp_driverPtr
phyp_driver
;
int
nids_numdomains
=
0
;
int
nids_listdomains
=
0
;
int
*
ids
=
NULL
;
unsigned
int
i
=
0
;
int
ret
=
-
1
;
bool
table_created
=
false
;
if
((
nids_numdomains
=
phypNumDomainsGeneric
(
conn
,
2
))
<
0
)
goto
err
;
goto
cleanup
;
if
(
VIR_ALLOC_N
(
ids
,
nids_numdomains
)
<
0
)
{
virReportOOMError
();
goto
err
;
goto
cleanup
;
}
if
((
nids_listdomains
=
phypListDomainsGeneric
(
conn
,
ids
,
nids_numdomains
,
1
))
<
0
)
goto
err
;
goto
cleanup
;
/* exit early if there are no domains */
if
(
nids_numdomains
==
0
&&
nids_listdomains
==
0
)
goto
exit
;
else
if
(
nids_numdomains
!=
nids_listdomains
)
{
if
(
nids_numdomains
==
0
&&
nids_listdomains
==
0
)
{
ret
=
0
;
goto
cleanup
;
}
if
(
nids_numdomains
!=
nids_listdomains
)
{
VIR_ERROR0
(
_
(
"Unable to determine number of domains."
));
goto
err
;
goto
cleanup
;
}
phyp_driver
=
conn
->
privateData
;
...
...
@@ -841,11 +845,12 @@ phypUUIDTable_Init(virConnectPtr conn)
/* try to get the table from server */
if
(
phypUUIDTable_Pull
(
conn
)
==
-
1
)
{
/* file not found in the server, creating a new one */
table_created
=
true
;
if
(
VIR_ALLOC_N
(
uuid_table
->
lpars
,
uuid_table
->
nlpars
)
>=
0
)
{
for
(
i
=
0
;
i
<
uuid_table
->
nlpars
;
i
++
)
{
if
(
VIR_ALLOC
(
uuid_table
->
lpars
[
i
])
<
0
)
{
virReportOOMError
();
goto
err
;
goto
cleanup
;
}
uuid_table
->
lpars
[
i
]
->
id
=
ids
[
i
];
...
...
@@ -855,27 +860,30 @@ phypUUIDTable_Init(virConnectPtr conn)
}
}
else
{
virReportOOMError
();
goto
err
;
goto
cleanup
;
}
if
(
phypUUIDTable_WriteFile
(
conn
)
==
-
1
)
goto
err
;
goto
cleanup
;
if
(
phypUUIDTable_Push
(
conn
)
==
-
1
)
goto
err
;
goto
cleanup
;
}
else
{
if
(
phypUUIDTable_ReadFile
(
conn
)
==
-
1
)
goto
err
;
goto
exit
;
goto
cleanup
;
}
exit:
VIR_FREE
(
ids
);
return
0
;
ret
=
0
;
err:
cleanup:
if
(
ret
<
0
&&
table_created
)
{
for
(
i
=
0
;
i
<
uuid_table
->
nlpars
;
i
++
)
{
VIR_FREE
(
uuid_table
->
lpars
[
i
]);
}
VIR_FREE
(
uuid_table
->
lpars
);
}
VIR_FREE
(
ids
);
return
-
1
;
return
ret
;
}
static
void
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录