Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
8da9516a
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,发现更多精彩内容 >>
提交
8da9516a
编写于
5月 24, 2013
作者:
O
Osier Yang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
qemu: Abstract code for the cpu controller setting into a helper
上级
38b90e4d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
36 addition
and
19 deletion
+36
-19
src/qemu/qemu_cgroup.c
src/qemu/qemu_cgroup.c
+36
-19
未找到文件。
src/qemu/qemu_cgroup.c
浏览文件 @
8da9516a
...
...
@@ -676,6 +676,36 @@ cleanup:
}
static
int
qemuSetupCpuCgroup
(
virDomainObjPtr
vm
)
{
qemuDomainObjPrivatePtr
priv
=
vm
->
privateData
;
int
rc
=
-
1
;
if
(
!
virCgroupHasController
(
priv
->
cgroup
,
VIR_CGROUP_CONTROLLER_CPU
))
{
if
(
vm
->
def
->
cputune
.
shares
)
{
virReportError
(
VIR_ERR_CONFIG_UNSUPPORTED
,
"%s"
,
_
(
"CPU tuning is not available on this host"
));
return
-
1
;
}
else
{
return
0
;
}
}
if
(
vm
->
def
->
cputune
.
shares
)
{
rc
=
virCgroupSetCpuShares
(
priv
->
cgroup
,
vm
->
def
->
cputune
.
shares
);
if
(
rc
!=
0
)
{
virReportSystemError
(
-
rc
,
_
(
"Unable to set io cpu shares for domain %s"
),
vm
->
def
->
name
);
return
-
1
;
}
}
return
0
;
}
int
qemuInitCgroup
(
virQEMUDriverPtr
driver
,
virDomainObjPtr
vm
,
bool
startup
)
...
...
@@ -789,14 +819,14 @@ int qemuSetupCgroup(virQEMUDriverPtr driver,
virDomainObjPtr
vm
,
virBitmapPtr
nodemask
)
{
int
rc
=
-
1
;
qemuDomainObjPrivatePtr
priv
=
vm
->
privateData
;
int
ret
=
-
1
;
if
(
qemuInitCgroup
(
driver
,
vm
,
true
)
<
0
)
return
-
1
;
if
(
!
priv
->
cgroup
)
goto
done
;
return
0
;
if
(
qemuSetupDevicesCgroup
(
driver
,
vm
)
<
0
)
goto
cleanup
;
...
...
@@ -807,28 +837,15 @@ int qemuSetupCgroup(virQEMUDriverPtr driver,
if
(
qemuSetupMemoryCgroup
(
vm
)
<
0
)
goto
cleanup
;
if
(
vm
->
def
->
cputune
.
shares
!=
0
)
{
if
(
virCgroupHasController
(
priv
->
cgroup
,
VIR_CGROUP_CONTROLLER_CPU
))
{
rc
=
virCgroupSetCpuShares
(
priv
->
cgroup
,
vm
->
def
->
cputune
.
shares
);
if
(
rc
!=
0
)
{
virReportSystemError
(
-
rc
,
_
(
"Unable to set io cpu shares for domain %s"
),
vm
->
def
->
name
);
goto
cleanup
;
}
}
else
{
virReportError
(
VIR_ERR_CONFIG_UNSUPPORTED
,
"%s"
,
_
(
"CPU tuning is not available on this host"
));
}
}
if
(
qemuSetupCpuCgroup
(
vm
)
<
0
)
goto
cleanup
;
if
(
qemuSetupCpusetCgroup
(
vm
,
nodemask
)
<
0
)
goto
cleanup
;
done:
rc
=
0
;
ret
=
0
;
cleanup:
return
r
c
==
0
?
0
:
-
1
;
return
r
et
;
}
int
qemuSetupCgroupVcpuBW
(
virCgroupPtr
cgroup
,
unsigned
long
long
period
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录