X-Git-Url: http://pilppa.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=kernel%2Firq%2Fresend.c;h=a8046791ba2d3fde84853ac7a7bfbb0bbca07b84;hb=273b2578392bbf6e5c47a8a3d1ee461ce6fc7182;hp=5bfeaed7e4872850049d40aef740d24b983adebf;hpb=ba00003aa83a61b615542dd66f5af8fb4a7cee1d;p=linux-2.6-omap-h63xx.git diff --git a/kernel/irq/resend.c b/kernel/irq/resend.c index 5bfeaed7e48..a8046791ba2 100644 --- a/kernel/irq/resend.c +++ b/kernel/irq/resend.c @@ -62,7 +62,12 @@ void check_irq_resend(struct irq_desc *desc, unsigned int irq) */ desc->chip->enable(irq); - if ((status & (IRQ_PENDING | IRQ_REPLAY)) == IRQ_PENDING) { + /* + * We do not resend level type interrupts. Level type + * interrupts are resent by hardware when they are still + * active. + */ + if ((status & (IRQ_LEVEL | IRQ_PENDING | IRQ_REPLAY)) == IRQ_PENDING) { desc->status = (status & ~IRQ_PENDING) | IRQ_REPLAY; if (!desc->chip || !desc->chip->retrigger ||