diff options
-rw-r--r-- | kernel/irq/handle.c | 2 | ||||
-rw-r--r-- | kernel/irq/internals.h | 40 |
2 files changed, 42 insertions, 0 deletions
diff --git a/kernel/irq/handle.c b/kernel/irq/handle.c index 01fc7f79d74a..5a360dd4331b 100644 --- a/kernel/irq/handle.c +++ b/kernel/irq/handle.c | |||
@@ -24,6 +24,7 @@ | |||
24 | void fastcall | 24 | void fastcall |
25 | handle_bad_irq(unsigned int irq, struct irq_desc *desc, struct pt_regs *regs) | 25 | handle_bad_irq(unsigned int irq, struct irq_desc *desc, struct pt_regs *regs) |
26 | { | 26 | { |
27 | print_irq_desc(irq, desc); | ||
27 | kstat_this_cpu.irqs[irq]++; | 28 | kstat_this_cpu.irqs[irq]++; |
28 | ack_bad_irq(irq); | 29 | ack_bad_irq(irq); |
29 | } | 30 | } |
@@ -61,6 +62,7 @@ struct irq_desc irq_desc[NR_IRQS] __cacheline_aligned = { | |||
61 | */ | 62 | */ |
62 | static void ack_bad(unsigned int irq) | 63 | static void ack_bad(unsigned int irq) |
63 | { | 64 | { |
65 | print_irq_desc(irq, irq_desc + irq); | ||
64 | ack_bad_irq(irq); | 66 | ack_bad_irq(irq); |
65 | } | 67 | } |
66 | 68 | ||
diff --git a/kernel/irq/internals.h b/kernel/irq/internals.h index 2ba8ae3c8e96..08a849a22447 100644 --- a/kernel/irq/internals.h +++ b/kernel/irq/internals.h | |||
@@ -22,3 +22,43 @@ static inline void unregister_handler_proc(unsigned int irq, | |||
22 | struct irqaction *action) { } | 22 | struct irqaction *action) { } |
23 | #endif | 23 | #endif |
24 | 24 | ||
25 | /* | ||
26 | * Debugging printout: | ||
27 | */ | ||
28 | |||
29 | #include <linux/kallsyms.h> | ||
30 | |||
31 | #define P(f) if (desc->status & f) printk("%14s set\n", #f) | ||
32 | |||
33 | static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc) | ||
34 | { | ||
35 | printk("irq %d, desc: %p, depth: %d, count: %d, unhandled: %d\n", | ||
36 | irq, desc, desc->depth, desc->irq_count, desc->irqs_unhandled); | ||
37 | printk("->handle_irq(): %p, ", desc->handle_irq); | ||
38 | print_symbol("%s\n", (unsigned long)desc->handle_irq); | ||
39 | printk("->chip(): %p, ", desc->chip); | ||
40 | print_symbol("%s\n", (unsigned long)desc->chip); | ||
41 | printk("->action(): %p\n", desc->action); | ||
42 | if (desc->action) { | ||
43 | printk("->action->handler(): %p, ", desc->action->handler); | ||
44 | print_symbol("%s\n", (unsigned long)desc->action->handler); | ||
45 | } | ||
46 | |||
47 | P(IRQ_INPROGRESS); | ||
48 | P(IRQ_DISABLED); | ||
49 | P(IRQ_PENDING); | ||
50 | P(IRQ_REPLAY); | ||
51 | P(IRQ_AUTODETECT); | ||
52 | P(IRQ_WAITING); | ||
53 | P(IRQ_LEVEL); | ||
54 | P(IRQ_MASKED); | ||
55 | #ifdef CONFIG_IRQ_PER_CPU | ||
56 | P(IRQ_PER_CPU); | ||
57 | #endif | ||
58 | P(IRQ_NOPROBE); | ||
59 | P(IRQ_NOREQUEST); | ||
60 | P(IRQ_NOAUTOEN); | ||
61 | } | ||
62 | |||
63 | #undef P | ||
64 | |||