3c59x: Fix shared IRQ handling
authorDenys Vlasenko <dvlasenk@redhat.com>
Tue, 7 Jul 2015 18:48:55 +0000 (20:48 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 9 Jul 2015 06:37:32 +0000 (23:37 -0700)
commit4eed4d8ff984abcb983ada5b3dbf56fce35f1068
tree98a1e4d6d28ae006ef1aba596b25ddc54a0eeaec
parent0769636cb5b95665ebadcd1a41c46f331f5a397d
3c59x: Fix shared IRQ handling

As its first order of business, boomerang_interrupt() checks whether
the device really has any pending interrupts. If it does not,
it does nothing and returns, but it still returns IRQ_HANDLED.

This is wrong: interrupt was not handled, IRQ handlers of other
devices sharing this IRQ line need to be called.

vortex_interrupt() has it right: it returns IRQ_NONE in this case
via IRQ_RETVAL(0).

Do the same in boomerang_interrupt().

Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
CC: David S. Miller <davem@davemloft.net>
CC: linux-kernel@vger.kernel.org
CC: netdev@vger.kernel.org
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/3com/3c59x.c