18c2ecf20Sopenharmony_ci#!/bin/bash 28c2ecf20Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0 38c2ecf20Sopenharmony_ci# 48c2ecf20Sopenharmony_ci# Test various aspects of VxLAN offloading which are specific to mlxsw, such 58c2ecf20Sopenharmony_ci# as sanitization of invalid configurations and offload indication. 68c2ecf20Sopenharmony_ci 78c2ecf20Sopenharmony_cilib_dir=$(dirname $0)/../../../net/forwarding 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ciALL_TESTS="sanitization_test offload_indication_test \ 108c2ecf20Sopenharmony_ci sanitization_vlan_aware_test offload_indication_vlan_aware_test" 118c2ecf20Sopenharmony_ciNUM_NETIFS=2 128c2ecf20Sopenharmony_ci: ${TIMEOUT:=20000} # ms 138c2ecf20Sopenharmony_cisource $lib_dir/lib.sh 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_cisetup_prepare() 168c2ecf20Sopenharmony_ci{ 178c2ecf20Sopenharmony_ci swp1=${NETIFS[p1]} 188c2ecf20Sopenharmony_ci swp2=${NETIFS[p2]} 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_ci ip link set dev $swp1 up 218c2ecf20Sopenharmony_ci ip link set dev $swp2 up 228c2ecf20Sopenharmony_ci} 238c2ecf20Sopenharmony_ci 248c2ecf20Sopenharmony_cicleanup() 258c2ecf20Sopenharmony_ci{ 268c2ecf20Sopenharmony_ci pre_cleanup 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_ci ip link set dev $swp2 down 298c2ecf20Sopenharmony_ci ip link set dev $swp1 down 308c2ecf20Sopenharmony_ci} 318c2ecf20Sopenharmony_ci 328c2ecf20Sopenharmony_cisanitization_single_dev_test_pass() 338c2ecf20Sopenharmony_ci{ 348c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 358c2ecf20Sopenharmony_ci check_err $? 368c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 378c2ecf20Sopenharmony_ci check_err $? 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 428c2ecf20Sopenharmony_ci check_err $? 438c2ecf20Sopenharmony_ci} 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_cisanitization_single_dev_test_fail() 468c2ecf20Sopenharmony_ci{ 478c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 488c2ecf20Sopenharmony_ci check_err $? 498c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 &> /dev/null 508c2ecf20Sopenharmony_ci check_fail $? 518c2ecf20Sopenharmony_ci 528c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 538c2ecf20Sopenharmony_ci 548c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 558c2ecf20Sopenharmony_ci check_err $? 568c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 &> /dev/null 578c2ecf20Sopenharmony_ci check_fail $? 588c2ecf20Sopenharmony_ci} 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_cisanitization_single_dev_valid_test() 618c2ecf20Sopenharmony_ci{ 628c2ecf20Sopenharmony_ci RET=0 638c2ecf20Sopenharmony_ci 648c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 678c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 688c2ecf20Sopenharmony_ci 698c2ecf20Sopenharmony_ci sanitization_single_dev_test_pass 708c2ecf20Sopenharmony_ci 718c2ecf20Sopenharmony_ci ip link del dev vxlan0 728c2ecf20Sopenharmony_ci ip link del dev br0 738c2ecf20Sopenharmony_ci 748c2ecf20Sopenharmony_ci log_test "vxlan device - valid configuration" 758c2ecf20Sopenharmony_ci} 768c2ecf20Sopenharmony_ci 778c2ecf20Sopenharmony_cisanitization_single_dev_vlan_aware_test() 788c2ecf20Sopenharmony_ci{ 798c2ecf20Sopenharmony_ci RET=0 808c2ecf20Sopenharmony_ci 818c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 vlan_filtering 1 828c2ecf20Sopenharmony_ci 838c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 848c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 858c2ecf20Sopenharmony_ci 868c2ecf20Sopenharmony_ci sanitization_single_dev_test_pass 878c2ecf20Sopenharmony_ci 888c2ecf20Sopenharmony_ci ip link del dev vxlan0 898c2ecf20Sopenharmony_ci ip link del dev br0 908c2ecf20Sopenharmony_ci 918c2ecf20Sopenharmony_ci log_test "vxlan device with a vlan-aware bridge" 928c2ecf20Sopenharmony_ci} 938c2ecf20Sopenharmony_ci 948c2ecf20Sopenharmony_cisanitization_single_dev_mcast_enabled_test() 958c2ecf20Sopenharmony_ci{ 968c2ecf20Sopenharmony_ci RET=0 978c2ecf20Sopenharmony_ci 988c2ecf20Sopenharmony_ci ip link add dev br0 type bridge 998c2ecf20Sopenharmony_ci 1008c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 1018c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 1028c2ecf20Sopenharmony_ci 1038c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 1048c2ecf20Sopenharmony_ci 1058c2ecf20Sopenharmony_ci ip link del dev vxlan0 1068c2ecf20Sopenharmony_ci ip link del dev br0 1078c2ecf20Sopenharmony_ci 1088c2ecf20Sopenharmony_ci log_test "vxlan device with a multicast enabled bridge" 1098c2ecf20Sopenharmony_ci} 1108c2ecf20Sopenharmony_ci 1118c2ecf20Sopenharmony_cisanitization_single_dev_mcast_group_test() 1128c2ecf20Sopenharmony_ci{ 1138c2ecf20Sopenharmony_ci RET=0 1148c2ecf20Sopenharmony_ci 1158c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 1168c2ecf20Sopenharmony_ci ip link add name dummy1 up type dummy 1178c2ecf20Sopenharmony_ci 1188c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 1198c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 \ 1208c2ecf20Sopenharmony_ci dev dummy1 group 239.0.0.1 1218c2ecf20Sopenharmony_ci 1228c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 1238c2ecf20Sopenharmony_ci 1248c2ecf20Sopenharmony_ci ip link del dev vxlan0 1258c2ecf20Sopenharmony_ci ip link del dev dummy1 1268c2ecf20Sopenharmony_ci ip link del dev br0 1278c2ecf20Sopenharmony_ci 1288c2ecf20Sopenharmony_ci log_test "vxlan device with a multicast group" 1298c2ecf20Sopenharmony_ci} 1308c2ecf20Sopenharmony_ci 1318c2ecf20Sopenharmony_cisanitization_single_dev_no_local_ip_test() 1328c2ecf20Sopenharmony_ci{ 1338c2ecf20Sopenharmony_ci RET=0 1348c2ecf20Sopenharmony_ci 1358c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 1368c2ecf20Sopenharmony_ci 1378c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 1388c2ecf20Sopenharmony_ci ttl 20 tos inherit dstport 4789 1398c2ecf20Sopenharmony_ci 1408c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 1418c2ecf20Sopenharmony_ci 1428c2ecf20Sopenharmony_ci ip link del dev vxlan0 1438c2ecf20Sopenharmony_ci ip link del dev br0 1448c2ecf20Sopenharmony_ci 1458c2ecf20Sopenharmony_ci log_test "vxlan device with no local ip" 1468c2ecf20Sopenharmony_ci} 1478c2ecf20Sopenharmony_ci 1488c2ecf20Sopenharmony_cisanitization_single_dev_local_ipv6_test() 1498c2ecf20Sopenharmony_ci{ 1508c2ecf20Sopenharmony_ci RET=0 1518c2ecf20Sopenharmony_ci 1528c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 1538c2ecf20Sopenharmony_ci 1548c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 1558c2ecf20Sopenharmony_ci ttl 20 tos inherit local 2001:db8::1 dstport 4789 1568c2ecf20Sopenharmony_ci 1578c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 1588c2ecf20Sopenharmony_ci 1598c2ecf20Sopenharmony_ci ip link del dev vxlan0 1608c2ecf20Sopenharmony_ci ip link del dev br0 1618c2ecf20Sopenharmony_ci 1628c2ecf20Sopenharmony_ci log_test "vxlan device with local ipv6 address" 1638c2ecf20Sopenharmony_ci} 1648c2ecf20Sopenharmony_ci 1658c2ecf20Sopenharmony_cisanitization_single_dev_learning_enabled_test() 1668c2ecf20Sopenharmony_ci{ 1678c2ecf20Sopenharmony_ci RET=0 1688c2ecf20Sopenharmony_ci 1698c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 1708c2ecf20Sopenharmony_ci 1718c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 learning noudpcsum \ 1728c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 1738c2ecf20Sopenharmony_ci 1748c2ecf20Sopenharmony_ci sanitization_single_dev_test_pass 1758c2ecf20Sopenharmony_ci 1768c2ecf20Sopenharmony_ci ip link del dev vxlan0 1778c2ecf20Sopenharmony_ci ip link del dev br0 1788c2ecf20Sopenharmony_ci 1798c2ecf20Sopenharmony_ci log_test "vxlan device with learning enabled" 1808c2ecf20Sopenharmony_ci} 1818c2ecf20Sopenharmony_ci 1828c2ecf20Sopenharmony_cisanitization_single_dev_local_interface_test() 1838c2ecf20Sopenharmony_ci{ 1848c2ecf20Sopenharmony_ci RET=0 1858c2ecf20Sopenharmony_ci 1868c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 1878c2ecf20Sopenharmony_ci ip link add name dummy1 up type dummy 1888c2ecf20Sopenharmony_ci 1898c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 1908c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 dev dummy1 1918c2ecf20Sopenharmony_ci 1928c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 1938c2ecf20Sopenharmony_ci 1948c2ecf20Sopenharmony_ci ip link del dev vxlan0 1958c2ecf20Sopenharmony_ci ip link del dev dummy1 1968c2ecf20Sopenharmony_ci ip link del dev br0 1978c2ecf20Sopenharmony_ci 1988c2ecf20Sopenharmony_ci log_test "vxlan device with local interface" 1998c2ecf20Sopenharmony_ci} 2008c2ecf20Sopenharmony_ci 2018c2ecf20Sopenharmony_cisanitization_single_dev_port_range_test() 2028c2ecf20Sopenharmony_ci{ 2038c2ecf20Sopenharmony_ci RET=0 2048c2ecf20Sopenharmony_ci 2058c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 2068c2ecf20Sopenharmony_ci 2078c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 2088c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 \ 2098c2ecf20Sopenharmony_ci srcport 4000 5000 2108c2ecf20Sopenharmony_ci 2118c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 2128c2ecf20Sopenharmony_ci 2138c2ecf20Sopenharmony_ci ip link del dev vxlan0 2148c2ecf20Sopenharmony_ci ip link del dev br0 2158c2ecf20Sopenharmony_ci 2168c2ecf20Sopenharmony_ci log_test "vxlan device with udp source port range" 2178c2ecf20Sopenharmony_ci} 2188c2ecf20Sopenharmony_ci 2198c2ecf20Sopenharmony_cisanitization_single_dev_tos_static_test() 2208c2ecf20Sopenharmony_ci{ 2218c2ecf20Sopenharmony_ci RET=0 2228c2ecf20Sopenharmony_ci 2238c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 2248c2ecf20Sopenharmony_ci 2258c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 2268c2ecf20Sopenharmony_ci ttl 20 tos 20 local 198.51.100.1 dstport 4789 2278c2ecf20Sopenharmony_ci 2288c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 2298c2ecf20Sopenharmony_ci 2308c2ecf20Sopenharmony_ci ip link del dev vxlan0 2318c2ecf20Sopenharmony_ci ip link del dev br0 2328c2ecf20Sopenharmony_ci 2338c2ecf20Sopenharmony_ci log_test "vxlan device with static tos" 2348c2ecf20Sopenharmony_ci} 2358c2ecf20Sopenharmony_ci 2368c2ecf20Sopenharmony_cisanitization_single_dev_ttl_inherit_test() 2378c2ecf20Sopenharmony_ci{ 2388c2ecf20Sopenharmony_ci RET=0 2398c2ecf20Sopenharmony_ci 2408c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 2418c2ecf20Sopenharmony_ci 2428c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 2438c2ecf20Sopenharmony_ci ttl inherit tos inherit local 198.51.100.1 dstport 4789 2448c2ecf20Sopenharmony_ci 2458c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 2468c2ecf20Sopenharmony_ci 2478c2ecf20Sopenharmony_ci ip link del dev vxlan0 2488c2ecf20Sopenharmony_ci ip link del dev br0 2498c2ecf20Sopenharmony_ci 2508c2ecf20Sopenharmony_ci log_test "vxlan device with inherit ttl" 2518c2ecf20Sopenharmony_ci} 2528c2ecf20Sopenharmony_ci 2538c2ecf20Sopenharmony_cisanitization_single_dev_udp_checksum_test() 2548c2ecf20Sopenharmony_ci{ 2558c2ecf20Sopenharmony_ci RET=0 2568c2ecf20Sopenharmony_ci 2578c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 2588c2ecf20Sopenharmony_ci 2598c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning udpcsum \ 2608c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 2618c2ecf20Sopenharmony_ci 2628c2ecf20Sopenharmony_ci sanitization_single_dev_test_fail 2638c2ecf20Sopenharmony_ci 2648c2ecf20Sopenharmony_ci ip link del dev vxlan0 2658c2ecf20Sopenharmony_ci ip link del dev br0 2668c2ecf20Sopenharmony_ci 2678c2ecf20Sopenharmony_ci log_test "vxlan device with udp checksum" 2688c2ecf20Sopenharmony_ci} 2698c2ecf20Sopenharmony_ci 2708c2ecf20Sopenharmony_cisanitization_single_dev_test() 2718c2ecf20Sopenharmony_ci{ 2728c2ecf20Sopenharmony_ci # These tests make sure that we correctly sanitize VxLAN device 2738c2ecf20Sopenharmony_ci # configurations we do not support 2748c2ecf20Sopenharmony_ci sanitization_single_dev_valid_test 2758c2ecf20Sopenharmony_ci sanitization_single_dev_vlan_aware_test 2768c2ecf20Sopenharmony_ci sanitization_single_dev_mcast_enabled_test 2778c2ecf20Sopenharmony_ci sanitization_single_dev_mcast_group_test 2788c2ecf20Sopenharmony_ci sanitization_single_dev_no_local_ip_test 2798c2ecf20Sopenharmony_ci sanitization_single_dev_local_ipv6_test 2808c2ecf20Sopenharmony_ci sanitization_single_dev_learning_enabled_test 2818c2ecf20Sopenharmony_ci sanitization_single_dev_local_interface_test 2828c2ecf20Sopenharmony_ci sanitization_single_dev_port_range_test 2838c2ecf20Sopenharmony_ci sanitization_single_dev_tos_static_test 2848c2ecf20Sopenharmony_ci sanitization_single_dev_ttl_inherit_test 2858c2ecf20Sopenharmony_ci sanitization_single_dev_udp_checksum_test 2868c2ecf20Sopenharmony_ci} 2878c2ecf20Sopenharmony_ci 2888c2ecf20Sopenharmony_cisanitization_multi_devs_test_pass() 2898c2ecf20Sopenharmony_ci{ 2908c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 2918c2ecf20Sopenharmony_ci check_err $? 2928c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 2938c2ecf20Sopenharmony_ci check_err $? 2948c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 2958c2ecf20Sopenharmony_ci check_err $? 2968c2ecf20Sopenharmony_ci ip link set dev vxlan1 master br1 2978c2ecf20Sopenharmony_ci check_err $? 2988c2ecf20Sopenharmony_ci 2998c2ecf20Sopenharmony_ci ip link set dev $swp2 nomaster 3008c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 3018c2ecf20Sopenharmony_ci 3028c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 3038c2ecf20Sopenharmony_ci check_err $? 3048c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 3058c2ecf20Sopenharmony_ci check_err $? 3068c2ecf20Sopenharmony_ci} 3078c2ecf20Sopenharmony_ci 3088c2ecf20Sopenharmony_cisanitization_multi_devs_test_fail() 3098c2ecf20Sopenharmony_ci{ 3108c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 3118c2ecf20Sopenharmony_ci check_err $? 3128c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 3138c2ecf20Sopenharmony_ci check_err $? 3148c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 3158c2ecf20Sopenharmony_ci check_err $? 3168c2ecf20Sopenharmony_ci ip link set dev vxlan1 master br1 &> /dev/null 3178c2ecf20Sopenharmony_ci check_fail $? 3188c2ecf20Sopenharmony_ci 3198c2ecf20Sopenharmony_ci ip link set dev $swp2 nomaster 3208c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 3218c2ecf20Sopenharmony_ci 3228c2ecf20Sopenharmony_ci ip link set dev vxlan1 master br1 3238c2ecf20Sopenharmony_ci check_err $? 3248c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 3258c2ecf20Sopenharmony_ci check_err $? 3268c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 &> /dev/null 3278c2ecf20Sopenharmony_ci check_fail $? 3288c2ecf20Sopenharmony_ci} 3298c2ecf20Sopenharmony_ci 3308c2ecf20Sopenharmony_cisanitization_multi_devs_valid_test() 3318c2ecf20Sopenharmony_ci{ 3328c2ecf20Sopenharmony_ci RET=0 3338c2ecf20Sopenharmony_ci 3348c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 3358c2ecf20Sopenharmony_ci ip link add dev br1 type bridge mcast_snooping 0 3368c2ecf20Sopenharmony_ci 3378c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 3388c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 3398c2ecf20Sopenharmony_ci ip link add name vxlan1 up type vxlan id 20 nolearning noudpcsum \ 3408c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 3418c2ecf20Sopenharmony_ci 3428c2ecf20Sopenharmony_ci sanitization_multi_devs_test_pass 3438c2ecf20Sopenharmony_ci 3448c2ecf20Sopenharmony_ci ip link del dev vxlan1 3458c2ecf20Sopenharmony_ci ip link del dev vxlan0 3468c2ecf20Sopenharmony_ci ip link del dev br1 3478c2ecf20Sopenharmony_ci ip link del dev br0 3488c2ecf20Sopenharmony_ci 3498c2ecf20Sopenharmony_ci log_test "multiple vxlan devices - valid configuration" 3508c2ecf20Sopenharmony_ci} 3518c2ecf20Sopenharmony_ci 3528c2ecf20Sopenharmony_cisanitization_multi_devs_ttl_test() 3538c2ecf20Sopenharmony_ci{ 3548c2ecf20Sopenharmony_ci RET=0 3558c2ecf20Sopenharmony_ci 3568c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 3578c2ecf20Sopenharmony_ci ip link add dev br1 type bridge mcast_snooping 0 3588c2ecf20Sopenharmony_ci 3598c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 3608c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 3618c2ecf20Sopenharmony_ci ip link add name vxlan1 up type vxlan id 20 nolearning noudpcsum \ 3628c2ecf20Sopenharmony_ci ttl 40 tos inherit local 198.51.100.1 dstport 4789 3638c2ecf20Sopenharmony_ci 3648c2ecf20Sopenharmony_ci sanitization_multi_devs_test_fail 3658c2ecf20Sopenharmony_ci 3668c2ecf20Sopenharmony_ci ip link del dev vxlan1 3678c2ecf20Sopenharmony_ci ip link del dev vxlan0 3688c2ecf20Sopenharmony_ci ip link del dev br1 3698c2ecf20Sopenharmony_ci ip link del dev br0 3708c2ecf20Sopenharmony_ci 3718c2ecf20Sopenharmony_ci log_test "multiple vxlan devices with different ttl" 3728c2ecf20Sopenharmony_ci} 3738c2ecf20Sopenharmony_ci 3748c2ecf20Sopenharmony_cisanitization_multi_devs_udp_dstport_test() 3758c2ecf20Sopenharmony_ci{ 3768c2ecf20Sopenharmony_ci RET=0 3778c2ecf20Sopenharmony_ci 3788c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 3798c2ecf20Sopenharmony_ci ip link add dev br1 type bridge mcast_snooping 0 3808c2ecf20Sopenharmony_ci 3818c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 3828c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 3838c2ecf20Sopenharmony_ci ip link add name vxlan1 up type vxlan id 20 nolearning noudpcsum \ 3848c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 5789 3858c2ecf20Sopenharmony_ci 3868c2ecf20Sopenharmony_ci sanitization_multi_devs_test_fail 3878c2ecf20Sopenharmony_ci 3888c2ecf20Sopenharmony_ci ip link del dev vxlan1 3898c2ecf20Sopenharmony_ci ip link del dev vxlan0 3908c2ecf20Sopenharmony_ci ip link del dev br1 3918c2ecf20Sopenharmony_ci ip link del dev br0 3928c2ecf20Sopenharmony_ci 3938c2ecf20Sopenharmony_ci log_test "multiple vxlan devices with different udp destination port" 3948c2ecf20Sopenharmony_ci} 3958c2ecf20Sopenharmony_ci 3968c2ecf20Sopenharmony_cisanitization_multi_devs_local_ip_test() 3978c2ecf20Sopenharmony_ci{ 3988c2ecf20Sopenharmony_ci RET=0 3998c2ecf20Sopenharmony_ci 4008c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 4018c2ecf20Sopenharmony_ci ip link add dev br1 type bridge mcast_snooping 0 4028c2ecf20Sopenharmony_ci 4038c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 4048c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 4058c2ecf20Sopenharmony_ci ip link add name vxlan1 up type vxlan id 20 nolearning noudpcsum \ 4068c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.2 dstport 4789 4078c2ecf20Sopenharmony_ci 4088c2ecf20Sopenharmony_ci sanitization_multi_devs_test_fail 4098c2ecf20Sopenharmony_ci 4108c2ecf20Sopenharmony_ci ip link del dev vxlan1 4118c2ecf20Sopenharmony_ci ip link del dev vxlan0 4128c2ecf20Sopenharmony_ci ip link del dev br1 4138c2ecf20Sopenharmony_ci ip link del dev br0 4148c2ecf20Sopenharmony_ci 4158c2ecf20Sopenharmony_ci log_test "multiple vxlan devices with different local ip" 4168c2ecf20Sopenharmony_ci} 4178c2ecf20Sopenharmony_ci 4188c2ecf20Sopenharmony_cisanitization_multi_devs_test() 4198c2ecf20Sopenharmony_ci{ 4208c2ecf20Sopenharmony_ci # The device has a single VTEP, which means all the VxLAN devices 4218c2ecf20Sopenharmony_ci # we offload must share certain properties such as source IP and 4228c2ecf20Sopenharmony_ci # UDP destination port. These tests make sure that we forbid 4238c2ecf20Sopenharmony_ci # configurations that violate this limitation 4248c2ecf20Sopenharmony_ci sanitization_multi_devs_valid_test 4258c2ecf20Sopenharmony_ci sanitization_multi_devs_ttl_test 4268c2ecf20Sopenharmony_ci sanitization_multi_devs_udp_dstport_test 4278c2ecf20Sopenharmony_ci sanitization_multi_devs_local_ip_test 4288c2ecf20Sopenharmony_ci} 4298c2ecf20Sopenharmony_ci 4308c2ecf20Sopenharmony_cisanitization_test() 4318c2ecf20Sopenharmony_ci{ 4328c2ecf20Sopenharmony_ci sanitization_single_dev_test 4338c2ecf20Sopenharmony_ci sanitization_multi_devs_test 4348c2ecf20Sopenharmony_ci} 4358c2ecf20Sopenharmony_ci 4368c2ecf20Sopenharmony_cioffload_indication_setup_create() 4378c2ecf20Sopenharmony_ci{ 4388c2ecf20Sopenharmony_ci # Create a simple setup with two bridges, each with a VxLAN device 4398c2ecf20Sopenharmony_ci # and one local port 4408c2ecf20Sopenharmony_ci ip link add name br0 up type bridge mcast_snooping 0 4418c2ecf20Sopenharmony_ci ip link add name br1 up type bridge mcast_snooping 0 4428c2ecf20Sopenharmony_ci 4438c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 4448c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 4458c2ecf20Sopenharmony_ci 4468c2ecf20Sopenharmony_ci ip address add 198.51.100.1/32 dev lo 4478c2ecf20Sopenharmony_ci 4488c2ecf20Sopenharmony_ci ip link add name vxlan0 up master br0 type vxlan id 10 nolearning \ 4498c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 4508c2ecf20Sopenharmony_ci ip link add name vxlan1 up master br1 type vxlan id 20 nolearning \ 4518c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 4528c2ecf20Sopenharmony_ci} 4538c2ecf20Sopenharmony_ci 4548c2ecf20Sopenharmony_cioffload_indication_setup_destroy() 4558c2ecf20Sopenharmony_ci{ 4568c2ecf20Sopenharmony_ci ip link del dev vxlan1 4578c2ecf20Sopenharmony_ci ip link del dev vxlan0 4588c2ecf20Sopenharmony_ci 4598c2ecf20Sopenharmony_ci ip address del 198.51.100.1/32 dev lo 4608c2ecf20Sopenharmony_ci 4618c2ecf20Sopenharmony_ci ip link set dev $swp2 nomaster 4628c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 4638c2ecf20Sopenharmony_ci 4648c2ecf20Sopenharmony_ci ip link del dev br1 4658c2ecf20Sopenharmony_ci ip link del dev br0 4668c2ecf20Sopenharmony_ci} 4678c2ecf20Sopenharmony_ci 4688c2ecf20Sopenharmony_cioffload_indication_fdb_flood_test() 4698c2ecf20Sopenharmony_ci{ 4708c2ecf20Sopenharmony_ci RET=0 4718c2ecf20Sopenharmony_ci 4728c2ecf20Sopenharmony_ci bridge fdb append 00:00:00:00:00:00 dev vxlan0 self dst 198.51.100.2 4738c2ecf20Sopenharmony_ci 4748c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb 00:00:00:00:00:00 \ 4758c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 4768c2ecf20Sopenharmony_ci check_err $? 4778c2ecf20Sopenharmony_ci 4788c2ecf20Sopenharmony_ci bridge fdb del 00:00:00:00:00:00 dev vxlan0 self 4798c2ecf20Sopenharmony_ci 4808c2ecf20Sopenharmony_ci log_test "vxlan flood entry offload indication" 4818c2ecf20Sopenharmony_ci} 4828c2ecf20Sopenharmony_ci 4838c2ecf20Sopenharmony_cioffload_indication_fdb_bridge_test() 4848c2ecf20Sopenharmony_ci{ 4858c2ecf20Sopenharmony_ci RET=0 4868c2ecf20Sopenharmony_ci 4878c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan0 self master static \ 4888c2ecf20Sopenharmony_ci dst 198.51.100.2 4898c2ecf20Sopenharmony_ci 4908c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 4918c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan0 4928c2ecf20Sopenharmony_ci check_err $? 4938c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 4948c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan0 4958c2ecf20Sopenharmony_ci check_err $? 4968c2ecf20Sopenharmony_ci 4978c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - initial state" 4988c2ecf20Sopenharmony_ci 4998c2ecf20Sopenharmony_ci # Remove FDB entry from the bridge driver and check that corresponding 5008c2ecf20Sopenharmony_ci # entry in the VxLAN driver is not marked as offloaded 5018c2ecf20Sopenharmony_ci RET=0 5028c2ecf20Sopenharmony_ci 5038c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan0 master 5048c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb \ 5058c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan0 5068c2ecf20Sopenharmony_ci check_err $? 5078c2ecf20Sopenharmony_ci 5088c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after removal from bridge" 5098c2ecf20Sopenharmony_ci 5108c2ecf20Sopenharmony_ci # Add the FDB entry back to the bridge driver and make sure it is 5118c2ecf20Sopenharmony_ci # marked as offloaded in both drivers 5128c2ecf20Sopenharmony_ci RET=0 5138c2ecf20Sopenharmony_ci 5148c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan0 master static 5158c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 5168c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan0 5178c2ecf20Sopenharmony_ci check_err $? 5188c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 5198c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan0 5208c2ecf20Sopenharmony_ci check_err $? 5218c2ecf20Sopenharmony_ci 5228c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after re-add to bridge" 5238c2ecf20Sopenharmony_ci 5248c2ecf20Sopenharmony_ci # Remove FDB entry from the VxLAN driver and check that corresponding 5258c2ecf20Sopenharmony_ci # entry in the bridge driver is not marked as offloaded 5268c2ecf20Sopenharmony_ci RET=0 5278c2ecf20Sopenharmony_ci 5288c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan0 self 5298c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb \ 5308c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan0 5318c2ecf20Sopenharmony_ci check_err $? 5328c2ecf20Sopenharmony_ci 5338c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after removal from vxlan" 5348c2ecf20Sopenharmony_ci 5358c2ecf20Sopenharmony_ci # Add the FDB entry back to the VxLAN driver and make sure it is 5368c2ecf20Sopenharmony_ci # marked as offloaded in both drivers 5378c2ecf20Sopenharmony_ci RET=0 5388c2ecf20Sopenharmony_ci 5398c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan0 self dst 198.51.100.2 5408c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 5418c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan0 5428c2ecf20Sopenharmony_ci check_err $? 5438c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 5448c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan0 5458c2ecf20Sopenharmony_ci check_err $? 5468c2ecf20Sopenharmony_ci 5478c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after re-add to vxlan" 5488c2ecf20Sopenharmony_ci 5498c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan0 self master 5508c2ecf20Sopenharmony_ci} 5518c2ecf20Sopenharmony_ci 5528c2ecf20Sopenharmony_cioffload_indication_fdb_test() 5538c2ecf20Sopenharmony_ci{ 5548c2ecf20Sopenharmony_ci offload_indication_fdb_flood_test 5558c2ecf20Sopenharmony_ci offload_indication_fdb_bridge_test 5568c2ecf20Sopenharmony_ci} 5578c2ecf20Sopenharmony_ci 5588c2ecf20Sopenharmony_cioffload_indication_decap_route_test() 5598c2ecf20Sopenharmony_ci{ 5608c2ecf20Sopenharmony_ci RET=0 5618c2ecf20Sopenharmony_ci 5628c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 5638c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5648c2ecf20Sopenharmony_ci check_err $? 5658c2ecf20Sopenharmony_ci 5668c2ecf20Sopenharmony_ci ip link set dev vxlan0 down 5678c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 5688c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5698c2ecf20Sopenharmony_ci check_err $? 5708c2ecf20Sopenharmony_ci 5718c2ecf20Sopenharmony_ci ip link set dev vxlan1 down 5728c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 5738c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5748c2ecf20Sopenharmony_ci check_err $? 5758c2ecf20Sopenharmony_ci 5768c2ecf20Sopenharmony_ci log_test "vxlan decap route - vxlan device down" 5778c2ecf20Sopenharmony_ci 5788c2ecf20Sopenharmony_ci RET=0 5798c2ecf20Sopenharmony_ci 5808c2ecf20Sopenharmony_ci ip link set dev vxlan1 up 5818c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 5828c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5838c2ecf20Sopenharmony_ci check_err $? 5848c2ecf20Sopenharmony_ci 5858c2ecf20Sopenharmony_ci ip link set dev vxlan0 up 5868c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 5878c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5888c2ecf20Sopenharmony_ci check_err $? 5898c2ecf20Sopenharmony_ci 5908c2ecf20Sopenharmony_ci log_test "vxlan decap route - vxlan device up" 5918c2ecf20Sopenharmony_ci 5928c2ecf20Sopenharmony_ci RET=0 5938c2ecf20Sopenharmony_ci 5948c2ecf20Sopenharmony_ci ip address delete 198.51.100.1/32 dev lo 5958c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 5968c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 5978c2ecf20Sopenharmony_ci check_err $? 5988c2ecf20Sopenharmony_ci 5998c2ecf20Sopenharmony_ci ip address add 198.51.100.1/32 dev lo 6008c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6018c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6028c2ecf20Sopenharmony_ci check_err $? 6038c2ecf20Sopenharmony_ci 6048c2ecf20Sopenharmony_ci log_test "vxlan decap route - add local route" 6058c2ecf20Sopenharmony_ci 6068c2ecf20Sopenharmony_ci RET=0 6078c2ecf20Sopenharmony_ci 6088c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 6098c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6108c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6118c2ecf20Sopenharmony_ci check_err $? 6128c2ecf20Sopenharmony_ci 6138c2ecf20Sopenharmony_ci ip link set dev $swp2 nomaster 6148c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 6158c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6168c2ecf20Sopenharmony_ci check_err $? 6178c2ecf20Sopenharmony_ci 6188c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 6198c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 6208c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6218c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6228c2ecf20Sopenharmony_ci check_err $? 6238c2ecf20Sopenharmony_ci 6248c2ecf20Sopenharmony_ci log_test "vxlan decap route - local ports enslavement" 6258c2ecf20Sopenharmony_ci 6268c2ecf20Sopenharmony_ci RET=0 6278c2ecf20Sopenharmony_ci 6288c2ecf20Sopenharmony_ci ip link del dev br0 6298c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6308c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6318c2ecf20Sopenharmony_ci check_err $? 6328c2ecf20Sopenharmony_ci 6338c2ecf20Sopenharmony_ci ip link del dev br1 6348c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 6358c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6368c2ecf20Sopenharmony_ci check_err $? 6378c2ecf20Sopenharmony_ci 6388c2ecf20Sopenharmony_ci log_test "vxlan decap route - bridge device deletion" 6398c2ecf20Sopenharmony_ci 6408c2ecf20Sopenharmony_ci RET=0 6418c2ecf20Sopenharmony_ci 6428c2ecf20Sopenharmony_ci ip link add name br0 up type bridge mcast_snooping 0 6438c2ecf20Sopenharmony_ci ip link add name br1 up type bridge mcast_snooping 0 6448c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 6458c2ecf20Sopenharmony_ci ip link set dev $swp2 master br1 6468c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 6478c2ecf20Sopenharmony_ci ip link set dev vxlan1 master br1 6488c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6498c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6508c2ecf20Sopenharmony_ci check_err $? 6518c2ecf20Sopenharmony_ci 6528c2ecf20Sopenharmony_ci ip link del dev vxlan0 6538c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 6548c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6558c2ecf20Sopenharmony_ci check_err $? 6568c2ecf20Sopenharmony_ci 6578c2ecf20Sopenharmony_ci ip link del dev vxlan1 6588c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 6598c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 6608c2ecf20Sopenharmony_ci check_err $? 6618c2ecf20Sopenharmony_ci 6628c2ecf20Sopenharmony_ci log_test "vxlan decap route - vxlan device deletion" 6638c2ecf20Sopenharmony_ci 6648c2ecf20Sopenharmony_ci ip link add name vxlan0 up master br0 type vxlan id 10 nolearning \ 6658c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 6668c2ecf20Sopenharmony_ci ip link add name vxlan1 up master br1 type vxlan id 20 nolearning \ 6678c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 6688c2ecf20Sopenharmony_ci} 6698c2ecf20Sopenharmony_ci 6708c2ecf20Sopenharmony_cicheck_fdb_offloaded() 6718c2ecf20Sopenharmony_ci{ 6728c2ecf20Sopenharmony_ci local mac=00:11:22:33:44:55 6738c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 6748c2ecf20Sopenharmony_ci 6758c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $mac self \ 6768c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 6778c2ecf20Sopenharmony_ci check_err $? 6788c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $mac master \ 6798c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 6808c2ecf20Sopenharmony_ci check_err $? 6818c2ecf20Sopenharmony_ci 6828c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $zmac self \ 6838c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 6848c2ecf20Sopenharmony_ci check_err $? 6858c2ecf20Sopenharmony_ci} 6868c2ecf20Sopenharmony_ci 6878c2ecf20Sopenharmony_cicheck_vxlan_fdb_not_offloaded() 6888c2ecf20Sopenharmony_ci{ 6898c2ecf20Sopenharmony_ci local mac=00:11:22:33:44:55 6908c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 6918c2ecf20Sopenharmony_ci 6928c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 | grep $mac | grep -q self 6938c2ecf20Sopenharmony_ci check_err $? 6948c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $mac self \ 6958c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 6968c2ecf20Sopenharmony_ci check_err $? 6978c2ecf20Sopenharmony_ci 6988c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 | grep $zmac | grep -q self 6998c2ecf20Sopenharmony_ci check_err $? 7008c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $zmac self \ 7018c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 7028c2ecf20Sopenharmony_ci check_err $? 7038c2ecf20Sopenharmony_ci} 7048c2ecf20Sopenharmony_ci 7058c2ecf20Sopenharmony_cicheck_bridge_fdb_not_offloaded() 7068c2ecf20Sopenharmony_ci{ 7078c2ecf20Sopenharmony_ci local mac=00:11:22:33:44:55 7088c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 7098c2ecf20Sopenharmony_ci 7108c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 | grep $mac | grep -q master 7118c2ecf20Sopenharmony_ci check_err $? 7128c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $mac master \ 7138c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 7148c2ecf20Sopenharmony_ci check_err $? 7158c2ecf20Sopenharmony_ci} 7168c2ecf20Sopenharmony_ci 7178c2ecf20Sopenharmony_ci__offload_indication_join_vxlan_first() 7188c2ecf20Sopenharmony_ci{ 7198c2ecf20Sopenharmony_ci local vid=$1; shift 7208c2ecf20Sopenharmony_ci 7218c2ecf20Sopenharmony_ci local mac=00:11:22:33:44:55 7228c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 7238c2ecf20Sopenharmony_ci 7248c2ecf20Sopenharmony_ci bridge fdb append $zmac dev vxlan0 self dst 198.51.100.2 7258c2ecf20Sopenharmony_ci 7268c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 7278c2ecf20Sopenharmony_ci bridge fdb add dev vxlan0 $mac self master static dst 198.51.100.2 7288c2ecf20Sopenharmony_ci 7298c2ecf20Sopenharmony_ci RET=0 7308c2ecf20Sopenharmony_ci check_vxlan_fdb_not_offloaded 7318c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 7328c2ecf20Sopenharmony_ci sleep .1 7338c2ecf20Sopenharmony_ci check_fdb_offloaded 7348c2ecf20Sopenharmony_ci log_test "offload indication - attach vxlan first" 7358c2ecf20Sopenharmony_ci 7368c2ecf20Sopenharmony_ci RET=0 7378c2ecf20Sopenharmony_ci ip link set dev vxlan0 down 7388c2ecf20Sopenharmony_ci check_vxlan_fdb_not_offloaded 7398c2ecf20Sopenharmony_ci check_bridge_fdb_not_offloaded 7408c2ecf20Sopenharmony_ci log_test "offload indication - set vxlan down" 7418c2ecf20Sopenharmony_ci 7428c2ecf20Sopenharmony_ci RET=0 7438c2ecf20Sopenharmony_ci ip link set dev vxlan0 up 7448c2ecf20Sopenharmony_ci sleep .1 7458c2ecf20Sopenharmony_ci check_fdb_offloaded 7468c2ecf20Sopenharmony_ci log_test "offload indication - set vxlan up" 7478c2ecf20Sopenharmony_ci 7488c2ecf20Sopenharmony_ci if [[ ! -z $vid ]]; then 7498c2ecf20Sopenharmony_ci RET=0 7508c2ecf20Sopenharmony_ci bridge vlan del dev vxlan0 vid $vid 7518c2ecf20Sopenharmony_ci check_vxlan_fdb_not_offloaded 7528c2ecf20Sopenharmony_ci check_bridge_fdb_not_offloaded 7538c2ecf20Sopenharmony_ci log_test "offload indication - delete VLAN" 7548c2ecf20Sopenharmony_ci 7558c2ecf20Sopenharmony_ci RET=0 7568c2ecf20Sopenharmony_ci bridge vlan add dev vxlan0 vid $vid 7578c2ecf20Sopenharmony_ci check_vxlan_fdb_not_offloaded 7588c2ecf20Sopenharmony_ci check_bridge_fdb_not_offloaded 7598c2ecf20Sopenharmony_ci log_test "offload indication - add tagged VLAN" 7608c2ecf20Sopenharmony_ci 7618c2ecf20Sopenharmony_ci RET=0 7628c2ecf20Sopenharmony_ci bridge vlan add dev vxlan0 vid $vid pvid untagged 7638c2ecf20Sopenharmony_ci sleep .1 7648c2ecf20Sopenharmony_ci check_fdb_offloaded 7658c2ecf20Sopenharmony_ci log_test "offload indication - add pvid/untagged VLAN" 7668c2ecf20Sopenharmony_ci fi 7678c2ecf20Sopenharmony_ci 7688c2ecf20Sopenharmony_ci RET=0 7698c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 7708c2ecf20Sopenharmony_ci check_vxlan_fdb_not_offloaded 7718c2ecf20Sopenharmony_ci log_test "offload indication - detach port" 7728c2ecf20Sopenharmony_ci} 7738c2ecf20Sopenharmony_ci 7748c2ecf20Sopenharmony_cioffload_indication_join_vxlan_first() 7758c2ecf20Sopenharmony_ci{ 7768c2ecf20Sopenharmony_ci ip link add dev br0 up type bridge mcast_snooping 0 7778c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 7788c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 7798c2ecf20Sopenharmony_ci 7808c2ecf20Sopenharmony_ci __offload_indication_join_vxlan_first 7818c2ecf20Sopenharmony_ci 7828c2ecf20Sopenharmony_ci ip link del dev vxlan0 7838c2ecf20Sopenharmony_ci ip link del dev br0 7848c2ecf20Sopenharmony_ci} 7858c2ecf20Sopenharmony_ci 7868c2ecf20Sopenharmony_ci__offload_indication_join_vxlan_last() 7878c2ecf20Sopenharmony_ci{ 7888c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 7898c2ecf20Sopenharmony_ci 7908c2ecf20Sopenharmony_ci RET=0 7918c2ecf20Sopenharmony_ci 7928c2ecf20Sopenharmony_ci bridge fdb append $zmac dev vxlan0 self dst 198.51.100.2 7938c2ecf20Sopenharmony_ci 7948c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 7958c2ecf20Sopenharmony_ci 7968c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $zmac self \ 7978c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 7988c2ecf20Sopenharmony_ci check_err $? 7998c2ecf20Sopenharmony_ci 8008c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 8018c2ecf20Sopenharmony_ci 8028c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $zmac self \ 8038c2ecf20Sopenharmony_ci bridge fdb show dev vxlan0 8048c2ecf20Sopenharmony_ci check_err $? 8058c2ecf20Sopenharmony_ci 8068c2ecf20Sopenharmony_ci log_test "offload indication - attach vxlan last" 8078c2ecf20Sopenharmony_ci} 8088c2ecf20Sopenharmony_ci 8098c2ecf20Sopenharmony_cioffload_indication_join_vxlan_last() 8108c2ecf20Sopenharmony_ci{ 8118c2ecf20Sopenharmony_ci ip link add dev br0 up type bridge mcast_snooping 0 8128c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 8138c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 8148c2ecf20Sopenharmony_ci 8158c2ecf20Sopenharmony_ci __offload_indication_join_vxlan_last 8168c2ecf20Sopenharmony_ci 8178c2ecf20Sopenharmony_ci ip link del dev vxlan0 8188c2ecf20Sopenharmony_ci ip link del dev br0 8198c2ecf20Sopenharmony_ci} 8208c2ecf20Sopenharmony_ci 8218c2ecf20Sopenharmony_cioffload_indication_test() 8228c2ecf20Sopenharmony_ci{ 8238c2ecf20Sopenharmony_ci offload_indication_setup_create 8248c2ecf20Sopenharmony_ci offload_indication_fdb_test 8258c2ecf20Sopenharmony_ci offload_indication_decap_route_test 8268c2ecf20Sopenharmony_ci offload_indication_setup_destroy 8278c2ecf20Sopenharmony_ci 8288c2ecf20Sopenharmony_ci log_info "offload indication - replay & cleanup" 8298c2ecf20Sopenharmony_ci offload_indication_join_vxlan_first 8308c2ecf20Sopenharmony_ci offload_indication_join_vxlan_last 8318c2ecf20Sopenharmony_ci} 8328c2ecf20Sopenharmony_ci 8338c2ecf20Sopenharmony_cisanitization_vlan_aware_test() 8348c2ecf20Sopenharmony_ci{ 8358c2ecf20Sopenharmony_ci RET=0 8368c2ecf20Sopenharmony_ci 8378c2ecf20Sopenharmony_ci ip link add dev br0 type bridge mcast_snooping 0 vlan_filtering 1 8388c2ecf20Sopenharmony_ci 8398c2ecf20Sopenharmony_ci ip link add name vxlan10 up master br0 type vxlan id 10 nolearning \ 8408c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 8418c2ecf20Sopenharmony_ci 8428c2ecf20Sopenharmony_ci ip link add name vxlan20 up master br0 type vxlan id 20 nolearning \ 8438c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 8448c2ecf20Sopenharmony_ci 8458c2ecf20Sopenharmony_ci # Test that when each VNI is mapped to a different VLAN we can enslave 8468c2ecf20Sopenharmony_ci # a port to the bridge 8478c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan10 pvid untagged 8488c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev vxlan20 pvid untagged 8498c2ecf20Sopenharmony_ci 8508c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 8518c2ecf20Sopenharmony_ci check_err $? 8528c2ecf20Sopenharmony_ci 8538c2ecf20Sopenharmony_ci log_test "vlan-aware - enslavement to vlan-aware bridge" 8548c2ecf20Sopenharmony_ci 8558c2ecf20Sopenharmony_ci # Try to map both VNIs to the same VLAN and make sure configuration 8568c2ecf20Sopenharmony_ci # fails 8578c2ecf20Sopenharmony_ci RET=0 8588c2ecf20Sopenharmony_ci 8598c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan20 pvid untagged &> /dev/null 8608c2ecf20Sopenharmony_ci check_fail $? 8618c2ecf20Sopenharmony_ci 8628c2ecf20Sopenharmony_ci log_test "vlan-aware - two vnis mapped to the same vlan" 8638c2ecf20Sopenharmony_ci 8648c2ecf20Sopenharmony_ci # Test that enslavement of a port to a bridge fails when two VNIs 8658c2ecf20Sopenharmony_ci # are mapped to the same VLAN 8668c2ecf20Sopenharmony_ci RET=0 8678c2ecf20Sopenharmony_ci 8688c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 8698c2ecf20Sopenharmony_ci 8708c2ecf20Sopenharmony_ci bridge vlan del vid 20 dev vxlan20 pvid untagged 8718c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan20 pvid untagged 8728c2ecf20Sopenharmony_ci 8738c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 &> /dev/null 8748c2ecf20Sopenharmony_ci check_fail $? 8758c2ecf20Sopenharmony_ci 8768c2ecf20Sopenharmony_ci log_test "vlan-aware - failed enslavement to vlan-aware bridge" 8778c2ecf20Sopenharmony_ci 8788c2ecf20Sopenharmony_ci bridge vlan del vid 10 dev vxlan20 8798c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev vxlan20 pvid untagged 8808c2ecf20Sopenharmony_ci 8818c2ecf20Sopenharmony_ci # Test that when two VXLAN tunnels with conflicting configurations 8828c2ecf20Sopenharmony_ci # (i.e., different TTL) are enslaved to the same VLAN-aware bridge, 8838c2ecf20Sopenharmony_ci # then the enslavement of a port to the bridge is denied. 8848c2ecf20Sopenharmony_ci 8858c2ecf20Sopenharmony_ci # Use the offload indication of the local route to ensure the VXLAN 8868c2ecf20Sopenharmony_ci # configuration was correctly rollbacked. 8878c2ecf20Sopenharmony_ci ip address add 198.51.100.1/32 dev lo 8888c2ecf20Sopenharmony_ci 8898c2ecf20Sopenharmony_ci ip link set dev vxlan10 type vxlan ttl 10 8908c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 &> /dev/null 8918c2ecf20Sopenharmony_ci check_fail $? 8928c2ecf20Sopenharmony_ci 8938c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 8948c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 8958c2ecf20Sopenharmony_ci check_err $? 8968c2ecf20Sopenharmony_ci 8978c2ecf20Sopenharmony_ci log_test "vlan-aware - failed enslavement to bridge due to conflict" 8988c2ecf20Sopenharmony_ci 8998c2ecf20Sopenharmony_ci ip link set dev vxlan10 type vxlan ttl 20 9008c2ecf20Sopenharmony_ci ip address del 198.51.100.1/32 dev lo 9018c2ecf20Sopenharmony_ci 9028c2ecf20Sopenharmony_ci ip link del dev vxlan20 9038c2ecf20Sopenharmony_ci ip link del dev vxlan10 9048c2ecf20Sopenharmony_ci ip link del dev br0 9058c2ecf20Sopenharmony_ci} 9068c2ecf20Sopenharmony_ci 9078c2ecf20Sopenharmony_cioffload_indication_vlan_aware_setup_create() 9088c2ecf20Sopenharmony_ci{ 9098c2ecf20Sopenharmony_ci # Create a simple setup with two VxLAN devices and a single VLAN-aware 9108c2ecf20Sopenharmony_ci # bridge 9118c2ecf20Sopenharmony_ci ip link add name br0 up type bridge mcast_snooping 0 vlan_filtering 1 \ 9128c2ecf20Sopenharmony_ci vlan_default_pvid 0 9138c2ecf20Sopenharmony_ci 9148c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 9158c2ecf20Sopenharmony_ci 9168c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev $swp1 9178c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev $swp1 9188c2ecf20Sopenharmony_ci 9198c2ecf20Sopenharmony_ci ip address add 198.51.100.1/32 dev lo 9208c2ecf20Sopenharmony_ci 9218c2ecf20Sopenharmony_ci ip link add name vxlan10 up master br0 type vxlan id 10 nolearning \ 9228c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 9238c2ecf20Sopenharmony_ci ip link add name vxlan20 up master br0 type vxlan id 20 nolearning \ 9248c2ecf20Sopenharmony_ci noudpcsum ttl 20 tos inherit local 198.51.100.1 dstport 4789 9258c2ecf20Sopenharmony_ci 9268c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan10 pvid untagged 9278c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev vxlan20 pvid untagged 9288c2ecf20Sopenharmony_ci} 9298c2ecf20Sopenharmony_ci 9308c2ecf20Sopenharmony_cioffload_indication_vlan_aware_setup_destroy() 9318c2ecf20Sopenharmony_ci{ 9328c2ecf20Sopenharmony_ci bridge vlan del vid 20 dev vxlan20 9338c2ecf20Sopenharmony_ci bridge vlan del vid 10 dev vxlan10 9348c2ecf20Sopenharmony_ci 9358c2ecf20Sopenharmony_ci ip link del dev vxlan20 9368c2ecf20Sopenharmony_ci ip link del dev vxlan10 9378c2ecf20Sopenharmony_ci 9388c2ecf20Sopenharmony_ci ip address del 198.51.100.1/32 dev lo 9398c2ecf20Sopenharmony_ci 9408c2ecf20Sopenharmony_ci bridge vlan del vid 20 dev $swp1 9418c2ecf20Sopenharmony_ci bridge vlan del vid 10 dev $swp1 9428c2ecf20Sopenharmony_ci 9438c2ecf20Sopenharmony_ci ip link set dev $swp1 nomaster 9448c2ecf20Sopenharmony_ci 9458c2ecf20Sopenharmony_ci ip link del dev br0 9468c2ecf20Sopenharmony_ci} 9478c2ecf20Sopenharmony_ci 9488c2ecf20Sopenharmony_cioffload_indication_vlan_aware_fdb_test() 9498c2ecf20Sopenharmony_ci{ 9508c2ecf20Sopenharmony_ci RET=0 9518c2ecf20Sopenharmony_ci 9528c2ecf20Sopenharmony_ci log_info "vxlan entry offload indication - vlan-aware" 9538c2ecf20Sopenharmony_ci 9548c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan10 self master static \ 9558c2ecf20Sopenharmony_ci dst 198.51.100.2 vlan 10 9568c2ecf20Sopenharmony_ci 9578c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 9588c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan10 9598c2ecf20Sopenharmony_ci check_err $? 9608c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 9618c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan10 9628c2ecf20Sopenharmony_ci check_err $? 9638c2ecf20Sopenharmony_ci 9648c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - initial state" 9658c2ecf20Sopenharmony_ci 9668c2ecf20Sopenharmony_ci # Remove FDB entry from the bridge driver and check that corresponding 9678c2ecf20Sopenharmony_ci # entry in the VxLAN driver is not marked as offloaded 9688c2ecf20Sopenharmony_ci RET=0 9698c2ecf20Sopenharmony_ci 9708c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan10 master vlan 10 9718c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb \ 9728c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan10 9738c2ecf20Sopenharmony_ci check_err $? 9748c2ecf20Sopenharmony_ci 9758c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after removal from bridge" 9768c2ecf20Sopenharmony_ci 9778c2ecf20Sopenharmony_ci # Add the FDB entry back to the bridge driver and make sure it is 9788c2ecf20Sopenharmony_ci # marked as offloaded in both drivers 9798c2ecf20Sopenharmony_ci RET=0 9808c2ecf20Sopenharmony_ci 9818c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan10 master static vlan 10 9828c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 9838c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan10 9848c2ecf20Sopenharmony_ci check_err $? 9858c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 9868c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan10 9878c2ecf20Sopenharmony_ci check_err $? 9888c2ecf20Sopenharmony_ci 9898c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after re-add to bridge" 9908c2ecf20Sopenharmony_ci 9918c2ecf20Sopenharmony_ci # Remove FDB entry from the VxLAN driver and check that corresponding 9928c2ecf20Sopenharmony_ci # entry in the bridge driver is not marked as offloaded 9938c2ecf20Sopenharmony_ci RET=0 9948c2ecf20Sopenharmony_ci 9958c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan10 self 9968c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb \ 9978c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan10 9988c2ecf20Sopenharmony_ci check_err $? 9998c2ecf20Sopenharmony_ci 10008c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after removal from vxlan" 10018c2ecf20Sopenharmony_ci 10028c2ecf20Sopenharmony_ci # Add the FDB entry back to the VxLAN driver and make sure it is 10038c2ecf20Sopenharmony_ci # marked as offloaded in both drivers 10048c2ecf20Sopenharmony_ci RET=0 10058c2ecf20Sopenharmony_ci 10068c2ecf20Sopenharmony_ci bridge fdb add de:ad:be:ef:13:37 dev vxlan10 self dst 198.51.100.2 10078c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 10088c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self bridge fdb show brport vxlan10 10098c2ecf20Sopenharmony_ci check_err $? 10108c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb \ 10118c2ecf20Sopenharmony_ci de:ad:be:ef:13:37 self -v bridge fdb show brport vxlan10 10128c2ecf20Sopenharmony_ci check_err $? 10138c2ecf20Sopenharmony_ci 10148c2ecf20Sopenharmony_ci log_test "vxlan entry offload indication - after re-add to vxlan" 10158c2ecf20Sopenharmony_ci 10168c2ecf20Sopenharmony_ci bridge fdb del de:ad:be:ef:13:37 dev vxlan10 self master vlan 10 10178c2ecf20Sopenharmony_ci} 10188c2ecf20Sopenharmony_ci 10198c2ecf20Sopenharmony_cioffload_indication_vlan_aware_decap_route_test() 10208c2ecf20Sopenharmony_ci{ 10218c2ecf20Sopenharmony_ci RET=0 10228c2ecf20Sopenharmony_ci 10238c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 10248c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 10258c2ecf20Sopenharmony_ci check_err $? 10268c2ecf20Sopenharmony_ci 10278c2ecf20Sopenharmony_ci # Toggle PVID flag on one VxLAN device and make sure route is still 10288c2ecf20Sopenharmony_ci # marked as offloaded 10298c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan10 untagged 10308c2ecf20Sopenharmony_ci 10318c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload \ 10328c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 10338c2ecf20Sopenharmony_ci check_err $? 10348c2ecf20Sopenharmony_ci 10358c2ecf20Sopenharmony_ci # Toggle PVID flag on second VxLAN device and make sure route is no 10368c2ecf20Sopenharmony_ci # longer marked as offloaded 10378c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev vxlan20 untagged 10388c2ecf20Sopenharmony_ci 10398c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload \ 10408c2ecf20Sopenharmony_ci ip route show table local 198.51.100.1 10418c2ecf20Sopenharmony_ci check_err $? 10428c2ecf20Sopenharmony_ci 10438c2ecf20Sopenharmony_ci # Toggle PVID flag back and make sure route is marked as offloaded 10448c2ecf20Sopenharmony_ci bridge vlan add vid 10 dev vxlan10 pvid untagged 10458c2ecf20Sopenharmony_ci bridge vlan add vid 20 dev vxlan20 pvid untagged 10468c2ecf20Sopenharmony_ci 10478c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload ip route show table local 198.51.100.1 10488c2ecf20Sopenharmony_ci check_err $? 10498c2ecf20Sopenharmony_ci 10508c2ecf20Sopenharmony_ci log_test "vxlan decap route - vni map/unmap" 10518c2ecf20Sopenharmony_ci} 10528c2ecf20Sopenharmony_ci 10538c2ecf20Sopenharmony_cioffload_indication_vlan_aware_join_vxlan_first() 10548c2ecf20Sopenharmony_ci{ 10558c2ecf20Sopenharmony_ci ip link add dev br0 up type bridge mcast_snooping 0 \ 10568c2ecf20Sopenharmony_ci vlan_filtering 1 vlan_default_pvid 1 10578c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 10588c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 10598c2ecf20Sopenharmony_ci 10608c2ecf20Sopenharmony_ci __offload_indication_join_vxlan_first 1 10618c2ecf20Sopenharmony_ci 10628c2ecf20Sopenharmony_ci ip link del dev vxlan0 10638c2ecf20Sopenharmony_ci ip link del dev br0 10648c2ecf20Sopenharmony_ci} 10658c2ecf20Sopenharmony_ci 10668c2ecf20Sopenharmony_cioffload_indication_vlan_aware_join_vxlan_last() 10678c2ecf20Sopenharmony_ci{ 10688c2ecf20Sopenharmony_ci ip link add dev br0 up type bridge mcast_snooping 0 \ 10698c2ecf20Sopenharmony_ci vlan_filtering 1 vlan_default_pvid 1 10708c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 10718c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 10728c2ecf20Sopenharmony_ci 10738c2ecf20Sopenharmony_ci __offload_indication_join_vxlan_last 10748c2ecf20Sopenharmony_ci 10758c2ecf20Sopenharmony_ci ip link del dev vxlan0 10768c2ecf20Sopenharmony_ci ip link del dev br0 10778c2ecf20Sopenharmony_ci} 10788c2ecf20Sopenharmony_ci 10798c2ecf20Sopenharmony_cioffload_indication_vlan_aware_l3vni_test() 10808c2ecf20Sopenharmony_ci{ 10818c2ecf20Sopenharmony_ci local zmac=00:00:00:00:00:00 10828c2ecf20Sopenharmony_ci 10838c2ecf20Sopenharmony_ci RET=0 10848c2ecf20Sopenharmony_ci 10858c2ecf20Sopenharmony_ci sysctl_set net.ipv6.conf.default.disable_ipv6 1 10868c2ecf20Sopenharmony_ci ip link add dev br0 up type bridge mcast_snooping 0 \ 10878c2ecf20Sopenharmony_ci vlan_filtering 1 vlan_default_pvid 0 10888c2ecf20Sopenharmony_ci ip link add name vxlan0 up type vxlan id 10 nolearning noudpcsum \ 10898c2ecf20Sopenharmony_ci ttl 20 tos inherit local 198.51.100.1 dstport 4789 10908c2ecf20Sopenharmony_ci 10918c2ecf20Sopenharmony_ci ip link set dev $swp1 master br0 10928c2ecf20Sopenharmony_ci 10938c2ecf20Sopenharmony_ci # The test will use the offload indication on the FDB entry to 10948c2ecf20Sopenharmony_ci # understand if the tunnel is offloaded or not 10958c2ecf20Sopenharmony_ci bridge fdb append $zmac dev vxlan0 self dst 192.0.2.1 10968c2ecf20Sopenharmony_ci 10978c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 10988c2ecf20Sopenharmony_ci bridge vlan add dev vxlan0 vid 10 pvid untagged 10998c2ecf20Sopenharmony_ci 11008c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $zmac self \ 11018c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 11028c2ecf20Sopenharmony_ci check_err $? "vxlan tunnel not offloaded when should" 11038c2ecf20Sopenharmony_ci 11048c2ecf20Sopenharmony_ci # Configure a VLAN interface and make sure tunnel is offloaded 11058c2ecf20Sopenharmony_ci ip link add link br0 name br10 up type vlan id 10 11068c2ecf20Sopenharmony_ci sysctl_set net.ipv6.conf.br10.disable_ipv6 0 11078c2ecf20Sopenharmony_ci ip -6 address add 2001:db8:1::1/64 dev br10 11088c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $zmac self \ 11098c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 11108c2ecf20Sopenharmony_ci check_err $? "vxlan tunnel not offloaded when should" 11118c2ecf20Sopenharmony_ci 11128c2ecf20Sopenharmony_ci # Unlink the VXLAN device, make sure tunnel is no longer offloaded, 11138c2ecf20Sopenharmony_ci # then add it back to the bridge and make sure it is offloaded 11148c2ecf20Sopenharmony_ci ip link set dev vxlan0 nomaster 11158c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $zmac self \ 11168c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 11178c2ecf20Sopenharmony_ci check_err $? "vxlan tunnel offloaded after unlinked from bridge" 11188c2ecf20Sopenharmony_ci 11198c2ecf20Sopenharmony_ci ip link set dev vxlan0 master br0 11208c2ecf20Sopenharmony_ci busywait "$TIMEOUT" not wait_for_offload grep_bridge_fdb $zmac self \ 11218c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 11228c2ecf20Sopenharmony_ci check_err $? "vxlan tunnel offloaded despite no matching vid" 11238c2ecf20Sopenharmony_ci 11248c2ecf20Sopenharmony_ci bridge vlan add dev vxlan0 vid 10 pvid untagged 11258c2ecf20Sopenharmony_ci busywait "$TIMEOUT" wait_for_offload grep_bridge_fdb $zmac self \ 11268c2ecf20Sopenharmony_ci bridge fdb show brport vxlan0 11278c2ecf20Sopenharmony_ci check_err $? "vxlan tunnel not offloaded after adding vid" 11288c2ecf20Sopenharmony_ci 11298c2ecf20Sopenharmony_ci log_test "vxlan - l3 vni" 11308c2ecf20Sopenharmony_ci 11318c2ecf20Sopenharmony_ci ip link del dev vxlan0 11328c2ecf20Sopenharmony_ci ip link del dev br0 11338c2ecf20Sopenharmony_ci sysctl_restore net.ipv6.conf.default.disable_ipv6 11348c2ecf20Sopenharmony_ci} 11358c2ecf20Sopenharmony_ci 11368c2ecf20Sopenharmony_cioffload_indication_vlan_aware_test() 11378c2ecf20Sopenharmony_ci{ 11388c2ecf20Sopenharmony_ci offload_indication_vlan_aware_setup_create 11398c2ecf20Sopenharmony_ci offload_indication_vlan_aware_fdb_test 11408c2ecf20Sopenharmony_ci offload_indication_vlan_aware_decap_route_test 11418c2ecf20Sopenharmony_ci offload_indication_vlan_aware_setup_destroy 11428c2ecf20Sopenharmony_ci 11438c2ecf20Sopenharmony_ci log_info "offload indication - replay & cleanup - vlan aware" 11448c2ecf20Sopenharmony_ci offload_indication_vlan_aware_join_vxlan_first 11458c2ecf20Sopenharmony_ci offload_indication_vlan_aware_join_vxlan_last 11468c2ecf20Sopenharmony_ci offload_indication_vlan_aware_l3vni_test 11478c2ecf20Sopenharmony_ci} 11488c2ecf20Sopenharmony_ci 11498c2ecf20Sopenharmony_citrap cleanup EXIT 11508c2ecf20Sopenharmony_ci 11518c2ecf20Sopenharmony_cisetup_prepare 11528c2ecf20Sopenharmony_cisetup_wait 11538c2ecf20Sopenharmony_ci 11548c2ecf20Sopenharmony_citests_run 11558c2ecf20Sopenharmony_ci 11568c2ecf20Sopenharmony_ciexit $EXIT_STATUS 1157