Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
ae3e0218
Commit
ae3e0218
authored
Sep 26, 2006
by
Tony Luck
Browse files
Options
Browse Files
Download
Plain Diff
Pull model-name into release branch
parents
e478bec0
76d08bb3
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
42 additions
and
10 deletions
+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
No files found.
arch/ia64/kernel/setup.c
View file @
ae3e0218
...
@@ -509,7 +509,7 @@ show_cpuinfo (struct seq_file *m, void *v)
...
@@ -509,7 +509,7 @@ show_cpuinfo (struct seq_file *m, void *v)
{
1UL
<<
1
,
"spontaneous deferral"
},
{
1UL
<<
1
,
"spontaneous deferral"
},
{
1UL
<<
2
,
"16-byte atomic ops"
}
{
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
;
struct
cpuinfo_ia64
*
c
=
v
;
unsigned
long
mask
;
unsigned
long
mask
;
unsigned
long
proc_freq
;
unsigned
long
proc_freq
;
...
@@ -517,12 +517,6 @@ show_cpuinfo (struct seq_file *m, void *v)
...
@@ -517,12 +517,6 @@ show_cpuinfo (struct seq_file *m, void *v)
mask
=
c
->
features
;
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: */
/* build the feature string: */
memcpy
(
features
,
" standard"
,
10
);
memcpy
(
features
,
" standard"
,
10
);
cp
=
features
;
cp
=
features
;
...
@@ -553,8 +547,9 @@ show_cpuinfo (struct seq_file *m, void *v)
...
@@ -553,8 +547,9 @@ show_cpuinfo (struct seq_file *m, void *v)
"processor : %d
\n
"
"processor : %d
\n
"
"vendor : %s
\n
"
"vendor : %s
\n
"
"arch : IA-64
\n
"
"arch : IA-64
\n
"
"family : %
s
\n
"
"family : %
u
\n
"
"model : %u
\n
"
"model : %u
\n
"
"model name : %s
\n
"
"revision : %u
\n
"
"revision : %u
\n
"
"archrev : %u
\n
"
"archrev : %u
\n
"
"features :%s
\n
"
/* don't change this---it _is_ right! */
"features :%s
\n
"
/* don't change this---it _is_ right! */
...
@@ -563,7 +558,8 @@ show_cpuinfo (struct seq_file *m, void *v)
...
@@ -563,7 +558,8 @@ show_cpuinfo (struct seq_file *m, void *v)
"cpu MHz : %lu.%06lu
\n
"
"cpu MHz : %lu.%06lu
\n
"
"itc MHz : %lu.%06lu
\n
"
"itc MHz : %lu.%06lu
\n
"
"BogoMIPS : %lu.%02lu
\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
,
features
,
c
->
ppn
,
c
->
number
,
proc_freq
/
1000
,
proc_freq
%
1000
,
proc_freq
/
1000
,
proc_freq
%
1000
,
c
->
itc_freq
/
1000000
,
c
->
itc_freq
%
1000000
,
c
->
itc_freq
/
1000000
,
c
->
itc_freq
%
1000000
,
...
@@ -611,6 +607,31 @@ struct seq_operations cpuinfo_op = {
...
@@ -611,6 +607,31 @@ struct seq_operations cpuinfo_op = {
.
show
=
show_cpuinfo
.
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
static
void
__cpuinit
identify_cpu
(
struct
cpuinfo_ia64
*
c
)
identify_cpu
(
struct
cpuinfo_ia64
*
c
)
{
{
...
@@ -640,7 +661,6 @@ identify_cpu (struct cpuinfo_ia64 *c)
...
@@ -640,7 +661,6 @@ identify_cpu (struct cpuinfo_ia64 *c)
pal_status_t
status
;
pal_status_t
status
;
unsigned
long
impl_va_msb
=
50
,
phys_addr_size
=
44
;
/* Itanium defaults */
unsigned
long
impl_va_msb
=
50
,
phys_addr_size
=
44
;
/* Itanium defaults */
int
i
;
int
i
;
for
(
i
=
0
;
i
<
5
;
++
i
)
for
(
i
=
0
;
i
<
5
;
++
i
)
cpuid
.
bits
[
i
]
=
ia64_get_cpuid
(
i
);
cpuid
.
bits
[
i
]
=
ia64_get_cpuid
(
i
);
...
@@ -663,6 +683,7 @@ identify_cpu (struct cpuinfo_ia64 *c)
...
@@ -663,6 +683,7 @@ identify_cpu (struct cpuinfo_ia64 *c)
c
->
family
=
cpuid
.
field
.
family
;
c
->
family
=
cpuid
.
field
.
family
;
c
->
archrev
=
cpuid
.
field
.
archrev
;
c
->
archrev
=
cpuid
.
field
.
archrev
;
c
->
features
=
cpuid
.
field
.
features
;
c
->
features
=
cpuid
.
field
.
features
;
c
->
model_name
=
get_model_name
(
c
->
family
,
c
->
model
);
status
=
ia64_pal_vm_summary
(
&
vm1
,
&
vm2
);
status
=
ia64_pal_vm_summary
(
&
vm1
,
&
vm2
);
if
(
status
==
PAL_STATUS_SUCCESS
)
{
if
(
status
==
PAL_STATUS_SUCCESS
)
{
...
...
include/asm-ia64/pal.h
View file @
ae3e0218
...
@@ -78,6 +78,7 @@
...
@@ -78,6 +78,7 @@
#define PAL_VM_TR_READ 261
/* read contents of translation register */
#define PAL_VM_TR_READ 261
/* read contents of translation register */
#define PAL_GET_PSTATE 262
/* get the current P-state */
#define PAL_GET_PSTATE 262
/* get the current P-state */
#define PAL_SET_PSTATE 263
/* set the P-state */
#define PAL_SET_PSTATE 263
/* set the P-state */
#define PAL_BRAND_INFO 274
/* Processor branding information */
#ifndef __ASSEMBLY__
#ifndef __ASSEMBLY__
...
@@ -1133,6 +1134,15 @@ ia64_pal_set_pstate (u64 pstate_index)
...
@@ -1133,6 +1134,15 @@ ia64_pal_set_pstate (u64 pstate_index)
return
iprv
.
status
;
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
/* Cause the processor to enter LIGHT HALT state, where prefetching and execution are
* suspended, but cache and TLB coherency is maintained.
* suspended, but cache and TLB coherency is maintained.
*/
*/
...
...
include/asm-ia64/processor.h
View file @
ae3e0218
...
@@ -163,6 +163,7 @@ struct cpuinfo_ia64 {
...
@@ -163,6 +163,7 @@ struct cpuinfo_ia64 {
__u8
family
;
__u8
family
;
__u8
archrev
;
__u8
archrev
;
char
vendor
[
16
];
char
vendor
[
16
];
char
*
model_name
;
#ifdef CONFIG_NUMA
#ifdef CONFIG_NUMA
struct
ia64_node_data
*
node_data
;
struct
ia64_node_data
*
node_data
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment