Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
e7bf3c06
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,发现更多精彩内容 >>
提交
e7bf3c06
编写于
3月 15, 2017
作者:
J
Jiri Denemark
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
cputest: Add cpuidIsSet helper to cpu-cpuid.py
Signed-off-by:
N
Jiri Denemark
<
jdenemar@redhat.com
>
上级
72c44a15
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
20 deletion
+21
-20
tests/cputestdata/cpu-cpuid.py
tests/cputestdata/cpu-cpuid.py
+21
-20
未找到文件。
tests/cputestdata/cpu-cpuid.py
浏览文件 @
e7bf3c06
...
...
@@ -171,6 +171,24 @@ cpuidMap = [
]
def
cpuidIsSet
(
cpuid
,
feature
):
in_eax
=
feature
[
"in_eax"
]
in_ecx
=
feature
[
"in_ecx"
]
eax
=
feature
[
"eax"
]
ebx
=
feature
[
"ebx"
]
ecx
=
feature
[
"ecx"
]
edx
=
feature
[
"edx"
]
if
in_eax
not
in
cpuid
or
in_ecx
not
in
cpuid
[
in_eax
]:
return
False
else
:
leaf
=
cpuid
[
in_eax
][
in_ecx
]
return
((
eax
>
0
and
leaf
[
"eax"
]
&
eax
>
0
)
or
(
ebx
>
0
and
leaf
[
"ebx"
]
&
ebx
>
0
)
or
(
ecx
>
0
and
leaf
[
"ecx"
]
&
ecx
>
0
)
or
(
edx
>
0
and
leaf
[
"edx"
]
&
edx
>
0
))
def
parseFeatureWords
(
path
):
features
=
None
...
...
@@ -217,30 +235,13 @@ def parseFeatureWords(path):
return
props
,
cpuid
def
propAdd
(
props
,
feature
,
value
):
for
name
in
feature
[
"names"
]:
props
[
name
]
=
value
def
convert
(
path
):
props
,
cpuid
=
parseFeatureWords
(
path
)
for
feature
in
cpuidMap
:
in_eax
=
feature
[
"in_eax"
]
in_ecx
=
feature
[
"in_ecx"
]
eax
=
feature
[
"eax"
]
ebx
=
feature
[
"ebx"
]
ecx
=
feature
[
"ecx"
]
edx
=
feature
[
"edx"
]
if
in_eax
not
in
cpuid
or
in_ecx
not
in
cpuid
[
in_eax
]:
propAdd
(
props
,
feature
,
False
)
else
:
leaf
=
cpuid
[
in_eax
][
in_ecx
]
propAdd
(
props
,
feature
,
((
eax
>
0
and
leaf
[
"eax"
]
&
eax
>
0
)
or
(
ebx
>
0
and
leaf
[
"ebx"
]
&
ebx
>
0
)
or
(
ecx
>
0
and
leaf
[
"ecx"
]
&
ecx
>
0
)
or
(
edx
>
0
and
leaf
[
"edx"
]
&
edx
>
0
)))
value
=
cpuidIsSet
(
cpuid
,
feature
)
for
name
in
feature
[
"names"
]:
props
[
name
]
=
value
with
open
(
path
,
"w"
)
as
f
:
json
.
dump
({
"return"
:
{
"model"
:
{
"name"
:
"base"
,
"props"
:
props
}},
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录