Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
c3c8cd4f
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看板
提交
c3c8cd4f
编写于
10月 24, 2014
作者:
T
Taowei Luo
提交者:
Michal Privoznik
10月 29, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vbox: Rewrite vboxStoragePoolListVolumes
上级
ce381d37
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
64 addition
and
48 deletion
+64
-48
src/vbox/vbox_storage.c
src/vbox/vbox_storage.c
+56
-0
src/vbox/vbox_tmpl.c
src/vbox/vbox_tmpl.c
+6
-48
src/vbox/vbox_uniformed_api.h
src/vbox/vbox_uniformed_api.h
+2
-0
未找到文件。
src/vbox/vbox_storage.c
浏览文件 @
c3c8cd4f
...
...
@@ -147,3 +147,59 @@ int vboxStoragePoolNumOfVolumes(virStoragePoolPtr pool)
return
ret
;
}
int
vboxStoragePoolListVolumes
(
virStoragePoolPtr
pool
,
char
**
const
names
,
int
nnames
)
{
vboxGlobalData
*
data
=
pool
->
conn
->
privateData
;
vboxArray
hardDisks
=
VBOX_ARRAY_INITIALIZER
;
PRUint32
numActive
=
0
;
nsresult
rc
;
size_t
i
;
int
ret
=
-
1
;
if
(
!
data
->
vboxObj
)
{
return
ret
;
}
rc
=
gVBoxAPI
.
UArray
.
vboxArrayGet
(
&
hardDisks
,
data
->
vboxObj
,
gVBoxAPI
.
UArray
.
handleGetHardDisks
(
data
->
vboxObj
));
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not get the volume list in the pool: %s, rc=%08x"
),
pool
->
name
,
(
unsigned
)
rc
);
return
ret
;
}
for
(
i
=
0
;
i
<
hardDisks
.
count
&&
numActive
<
nnames
;
++
i
)
{
IHardDisk
*
hardDisk
=
hardDisks
.
items
[
i
];
PRUint32
hddstate
;
char
*
nameUtf8
=
NULL
;
PRUnichar
*
nameUtf16
=
NULL
;
if
(
!
hardDisk
)
continue
;
gVBoxAPI
.
UIMedium
.
GetState
(
hardDisk
,
&
hddstate
);
if
(
hddstate
==
MediaState_Inaccessible
)
continue
;
gVBoxAPI
.
UIMedium
.
GetName
(
hardDisk
,
&
nameUtf16
);
VBOX_UTF16_TO_UTF8
(
nameUtf16
,
&
nameUtf8
);
VBOX_UTF16_FREE
(
nameUtf16
);
if
(
!
nameUtf8
)
continue
;
VIR_DEBUG
(
"nnames[%d]: %s"
,
numActive
,
nameUtf8
);
if
(
VIR_STRDUP
(
names
[
numActive
],
nameUtf8
)
>
0
)
numActive
++
;
VBOX_UTF8_FREE
(
nameUtf8
);
}
gVBoxAPI
.
UArray
.
vboxArrayRelease
(
&
hardDisks
);
ret
=
numActive
;
return
ret
;
}
src/vbox/vbox_tmpl.c
浏览文件 @
c3c8cd4f
...
...
@@ -2033,54 +2033,6 @@ _registerDomainEvent(virHypervisorDriverPtr driver)
* The Storage Functions here on
*/
static
int
vboxStoragePoolListVolumes
(
virStoragePoolPtr
pool
,
char
**
const
names
,
int
nnames
)
{
VBOX_OBJECT_CHECK
(
pool
->
conn
,
int
,
-
1
);
vboxArray
hardDisks
=
VBOX_ARRAY_INITIALIZER
;
PRUint32
numActive
=
0
;
nsresult
rc
;
size_t
i
;
rc
=
vboxArrayGet
(
&
hardDisks
,
data
->
vboxObj
,
data
->
vboxObj
->
vtbl
->
GetHardDisks
);
if
(
NS_SUCCEEDED
(
rc
))
{
for
(
i
=
0
;
i
<
hardDisks
.
count
&&
numActive
<
nnames
;
++
i
)
{
IHardDisk
*
hardDisk
=
hardDisks
.
items
[
i
];
if
(
hardDisk
)
{
PRUint32
hddstate
;
char
*
nameUtf8
=
NULL
;
PRUnichar
*
nameUtf16
=
NULL
;
VBOX_MEDIUM_FUNC_ARG1
(
hardDisk
,
GetState
,
&
hddstate
);
if
(
hddstate
!=
MediaState_Inaccessible
)
{
VBOX_MEDIUM_FUNC_ARG1
(
hardDisk
,
GetName
,
&
nameUtf16
);
VBOX_UTF16_TO_UTF8
(
nameUtf16
,
&
nameUtf8
);
VBOX_UTF16_FREE
(
nameUtf16
);
if
(
nameUtf8
)
{
VIR_DEBUG
(
"nnames[%d]: %s"
,
numActive
,
nameUtf8
);
if
(
VIR_STRDUP
(
names
[
numActive
],
nameUtf8
)
>
0
)
numActive
++
;
VBOX_UTF8_FREE
(
nameUtf8
);
}
}
}
}
vboxArrayRelease
(
&
hardDisks
);
ret
=
numActive
;
}
else
{
ret
=
-
1
;
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"could not get the volume list in the pool: %s, rc=%08x"
),
pool
->
name
,
(
unsigned
)
rc
);
}
return
ret
;
}
static
virStorageVolPtr
vboxStorageVolLookupByName
(
virStoragePoolPtr
pool
,
const
char
*
name
)
{
...
...
@@ -4904,6 +4856,11 @@ static nsresult _mediumGetState(IMedium *medium, PRUint32 *state)
return
medium
->
vtbl
->
GetState
(
medium
,
state
);
}
static
nsresult
_mediumGetName
(
IMedium
*
medium
,
PRUnichar
**
name
)
{
return
medium
->
vtbl
->
GetName
(
medium
,
name
);
}
static
nsresult
_mediumGetReadOnly
(
IMedium
*
medium
ATTRIBUTE_UNUSED
,
PRBool
*
readOnly
ATTRIBUTE_UNUSED
)
{
...
...
@@ -5626,6 +5583,7 @@ static vboxUniformedIMedium _UIMedium = {
.
GetId
=
_mediumGetId
,
.
GetLocation
=
_mediumGetLocation
,
.
GetState
=
_mediumGetState
,
.
GetName
=
_mediumGetName
,
.
GetReadOnly
=
_mediumGetReadOnly
,
.
GetParent
=
_mediumGetParent
,
.
GetChildren
=
_mediumGetChildren
,
...
...
src/vbox/vbox_uniformed_api.h
浏览文件 @
c3c8cd4f
...
...
@@ -409,6 +409,7 @@ typedef struct {
nsresult
(
*
GetId
)(
IMedium
*
medium
,
vboxIIDUnion
*
iidu
);
nsresult
(
*
GetLocation
)(
IMedium
*
medium
,
PRUnichar
**
location
);
nsresult
(
*
GetState
)(
IMedium
*
medium
,
PRUint32
*
state
);
nsresult
(
*
GetName
)(
IMedium
*
medium
,
PRUnichar
**
name
);
nsresult
(
*
GetReadOnly
)(
IMedium
*
medium
,
PRBool
*
readOnly
);
nsresult
(
*
GetParent
)(
IMedium
*
medium
,
IMedium
**
parent
);
nsresult
(
*
GetChildren
)(
IMedium
*
medium
,
PRUint32
*
childrenSize
,
IMedium
***
children
);
...
...
@@ -595,6 +596,7 @@ int vboxConnectNumOfStoragePools(virConnectPtr conn);
int
vboxConnectListStoragePools
(
virConnectPtr
conn
,
char
**
const
names
,
int
nnames
);
virStoragePoolPtr
vboxStoragePoolLookupByName
(
virConnectPtr
conn
,
const
char
*
name
);
int
vboxStoragePoolNumOfVolumes
(
virStoragePoolPtr
pool
);
int
vboxStoragePoolListVolumes
(
virStoragePoolPtr
pool
,
char
**
const
names
,
int
nnames
);
/* Version specified functions for installing uniformed API */
void
vbox22InstallUniformedAPI
(
vboxUniformedAPI
*
pVBoxAPI
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录