diff options
| author | David S. Miller <davem@davemloft.net> | 2009-03-27 20:19:16 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2009-03-27 20:19:16 -0400 |
| commit | a83398570e17af6bb81eb94f4f5dd356bd2828d8 (patch) | |
| tree | 5b5c7c3a56898485479291b7c964a1f3887d469c /kernel/irq/chip.c | |
| parent | f9384d41c02408dd404aa64d66d0ef38adcf6479 (diff) | |
| parent | 0b4d569de222452bcb55a4a536ade6cf4d8d1e30 (diff) | |
Merge branch 'master' of /home/davem/src/GIT/linux-2.6/
Diffstat (limited to 'kernel/irq/chip.c')
| -rw-r--r-- | kernel/irq/chip.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/kernel/irq/chip.c b/kernel/irq/chip.c index 7de11bd64dfe..03d0bed2b8d9 100644 --- a/kernel/irq/chip.c +++ b/kernel/irq/chip.c | |||
| @@ -78,6 +78,7 @@ void dynamic_irq_cleanup(unsigned int irq) | |||
| 78 | desc->handle_irq = handle_bad_irq; | 78 | desc->handle_irq = handle_bad_irq; |
| 79 | desc->chip = &no_irq_chip; | 79 | desc->chip = &no_irq_chip; |
| 80 | desc->name = NULL; | 80 | desc->name = NULL; |
| 81 | clear_kstat_irqs(desc); | ||
| 81 | spin_unlock_irqrestore(&desc->lock, flags); | 82 | spin_unlock_irqrestore(&desc->lock, flags); |
| 82 | } | 83 | } |
| 83 | 84 | ||
| @@ -290,7 +291,8 @@ static inline void mask_ack_irq(struct irq_desc *desc, int irq) | |||
| 290 | desc->chip->mask_ack(irq); | 291 | desc->chip->mask_ack(irq); |
| 291 | else { | 292 | else { |
| 292 | desc->chip->mask(irq); | 293 | desc->chip->mask(irq); |
| 293 | desc->chip->ack(irq); | 294 | if (desc->chip->ack) |
| 295 | desc->chip->ack(irq); | ||
| 294 | } | 296 | } |
| 295 | } | 297 | } |
| 296 | 298 | ||
| @@ -476,7 +478,8 @@ handle_edge_irq(unsigned int irq, struct irq_desc *desc) | |||
| 476 | kstat_incr_irqs_this_cpu(irq, desc); | 478 | kstat_incr_irqs_this_cpu(irq, desc); |
| 477 | 479 | ||
| 478 | /* Start handling the irq */ | 480 | /* Start handling the irq */ |
| 479 | desc->chip->ack(irq); | 481 | if (desc->chip->ack) |
| 482 | desc->chip->ack(irq); | ||
| 480 | desc = irq_remap_to_desc(irq, desc); | 483 | desc = irq_remap_to_desc(irq, desc); |
| 481 | 484 | ||
| 482 | /* Mark the IRQ currently in progress.*/ | 485 | /* Mark the IRQ currently in progress.*/ |
