diff options
author | Govindarajulu Varadarajan <gvaradar@cisco.com> | 2019-01-30 15:59:00 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2019-02-01 23:41:42 +0100 |
commit | 7596175e99b3d4bce28022193efd954c201a782a (patch) | |
tree | 161c3bdce3098d9fa241596cf60209a967af50c2 | |
parent | sctp: walk the list of asoc safely (diff) | |
download | linux-7596175e99b3d4bce28022193efd954c201a782a.tar.xz linux-7596175e99b3d4bce28022193efd954c201a782a.zip |
enic: fix checksum validation for IPv6
In case of IPv6 pkts, ipv4_csum_ok is 0. Because of this, driver does
not set skb->ip_summed. So IPv6 rx checksum is not offloaded.
Signed-off-by: Govindarajulu Varadarajan <gvaradar@cisco.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/cisco/enic/enic_main.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/net/ethernet/cisco/enic/enic_main.c b/drivers/net/ethernet/cisco/enic/enic_main.c index 60641e202534..9a7f70db20c7 100644 --- a/drivers/net/ethernet/cisco/enic/enic_main.c +++ b/drivers/net/ethernet/cisco/enic/enic_main.c @@ -1434,7 +1434,8 @@ static void enic_rq_indicate_buf(struct vnic_rq *rq, * csum is correct or is zero. */ if ((netdev->features & NETIF_F_RXCSUM) && !csum_not_calc && - tcp_udp_csum_ok && ipv4_csum_ok && outer_csum_ok) { + tcp_udp_csum_ok && outer_csum_ok && + (ipv4_csum_ok || ipv6)) { skb->ip_summed = CHECKSUM_UNNECESSARY; skb->csum_level = encap; } |