summaryrefslogtreecommitdiff
path: root/net
diff options
context:
space:
mode:
authorEmeel Hakim <ehakim@nvidia.com>2021-10-18 15:31:19 +0300
committerSaeed Mahameed <saeedm@nvidia.com>2021-10-20 20:42:51 +0300
commit1d000323940137332d4d62c6332b6daf5f07aba7 (patch)
tree31dca1cbf0a6138da28774eb58e21f6bbb93377e /net
parentd10457f85d4ae4d32c0df0cd65358a78c577fbe6 (diff)
downloadlinux-1d000323940137332d4d62c6332b6daf5f07aba7.tar.xz
net/mlx5e: IPsec: Fix work queue entry ethernet segment checksum flags
Current Work Queue Entry (WQE) checksum (csum) flags in the ethernet segment (eseg) in case of IPsec crypto offload datapath are not aligned with PRM/HW expectations. Currently the driver always sets the l3_inner_csum flag in case of IPsec because of the wrong usage of skb->encapsulation as indicator for inner IPsec header since skb->encapsulation is always ON for IPsec packets since IPsec itself is an encapsulation protocol. The above forced a failing attempts of calculating csum of non-existing segments (like in the IP|ESP|TCP packet case which does not have an l3_inner) which led to lots of packet drops hence the low throughput. Fix by using xo->inner_ipproto as indicator for inner IPsec header instead of skb->encapsulation in addition to setting the csum flags as following: * Tunnel Mode: * Pkt: MAC IP ESP IP L4 * CSUM: l3_cs | l3_inner_cs | l4_inner_cs * * Transport Mode: * Pkt: MAC IP ESP L4 * CSUM: l3_cs [ | l4_cs (checksum partial case)] * * Tunnel(VXLAN TCP/UDP) over Transport Mode * Pkt: MAC IP ESP UDP VXLAN IP L4 * CSUM: l3_cs | l3_inner_cs | l4_inner_cs Fixes: f1267798c980 ("net/mlx5: Fix checksum issue of VXLAN and IPsec crypto offload") Signed-off-by: Emeel Hakim <ehakim@nvidia.com> Signed-off-by: Saeed Mahameed <saeedm@nvidia.com>
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions