diff options
author | Daniel Hellstrom <daniel@gaisler.com> | 2011-01-13 22:02:42 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-01-14 15:45:54 -0500 |
commit | 1ca23434dd0001bd2bfff31b8251436b34aa9066 (patch) | |
tree | aa6696927db181540cfd9ec551e54d18dfc60e4a /drivers/net/greth.c | |
parent | 2436af8ca7a6c4679cf7da7e3867f1d5cd8528b7 (diff) |
GRETH: handle frame error interrupts
Frame error interrupts must also be handled since the RX flag only indicates
successful reception, it is unlikely but the old code may lead to dead lock
if 128 error frames are recieved in a row.
Signed-off-by: Daniel Hellstrom <daniel@gaisler.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/greth.c')
-rw-r--r-- | drivers/net/greth.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/net/greth.c b/drivers/net/greth.c index e48d18216cbe..b888abe6cd21 100644 --- a/drivers/net/greth.c +++ b/drivers/net/greth.c | |||
@@ -586,12 +586,13 @@ static irqreturn_t greth_interrupt(int irq, void *dev_id) | |||
586 | status = GRETH_REGLOAD(greth->regs->status); | 586 | status = GRETH_REGLOAD(greth->regs->status); |
587 | 587 | ||
588 | /* Handle rx and tx interrupts through poll */ | 588 | /* Handle rx and tx interrupts through poll */ |
589 | if (status & (GRETH_INT_RX | GRETH_INT_TX)) { | 589 | if (status & (GRETH_INT_RE | GRETH_INT_RX | |
590 | GRETH_INT_TE | GRETH_INT_TX)) { | ||
590 | 591 | ||
591 | /* Clear interrupt status */ | 592 | /* Clear interrupt status */ |
592 | GRETH_REGORIN(greth->regs->status, | 593 | GRETH_REGSAVE(greth->regs->status, |
593 | status & (GRETH_INT_RX | GRETH_INT_TX)); | 594 | status & (GRETH_INT_RE | GRETH_INT_RX | |
594 | 595 | GRETH_INT_TE | GRETH_INT_TX)); | |
595 | retval = IRQ_HANDLED; | 596 | retval = IRQ_HANDLED; |
596 | 597 | ||
597 | /* Disable interrupts and schedule poll() */ | 598 | /* Disable interrupts and schedule poll() */ |