PCI: Use IRQF_ONESHOT if pci_request_irq() called with no handler
authorHeiner Kallweit <hkallweit1@gmail.com>
Sun, 29 Jul 2018 22:03:42 +0000 (00:03 +0200)
committerBjorn Helgaas <bhelgaas@google.com>
Tue, 31 Jul 2018 15:43:43 +0000 (10:43 -0500)
If we have a threaded interrupt with the handler being NULL, then
request_threaded_irq() -> __setup_irq() will complain and bail out if the
IRQF_ONESHOT flag isn't set.  Therefore check for the handler being NULL
and set IRQF_ONESHOT in this case.

This change is needed to migrate the mei_me driver to
pci_alloc_irq_vectors() and pci_request_irq().

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
drivers/pci/irq.c

index 2a808e10645f3d49813d415faeb3e6358b530a58..a1de501a27299bdd7856979e71baa4aa641e9a0a 100644 (file)
@@ -86,13 +86,17 @@ int pci_request_irq(struct pci_dev *dev, unsigned int nr, irq_handler_t handler,
        va_list ap;
        int ret;
        char *devname;
+       unsigned long irqflags = IRQF_SHARED;
+
+       if (!handler)
+               irqflags |= IRQF_ONESHOT;
 
        va_start(ap, fmt);
        devname = kvasprintf(GFP_KERNEL, fmt, ap);
        va_end(ap);
 
        ret = request_threaded_irq(pci_irq_vector(dev, nr), handler, thread_fn,
-                       IRQF_SHARED, devname, dev_id);
+                                  irqflags, devname, dev_id);
        if (ret)
                kfree(devname);
        return ret;