提交 9f687888 编写于 作者: J Jeff Kirsher 提交者: root

e1000: Add 82573 controller support to TSO fix

Signed-off-by: NJeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: NJesse Brandeburg <jesse.brandeburg@intel.com>
Signed-off-by: NJohn Ronciak <john.ronciak@intel.com>
上级 329bfd0b
...@@ -2796,21 +2796,29 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev) ...@@ -2796,21 +2796,29 @@ e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
max_per_txd = min(mss << 2, max_per_txd); max_per_txd = min(mss << 2, max_per_txd);
max_txd_pwr = fls(max_per_txd) - 1; max_txd_pwr = fls(max_per_txd) - 1;
/* TSO Workaround for 82571/2 Controllers -- if skb->data /* TSO Workaround for 82571/2/3 Controllers -- if skb->data
* points to just header, pull a few bytes of payload from * points to just header, pull a few bytes of payload from
* frags into skb->data */ * frags into skb->data */
hdr_len = ((skb->h.raw - skb->data) + (skb->h.th->doff << 2)); hdr_len = ((skb->h.raw - skb->data) + (skb->h.th->doff << 2));
if (skb->data_len && (hdr_len == (skb->len - skb->data_len)) && if (skb->data_len && (hdr_len == (skb->len - skb->data_len))) {
(adapter->hw.mac_type == e1000_82571 || switch (adapter->hw.mac_type) {
adapter->hw.mac_type == e1000_82572)) { unsigned int pull_size;
unsigned int pull_size; case e1000_82571:
pull_size = min((unsigned int)4, skb->data_len); case e1000_82572:
if (!__pskb_pull_tail(skb, pull_size)) { case e1000_82573:
printk(KERN_ERR "__pskb_pull_tail failed.\n"); pull_size = min((unsigned int)4, skb->data_len);
dev_kfree_skb_any(skb); if (!__pskb_pull_tail(skb, pull_size)) {
return -EFAULT; printk(KERN_ERR
"__pskb_pull_tail failed.\n");
dev_kfree_skb_any(skb);
return -EFAULT;
}
len = skb->len - skb->data_len;
break;
default:
/* do nothing */
break;
} }
len = skb->len - skb->data_len;
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册