2 # SPDX-License-Identifier: GPL-2.0
4 # This test uses standard topology for testing gretap. See
5 # mirror_gre_topo_lib.sh for more details.
7 # Test for "tc action mirred egress mirror" when the underlay route points at a
8 # vlan device on top of a bridge device with vlan filtering (802.1q).
13 test_gretap_forbidden_cpu
14 test_ip6gretap_forbidden_cpu
15 test_gretap_forbidden_egress
16 test_ip6gretap_forbidden_egress
17 test_gretap_untagged_egress
18 test_ip6gretap_untagged_egress
19 test_gretap_fdb_roaming
20 test_ip6gretap_fdb_roaming
28 source mirror_gre_lib.sh
29 source mirror_gre_topo_lib.sh
31 require_command $ARPING
44 # gt4's remote address is at $h3.555, not $h3. Thus the packets arriving
45 # directly to $h3 for test_gretap_untagged_egress() are rejected by
46 # rp_filter and the test spuriously fails.
47 sysctl_set net.ipv4.conf.all.rp_filter 0
48 sysctl_set net.ipv4.conf.$h3.rp_filter 0
51 mirror_gre_topo_create
53 vlan_create br1 555 "" 192.0.2.129/32 2001:db8:2::1/128
54 bridge vlan add dev br1 vid 555 self
55 ip route rep 192.0.2.130/32 dev br1.555
56 ip -6 route rep 2001:db8:2::2/128 dev br1.555
58 vlan_create $h3 555 v$h3 192.0.2.130/28 2001:db8:2::2/64
60 ip link set dev $swp3 master br1
61 bridge vlan add dev $swp3 vid 555
62 bridge vlan add dev $swp2 vid 555
69 ip link set dev $swp2 nomaster
70 ip link set dev $swp3 nomaster
74 mirror_gre_topo_destroy
77 sysctl_restore net.ipv4.conf.$h3.rp_filter
78 sysctl_restore net.ipv4.conf.all.rp_filter
83 local tundev=$1; shift
84 local vlan_match=$1; shift
87 full_test_span_gre_dir_vlan $tundev ingress "$vlan_match" 8 0 "$what"
88 full_test_span_gre_dir_vlan $tundev egress "$vlan_match" 0 8 "$what"
93 test_vlan_match gt4 'skip_hw vlan_id 555 vlan_ethtype ip' \
99 test_vlan_match gt6 'skip_hw vlan_id 555 vlan_ethtype ip' \
100 "mirror to ip6gretap"
103 test_span_gre_forbidden_cpu()
105 local tundev=$1; shift
110 # Run the pass-test first, to prime neighbor table.
111 mirror_install $swp1 ingress $tundev "matchall $tcflags"
112 quick_test_span_gre_dir $tundev ingress
114 # Now forbid the VLAN at the bridge and see it fail.
115 bridge vlan del dev br1 vid 555 self
117 fail_test_span_gre_dir $tundev ingress
119 bridge vlan add dev br1 vid 555 self
121 quick_test_span_gre_dir $tundev ingress
123 mirror_uninstall $swp1 ingress
125 log_test "$what: vlan forbidden at a bridge ($tcflags)"
128 test_gretap_forbidden_cpu()
130 test_span_gre_forbidden_cpu gt4 "mirror to gretap"
133 test_ip6gretap_forbidden_cpu()
135 test_span_gre_forbidden_cpu gt6 "mirror to ip6gretap"
138 test_span_gre_forbidden_egress()
140 local tundev=$1; shift
145 mirror_install $swp1 ingress $tundev "matchall $tcflags"
146 quick_test_span_gre_dir $tundev ingress
148 bridge vlan del dev $swp3 vid 555
150 fail_test_span_gre_dir $tundev ingress
152 bridge vlan add dev $swp3 vid 555
154 $ARPING -I br1.555 192.0.2.130 -fqc 1
156 quick_test_span_gre_dir $tundev ingress
158 mirror_uninstall $swp1 ingress
160 log_test "$what: vlan forbidden at a bridge egress ($tcflags)"
163 test_gretap_forbidden_egress()
165 test_span_gre_forbidden_egress gt4 "mirror to gretap"
168 test_ip6gretap_forbidden_egress()
170 test_span_gre_forbidden_egress gt6 "mirror to ip6gretap"
173 test_span_gre_untagged_egress()
175 local tundev=$1; shift
180 mirror_install $swp1 ingress $tundev "matchall $tcflags"
182 quick_test_span_gre_dir $tundev ingress
183 quick_test_span_vlan_dir $h3 555 ingress
185 bridge vlan add dev $swp3 vid 555 pvid untagged
187 quick_test_span_gre_dir $tundev ingress
188 fail_test_span_vlan_dir $h3 555 ingress
190 bridge vlan add dev $swp3 vid 555
192 quick_test_span_gre_dir $tundev ingress
193 quick_test_span_vlan_dir $h3 555 ingress
195 mirror_uninstall $swp1 ingress
197 log_test "$what: vlan untagged at a bridge egress ($tcflags)"
200 test_gretap_untagged_egress()
202 test_span_gre_untagged_egress gt4 "mirror to gretap"
205 test_ip6gretap_untagged_egress()
207 test_span_gre_untagged_egress gt6 "mirror to ip6gretap"
210 test_span_gre_fdb_roaming()
212 local tundev=$1; shift
214 local h3mac=$(mac_get $h3)
218 mirror_install $swp1 ingress $tundev "matchall $tcflags"
219 quick_test_span_gre_dir $tundev ingress
221 bridge fdb del dev $swp3 $h3mac vlan 555 master
222 bridge fdb add dev $swp2 $h3mac vlan 555 master
224 fail_test_span_gre_dir $tundev ingress
226 bridge fdb del dev $swp2 $h3mac vlan 555 master
228 $ARPING -I br1.555 192.0.2.130 -fqc 1
230 quick_test_span_gre_dir $tundev ingress
232 mirror_uninstall $swp1 ingress
234 log_test "$what: MAC roaming ($tcflags)"
237 test_gretap_fdb_roaming()
239 test_span_gre_fdb_roaming gt4 "mirror to gretap"
242 test_ip6gretap_fdb_roaming()
244 test_span_gre_fdb_roaming gt6 "mirror to ip6gretap"
249 full_test_span_gre_stp gt4 $swp3 "mirror to gretap"
254 full_test_span_gre_stp gt6 $swp3 "mirror to ip6gretap"
259 slow_path_trap_install $swp1 ingress
260 slow_path_trap_install $swp1 egress
264 slow_path_trap_uninstall $swp1 egress
265 slow_path_trap_uninstall $swp1 ingress
276 if ! tc_offload_check; then
277 echo "WARN: Could not test offloaded functionality"