ACPI: disable MPS when NO APIC-table found
authorLen Brown <len.brown@intel.com>
Tue, 23 Dec 2008 06:47:42 +0000 (01:47 -0500)
committerLen Brown <len.brown@intel.com>
Tue, 23 Dec 2008 06:47:42 +0000 (01:47 -0500)
When ACPI is asked to find an MADT (APIC table)
and fails, then ACPI expects to run in PIC mode.

However, if an MP Table is was found, IRQs will be
registered as if an IOAPIC is being used, even
though ACPI is configuring interrupt links links for PIC mode.

In this scenario, disable MPS so that IRQs
are registered in PIC mode, consistent with ACPI.

http://bugzilla.kernel.org/show_bug.cgi?id=12257

Signed-off-by: Len Brown <len.brown@intel.com>
arch/x86/kernel/acpi/boot.c

index 4c51a2f8fd315900071de65e6ee3bee43ea2718f..de8ce79dd8818a5295c712a1dd656703026c32be 100644 (file)
@@ -1359,6 +1359,17 @@ static void __init acpi_process_madt(void)
                               "Invalid BIOS MADT, disabling ACPI\n");
                        disable_acpi();
                }
+       } else {
+               /*
+                * ACPI found no MADT, and so ACPI wants UP PIC mode.
+                * In the event an MPS table was found, forget it.
+                * Boot with "acpi=off" to use MPS on such a system.
+                */
+               if (smp_found_config) {
+                       printk(KERN_WARNING PREFIX
+                               "No APIC-table, disabling MPS\n");
+                       smp_found_config = 0;
+               }
        }
 #endif
        return;