Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
e4f24f89
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,发现更多精彩内容 >>
提交
e4f24f89
编写于
10月 02, 2014
作者:
T
Taowei
提交者:
Michal Privoznik
10月 03, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vbox: Rewrite vboxNetworkLookupByUUID
上级
85a3cd99
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
86 addition
and
44 deletion
+86
-44
src/vbox/vbox_network.c
src/vbox/vbox_network.c
+65
-0
src/vbox/vbox_tmpl.c
src/vbox/vbox_tmpl.c
+13
-44
src/vbox/vbox_uniformed_api.h
src/vbox/vbox_uniformed_api.h
+8
-0
未找到文件。
src/vbox/vbox_network.c
浏览文件 @
e4f24f89
...
...
@@ -61,6 +61,19 @@ VIR_LOG_INIT("vbox.vbox_network");
} \
} while (0)
#define vboxIIDUnalloc(iid) gVBoxAPI.UIID.vboxIIDUnalloc(data, iid)
#define vboxIIDToUUID(iid, uuid) gVBoxAPI.UIID.vboxIIDToUUID(data, iid, uuid)
#define vboxIIDFromUUID(iid, uuid) gVBoxAPI.UIID.vboxIIDFromUUID(data, iid, uuid)
#define vboxIIDIsEqual(iid1, iid2) gVBoxAPI.UIID.vboxIIDIsEqual(data, iid1, iid2)
#define DEBUGIID(msg, iid) gVBoxAPI.UIID.DEBUGIID(msg, iid)
#define vboxIIDFromArrayItem(iid, array, idx) \
gVBoxAPI.UIID.vboxIIDFromArrayItem(data, iid, array, idx)
#define VBOX_IID_INITIALIZE(iid) gVBoxAPI.UIID.vboxIIDInitialize(iid)
#define ARRAY_GET_MACHINES \
(gVBoxAPI.UArray.handleGetMachines(data->vboxObj))
static
vboxUniformedAPI
gVBoxAPI
;
/**
...
...
@@ -299,3 +312,55 @@ int vboxConnectListDefinedNetworks(virConnectPtr conn, char **const names, int n
return
ret
;
}
virNetworkPtr
vboxNetworkLookupByUUID
(
virConnectPtr
conn
,
const
unsigned
char
*
uuid
)
{
vboxGlobalData
*
data
=
conn
->
privateData
;
PRUint32
interfaceType
=
0
;
char
*
nameUtf8
=
NULL
;
PRUnichar
*
nameUtf16
=
NULL
;
IHostNetworkInterface
*
networkInterface
=
NULL
;
vboxIIDUnion
iid
;
IHost
*
host
=
NULL
;
virNetworkPtr
ret
=
NULL
;
if
(
!
data
->
vboxObj
)
return
ret
;
gVBoxAPI
.
UIVirtualBox
.
GetHost
(
data
->
vboxObj
,
&
host
);
if
(
!
host
)
return
ret
;
VBOX_IID_INITIALIZE
(
&
iid
);
vboxIIDFromUUID
(
&
iid
,
uuid
);
/* TODO: "internal" networks are just strings and
* thus can't do much with them
*/
gVBoxAPI
.
UIHost
.
FindHostNetworkInterfaceById
(
host
,
&
iid
,
&
networkInterface
);
if
(
!
networkInterface
)
goto
cleanup
;
gVBoxAPI
.
UIHNInterface
.
GetInterfaceType
(
networkInterface
,
&
interfaceType
);
if
(
interfaceType
!=
HostNetworkInterfaceType_HostOnly
)
goto
cleanup
;
gVBoxAPI
.
UIHNInterface
.
GetName
(
networkInterface
,
&
nameUtf16
);
VBOX_UTF16_TO_UTF8
(
nameUtf16
,
&
nameUtf8
);
ret
=
virGetNetwork
(
conn
,
nameUtf8
,
uuid
);
VIR_DEBUG
(
"Network Name: %s"
,
nameUtf8
);
DEBUGIID
(
"Network UUID"
,
&
iid
);
VBOX_UTF8_FREE
(
nameUtf8
);
VBOX_UTF16_FREE
(
nameUtf16
);
cleanup:
VBOX_RELEASE
(
networkInterface
);
VBOX_RELEASE
(
host
);
vboxIIDUnalloc
(
&
iid
);
return
ret
;
}
src/vbox/vbox_tmpl.c
浏览文件 @
e4f24f89
...
...
@@ -2060,50 +2060,6 @@ _registerDomainEvent(virDriverPtr driver)
* The Network Functions here on
*/
static
virNetworkPtr
vboxNetworkLookupByUUID
(
virConnectPtr
conn
,
const
unsigned
char
*
uuid
)
{
VBOX_OBJECT_HOST_CHECK
(
conn
,
virNetworkPtr
,
NULL
);
vboxIID
iid
=
VBOX_IID_INITIALIZER
;
vboxIIDFromUUID
(
&
iid
,
uuid
);
/* TODO: "internal" networks are just strings and
* thus can't do much with them
*/
IHostNetworkInterface
*
networkInterface
=
NULL
;
host
->
vtbl
->
FindHostNetworkInterfaceById
(
host
,
iid
.
value
,
&
networkInterface
);
if
(
networkInterface
)
{
PRUint32
interfaceType
=
0
;
networkInterface
->
vtbl
->
GetInterfaceType
(
networkInterface
,
&
interfaceType
);
if
(
interfaceType
==
HostNetworkInterfaceType_HostOnly
)
{
char
*
nameUtf8
=
NULL
;
PRUnichar
*
nameUtf16
=
NULL
;
networkInterface
->
vtbl
->
GetName
(
networkInterface
,
&
nameUtf16
);
VBOX_UTF16_TO_UTF8
(
nameUtf16
,
&
nameUtf8
);
ret
=
virGetNetwork
(
conn
,
nameUtf8
,
uuid
);
VIR_DEBUG
(
"Network Name: %s"
,
nameUtf8
);
DEBUGIID
(
"Network UUID"
,
iid
.
value
);
VBOX_UTF8_FREE
(
nameUtf8
);
VBOX_UTF16_FREE
(
nameUtf16
);
}
VBOX_RELEASE
(
networkInterface
);
}
VBOX_RELEASE
(
host
);
vboxIIDUnalloc
(
&
iid
);
return
ret
;
}
static
virNetworkPtr
vboxNetworkLookupByName
(
virConnectPtr
conn
,
const
char
*
name
)
{
...
...
@@ -5896,6 +5852,14 @@ _displayTakeScreenShotPNGToArray(IDisplay *display ATTRIBUTE_UNUSED,
#endif
/* VBOX_API_VERSION >= 4000000 */
}
static
nsresult
_hostFindHostNetworkInterfaceById
(
IHost
*
host
,
vboxIIDUnion
*
iidu
,
IHostNetworkInterface
**
networkInterface
)
{
return
host
->
vtbl
->
FindHostNetworkInterfaceById
(
host
,
IID_MEMBER
(
value
),
networkInterface
);
}
static
nsresult
_hnInterfaceGetInterfaceType
(
IHostNetworkInterface
*
hni
,
PRUint32
*
interfaceType
)
{
...
...
@@ -6217,6 +6181,10 @@ static vboxUniformedIDisplay _UIDisplay = {
.
TakeScreenShotPNGToArray
=
_displayTakeScreenShotPNGToArray
,
};
static
vboxUniformedIHost
_UIHost
=
{
.
FindHostNetworkInterfaceById
=
_hostFindHostNetworkInterfaceById
,
};
static
vboxUniformedIHNInterface
_UIHNInterface
=
{
.
GetInterfaceType
=
_hnInterfaceGetInterfaceType
,
.
GetStatus
=
_hnInterfaceGetStatus
,
...
...
@@ -6276,6 +6244,7 @@ void NAME(InstallUniformedAPI)(vboxUniformedAPI *pVBoxAPI)
pVBoxAPI
->
UISharedFolder
=
_UISharedFolder
;
pVBoxAPI
->
UISnapshot
=
_UISnapshot
;
pVBoxAPI
->
UIDisplay
=
_UIDisplay
;
pVBoxAPI
->
UIHost
=
_UIHost
;
pVBoxAPI
->
UIHNInterface
=
_UIHNInterface
;
pVBoxAPI
->
machineStateChecker
=
_machineStateChecker
;
...
...
src/vbox/vbox_uniformed_api.h
浏览文件 @
e4f24f89
...
...
@@ -466,6 +466,12 @@ typedef struct {
PRUint8
**
screenData
);
}
vboxUniformedIDisplay
;
/* Functions for IHost */
typedef
struct
{
nsresult
(
*
FindHostNetworkInterfaceById
)(
IHost
*
host
,
vboxIIDUnion
*
iidu
,
IHostNetworkInterface
**
networkInterface
);
}
vboxUniformedIHost
;
/* Functions for IHostNetworkInterface */
typedef
struct
{
nsresult
(
*
GetInterfaceType
)(
IHostNetworkInterface
*
hni
,
PRUint32
*
interfaceType
);
...
...
@@ -527,6 +533,7 @@ typedef struct {
vboxUniformedISharedFolder
UISharedFolder
;
vboxUniformedISnapshot
UISnapshot
;
vboxUniformedIDisplay
UIDisplay
;
vboxUniformedIHost
UIHost
;
vboxUniformedIHNInterface
UIHNInterface
;
uniformedMachineStateChecker
machineStateChecker
;
/* vbox API features */
...
...
@@ -552,6 +559,7 @@ int vboxConnectNumOfNetworks(virConnectPtr conn);
int
vboxConnectListNetworks
(
virConnectPtr
conn
,
char
**
const
names
,
int
nnames
);
int
vboxConnectNumOfDefinedNetworks
(
virConnectPtr
conn
);
int
vboxConnectListDefinedNetworks
(
virConnectPtr
conn
,
char
**
const
names
,
int
nnames
);
virNetworkPtr
vboxNetworkLookupByUUID
(
virConnectPtr
conn
,
const
unsigned
char
*
uuid
);
/* 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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录