Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
5d6f6367
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看板
提交
5d6f6367
编写于
2月 19, 2013
作者:
J
Jiri Denemark
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
qemu: Use atomic ops for driver->nactive
上级
921af429
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
6 addition
and
9 deletion
+6
-9
src/qemu/qemu_conf.h
src/qemu/qemu_conf.h
+1
-1
src/qemu/qemu_process.c
src/qemu/qemu_process.c
+5
-8
未找到文件。
src/qemu/qemu_conf.h
浏览文件 @
5d6f6367
...
...
@@ -168,7 +168,7 @@ struct _virQEMUDriver {
virCgroupPtr
cgroup
;
/* Atomic inc/dec only */
size_
t
nactive
;
unsigned
in
t
nactive
;
/* Immutable pointers. Caller must provide locking */
virStateInhibitCallback
inhibitCallback
;
...
...
src/qemu/qemu_process.c
浏览文件 @
5d6f6367
...
...
@@ -69,6 +69,7 @@
#include "virtime.h"
#include "virnetdevtap.h"
#include "virbitmap.h"
#include "viratomic.h"
#define VIR_FROM_THIS VIR_FROM_QEMU
...
...
@@ -3300,9 +3301,8 @@ qemuProcessReconnect(void *opaque)
goto
error
;
}
if
(
!
driver
->
nactive
&&
driver
->
inhibitCallback
)
if
(
virAtomicIntInc
(
&
driver
->
nactive
)
==
1
&&
driver
->
inhibitCallback
)
driver
->
inhibitCallback
(
true
,
driver
->
inhibitOpaque
);
driver
->
nactive
++
;
endjob:
if
(
!
qemuDomainObjEndJob
(
driver
,
obj
))
...
...
@@ -3589,9 +3589,8 @@ int qemuProcessStart(virConnectPtr conn,
qemuDomainSetFakeReboot
(
driver
,
vm
,
false
);
virDomainObjSetState
(
vm
,
VIR_DOMAIN_SHUTOFF
,
VIR_DOMAIN_SHUTOFF_UNKNOWN
);
if
(
!
driver
->
nactive
&&
driver
->
inhibitCallback
)
if
(
virAtomicIntInc
(
&
driver
->
nactive
)
==
1
&&
driver
->
inhibitCallback
)
driver
->
inhibitCallback
(
true
,
driver
->
inhibitOpaque
);
driver
->
nactive
++
;
/* Run an early hook to set-up missing devices */
if
(
virHookPresent
(
VIR_HOOK_DRIVER_QEMU
))
{
...
...
@@ -4188,8 +4187,7 @@ void qemuProcessStop(virQEMUDriverPtr driver,
*/
vm
->
def
->
id
=
-
1
;
driver
->
nactive
--
;
if
(
!
driver
->
nactive
&&
driver
->
inhibitCallback
)
if
(
virAtomicIntDecAndTest
(
&
driver
->
nactive
)
&&
driver
->
inhibitCallback
)
driver
->
inhibitCallback
(
false
,
driver
->
inhibitOpaque
);
if
((
logfile
=
qemuDomainCreateLog
(
driver
,
vm
,
true
))
<
0
)
{
...
...
@@ -4442,9 +4440,8 @@ int qemuProcessAttach(virConnectPtr conn ATTRIBUTE_UNUSED,
vm
->
def
->
id
=
qemuDriverAllocateID
(
driver
);
if
(
!
driver
->
nactive
&&
driver
->
inhibitCallback
)
if
(
virAtomicIntInc
(
&
driver
->
nactive
)
==
1
&&
driver
->
inhibitCallback
)
driver
->
inhibitCallback
(
true
,
driver
->
inhibitOpaque
);
driver
->
nactive
++
;
if
(
virFileMakePath
(
cfg
->
logDir
)
<
0
)
{
virReportSystemError
(
errno
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录