aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/setup_64.c
diff options
context:
space:
mode:
authorYinghai Lu <yhlu.kernel@gmail.com>2008-06-19 18:30:31 -0400
committerIngo Molnar <mingo@elte.hu>2008-07-08 01:47:40 -0400
commitc49c412a47b5102516d3313d4eba38cb1e968721 (patch)
tree4b529258e039383a78a64f476954cdbf2868dbb8 /arch/x86/kernel/setup_64.c
parentdcd32b6a1ffe6c040f8346f7fbaf4318bb8ae41c (diff)
x86: make 64bit identify_cpu use cpu_dev v2
v2: fix early_panic on this config: http://redhat.com/~mingo/misc/config-Thu_Jun_19_14_22_37_CEST_2008.bad reason : struct cpu_vendor_dev size is 16, need to make table to be 16 byte alignment also print out the cpu supported... Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com> Cc: Dave Jones <davej@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/setup_64.c')
-rw-r--r--arch/x86/kernel/setup_64.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/arch/x86/kernel/setup_64.c b/arch/x86/kernel/setup_64.c
index 0cebf953c25a..b789ec599923 100644
--- a/arch/x86/kernel/setup_64.c
+++ b/arch/x86/kernel/setup_64.c
@@ -664,6 +664,25 @@ static void __cpuinit get_cpu_vendor(struct cpuinfo_x86 *c)
664 c->x86_vendor = X86_VENDOR_UNKNOWN; 664 c->x86_vendor = X86_VENDOR_UNKNOWN;
665} 665}
666 666
667static void __init early_cpu_support_print(void)
668{
669 int i,j;
670 struct cpu_dev *cpu_devx;
671
672 printk("KERNEL supported cpus:\n");
673 for (i = 0; i < X86_VENDOR_NUM; i++) {
674 cpu_devx = cpu_devs[i];
675 if (!cpu_devx)
676 continue;
677 for (j = 0; j < 2; j++) {
678 if (!cpu_devx->c_ident[j])
679 continue;
680 printk(" %s %s\n", cpu_devx->c_vendor,
681 cpu_devx->c_ident[j]);
682 }
683 }
684}
685
667static void __init early_cpu_init(void) 686static void __init early_cpu_init(void)
668{ 687{
669 struct cpu_vendor_dev *cvdev; 688 struct cpu_vendor_dev *cvdev;
@@ -672,6 +691,7 @@ static void __init early_cpu_init(void)
672 cvdev < __x86cpuvendor_end ; 691 cvdev < __x86cpuvendor_end ;
673 cvdev++) 692 cvdev++)
674 cpu_devs[cvdev->vendor] = cvdev->cpu_dev; 693 cpu_devs[cvdev->vendor] = cvdev->cpu_dev;
694 early_cpu_support_print();
675} 695}
676 696
677/* Do some early cpuid on the boot CPU to get some parameter that are 697/* Do some early cpuid on the boot CPU to get some parameter that are