[PATCH] sky2: remove cloned/pskb_expand_head check
The code to handle cloned skb overwriting is unnecessary in the sky2 driver and is buggy. The bug is that pskb_expand_head can change the skb but the driver has already mapped in the header. Since the sky2 hardware doesn't need to overwrite memory, the buggy code can just be removed; it was mistakenly copied from the tg3 driver. Signed-off-by: Stephen Hemminger <shemminger@osdl.org> Signed-off-by: Jeff Garzik <jeff@garzik.org>
This commit is contained in:
parent
699a712388
commit
fba5008cda
|
@ -1239,13 +1239,6 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev)
|
||||||
/* Check for TCP Segmentation Offload */
|
/* Check for TCP Segmentation Offload */
|
||||||
mss = skb_shinfo(skb)->gso_size;
|
mss = skb_shinfo(skb)->gso_size;
|
||||||
if (mss != 0) {
|
if (mss != 0) {
|
||||||
/* just drop the packet if non-linear expansion fails */
|
|
||||||
if (skb_header_cloned(skb) &&
|
|
||||||
pskb_expand_head(skb, 0, 0, GFP_ATOMIC)) {
|
|
||||||
dev_kfree_skb(skb);
|
|
||||||
goto out_unlock;
|
|
||||||
}
|
|
||||||
|
|
||||||
mss += ((skb->h.th->doff - 5) * 4); /* TCP options */
|
mss += ((skb->h.th->doff - 5) * 4); /* TCP options */
|
||||||
mss += (skb->nh.iph->ihl * 4) + sizeof(struct tcphdr);
|
mss += (skb->nh.iph->ihl * 4) + sizeof(struct tcphdr);
|
||||||
mss += ETH_HLEN;
|
mss += ETH_HLEN;
|
||||||
|
@ -1341,7 +1334,6 @@ static int sky2_xmit_frame(struct sk_buff *skb, struct net_device *dev)
|
||||||
|
|
||||||
sky2_put_idx(hw, txqaddr[sky2->port], sky2->tx_prod);
|
sky2_put_idx(hw, txqaddr[sky2->port], sky2->tx_prod);
|
||||||
|
|
||||||
out_unlock:
|
|
||||||
spin_unlock(&sky2->tx_lock);
|
spin_unlock(&sky2->tx_lock);
|
||||||
|
|
||||||
dev->trans_start = jiffies;
|
dev->trans_start = jiffies;
|
||||||
|
|
Loading…
Reference in New Issue