X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=kernel%2Firq%2Fresend.c;h=a8046791ba2d3fde84853ac7a7bfbb0bbca07b84;hb=af76bbabbdf5cebea6a3863446f9f74b469c4bdc;hp=c382727468876dbd84c2ba6b9e89ae5a6464de1e;hpb=b5625481832ef1ab1a8e31fac0b1d14acdbbc148;p=linux-2.6 diff --git a/kernel/irq/resend.c b/kernel/irq/resend.c index c382727468..a8046791ba 100644 --- a/kernel/irq/resend.c +++ b/kernel/irq/resend.c @@ -63,15 +63,11 @@ void check_irq_resend(struct irq_desc *desc, unsigned int irq) desc->chip->enable(irq); /* - * Temporary hack to figure out more about the problem, which - * is causing the ancient network cards to die. + * We do not resend level type interrupts. Level type + * interrupts are resent by hardware when they are still + * active. */ - if (desc->handle_irq != handle_edge_irq) { - WARN_ON_ONCE(1); - return; - } - - if ((status & (IRQ_PENDING | IRQ_REPLAY)) == IRQ_PENDING) { + if ((status & (IRQ_LEVEL | IRQ_PENDING | IRQ_REPLAY)) == IRQ_PENDING) { desc->status = (status & ~IRQ_PENDING) | IRQ_REPLAY; if (!desc->chip || !desc->chip->retrigger ||