apic, i386/bigsmp: Fix false warnings regarding logical APIC ID mismatches
[pandora-kernel.git] / arch / x86 / kernel / apic / bigsmp_32.c
index d84ac5a..521bead 100644 (file)
@@ -193,7 +193,7 @@ static int probe_bigsmp(void)
        return dmi_bigsmp;
 }
 
-struct apic apic_bigsmp = {
+static struct apic apic_bigsmp = {
 
        .name                           = "bigsmp",
        .probe                          = probe_bigsmp,
@@ -254,3 +254,25 @@ struct apic apic_bigsmp = {
 
        .x86_32_early_logical_apicid    = bigsmp_early_logical_apicid,
 };
+
+void __init generic_bigsmp_probe(void)
+{
+       unsigned int cpu;
+
+       if (!probe_bigsmp())
+               return;
+
+       apic = &apic_bigsmp;
+
+       for_each_possible_cpu(cpu) {
+               if (early_per_cpu(x86_cpu_to_logical_apicid,
+                                 cpu) == BAD_APICID)
+                       continue;
+               early_per_cpu(x86_cpu_to_logical_apicid, cpu) =
+                       bigsmp_early_logical_apicid(cpu);
+       }
+
+       pr_info("Overriding APIC driver with %s\n", apic_bigsmp.name);
+}
+
+apic_driver(apic_bigsmp);