aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorStephen Hemminger <shemminger@osdl.org>2005-12-20 18:08:09 -0500
committerJeff Garzik <jgarzik@pobox.com>2005-12-24 09:38:35 -0500
commit6e15b7124990e4b91645601e7a90d3fe72873336 (patch)
tree4b7e90e86467ed541c055a69362dc5ba8bc34ec8 /drivers
parent6ed995bb29f042eece8392d9bae0b83f84bcdb23 (diff)
[PATCH] sky2: handle hardware packet overrun
It is possible for hardware to get confused when an oversized frame is received. In that case, just drop the packet and increment a counter. Signed-off-by: Stephen Hemminger <shemminger@osdl.org> Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/sky2.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c
index c7b4da1d717f..9b428e423c3d 100644
--- a/drivers/net/sky2.c
+++ b/drivers/net/sky2.c
@@ -1694,6 +1694,9 @@ static struct sk_buff *sky2_receive(struct sky2_port *sky2,
1694 if (!(status & GMR_FS_RX_OK)) 1694 if (!(status & GMR_FS_RX_OK))
1695 goto resubmit; 1695 goto resubmit;
1696 1696
1697 if ((status >> 16) != length || length > sky2->rx_bufsize)
1698 goto oversize;
1699
1697 if (length < copybreak) { 1700 if (length < copybreak) {
1698 skb = alloc_skb(length + 2, GFP_ATOMIC); 1701 skb = alloc_skb(length + 2, GFP_ATOMIC);
1699 if (!skb) 1702 if (!skb)
@@ -1735,7 +1738,13 @@ resubmit:
1735 1738
1736 return skb; 1739 return skb;
1737 1740
1741oversize:
1742 ++sky2->net_stats.rx_over_errors;
1743 goto resubmit;
1744
1738error: 1745error:
1746 ++sky2->net_stats.rx_errors;
1747
1739 if (netif_msg_rx_err(sky2)) 1748 if (netif_msg_rx_err(sky2))
1740 printk(KERN_INFO PFX "%s: rx error, status 0x%x length %d\n", 1749 printk(KERN_INFO PFX "%s: rx error, status 0x%x length %d\n",
1741 sky2->netdev->name, status, length); 1750 sky2->netdev->name, status, length);