aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/kernel/cpu/common.c20
-rw-r--r--arch/x86/kernel/cpu/common_64.c2
2 files changed, 22 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c
index b2018f76c94d..ffc2f5ed09a3 100644
--- a/arch/x86/kernel/cpu/common.c
+++ b/arch/x86/kernel/cpu/common.c
@@ -458,6 +458,26 @@ static void __cpuinit get_cpu_cap(struct cpuinfo_x86 *c)
458 c->x86_capability[6] = cpuid_ecx(0x80000001); 458 c->x86_capability[6] = cpuid_ecx(0x80000001);
459 } 459 }
460 } 460 }
461
462#ifdef CONFIG_X86_64
463 /* Transmeta-defined flags: level 0x80860001 */
464 xlvl = cpuid_eax(0x80860000);
465 if ((xlvl & 0xffff0000) == 0x80860000) {
466 /* Don't set x86_cpuid_level here for now to not confuse. */
467 if (xlvl >= 0x80860001)
468 c->x86_capability[2] = cpuid_edx(0x80860001);
469 }
470
471 if (c->extended_cpuid_level >= 0x80000007)
472 c->x86_power = cpuid_edx(0x80000007);
473
474 if (c->extended_cpuid_level >= 0x80000008) {
475 u32 eax = cpuid_eax(0x80000008);
476
477 c->x86_virt_bits = (eax >> 8) & 0xff;
478 c->x86_phys_bits = eax & 0xff;
479 }
480#endif
461} 481}
462/* 482/*
463 * Do minimum CPU detection early. 483 * Do minimum CPU detection early.
diff --git a/arch/x86/kernel/cpu/common_64.c b/arch/x86/kernel/cpu/common_64.c
index 7ac0a00743c7..75bb7ff99ee3 100644
--- a/arch/x86/kernel/cpu/common_64.c
+++ b/arch/x86/kernel/cpu/common_64.c
@@ -461,6 +461,7 @@ static void __cpuinit get_cpu_cap(struct cpuinfo_x86 *c)
461 } 461 }
462 } 462 }
463 463
464#ifdef CONFIG_X86_64
464 /* Transmeta-defined flags: level 0x80860001 */ 465 /* Transmeta-defined flags: level 0x80860001 */
465 xlvl = cpuid_eax(0x80860000); 466 xlvl = cpuid_eax(0x80860000);
466 if ((xlvl & 0xffff0000) == 0x80860000) { 467 if ((xlvl & 0xffff0000) == 0x80860000) {
@@ -478,6 +479,7 @@ static void __cpuinit get_cpu_cap(struct cpuinfo_x86 *c)
478 c->x86_virt_bits = (eax >> 8) & 0xff; 479 c->x86_virt_bits = (eax >> 8) & 0xff;
479 c->x86_phys_bits = eax & 0xff; 480 c->x86_phys_bits = eax & 0xff;
480 } 481 }
482#endif
481} 483}
482 484
483/* Do some early cpuid on the boot CPU to get some parameter that are 485/* Do some early cpuid on the boot CPU to get some parameter that are