Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
ae3e0218
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ae3e0218
编写于
9月 26, 2006
作者:
T
Tony Luck
浏览文件
操作
浏览文件
下载
差异文件
Pull model-name into release branch
上级
e478bec0
76d08bb3
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
42 addition
and
10 deletion
+42
-10
arch/ia64/kernel/setup.c
arch/ia64/kernel/setup.c
+31
-10
include/asm-ia64/pal.h
include/asm-ia64/pal.h
+10
-0
include/asm-ia64/processor.h
include/asm-ia64/processor.h
+1
-0
未找到文件。
arch/ia64/kernel/setup.c
浏览文件 @
ae3e0218
...
...
@@ -509,7 +509,7 @@ show_cpuinfo (struct seq_file *m, void *v)
{
1UL
<<
1
,
"spontaneous deferral"
},
{
1UL
<<
2
,
"16-byte atomic ops"
}
};
char
f
amily
[
32
],
f
eatures
[
128
],
*
cp
,
sep
;
char
features
[
128
],
*
cp
,
sep
;
struct
cpuinfo_ia64
*
c
=
v
;
unsigned
long
mask
;
unsigned
long
proc_freq
;
...
...
@@ -517,12 +517,6 @@ show_cpuinfo (struct seq_file *m, void *v)
mask
=
c
->
features
;
switch
(
c
->
family
)
{
case
0x07
:
memcpy
(
family
,
"Itanium"
,
8
);
break
;
case
0x1f
:
memcpy
(
family
,
"Itanium 2"
,
10
);
break
;
default:
sprintf
(
family
,
"%u"
,
c
->
family
);
break
;
}
/* build the feature string: */
memcpy
(
features
,
" standard"
,
10
);
cp
=
features
;
...
...
@@ -553,8 +547,9 @@ show_cpuinfo (struct seq_file *m, void *v)
"processor : %d
\n
"
"vendor : %s
\n
"
"arch : IA-64
\n
"
"family : %
s
\n
"
"family : %
u
\n
"
"model : %u
\n
"
"model name : %s
\n
"
"revision : %u
\n
"
"archrev : %u
\n
"
"features :%s
\n
"
/* don't change this---it _is_ right! */
...
...
@@ -563,7 +558,8 @@ show_cpuinfo (struct seq_file *m, void *v)
"cpu MHz : %lu.%06lu
\n
"
"itc MHz : %lu.%06lu
\n
"
"BogoMIPS : %lu.%02lu
\n
"
,
cpunum
,
c
->
vendor
,
family
,
c
->
model
,
c
->
revision
,
c
->
archrev
,
cpunum
,
c
->
vendor
,
c
->
family
,
c
->
model
,
c
->
model_name
,
c
->
revision
,
c
->
archrev
,
features
,
c
->
ppn
,
c
->
number
,
proc_freq
/
1000
,
proc_freq
%
1000
,
c
->
itc_freq
/
1000000
,
c
->
itc_freq
%
1000000
,
...
...
@@ -611,6 +607,31 @@ struct seq_operations cpuinfo_op = {
.
show
=
show_cpuinfo
};
static
char
brandname
[
128
];
static
char
*
__cpuinit
get_model_name
(
__u8
family
,
__u8
model
)
{
char
brand
[
128
];
if
(
ia64_pal_get_brand_info
(
brand
))
{
if
(
family
==
0x7
)
memcpy
(
brand
,
"Merced"
,
7
);
else
if
(
family
==
0x1f
)
switch
(
model
)
{
case
0
:
memcpy
(
brand
,
"McKinley"
,
9
);
break
;
case
1
:
memcpy
(
brand
,
"Madison"
,
8
);
break
;
case
2
:
memcpy
(
brand
,
"Madison up to 9M cache"
,
23
);
break
;
}
else
memcpy
(
brand
,
"Unknown"
,
8
);
}
if
(
brandname
[
0
]
==
'\0'
)
return
strcpy
(
brandname
,
brand
);
else
if
(
strcmp
(
brandname
,
brand
)
==
0
)
return
brandname
;
else
return
kstrdup
(
brand
,
GFP_KERNEL
);
}
static
void
__cpuinit
identify_cpu
(
struct
cpuinfo_ia64
*
c
)
{
...
...
@@ -640,7 +661,6 @@ identify_cpu (struct cpuinfo_ia64 *c)
pal_status_t
status
;
unsigned
long
impl_va_msb
=
50
,
phys_addr_size
=
44
;
/* Itanium defaults */
int
i
;
for
(
i
=
0
;
i
<
5
;
++
i
)
cpuid
.
bits
[
i
]
=
ia64_get_cpuid
(
i
);
...
...
@@ -663,6 +683,7 @@ identify_cpu (struct cpuinfo_ia64 *c)
c
->
family
=
cpuid
.
field
.
family
;
c
->
archrev
=
cpuid
.
field
.
archrev
;
c
->
features
=
cpuid
.
field
.
features
;
c
->
model_name
=
get_model_name
(
c
->
family
,
c
->
model
);
status
=
ia64_pal_vm_summary
(
&
vm1
,
&
vm2
);
if
(
status
==
PAL_STATUS_SUCCESS
)
{
...
...
include/asm-ia64/pal.h
浏览文件 @
ae3e0218
...
...
@@ -78,6 +78,7 @@
#define PAL_VM_TR_READ 261
/* read contents of translation register */
#define PAL_GET_PSTATE 262
/* get the current P-state */
#define PAL_SET_PSTATE 263
/* set the P-state */
#define PAL_BRAND_INFO 274
/* Processor branding information */
#ifndef __ASSEMBLY__
...
...
@@ -1133,6 +1134,15 @@ ia64_pal_set_pstate (u64 pstate_index)
return
iprv
.
status
;
}
/* Processor branding information*/
static
inline
s64
ia64_pal_get_brand_info
(
char
*
brand_info
)
{
struct
ia64_pal_retval
iprv
;
PAL_CALL_STK
(
iprv
,
PAL_BRAND_INFO
,
0
,
(
u64
)
brand_info
,
0
);
return
iprv
.
status
;
}
/* Cause the processor to enter LIGHT HALT state, where prefetching and execution are
* suspended, but cache and TLB coherency is maintained.
*/
...
...
include/asm-ia64/processor.h
浏览文件 @
ae3e0218
...
...
@@ -163,6 +163,7 @@ struct cpuinfo_ia64 {
__u8
family
;
__u8
archrev
;
char
vendor
[
16
];
char
*
model_name
;
#ifdef CONFIG_NUMA
struct
ia64_node_data
*
node_data
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录