diff options
author | Stephen Hemminger <shemminger@osdl.org> | 2005-12-09 14:35:02 -0500 |
---|---|---|
committer | Jeff Garzik <jgarzik@pobox.com> | 2005-12-12 15:27:21 -0500 |
commit | 0e3ff6aab1ff2d093996bd7b8c9c06c3d823855c (patch) | |
tree | 044b1b395a657643750ab79641a12889c8fdc765 /drivers/net | |
parent | 6cdbbdf3055f4657c9d6ccc79257bbcac1a9a1fc (diff) |
[PATCH] sky2: transmit logic fixes
Some transmit side small fixes:
* When computing number of list elements per transmit, do full
comparision to check for checksuming.
* Get rid of racy check for tx_complete
* Change stop test to match wake condition.
Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/sky2.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index 1eefacbfcd2..8dfd27d4d6e 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
@@ -1051,7 +1051,7 @@ static inline unsigned tx_le_req(const struct sk_buff *skb) | |||
1051 | if (skb_shinfo(skb)->tso_size) | 1051 | if (skb_shinfo(skb)->tso_size) |
1052 | ++count; | 1052 | ++count; |
1053 | 1053 | ||
1054 | if (skb->ip_summed) | 1054 | if (skb->ip_summed == CHECKSUM_HW) |
1055 | ++count; | 1055 | ++count; |
1056 | 1056 | ||
1057 | return count; | 1057 | return count; |
@@ -1207,7 +1207,7 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev) | |||
1207 | sky2_put_idx(hw, txqaddr[sky2->port], sky2->tx_prod, | 1207 | sky2_put_idx(hw, txqaddr[sky2->port], sky2->tx_prod, |
1208 | &sky2->tx_last_put, TX_RING_SIZE); | 1208 | &sky2->tx_last_put, TX_RING_SIZE); |
1209 | 1209 | ||
1210 | if (tx_avail(sky2) < MAX_SKB_TX_LE + 1) | 1210 | if (tx_avail(sky2) <= MAX_SKB_TX_LE) |
1211 | netif_stop_queue(dev); | 1211 | netif_stop_queue(dev); |
1212 | 1212 | ||
1213 | out_unlock: | 1213 | out_unlock: |
@@ -1229,8 +1229,7 @@ static void sky2_tx_complete(struct sky2_port *sky2, u16 done) | |||
1229 | struct net_device *dev = sky2->netdev; | 1229 | struct net_device *dev = sky2->netdev; |
1230 | unsigned i; | 1230 | unsigned i; |
1231 | 1231 | ||
1232 | if (done == sky2->tx_cons) | 1232 | BUG_ON(done >= TX_RING_SIZE); |
1233 | return; | ||
1234 | 1233 | ||
1235 | if (unlikely(netif_msg_tx_done(sky2))) | 1234 | if (unlikely(netif_msg_tx_done(sky2))) |
1236 | printk(KERN_DEBUG "%s: tx done, up to %u\n", | 1235 | printk(KERN_DEBUG "%s: tx done, up to %u\n", |