intel-iommu: Fix boot inside 64bit virtualbox with io-apic disabled
authorArnaud Patard <apatard@mandriva.com>
Thu, 25 Mar 2010 18:02:58 +0000 (18:02 +0000)
committerDavid Woodhouse <David.Woodhouse@intel.com>
Wed, 14 Apr 2010 14:38:59 +0000 (15:38 +0100)
Commit 074835f0143b83845af5044af2739c52c9f53808 ("intel-iommu: Fix
kernel hand if interrupt remapping disabled in BIOS") is adding a check
for interrupt remapping disabled and is dereferencing the dmar_tbl
pointer without checking its value.

Unfortunately, this value is null when booting inside a 64bit virtual
box guest with io-apic disabled, leading to a crash. With a check on it,
the guest is now booting. It's triggering a WARN() in
clockevent_delta2ns but it's better than not booting at all and allows
the user to see there's something wrong on their io-apic setup.

Signed-off-by: Arnaud Patard <apatard@mandriva.com>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
drivers/pci/dmar.c

index edc5f002e055a98fe6455301218303dd65850aa3..7771b2dd59783846bac30ce03e934dbd5d05c750 100644 (file)
@@ -1466,5 +1466,7 @@ int __init dmar_ir_support(void)
 {
        struct acpi_table_dmar *dmar;
        dmar = (struct acpi_table_dmar *)dmar_tbl;
+       if (!dmar)
+               return 0;
        return dmar->flags & 0x1;
 }