bna: Support TSO and partial checksum with non-accelerated vlans.
This device claims TSO and checksum support for vlans. It also allows a user to control vlan acceleration offloading. As such, it is possible to turn off vlan acceleration and configure a vlan which will continue to support TSO. In such situation the packet passed down the the device will contain a vlan header and skb->protocol will be set to ETH_P_8021Q. The device assumes that skb->protocol contains network protocol value and uses that value to set up TSO information. This results in corrupted frames sent on the wire. This patch extract the protocol value correctly and corrects TSO and checksums for non-accelerated traffic. CC: Rasesh Mody <rmody@brocade.com> Signed-off-by: Vladislav Yasevich <vyasevic@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
06f4d0333e
commit
1c53730a04
@ -2506,7 +2506,7 @@ bnad_tso_prepare(struct bnad *bnad, struct sk_buff *skb)
|
||||
* For TSO, the TCP checksum field is seeded with pseudo-header sum
|
||||
* excluding the length field.
|
||||
*/
|
||||
if (skb->protocol == htons(ETH_P_IP)) {
|
||||
if (vlan_get_protocol(skb) == htons(ETH_P_IP)) {
|
||||
struct iphdr *iph = ip_hdr(skb);
|
||||
|
||||
/* Do we really need these? */
|
||||
@ -2870,12 +2870,13 @@ bnad_txq_wi_prepare(struct bnad *bnad, struct bna_tcb *tcb,
|
||||
}
|
||||
|
||||
if (skb->ip_summed == CHECKSUM_PARTIAL) {
|
||||
__be16 net_proto = vlan_get_protocol(skb);
|
||||
u8 proto = 0;
|
||||
|
||||
if (skb->protocol == htons(ETH_P_IP))
|
||||
if (net_proto == htons(ETH_P_IP))
|
||||
proto = ip_hdr(skb)->protocol;
|
||||
#ifdef NETIF_F_IPV6_CSUM
|
||||
else if (skb->protocol == htons(ETH_P_IPV6)) {
|
||||
else if (net_proto == htons(ETH_P_IPV6)) {
|
||||
/* nexthdr may not be TCP immediately. */
|
||||
proto = ipv6_hdr(skb)->nexthdr;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user