summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2017-02-15 15:43:54 +0100
committerThomas Gleixner <tglx@linutronix.de>2017-02-16 15:32:19 +0100
commitf91f694540f3f8ed25da57814fe0c673afd36e7e (patch)
tree87a7f29fd559573209560f92b6f6247d8b9cd06e /kernel
parent5d4bac9a5f4ef24b2482529bda6661a58e5b5b65 (diff)
genirq: Reenable shared irq debugging in request_*_irq()
Commit 6d83f94db95c ("genirq: Disable the SHIRQ_DEBUG call in request_threaded_irq for now") disabled the SHIRQ_DEBUG facility for the irq request side. Unfortunately the 'for now' part and the _FIXME add on to the CONFIG_SHIRQ_DEBUG guard got forgotten. It's unfortunately not possible to keep the original idea of just invoking the newly installed handler due to the reasons described in the commit which disabled it, but having this debug facility available makes a lot of sense. The only way to regain that testing is to invoke the real interrupt handling mechanism, which will also invoke an already registered handler, but that's not an issue because _all_ interrupt handlers need to be prepared for handling spurious interrupts. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/alpine.DEB.2.20.1702151542330.3562@nanos Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/irq/manage.c10
1 files changed, 2 insertions, 8 deletions
diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c
index 6b669593e7eb..6db434547a3e 100644
--- a/kernel/irq/manage.c
+++ b/kernel/irq/manage.c
@@ -1696,23 +1696,17 @@ int request_threaded_irq(unsigned int irq, irq_handler_t handler,
kfree(action);
}
-#ifdef CONFIG_DEBUG_SHIRQ_FIXME
+#ifdef CONFIG_DEBUG_SHIRQ
if (!retval && (irqflags & IRQF_SHARED)) {
/*
* It's a shared IRQ -- the driver ought to be prepared for it
* to happen immediately, so let's make sure....
- * We disable the irq to make sure that a 'real' IRQ doesn't
- * run in parallel with our fake.
*/
unsigned long flags;
- disable_irq(irq);
local_irq_save(flags);
-
- handler(irq, dev_id);
-
+ generic_handle_irq_desc(desc);
local_irq_restore(flags);
- enable_irq(irq);
}
#endif
return retval;