PCI/MSI: Check that we have a legacy interrupt line before using it
authorChristoph Hellwig <hch@lst.de>
Wed, 1 Feb 2017 13:41:42 +0000 (14:41 +0100)
committerBjorn Helgaas <bhelgaas@google.com>
Fri, 10 Feb 2017 22:05:06 +0000 (16:05 -0600)
It seems like there are some devices (e.g. the PCIe root port driver) that
may not always have a INTx interrupt.  Check for dev->irq before returning
a legacy interrupt in pci_irq_alloc_vectors to properly handle this case.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
drivers/pci/msi.c

index b44ad7c21b29ea11fa1bcf83189f577e332ba3ea..52ac675f0bd7f8b886e9cf29eb115dba65764257 100644 (file)
@@ -1198,9 +1198,11 @@ int pci_alloc_irq_vectors_affinity(struct pci_dev *dev, unsigned int min_vecs,
        }
 
        /* use legacy irq if allowed */
-       if ((flags & PCI_IRQ_LEGACY) && min_vecs == 1) {
-               pci_intx(dev, 1);
-               return 1;
+       if (flags & PCI_IRQ_LEGACY) {
+               if (min_vecs == 1 && dev->irq) {
+                       pci_intx(dev, 1);
+                       return 1;
+               }
        }
 
        return vecs;