diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2006-06-29 05:24:50 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-29 13:26:24 -0400 |
commit | 94d39e1f6e8132ea982a1d61acbe0423d3d14365 (patch) | |
tree | 68ba3666c1d2c0805089e8ffdb47da961a760450 /kernel/irq/manage.c | |
parent | 6550c775cb5ee94c132d93d84de3bb23f0abf37b (diff) |
[PATCH] genirq: add IRQ_NOAUTOEN support
Enable platforms to disable the automatic enabling of freshly set up irqs.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel/irq/manage.c')
-rw-r--r-- | kernel/irq/manage.c | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c index cae900a849c4..9ea18879fb62 100644 --- a/kernel/irq/manage.c +++ b/kernel/irq/manage.c | |||
@@ -216,13 +216,17 @@ int setup_irq(unsigned int irq, struct irqaction *new) | |||
216 | desc->status |= IRQ_PER_CPU; | 216 | desc->status |= IRQ_PER_CPU; |
217 | #endif | 217 | #endif |
218 | if (!shared) { | 218 | if (!shared) { |
219 | desc->depth = 0; | 219 | desc->status &= ~(IRQ_AUTODETECT | IRQ_WAITING | |
220 | desc->status &= ~(IRQ_DISABLED | IRQ_AUTODETECT | | 220 | IRQ_INPROGRESS); |
221 | IRQ_WAITING | IRQ_INPROGRESS); | 221 | |
222 | if (desc->chip->startup) | 222 | if (!(desc->status & IRQ_NOAUTOEN)) { |
223 | desc->chip->startup(irq); | 223 | desc->depth = 0; |
224 | else | 224 | desc->status &= ~IRQ_DISABLED; |
225 | desc->chip->enable(irq); | 225 | if (desc->chip->startup) |
226 | desc->chip->startup(irq); | ||
227 | else | ||
228 | desc->chip->enable(irq); | ||
229 | } | ||
226 | } | 230 | } |
227 | spin_unlock_irqrestore(&desc->lock, flags); | 231 | spin_unlock_irqrestore(&desc->lock, flags); |
228 | 232 | ||