summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2010-05-03 23:21:27 -0700
committerDavid S. Miller <davem@davemloft.net>2010-05-03 23:21:27 -0700
commit1827d2e943eeb5cba0662f3e6edc342d6bd65ae6 (patch)
treee8e22b3eee8ae229ee323b14675beab1f5c7400a /drivers
parentd05070091849015f8c5b7d55cd75b86ebb61b3ec (diff)
downloadlinux-3.10-1827d2e943eeb5cba0662f3e6edc342d6bd65ae6.tar.gz
linux-3.10-1827d2e943eeb5cba0662f3e6edc342d6bd65ae6.tar.bz2
linux-3.10-1827d2e943eeb5cba0662f3e6edc342d6bd65ae6.zip
net: ep93xx_eth stops receiving packets
Receiving small packet(s) in a fast pace leads to not receiving any packets at all after some time. After ethernet packet(s) arrived the receive descriptor is incremented by the number of frames processed. If another packet arrives while processing, this is processed in another call of ep93xx_rx. This second call leads that too many receive descriptors getting released. This fix increments, even in these case, the right number of processed receive descriptors. Signed-off-by: Stefan Agner <stefan@agner.ch> Acked-by: Lennert Buytenhek <buytenh@wantstofly.org> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/arm/ep93xx_eth.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/net/arm/ep93xx_eth.c b/drivers/net/arm/ep93xx_eth.c
index 6995169d285..cd17d09f385 100644
--- a/drivers/net/arm/ep93xx_eth.c
+++ b/drivers/net/arm/ep93xx_eth.c
@@ -311,11 +311,6 @@ err:
processed++;
}
- if (processed) {
- wrw(ep, REG_RXDENQ, processed);
- wrw(ep, REG_RXSTSENQ, processed);
- }
-
return processed;
}
@@ -350,6 +345,11 @@ poll_some_more:
goto poll_some_more;
}
+ if (rx) {
+ wrw(ep, REG_RXDENQ, rx);
+ wrw(ep, REG_RXSTSENQ, rx);
+ }
+
return rx;
}