intel-iommu: Fix oops with intel_iommu=igfx_off
authorDavid Woodhouse <David.Woodhouse@intel.com>
Wed, 2 Dec 2009 10:18:30 +0000 (10:18 +0000)
committerDavid Woodhouse <David.Woodhouse@intel.com>
Tue, 8 Dec 2009 10:03:06 +0000 (10:03 +0000)
The hotplug notifier will call find_domain() to see if the device in
question has been assigned an IOMMU domain. However, this should never
be called for devices with a "dummy" domain, such as graphics devices
when intel_iommu=igfx_off is set and the corresponding IOMMU isn't even
initialised. If you do that, it'll oops as it dereferences the (-1)
pointer.

The notifier function should check iommu_no_mapping() for the
device before doing anything else.

Cc: stable@kernel.org
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
drivers/pci/intel-iommu.c

index 83cabdc118dba815d10643179385ce690e7f6b6d..e3e84cac0e9891958e1a534aaced55a4078a476b 100644 (file)
@@ -3247,6 +3247,9 @@ static int device_notifier(struct notifier_block *nb,
        struct pci_dev *pdev = to_pci_dev(dev);
        struct dmar_domain *domain;
 
+       if (iommu_no_mapping(dev))
+               return 0;
+
        domain = find_domain(pdev);
        if (!domain)
                return 0;