diff options
| author | Jeff Garzik <jgarzik@pobox.com> | 2005-11-04 21:39:31 -0500 |
|---|---|---|
| committer | Jeff Garzik <jgarzik@pobox.com> | 2005-11-04 21:39:31 -0500 |
| commit | c2cc87ca9561ddfe744d446789cc10f507e87db9 (patch) | |
| tree | d505fc0110eb1a3d8750ba2f67648c131f0d9aca /kernel/irq/handle.c | |
| parent | ce1eeb95fc4eb25109c00bea3e83a87eeff6b07d (diff) | |
| parent | 7015faa7df829876a0f931cd18aa6d7c24a1b581 (diff) | |
Merge branch 'master'
Diffstat (limited to 'kernel/irq/handle.c')
| -rw-r--r-- | kernel/irq/handle.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/kernel/irq/handle.c b/kernel/irq/handle.c index 3ff7b925c387..51df337b37db 100644 --- a/kernel/irq/handle.c +++ b/kernel/irq/handle.c | |||
| @@ -117,14 +117,16 @@ fastcall unsigned int __do_IRQ(unsigned int irq, struct pt_regs *regs) | |||
| 117 | /* | 117 | /* |
| 118 | * No locking required for CPU-local interrupts: | 118 | * No locking required for CPU-local interrupts: |
| 119 | */ | 119 | */ |
| 120 | desc->handler->ack(irq); | 120 | if (desc->handler->ack) |
| 121 | desc->handler->ack(irq); | ||
| 121 | action_ret = handle_IRQ_event(irq, regs, desc->action); | 122 | action_ret = handle_IRQ_event(irq, regs, desc->action); |
| 122 | desc->handler->end(irq); | 123 | desc->handler->end(irq); |
| 123 | return 1; | 124 | return 1; |
| 124 | } | 125 | } |
| 125 | 126 | ||
| 126 | spin_lock(&desc->lock); | 127 | spin_lock(&desc->lock); |
| 127 | desc->handler->ack(irq); | 128 | if (desc->handler->ack) |
| 129 | desc->handler->ack(irq); | ||
| 128 | /* | 130 | /* |
| 129 | * REPLAY is when Linux resends an IRQ that was dropped earlier | 131 | * REPLAY is when Linux resends an IRQ that was dropped earlier |
| 130 | * WAITING is used by probe to mark irqs that are being tested | 132 | * WAITING is used by probe to mark irqs that are being tested |
