Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
a5e72f91
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看板
提交
a5e72f91
编写于
11月 17, 2008
作者:
D
Daniel P. Berrange
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add QEMU driver events for defined/undefined config files
上级
d3d54d2f
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
67 addition
and
10 deletion
+67
-10
ChangeLog
ChangeLog
+10
-0
src/domain_conf.c
src/domain_conf.c
+16
-5
src/domain_conf.h
src/domain_conf.h
+10
-2
src/lxc_driver.c
src/lxc_driver.c
+2
-1
src/qemu_driver.c
src/qemu_driver.c
+29
-2
未找到文件。
ChangeLog
浏览文件 @
a5e72f91
Mon Nov 17 16:45:00 GMT 2008 Daniel Berrange <berrange@redhat.com>
Generate domain events for QEMU driver config files
* src/qemu_driver.c: Generate events when config is defined
and undefined
* src/domain_conf.c, src/domain_conf.h: Add a callback for
notifications of each loaded config file
* src/lxc_driver.c: Pass NULL for config file notification
callback parameter
Mon Nov 17 16:42:00 GMT 2008 Daniel Berrange <berrange@redhat.com>
Mon Nov 17 16:42:00 GMT 2008 Daniel Berrange <berrange@redhat.com>
Include an event 'detail' field providing the cause of
Include an event 'detail' field providing the cause of
...
...
src/domain_conf.c
浏览文件 @
a5e72f91
...
@@ -3242,31 +3242,38 @@ virDomainObjPtr virDomainLoadConfig(virConnectPtr conn,
...
@@ -3242,31 +3242,38 @@ virDomainObjPtr virDomainLoadConfig(virConnectPtr conn,
virDomainObjListPtr
doms
,
virDomainObjListPtr
doms
,
const
char
*
configDir
,
const
char
*
configDir
,
const
char
*
autostartDir
,
const
char
*
autostartDir
,
const
char
*
name
)
const
char
*
name
,
virDomainLoadConfigNotify
notify
,
void
*
opaque
)
{
{
char
*
configFile
=
NULL
,
*
autostartLink
=
NULL
;
char
*
configFile
=
NULL
,
*
autostartLink
=
NULL
;
virDomainDefPtr
def
=
NULL
;
virDomainDefPtr
def
=
NULL
;
virDomainObjPtr
dom
;
virDomainObjPtr
dom
;
int
autostart
;
int
autostart
;
int
newVM
=
1
;
if
((
configFile
=
virDomainConfigFile
(
conn
,
configDir
,
name
))
==
NULL
)
if
((
configFile
=
virDomainConfigFile
(
conn
,
configDir
,
name
))
==
NULL
)
goto
error
;
goto
error
;
if
((
autostartLink
=
virDomainConfigFile
(
conn
,
autostartDir
,
name
))
==
NULL
)
if
((
autostartLink
=
virDomainConfigFile
(
conn
,
autostartDir
,
name
))
==
NULL
)
goto
error
;
goto
error
;
if
((
autostart
=
virFileLinkPointsTo
(
autostartLink
,
configFile
))
<
0
)
if
((
autostart
=
virFileLinkPointsTo
(
autostartLink
,
configFile
))
<
0
)
goto
error
;
goto
error
;
if
(
!
(
def
=
virDomainDefParseFile
(
conn
,
caps
,
configFile
)))
if
(
!
(
def
=
virDomainDefParseFile
(
conn
,
caps
,
configFile
)))
goto
error
;
goto
error
;
if
(
virDomainFindByName
(
doms
,
def
->
name
))
newVM
=
0
;
if
(
!
(
dom
=
virDomainAssignDef
(
conn
,
doms
,
def
)))
if
(
!
(
dom
=
virDomainAssignDef
(
conn
,
doms
,
def
)))
goto
error
;
goto
error
;
dom
->
state
=
VIR_DOMAIN_SHUTOFF
;
dom
->
autostart
=
autostart
;
dom
->
autostart
=
autostart
;
if
(
notify
)
(
*
notify
)(
dom
,
newVM
,
opaque
);
return
dom
;
return
dom
;
error:
error:
...
@@ -3280,7 +3287,9 @@ int virDomainLoadAllConfigs(virConnectPtr conn,
...
@@ -3280,7 +3287,9 @@ int virDomainLoadAllConfigs(virConnectPtr conn,
virCapsPtr
caps
,
virCapsPtr
caps
,
virDomainObjListPtr
doms
,
virDomainObjListPtr
doms
,
const
char
*
configDir
,
const
char
*
configDir
,
const
char
*
autostartDir
)
const
char
*
autostartDir
,
virDomainLoadConfigNotify
notify
,
void
*
opaque
)
{
{
DIR
*
dir
;
DIR
*
dir
;
struct
dirent
*
entry
;
struct
dirent
*
entry
;
...
@@ -3310,7 +3319,9 @@ int virDomainLoadAllConfigs(virConnectPtr conn,
...
@@ -3310,7 +3319,9 @@ int virDomainLoadAllConfigs(virConnectPtr conn,
doms
,
doms
,
configDir
,
configDir
,
autostartDir
,
autostartDir
,
entry
->
d_name
);
entry
->
d_name
,
notify
,
opaque
);
if
(
dom
)
if
(
dom
)
dom
->
persistent
=
1
;
dom
->
persistent
=
1
;
}
}
...
...
src/domain_conf.h
浏览文件 @
a5e72f91
...
@@ -549,18 +549,26 @@ int virDomainSaveConfig(virConnectPtr conn,
...
@@ -549,18 +549,26 @@ int virDomainSaveConfig(virConnectPtr conn,
const
char
*
configDir
,
const
char
*
configDir
,
virDomainDefPtr
def
);
virDomainDefPtr
def
);
typedef
void
(
*
virDomainLoadConfigNotify
)(
virDomainObjPtr
dom
,
int
newDomain
,
void
*
opaque
);
virDomainObjPtr
virDomainLoadConfig
(
virConnectPtr
conn
,
virDomainObjPtr
virDomainLoadConfig
(
virConnectPtr
conn
,
virCapsPtr
caps
,
virCapsPtr
caps
,
virDomainObjListPtr
doms
,
virDomainObjListPtr
doms
,
const
char
*
configDir
,
const
char
*
configDir
,
const
char
*
autostartDir
,
const
char
*
autostartDir
,
const
char
*
name
);
const
char
*
name
,
virDomainLoadConfigNotify
notify
,
void
*
opaque
);
int
virDomainLoadAllConfigs
(
virConnectPtr
conn
,
int
virDomainLoadAllConfigs
(
virConnectPtr
conn
,
virCapsPtr
caps
,
virCapsPtr
caps
,
virDomainObjListPtr
doms
,
virDomainObjListPtr
doms
,
const
char
*
configDir
,
const
char
*
configDir
,
const
char
*
autostartDir
);
const
char
*
autostartDir
,
virDomainLoadConfigNotify
notify
,
void
*
opaque
);
int
virDomainDeleteConfig
(
virConnectPtr
conn
,
int
virDomainDeleteConfig
(
virConnectPtr
conn
,
const
char
*
configDir
,
const
char
*
configDir
,
...
...
src/lxc_driver.c
浏览文件 @
a5e72f91
...
@@ -1015,7 +1015,8 @@ static int lxcStartup(void)
...
@@ -1015,7 +1015,8 @@ static int lxcStartup(void)
lxc_driver
->
caps
,
lxc_driver
->
caps
,
&
lxc_driver
->
domains
,
&
lxc_driver
->
domains
,
lxc_driver
->
configDir
,
lxc_driver
->
configDir
,
lxc_driver
->
autostartDir
)
<
0
)
{
lxc_driver
->
autostartDir
,
NULL
,
NULL
)
<
0
)
{
lxcShutdown
();
lxcShutdown
();
return
-
1
;
return
-
1
;
}
}
...
...
src/qemu_driver.c
浏览文件 @
a5e72f91
...
@@ -226,7 +226,8 @@ qemudStartup(void) {
...
@@ -226,7 +226,8 @@ qemudStartup(void) {
qemu_driver
->
caps
,
qemu_driver
->
caps
,
&
qemu_driver
->
domains
,
&
qemu_driver
->
domains
,
qemu_driver
->
configDir
,
qemu_driver
->
configDir
,
qemu_driver
->
autostartDir
)
<
0
)
{
qemu_driver
->
autostartDir
,
NULL
,
NULL
)
<
0
)
{
qemudShutdown
();
qemudShutdown
();
return
-
1
;
return
-
1
;
}
}
...
@@ -243,6 +244,16 @@ qemudStartup(void) {
...
@@ -243,6 +244,16 @@ qemudStartup(void) {
return
-
1
;
return
-
1
;
}
}
static
void
qemudNotifyLoadDomain
(
virDomainObjPtr
vm
,
int
newVM
,
void
*
opaque
)
{
struct
qemud_driver
*
driver
=
opaque
;
if
(
newVM
)
qemudDomainEventDispatch
(
driver
,
vm
,
VIR_DOMAIN_EVENT_DEFINED
,
VIR_DOMAIN_EVENT_DEFINED_ADDED
);
}
/**
/**
* qemudReload:
* qemudReload:
*
*
...
@@ -258,7 +269,8 @@ qemudReload(void) {
...
@@ -258,7 +269,8 @@ qemudReload(void) {
qemu_driver
->
caps
,
qemu_driver
->
caps
,
&
qemu_driver
->
domains
,
&
qemu_driver
->
domains
,
qemu_driver
->
configDir
,
qemu_driver
->
configDir
,
qemu_driver
->
autostartDir
);
qemu_driver
->
autostartDir
,
qemudNotifyLoadDomain
,
qemu_driver
);
qemudAutostartConfigs
(
qemu_driver
);
qemudAutostartConfigs
(
qemu_driver
);
...
@@ -2365,10 +2377,15 @@ static virDomainPtr qemudDomainDefine(virConnectPtr conn, const char *xml) {
...
@@ -2365,10 +2377,15 @@ static virDomainPtr qemudDomainDefine(virConnectPtr conn, const char *xml) {
virDomainDefPtr
def
;
virDomainDefPtr
def
;
virDomainObjPtr
vm
;
virDomainObjPtr
vm
;
virDomainPtr
dom
;
virDomainPtr
dom
;
int
newVM
=
1
;
if
(
!
(
def
=
virDomainDefParseString
(
conn
,
driver
->
caps
,
xml
)))
if
(
!
(
def
=
virDomainDefParseString
(
conn
,
driver
->
caps
,
xml
)))
return
NULL
;
return
NULL
;
vm
=
virDomainFindByName
(
&
driver
->
domains
,
def
->
name
);
if
(
vm
)
newVM
=
0
;
if
(
!
(
vm
=
virDomainAssignDef
(
conn
,
if
(
!
(
vm
=
virDomainAssignDef
(
conn
,
&
driver
->
domains
,
&
driver
->
domains
,
def
)))
{
def
)))
{
...
@@ -2385,6 +2402,12 @@ static virDomainPtr qemudDomainDefine(virConnectPtr conn, const char *xml) {
...
@@ -2385,6 +2402,12 @@ static virDomainPtr qemudDomainDefine(virConnectPtr conn, const char *xml) {
return
NULL
;
return
NULL
;
}
}
qemudDomainEventDispatch
(
driver
,
vm
,
VIR_DOMAIN_EVENT_DEFINED
,
newVM
?
VIR_DOMAIN_EVENT_DEFINED_ADDED
:
VIR_DOMAIN_EVENT_DEFINED_UPDATED
);
dom
=
virGetDomain
(
conn
,
vm
->
def
->
name
,
vm
->
def
->
uuid
);
dom
=
virGetDomain
(
conn
,
vm
->
def
->
name
,
vm
->
def
->
uuid
);
if
(
dom
)
dom
->
id
=
vm
->
def
->
id
;
if
(
dom
)
dom
->
id
=
vm
->
def
->
id
;
return
dom
;
return
dom
;
...
@@ -2415,6 +2438,10 @@ static int qemudDomainUndefine(virDomainPtr dom) {
...
@@ -2415,6 +2438,10 @@ static int qemudDomainUndefine(virDomainPtr dom) {
if
(
virDomainDeleteConfig
(
dom
->
conn
,
driver
->
configDir
,
driver
->
autostartDir
,
vm
)
<
0
)
if
(
virDomainDeleteConfig
(
dom
->
conn
,
driver
->
configDir
,
driver
->
autostartDir
,
vm
)
<
0
)
return
-
1
;
return
-
1
;
qemudDomainEventDispatch
(
driver
,
vm
,
VIR_DOMAIN_EVENT_UNDEFINED
,
VIR_DOMAIN_EVENT_UNDEFINED_REMOVED
);
virDomainRemoveInactive
(
&
driver
->
domains
,
virDomainRemoveInactive
(
&
driver
->
domains
,
vm
);
vm
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录