Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
104fdbf0
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看板
提交
104fdbf0
编写于
10月 27, 2009
作者:
C
Cole Robinson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
test: Implement virDomainPinVcpu
上级
07a107f0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
58 addition
and
1 deletion
+58
-1
src/test/test_driver.c
src/test/test_driver.c
+58
-1
未找到文件。
src/test/test_driver.c
浏览文件 @
104fdbf0
...
...
@@ -2094,6 +2094,63 @@ cleanup:
return
ret
;
}
static
int
testDomainPinVcpu
(
virDomainPtr
domain
,
unsigned
int
vcpu
,
unsigned
char
*
cpumap
,
int
maplen
)
{
testConnPtr
privconn
=
domain
->
conn
->
privateData
;
testDomainObjPrivatePtr
privdomdata
;
virDomainObjPtr
privdom
;
unsigned
char
*
privcpumap
;
int
i
,
maxcpu
,
hostcpus
,
privmaplen
;
int
ret
=
-
1
;
testDriverLock
(
privconn
);
privdom
=
virDomainFindByName
(
&
privconn
->
domains
,
domain
->
name
);
testDriverUnlock
(
privconn
);
if
(
privdom
==
NULL
)
{
testError
(
domain
->
conn
,
VIR_ERR_INVALID_ARG
,
__FUNCTION__
);
goto
cleanup
;
}
if
(
!
virDomainObjIsActive
(
privdom
))
{
testError
(
domain
->
conn
,
VIR_ERR_OPERATION_INVALID
,
"%s"
,
_
(
"cannot pin vcpus on an inactive domain"
));
goto
cleanup
;
}
if
(
vcpu
>
privdom
->
def
->
vcpus
)
{
testError
(
domain
->
conn
,
VIR_ERR_INVALID_ARG
,
"%s"
,
_
(
"requested vcpu is higher than allocated vcpus"
));
goto
cleanup
;
}
privdomdata
=
privdom
->
privateData
;
hostcpus
=
VIR_NODEINFO_MAXCPUS
(
privconn
->
nodeInfo
);
privmaplen
=
VIR_CPU_MAPLEN
(
hostcpus
);
maxcpu
=
maplen
*
8
;
if
(
maxcpu
>
hostcpus
)
maxcpu
=
hostcpus
;
privcpumap
=
VIR_GET_CPUMAP
(
privdomdata
->
cpumaps
,
privmaplen
,
vcpu
);
memset
(
privcpumap
,
0
,
privmaplen
);
for
(
i
=
0
;
i
<
maxcpu
;
i
++
)
{
if
(
VIR_CPU_USABLE
(
cpumap
,
maplen
,
0
,
i
))
{
VIR_USE_CPU
(
privcpumap
,
i
);
}
}
ret
=
0
;
cleanup:
if
(
privdom
)
virDomainObjUnlock
(
privdom
);
return
ret
;
}
static
char
*
testDomainDumpXML
(
virDomainPtr
domain
,
int
flags
)
{
testConnPtr
privconn
=
domain
->
conn
->
privateData
;
...
...
@@ -4948,7 +5005,7 @@ static virDriver testDriver = {
testDomainRestore
,
/* domainRestore */
testDomainCoreDump
,
/* domainCoreDump */
testSetVcpus
,
/* domainSetVcpus */
NULL
,
/* domainPinVcpu */
testDomainPinVcpu
,
/* domainPinVcpu */
testDomainGetVcpus
,
/* domainGetVcpus */
testDomainGetMaxVcpus
,
/* domainGetMaxVcpus */
NULL
,
/* domainGetSecurityLabel */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录