s390/qeth: limit csum offload erratum to L3 devices
authorJulian Wiedmann <jwi@linux.ibm.com>
Mon, 17 Sep 2018 15:35:59 +0000 (17:35 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 17 Sep 2018 16:10:25 +0000 (09:10 -0700)
Combined L3+L4 csum offload is only required for some L3 HW. So for
L2 devices, don't offload the IP header csum calculation.

Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com>
Reference-ID: JUP 394553
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/s390/net/qeth_core.h
drivers/s390/net/qeth_l3_main.c

index 0857b1286660c92f651de330b4e61606b8c0a972..b47fb95a49e9e9f414e8e1211fdcc7e63ef37ecf 100644 (file)
@@ -892,11 +892,6 @@ static inline void qeth_tx_csum(struct sk_buff *skb, u8 *flags, int ipv)
        if ((ipv == 4 && ip_hdr(skb)->protocol == IPPROTO_UDP) ||
            (ipv == 6 && ipv6_hdr(skb)->nexthdr == IPPROTO_UDP))
                *flags |= QETH_HDR_EXT_UDP;
-       if (ipv == 4) {
-               /* some HW requires combined L3+L4 csum offload: */
-               *flags |= QETH_HDR_EXT_CSUM_HDR_REQ;
-               ip_hdr(skb)->check = 0;
-       }
 }
 
 static inline void qeth_put_buffer_pool_entry(struct qeth_card *card,
index 1d92584e01b34880405b9652e92fe51afb36bc48..d4a967077279c25cb8bdb3e0b7f629ff63c28529 100644 (file)
@@ -2055,6 +2055,11 @@ static void qeth_l3_fill_header(struct qeth_card *card, struct qeth_hdr *hdr,
 
        if (!skb_is_gso(skb) && skb->ip_summed == CHECKSUM_PARTIAL) {
                qeth_tx_csum(skb, &hdr->hdr.l3.ext_flags, ipv);
+               /* some HW requires combined L3+L4 csum offload: */
+               if (ipv == 4) {
+                       hdr->hdr.l3.ext_flags |= QETH_HDR_EXT_CSUM_HDR_REQ;
+                       ip_hdr(skb)->check = 0;
+               }
                if (card->options.performance_stats)
                        card->perf_stats.tx_csum++;
        }