#!/bin/bash # SPDX-License-Identifier: GPL-2.0 # This test uses standard topology for testing gretap. See # mirror_gre_topo_lib.sh for more details. # # Test that gretap and ip6gretap mirroring works when the other tunnel endpoint # is reachable through a next-hop route (as opposed to directly-attached route). ALL_TESTS=" test_gretap test_ip6gretap " NUM_NETIFS=6 source lib.sh source mirror_lib.sh source mirror_gre_lib.sh source mirror_gre_topo_lib.sh setup_prepare() { h1=${NETIFS[p1]} swp1=${NETIFS[p2]} swp2=${NETIFS[p3]} h2=${NETIFS[p4]} swp3=${NETIFS[p5]} h3=${NETIFS[p6]} sysctl_set net.ipv4.conf.all.rp_filter 0 sysctl_set net.ipv4.conf.$h3.rp_filter 0 vrf_prepare mirror_gre_topo_create sysctl_set net.ipv4.conf.v$h3.rp_filter 0 ip address add dev $swp3 192.0.2.161/28 ip address add dev $h3 192.0.2.162/28 ip address add dev gt4 192.0.2.129/32 ip address add dev h3-gt4 192.0.2.130/32 # IPv6 route can't be added after address. Such routes are rejected due # to the gateway address having been configured on the local system. It # works the other way around though. ip address add dev $swp3 2001:db8:4::1/64 ip -6 route add 2001:db8:2::2/128 via 2001:db8:4::2 ip address add dev $h3 2001:db8:4::2/64 ip address add dev gt6 2001:db8:2::1 ip address add dev h3-gt6 2001:db8:2::2 } cleanup() { pre_cleanup ip -6 route del 2001:db8:2::2/128 via 2001:db8:4::2 ip address del dev $h3 2001:db8:4::2/64 ip address del dev $swp3 2001:db8:4::1/64 ip address del dev $h3 192.0.2.162/28 ip address del dev $swp3 192.0.2.161/28 sysctl_restore net.ipv4.conf.v$h3.rp_filter 0 mirror_gre_topo_destroy vrf_cleanup sysctl_restore net.ipv4.conf.$h3.rp_filter sysctl_restore net.ipv4.conf.all.rp_filter } test_gretap() { RET=0 mirror_install $swp1 ingress gt4 "matchall $tcflags" # For IPv4, test that there's no mirroring without the route directing # the traffic to tunnel remote address. Then add it and test that # mirroring starts. For IPv6 we can't test this due to the limitation # that routes for locally-specified IPv6 addresses can't be added. fail_test_span_gre_dir gt4 ingress ip route add 192.0.2.130/32 via 192.0.2.162 quick_test_span_gre_dir gt4 ingress ip route del 192.0.2.130/32 via 192.0.2.162 mirror_uninstall $swp1 ingress log_test "mirror to gre with next-hop remote ($tcflags)" } test_ip6gretap() { RET=0 mirror_install $swp1 ingress gt6 "matchall $tcflags" quick_test_span_gre_dir gt6 ingress mirror_uninstall $swp1 ingress log_test "mirror to ip6gre with next-hop remote ($tcflags)" } test_all() { slow_path_trap_install $swp1 ingress slow_path_trap_install $swp1 egress tests_run slow_path_trap_uninstall $swp1 egress slow_path_trap_uninstall $swp1 ingress } trap cleanup EXIT setup_prepare setup_wait tcflags="skip_hw" test_all if ! tc_offload_check; then echo "WARN: Could not test offloaded functionality" else tcflags="skip_sw" test_all fi exit $EXIT_STATUS