Skip to content

Commit

Permalink
[PATCH] genirq: add handle_bad_irq()
Browse files Browse the repository at this point in the history
Handle bad IRQ vectors via the irqchip mechanism.

Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
  • Loading branch information
Ingo Molnar authored and Linus Torvalds committed Jun 29, 2006
1 parent dd87eb3 commit 7a55713
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 0 deletions.
8 changes: 8 additions & 0 deletions kernel/irq/autoprobe.c
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@
#include <linux/interrupt.h>
#include <linux/delay.h>

#include "internals.h"

/*
* Autodetection depends on the fact that any interrupt that
* comes in on to an unassigned handler will get stuck with
Expand Down Expand Up @@ -41,6 +43,12 @@ unsigned long probe_irq_on(void)

spin_lock_irq(&desc->lock);
if (!desc->action && !(desc->status & IRQ_NOPROBE)) {
/*
* An old-style architecture might still have
* the handle_bad_irq handler there:
*/
compat_irq_chip_set_default_handler(desc);

/*
* Some chips need to know about probing in
* progress:
Expand Down
1 change: 1 addition & 0 deletions kernel/irq/handle.c
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ struct irq_desc irq_desc[NR_IRQS] __cacheline_aligned = {
[0 ... NR_IRQS-1] = {
.status = IRQ_DISABLED,
.chip = &no_irq_type,
.handle_irq = handle_bad_irq,
.depth = 1,
.lock = SPIN_LOCK_UNLOCKED,
#ifdef CONFIG_SMP
Expand Down

0 comments on commit 7a55713

Please sign in to comment.