selftests: mlxsw: vxlan: Disable IPv6 autogen on bridges
authorPetr Machata <petrm@nvidia.com>
Tue, 20 Jun 2023 13:56:01 +0000 (15:56 +0200)
committerJakub Kicinski <kuba@kernel.org>
Wed, 21 Jun 2023 21:02:52 +0000 (14:02 -0700)
In a future patch, mlxsw will start adding RIFs to uppers of front panel
port netdevices, if they have an IP address.

At the time that the front panel port is enslaved to the bridge (this holds
for all bridges used here), the bridge MAC address does not have the same
prefix as other interfaces in the system. On Nvidia Spectrum-1 machines all
the RIFs have to have the same 38-bit MAC address prefix. Since the bridge
does not obey this limitation, the RIF cannot be created, and the
enslavement attempt is vetoed on the grounds of the configuration not being
offloadable.

The selftest itself however checks various aspects of VXLAN offloading and
the bridges do not need to participate in routing traffic. The IP addresses
or the RIFs are irrelevant.

Fix by disabling automatic IPv6 address generation for the HW-offloaded
bridges in this selftest, thus exempting them from mlxsw router attention.

Signed-off-by: Petr Machata <petrm@nvidia.com>
Reviewed-by: Danielle Ratson <danieller@nvidia.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
tools/testing/selftests/drivers/net/mlxsw/vxlan.sh

index 99a332b712f0f8cbdccb238f49f97c2d4e094cc3..4687b0a7dffbf19ee25f47d14665bf67d94bda46 100755 (executable)
@@ -444,8 +444,12 @@ offload_indication_setup_create()
 {
        # Create a simple setup with two bridges, each with a VxLAN device
        # and one local port
-       ip link add name br0 up type bridge mcast_snooping 0
-       ip link add name br1 up type bridge mcast_snooping 0
+       ip link add name br0 type bridge mcast_snooping 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
+       ip link add name br1 type bridge mcast_snooping 0
+       ip link set dev br1 addrgenmode none
+       ip link set dev br1 up
 
        ip link set dev $swp1 master br0
        ip link set dev $swp2 master br1
@@ -646,8 +650,12 @@ offload_indication_decap_route_test()
 
        RET=0
 
-       ip link add name br0 up type bridge mcast_snooping 0
-       ip link add name br1 up type bridge mcast_snooping 0
+       ip link add name br0 type bridge mcast_snooping 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
+       ip link add name br1 type bridge mcast_snooping 0
+       ip link set dev br1 addrgenmode none
+       ip link set dev br1 up
        ip link set dev $swp1 master br0
        ip link set dev $swp2 master br1
        ip link set dev vxlan0 master br0
@@ -780,7 +788,9 @@ __offload_indication_join_vxlan_first()
 
 offload_indication_join_vxlan_first()
 {
-       ip link add dev br0 up type bridge mcast_snooping 0
+       ip link add dev br0 type bridge mcast_snooping 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
        ip link add name vxlan0 up type vxlan id 10 nolearning $UDPCSUM_FLAFS \
                ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789
 
@@ -815,7 +825,9 @@ __offload_indication_join_vxlan_last()
 
 offload_indication_join_vxlan_last()
 {
-       ip link add dev br0 up type bridge mcast_snooping 0
+       ip link add dev br0 type bridge mcast_snooping 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
        ip link add name vxlan0 up type vxlan id 10 nolearning $UDPCSUM_FLAFS \
                ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789
 
@@ -842,6 +854,7 @@ sanitization_vlan_aware_test()
        RET=0
 
        ip link add dev br0 type bridge mcast_snooping 0 vlan_filtering 1
+       ip link set dev br0 addrgenmode none
 
        ip link add name vxlan10 up master br0 type vxlan id 10 nolearning \
                $UDPCSUM_FLAFS ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789
@@ -915,8 +928,10 @@ offload_indication_vlan_aware_setup_create()
 {
        # Create a simple setup with two VxLAN devices and a single VLAN-aware
        # bridge
-       ip link add name br0 up type bridge mcast_snooping 0 vlan_filtering 1 \
+       ip link add name br0 type bridge mcast_snooping 0 vlan_filtering 1 \
                vlan_default_pvid 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
 
        ip link set dev $swp1 master br0
 
@@ -1060,8 +1075,10 @@ offload_indication_vlan_aware_decap_route_test()
 
 offload_indication_vlan_aware_join_vxlan_first()
 {
-       ip link add dev br0 up type bridge mcast_snooping 0 \
+       ip link add dev br0 type bridge mcast_snooping 0 \
                vlan_filtering 1 vlan_default_pvid 1
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
        ip link add name vxlan0 up type vxlan id 10 nolearning $UDPCSUM_FLAFS \
                ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789
 
@@ -1073,8 +1090,10 @@ offload_indication_vlan_aware_join_vxlan_first()
 
 offload_indication_vlan_aware_join_vxlan_last()
 {
-       ip link add dev br0 up type bridge mcast_snooping 0 \
+       ip link add dev br0 type bridge mcast_snooping 0 \
                vlan_filtering 1 vlan_default_pvid 1
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
        ip link add name vxlan0 up type vxlan id 10 nolearning $UDPCSUM_FLAFS \
                ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789
 
@@ -1091,8 +1110,10 @@ offload_indication_vlan_aware_l3vni_test()
        RET=0
 
        sysctl_set net.ipv6.conf.default.disable_ipv6 1
-       ip link add dev br0 up type bridge mcast_snooping 0 \
+       ip link add dev br0 type bridge mcast_snooping 0 \
                vlan_filtering 1 vlan_default_pvid 0
+       ip link set dev br0 addrgenmode none
+       ip link set dev br0 up
        ip link add name vxlan0 up type vxlan id 10 nolearning $UDPCSUM_FLAFS \
                ttl 20 tos inherit local $LOCAL_IP_1 dstport 4789