diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2005-11-05 11:25:53 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-11-14 22:55:14 -0500 |
commit | f5f786d0455c359c554b8f74783f887c0a2c9fac (patch) | |
tree | 2d8bf241afe4d9242657f29f6494ce8763b3418d | |
parent | e9b59d834faf0305cb6214a358f65f72c57b9e99 (diff) |
[PATCH] x86-64/i386: Fix CPU model for family 6
According to cpuid instruction in IA32 SDM-Vol2, when computing cpu model,
we need to consider extended model ID for family 0x6 also.
AK: Also added fixes/simplifcation from Petr Vandrovec
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: Andi Kleen <ak@suse.de>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r-- | arch/i386/kernel/cpu/common.c | 4 | ||||
-rw-r--r-- | arch/x86_64/kernel/setup.c | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/arch/i386/kernel/cpu/common.c b/arch/i386/kernel/cpu/common.c index 74145a33cb0f..35a67dab4a94 100644 --- a/arch/i386/kernel/cpu/common.c +++ b/arch/i386/kernel/cpu/common.c | |||
@@ -233,10 +233,10 @@ static void __init early_cpu_detect(void) | |||
233 | cpuid(0x00000001, &tfms, &misc, &junk, &cap0); | 233 | cpuid(0x00000001, &tfms, &misc, &junk, &cap0); |
234 | c->x86 = (tfms >> 8) & 15; | 234 | c->x86 = (tfms >> 8) & 15; |
235 | c->x86_model = (tfms >> 4) & 15; | 235 | c->x86_model = (tfms >> 4) & 15; |
236 | if (c->x86 == 0xf) { | 236 | if (c->x86 == 0xf) |
237 | c->x86 += (tfms >> 20) & 0xff; | 237 | c->x86 += (tfms >> 20) & 0xff; |
238 | if (c->x86 >= 0x6) | ||
238 | c->x86_model += ((tfms >> 16) & 0xF) << 4; | 239 | c->x86_model += ((tfms >> 16) & 0xF) << 4; |
239 | } | ||
240 | c->x86_mask = tfms & 15; | 240 | c->x86_mask = tfms & 15; |
241 | if (cap0 & (1<<19)) | 241 | if (cap0 & (1<<19)) |
242 | c->x86_cache_alignment = ((misc >> 8) & 0xff) * 8; | 242 | c->x86_cache_alignment = ((misc >> 8) & 0xff) * 8; |
diff --git a/arch/x86_64/kernel/setup.c b/arch/x86_64/kernel/setup.c index da0bc3e7bdf5..f27731ac95c5 100644 --- a/arch/x86_64/kernel/setup.c +++ b/arch/x86_64/kernel/setup.c | |||
@@ -1060,10 +1060,10 @@ void __cpuinit early_identify_cpu(struct cpuinfo_x86 *c) | |||
1060 | c->x86 = (tfms >> 8) & 0xf; | 1060 | c->x86 = (tfms >> 8) & 0xf; |
1061 | c->x86_model = (tfms >> 4) & 0xf; | 1061 | c->x86_model = (tfms >> 4) & 0xf; |
1062 | c->x86_mask = tfms & 0xf; | 1062 | c->x86_mask = tfms & 0xf; |
1063 | if (c->x86 == 0xf) { | 1063 | if (c->x86 == 0xf) |
1064 | c->x86 += (tfms >> 20) & 0xff; | 1064 | c->x86 += (tfms >> 20) & 0xff; |
1065 | if (c->x86 >= 0x6) | ||
1065 | c->x86_model += ((tfms >> 16) & 0xF) << 4; | 1066 | c->x86_model += ((tfms >> 16) & 0xF) << 4; |
1066 | } | ||
1067 | if (c->x86_capability[0] & (1<<19)) | 1067 | if (c->x86_capability[0] & (1<<19)) |
1068 | c->x86_clflush_size = ((misc >> 8) & 0xff) * 8; | 1068 | c->x86_clflush_size = ((misc >> 8) & 0xff) * 8; |
1069 | } else { | 1069 | } else { |