Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
9dd4f8ed
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看板
提交
9dd4f8ed
编写于
8月 11, 2014
作者:
T
Taowei
提交者:
Michal Privoznik
8月 15, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vbox: Rewrite vboxDomainLookupById
上级
5f15b511
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
90 addition
and
68 deletion
+90
-68
src/vbox/vbox_common.c
src/vbox/vbox_common.c
+73
-0
src/vbox/vbox_tmpl.c
src/vbox/vbox_tmpl.c
+14
-68
src/vbox/vbox_uniformed_api.h
src/vbox/vbox_uniformed_api.h
+3
-0
未找到文件。
src/vbox/vbox_common.c
浏览文件 @
9dd4f8ed
...
...
@@ -551,3 +551,76 @@ int vboxConnectNumOfDomains(virConnectPtr conn)
gVBoxAPI
.
UArray
.
vboxArrayRelease
(
&
machines
);
return
ret
;
}
virDomainPtr
vboxDomainLookupByID
(
virConnectPtr
conn
,
int
id
)
{
VBOX_OBJECT_CHECK
(
conn
,
virDomainPtr
,
NULL
);
vboxArray
machines
=
VBOX_ARRAY_INITIALIZER
;
IMachine
*
machine
;
PRBool
isAccessible
=
PR_FALSE
;
PRUnichar
*
machineNameUtf16
=
NULL
;
char
*
machineNameUtf8
=
NULL
;
vboxIIDUnion
iid
;
unsigned
char
uuid
[
VIR_UUID_BUFLEN
];
PRUint32
state
;
nsresult
rc
;
VBOX_IID_INITIALIZE
(
&
iid
);
/* Internal vbox IDs start from 0, the public libvirt ID
* starts from 1, so refuse id == 0, and adjust the rest*/
if
(
id
==
0
)
{
virReportError
(
VIR_ERR_NO_DOMAIN
,
_
(
"no domain with matching id %d"
),
id
);
return
NULL
;
}
id
=
id
-
1
;
rc
=
gVBoxAPI
.
UArray
.
vboxArrayGet
(
&
machines
,
data
->
vboxObj
,
ARRAY_GET_MACHINES
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"Could not get list of machines, rc=%08x"
),
(
unsigned
)
rc
);
return
NULL
;
}
if
(
id
>=
machines
.
count
)
goto
cleanup
;
machine
=
machines
.
items
[
id
];
if
(
!
machine
)
goto
cleanup
;
isAccessible
=
PR_FALSE
;
gVBoxAPI
.
UIMachine
.
GetAccessible
(
machine
,
&
isAccessible
);
if
(
!
isAccessible
)
goto
cleanup
;
gVBoxAPI
.
UIMachine
.
GetState
(
machine
,
&
state
);
if
(
!
gVBoxAPI
.
machineStateChecker
.
Online
(
state
))
goto
cleanup
;
gVBoxAPI
.
UIMachine
.
GetName
(
machine
,
&
machineNameUtf16
);
VBOX_UTF16_TO_UTF8
(
machineNameUtf16
,
&
machineNameUtf8
);
gVBoxAPI
.
UIMachine
.
GetId
(
machine
,
&
iid
);
vboxIIDToUUID
(
&
iid
,
uuid
);
vboxIIDUnalloc
(
&
iid
);
/* get a new domain pointer from virGetDomain, if it fails
* then no need to assign the id, else assign the id, cause
* it is -1 by default. rest is taken care by virGetDomain
* itself, so need not worry.
*/
ret
=
virGetDomain
(
conn
,
machineNameUtf8
,
uuid
);
if
(
ret
)
ret
->
id
=
id
+
1
;
/* Cleanup all the XPCOM allocated stuff here */
VBOX_UTF8_FREE
(
machineNameUtf8
);
VBOX_UTF16_FREE
(
machineNameUtf16
);
cleanup:
gVBoxAPI
.
UArray
.
vboxArrayRelease
(
&
machines
);
return
ret
;
}
src/vbox/vbox_tmpl.c
浏览文件 @
9dd4f8ed
...
...
@@ -949,74 +949,6 @@ static virDomainPtr vboxDomainCreateXML(virConnectPtr conn, const char *xml,
return
dom
;
}
static
virDomainPtr
vboxDomainLookupByID
(
virConnectPtr
conn
,
int
id
)
{
VBOX_OBJECT_CHECK
(
conn
,
virDomainPtr
,
NULL
);
vboxArray
machines
=
VBOX_ARRAY_INITIALIZER
;
vboxIID
iid
=
VBOX_IID_INITIALIZER
;
unsigned
char
uuid
[
VIR_UUID_BUFLEN
];
PRUint32
state
;
nsresult
rc
;
/* Internal vbox IDs start from 0, the public libvirt ID
* starts from 1, so refuse id == 0, and adjust the rest*/
if
(
id
==
0
)
{
virReportError
(
VIR_ERR_NO_DOMAIN
,
_
(
"no domain with matching id %d"
),
id
);
return
NULL
;
}
id
=
id
-
1
;
rc
=
vboxArrayGet
(
&
machines
,
data
->
vboxObj
,
data
->
vboxObj
->
vtbl
->
GetMachines
);
if
(
NS_FAILED
(
rc
))
{
virReportError
(
VIR_ERR_INTERNAL_ERROR
,
_
(
"Could not get list of machines, rc=%08x"
),
(
unsigned
)
rc
);
return
NULL
;
}
if
(
id
<
machines
.
count
)
{
IMachine
*
machine
=
machines
.
items
[
id
];
if
(
machine
)
{
PRBool
isAccessible
=
PR_FALSE
;
machine
->
vtbl
->
GetAccessible
(
machine
,
&
isAccessible
);
if
(
isAccessible
)
{
machine
->
vtbl
->
GetState
(
machine
,
&
state
);
if
((
state
>=
MachineState_FirstOnline
)
&&
(
state
<=
MachineState_LastOnline
))
{
PRUnichar
*
machineNameUtf16
=
NULL
;
char
*
machineNameUtf8
=
NULL
;
machine
->
vtbl
->
GetName
(
machine
,
&
machineNameUtf16
);
VBOX_UTF16_TO_UTF8
(
machineNameUtf16
,
&
machineNameUtf8
);
machine
->
vtbl
->
GetId
(
machine
,
&
iid
.
value
);
vboxIIDToUUID
(
&
iid
,
uuid
);
vboxIIDUnalloc
(
&
iid
);
/* get a new domain pointer from virGetDomain, if it fails
* then no need to assign the id, else assign the id, cause
* it is -1 by default. rest is taken care by virGetDomain
* itself, so need not worry.
*/
ret
=
virGetDomain
(
conn
,
machineNameUtf8
,
uuid
);
if
(
ret
)
ret
->
id
=
id
+
1
;
/* Cleanup all the XPCOM allocated stuff here */
VBOX_UTF8_FREE
(
machineNameUtf8
);
VBOX_UTF16_FREE
(
machineNameUtf16
);
}
}
}
}
vboxArrayRelease
(
&
machines
);
return
ret
;
}
static
virDomainPtr
vboxDomainLookupByUUID
(
virConnectPtr
conn
,
const
unsigned
char
*
uuid
)
{
...
...
@@ -11267,6 +11199,18 @@ _machineGetState(IMachine *machine, PRUint32 *state)
return
machine
->
vtbl
->
GetState
(
machine
,
state
);
}
static
nsresult
_machineGetName
(
IMachine
*
machine
,
PRUnichar
**
name
)
{
return
machine
->
vtbl
->
GetName
(
machine
,
name
);
}
static
nsresult
_machineGetId
(
IMachine
*
machine
,
vboxIIDUnion
*
iidu
)
{
return
machine
->
vtbl
->
GetId
(
machine
,
&
IID_MEMBER
(
value
));
}
#if VBOX_API_VERSION < 4000000
static
nsresult
...
...
@@ -11376,6 +11320,8 @@ static vboxUniformedIVirtualBox _UIVirtualBox = {
static
vboxUniformedIMachine
_UIMachine
=
{
.
GetAccessible
=
_machineGetAccessible
,
.
GetState
=
_machineGetState
,
.
GetName
=
_machineGetName
,
.
GetId
=
_machineGetId
,
};
static
vboxUniformedISession
_UISession
=
{
...
...
src/vbox/vbox_uniformed_api.h
浏览文件 @
9dd4f8ed
...
...
@@ -186,6 +186,8 @@ typedef struct {
typedef
struct
{
nsresult
(
*
GetAccessible
)(
IMachine
*
machine
,
PRBool
*
isAccessible
);
nsresult
(
*
GetState
)(
IMachine
*
machine
,
PRUint32
*
state
);
nsresult
(
*
GetName
)(
IMachine
*
machine
,
PRUnichar
**
name
);
nsresult
(
*
GetId
)(
IMachine
*
machine
,
vboxIIDUnion
*
iidu
);
}
vboxUniformedIMachine
;
/* Functions for ISession */
...
...
@@ -257,6 +259,7 @@ int vboxConnectGetMaxVcpus(virConnectPtr conn, const char *type);
char
*
vboxConnectGetCapabilities
(
virConnectPtr
conn
);
int
vboxConnectListDomains
(
virConnectPtr
conn
,
int
*
ids
,
int
nids
);
int
vboxConnectNumOfDomains
(
virConnectPtr
conn
);
virDomainPtr
vboxDomainLookupByID
(
virConnectPtr
conn
,
int
id
);
/* 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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录