]> git.baikalelectronics.ru Git - kernel.git/commit
mlxsw: spectrum: Fix ECN marking in tunnel decapsulation
authorIdo Schimmel <idosch@nvidia.com>
Mon, 29 Mar 2021 08:29:23 +0000 (11:29 +0300)
committerDavid S. Miller <davem@davemloft.net>
Mon, 29 Mar 2021 20:29:49 +0000 (13:29 -0700)
commit9bf50a35a5586b37c1629e9a03c937f893890367
tree4917afd77ef22fc39219c1733b76908ab161dcfb
parent7b4a9139c327c59936b021dbeefd3bdf69965ded
mlxsw: spectrum: Fix ECN marking in tunnel decapsulation

Cited commit changed the behavior of the software data path with regards
to the ECN marking of decapsulated packets. However, the commit did not
change other callers of __INET_ECN_decapsulate(), namely mlxsw. The
driver is using the function in order to ensure that the hardware and
software data paths act the same with regards to the ECN marking of
decapsulated packets.

The discrepancy was uncovered by commit 1dddb15fc3ce ("selftests:
forwarding: vxlan_bridge_1d: Fix vxlan ecn decapsulate value") that
aligned the selftest to the new behavior. Without this patch the
selftest passes when used with veth pairs, but fails when used with
mlxsw netdevs.

Fix this by instructing the device to propagate the ECT(1) mark from the
outer header to the inner header when the inner header is ECT(0), for
both NVE and IP-in-IP tunnels.

A helper is added in order not to duplicate the code between both tunnel
types.

Fixes: 2732061e4836 ("tunnel: Propagate ECT(1) when decapsulating as recommended by RFC6040")
Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Reviewed-by: Petr Machata <petrm@nvidia.com>
Acked-by: Toke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/spectrum.h
drivers/net/ethernet/mellanox/mlxsw/spectrum_ipip.c
drivers/net/ethernet/mellanox/mlxsw/spectrum_nve.c