aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRon Mercer <ron.mercer@qlogic.com>2009-03-09 10:59:27 +0000
committerDavid S. Miller <davem@davemloft.net>2009-03-10 04:43:58 -0700
commit74c50b4bae225b8e5aff9a1ceca256ba46c665c6 (patch)
tree396c3c21b6aff97055691bbbeddf442b5c4a965a
parentqlge: bugfix: Move netif_napi_del() to common call point. (diff)
downloadlinux-dev-74c50b4bae225b8e5aff9a1ceca256ba46c665c6.tar.xz
linux-dev-74c50b4bae225b8e5aff9a1ceca256ba46c665c6.zip
qlge: bugfix: Pad outbound frames smaller than 60 bytes.
With some asic configurations xmit of frames smaller than 60 bytes may fail. Signed-off-by: Ron Mercer <ron.mercer@qlogic.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/qlge/qlge_main.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/qlge/qlge_main.c b/drivers/net/qlge/qlge_main.c
index ce826da6f165..189584684aae 100644
--- a/drivers/net/qlge/qlge_main.c
+++ b/drivers/net/qlge/qlge_main.c
@@ -2057,6 +2057,9 @@ static int qlge_send(struct sk_buff *skb, struct net_device *ndev)
tx_ring = &qdev->tx_ring[tx_ring_idx];
+ if (skb_padto(skb, ETH_ZLEN))
+ return NETDEV_TX_OK;
+
if (unlikely(atomic_read(&tx_ring->tx_count) < 2)) {
QPRINTK(qdev, TX_QUEUED, INFO,
"%s: shutting down tx queue %d du to lack of resources.\n",