xref: /openbmc/linux/tools/testing/selftests/net/veth.sh (revision 1ec2230fc721e6270b0504c07945a74742c81f81)
11c3cadbeSPaolo Abeni#!/bin/sh
21c3cadbeSPaolo Abeni# SPDX-License-Identifier: GPL-2.0
31c3cadbeSPaolo Abeni
41c3cadbeSPaolo Abenireadonly STATS="$(mktemp -p /tmp ns-XXXXXX)"
51c3cadbeSPaolo Abenireadonly BASE=`basename $STATS`
61c3cadbeSPaolo Abenireadonly SRC=2
71c3cadbeSPaolo Abenireadonly DST=1
81c3cadbeSPaolo Abenireadonly DST_NAT=100
91c3cadbeSPaolo Abenireadonly NS_SRC=$BASE$SRC
101c3cadbeSPaolo Abenireadonly NS_DST=$BASE$DST
111c3cadbeSPaolo Abeni
121c3cadbeSPaolo Abeni# "baremetal" network used for raw UDP traffic
131c3cadbeSPaolo Abenireadonly BM_NET_V4=192.168.1.
141c3cadbeSPaolo Abenireadonly BM_NET_V6=2001:db8::
151c3cadbeSPaolo Abeni
16*1ec2230fSPaolo Abenireadonly CPUS=`nproc`
171c3cadbeSPaolo Abeniret=0
181c3cadbeSPaolo Abeni
191c3cadbeSPaolo Abenicleanup() {
201c3cadbeSPaolo Abeni	local ns
210fd158b8SAndrea Righi	local jobs
220fd158b8SAndrea Righi	readonly jobs="$(jobs -p)"
231c3cadbeSPaolo Abeni	[ -n "${jobs}" ] && kill -1 ${jobs} 2>/dev/null
241c3cadbeSPaolo Abeni	rm -f $STATS
251c3cadbeSPaolo Abeni
261c3cadbeSPaolo Abeni	for ns in $NS_SRC $NS_DST; do
271c3cadbeSPaolo Abeni		ip netns del $ns 2>/dev/null
281c3cadbeSPaolo Abeni	done
291c3cadbeSPaolo Abeni}
301c3cadbeSPaolo Abeni
311c3cadbeSPaolo Abenitrap cleanup EXIT
321c3cadbeSPaolo Abeni
331c3cadbeSPaolo Abenicreate_ns() {
341c3cadbeSPaolo Abeni	local ns
351c3cadbeSPaolo Abeni
361c3cadbeSPaolo Abeni	for ns in $NS_SRC $NS_DST; do
371c3cadbeSPaolo Abeni		ip netns add $ns
381c3cadbeSPaolo Abeni		ip -n $ns link set dev lo up
391c3cadbeSPaolo Abeni	done
401c3cadbeSPaolo Abeni
411c3cadbeSPaolo Abeni	ip link add name veth$SRC type veth peer name veth$DST
421c3cadbeSPaolo Abeni
431c3cadbeSPaolo Abeni	for ns in $SRC $DST; do
441c3cadbeSPaolo Abeni		ip link set dev veth$ns netns $BASE$ns up
451c3cadbeSPaolo Abeni		ip -n $BASE$ns addr add dev veth$ns $BM_NET_V4$ns/24
461c3cadbeSPaolo Abeni		ip -n $BASE$ns addr add dev veth$ns $BM_NET_V6$ns/64 nodad
471c3cadbeSPaolo Abeni	done
481c3cadbeSPaolo Abeni	echo "#kernel" > $BASE
491c3cadbeSPaolo Abeni	chmod go-rw $BASE
501c3cadbeSPaolo Abeni}
511c3cadbeSPaolo Abeni
521c3cadbeSPaolo Abeni__chk_flag() {
531c3cadbeSPaolo Abeni	local msg="$1"
541c3cadbeSPaolo Abeni	local target=$2
551c3cadbeSPaolo Abeni	local expected=$3
561c3cadbeSPaolo Abeni	local flagname=$4
571c3cadbeSPaolo Abeni
581c3cadbeSPaolo Abeni	local flag=`ip netns exec $BASE$target ethtool -k veth$target |\
591c3cadbeSPaolo Abeni		    grep $flagname | awk '{print $2}'`
601c3cadbeSPaolo Abeni
611c3cadbeSPaolo Abeni	printf "%-60s" "$msg"
621c3cadbeSPaolo Abeni	if [ "$flag" = "$expected" ]; then
631c3cadbeSPaolo Abeni		echo " ok "
641c3cadbeSPaolo Abeni	else
651c3cadbeSPaolo Abeni		echo " fail - expected $expected found $flag"
661c3cadbeSPaolo Abeni		ret=1
671c3cadbeSPaolo Abeni	fi
681c3cadbeSPaolo Abeni}
691c3cadbeSPaolo Abeni
701c3cadbeSPaolo Abenichk_gro_flag() {
711c3cadbeSPaolo Abeni	__chk_flag "$1" $2 $3 generic-receive-offload
721c3cadbeSPaolo Abeni}
731c3cadbeSPaolo Abeni
741c3cadbeSPaolo Abenichk_tso_flag() {
751c3cadbeSPaolo Abeni	__chk_flag "$1" $2 $3 tcp-segmentation-offload
761c3cadbeSPaolo Abeni}
771c3cadbeSPaolo Abeni
78*1ec2230fSPaolo Abenichk_channels() {
79*1ec2230fSPaolo Abeni	local msg="$1"
80*1ec2230fSPaolo Abeni	local target=$2
81*1ec2230fSPaolo Abeni	local rx=$3
82*1ec2230fSPaolo Abeni	local tx=$4
83*1ec2230fSPaolo Abeni
84*1ec2230fSPaolo Abeni	local dev=veth$target
85*1ec2230fSPaolo Abeni
86*1ec2230fSPaolo Abeni	local cur_rx=`ip netns exec $BASE$target ethtool -l $dev |\
87*1ec2230fSPaolo Abeni		grep RX: | tail -n 1 | awk '{print $2}' `
88*1ec2230fSPaolo Abeni		local cur_tx=`ip netns exec $BASE$target ethtool -l $dev |\
89*1ec2230fSPaolo Abeni		grep TX: | tail -n 1 | awk '{print $2}'`
90*1ec2230fSPaolo Abeni	local cur_combined=`ip netns exec $BASE$target ethtool -l $dev |\
91*1ec2230fSPaolo Abeni		grep Combined: | tail -n 1 | awk '{print $2}'`
92*1ec2230fSPaolo Abeni
93*1ec2230fSPaolo Abeni	printf "%-60s" "$msg"
94*1ec2230fSPaolo Abeni	if [ "$cur_rx" = "$rx" -a "$cur_tx" = "$tx" -a "$cur_combined" = "n/a" ]; then
95*1ec2230fSPaolo Abeni		echo " ok "
96*1ec2230fSPaolo Abeni	else
97*1ec2230fSPaolo Abeni		echo " fail rx:$rx:$cur_rx tx:$tx:$cur_tx combined:n/a:$cur_combined"
98*1ec2230fSPaolo Abeni	fi
99*1ec2230fSPaolo Abeni}
100*1ec2230fSPaolo Abeni
1011c3cadbeSPaolo Abenichk_gro() {
1021c3cadbeSPaolo Abeni	local msg="$1"
1031c3cadbeSPaolo Abeni	local expected=$2
1041c3cadbeSPaolo Abeni
1051c3cadbeSPaolo Abeni	ip netns exec $BASE$SRC ping -qc 1 $BM_NET_V4$DST >/dev/null
1061c3cadbeSPaolo Abeni	NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat -n
1071c3cadbeSPaolo Abeni
1081c3cadbeSPaolo Abeni	printf "%-60s" "$msg"
1091c3cadbeSPaolo Abeni	ip netns exec $BASE$DST ./udpgso_bench_rx -C 1000 -R 10 &
1101c3cadbeSPaolo Abeni	local spid=$!
1111c3cadbeSPaolo Abeni	sleep 0.1
1121c3cadbeSPaolo Abeni
1131c3cadbeSPaolo Abeni	ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 13000 -S 1300 -M 1 -D $BM_NET_V4$DST
1141c3cadbeSPaolo Abeni	local retc=$?
1151c3cadbeSPaolo Abeni	wait $spid
1161c3cadbeSPaolo Abeni	local rets=$?
1171c3cadbeSPaolo Abeni	if [ ${rets} -ne 0 ] || [ ${retc} -ne 0 ]; then
1181c3cadbeSPaolo Abeni		echo " fail client exit code $retc, server $rets"
1191c3cadbeSPaolo Abeni		ret=1
1201c3cadbeSPaolo Abeni		return
1211c3cadbeSPaolo Abeni	fi
1221c3cadbeSPaolo Abeni
1231c3cadbeSPaolo Abeni	local pkts=`NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat IpInReceives | \
1241c3cadbeSPaolo Abeni		    awk '{print $2}' | tail -n 1`
1251c3cadbeSPaolo Abeni	if [ "$pkts" = "$expected" ]; then
1261c3cadbeSPaolo Abeni		echo " ok "
1271c3cadbeSPaolo Abeni	else
1281c3cadbeSPaolo Abeni		echo " fail - got $pkts packets, expected $expected "
1291c3cadbeSPaolo Abeni		ret=1
1301c3cadbeSPaolo Abeni	fi
1311c3cadbeSPaolo Abeni}
1321c3cadbeSPaolo Abeni
133*1ec2230fSPaolo Abeni__change_channels()
134*1ec2230fSPaolo Abeni{
135*1ec2230fSPaolo Abeni	local cur_cpu
136*1ec2230fSPaolo Abeni	local end=$1
137*1ec2230fSPaolo Abeni	local cur
138*1ec2230fSPaolo Abeni	local i
139*1ec2230fSPaolo Abeni
140*1ec2230fSPaolo Abeni	while true; do
141*1ec2230fSPaolo Abeni		printf -v cur '%(%s)T'
142*1ec2230fSPaolo Abeni		[ $cur -le $end ] || break
143*1ec2230fSPaolo Abeni
144*1ec2230fSPaolo Abeni		for i in `seq 1 $CPUS`; do
145*1ec2230fSPaolo Abeni			ip netns exec $NS_SRC ethtool -L veth$SRC rx $i tx $i
146*1ec2230fSPaolo Abeni			ip netns exec $NS_DST ethtool -L veth$DST rx $i tx $i
147*1ec2230fSPaolo Abeni		done
148*1ec2230fSPaolo Abeni
149*1ec2230fSPaolo Abeni		for i in `seq 1 $((CPUS - 1))`; do
150*1ec2230fSPaolo Abeni			cur_cpu=$((CPUS - $i))
151*1ec2230fSPaolo Abeni			ip netns exec $NS_SRC ethtool -L veth$SRC rx $cur_cpu tx $cur_cpu
152*1ec2230fSPaolo Abeni			ip netns exec $NS_DST ethtool -L veth$DST rx $cur_cpu tx $cur_cpu
153*1ec2230fSPaolo Abeni		done
154*1ec2230fSPaolo Abeni	done
155*1ec2230fSPaolo Abeni}
156*1ec2230fSPaolo Abeni
157*1ec2230fSPaolo Abeni__send_data() {
158*1ec2230fSPaolo Abeni	local end=$1
159*1ec2230fSPaolo Abeni
160*1ec2230fSPaolo Abeni	while true; do
161*1ec2230fSPaolo Abeni		printf -v cur '%(%s)T'
162*1ec2230fSPaolo Abeni		[ $cur -le $end ] || break
163*1ec2230fSPaolo Abeni
164*1ec2230fSPaolo Abeni		ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 1000 -M 300 -D $BM_NET_V4$DST
165*1ec2230fSPaolo Abeni	done
166*1ec2230fSPaolo Abeni}
167*1ec2230fSPaolo Abeni
168*1ec2230fSPaolo Abenido_stress() {
169*1ec2230fSPaolo Abeni	local end
170*1ec2230fSPaolo Abeni	printf -v end '%(%s)T'
171*1ec2230fSPaolo Abeni	end=$((end + $STRESS))
172*1ec2230fSPaolo Abeni
173*1ec2230fSPaolo Abeni	ip netns exec $NS_SRC ethtool -L veth$SRC rx 3 tx 3
174*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 3 tx 3
175*1ec2230fSPaolo Abeni
176*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ./udpgso_bench_rx &
177*1ec2230fSPaolo Abeni	local rx_pid=$!
178*1ec2230fSPaolo Abeni
179*1ec2230fSPaolo Abeni	echo "Running stress test for $STRESS seconds..."
180*1ec2230fSPaolo Abeni	__change_channels $end &
181*1ec2230fSPaolo Abeni	local ch_pid=$!
182*1ec2230fSPaolo Abeni	__send_data $end &
183*1ec2230fSPaolo Abeni	local data_pid_1=$!
184*1ec2230fSPaolo Abeni	__send_data $end &
185*1ec2230fSPaolo Abeni	local data_pid_2=$!
186*1ec2230fSPaolo Abeni	__send_data $end &
187*1ec2230fSPaolo Abeni	local data_pid_3=$!
188*1ec2230fSPaolo Abeni	__send_data $end &
189*1ec2230fSPaolo Abeni	local data_pid_4=$!
190*1ec2230fSPaolo Abeni
191*1ec2230fSPaolo Abeni	wait $ch_pid $data_pid_1 $data_pid_2 $data_pid_3 $data_pid_4
192*1ec2230fSPaolo Abeni	kill -9 $rx_pid
193*1ec2230fSPaolo Abeni	echo "done"
194*1ec2230fSPaolo Abeni
195*1ec2230fSPaolo Abeni	# restore previous setting
196*1ec2230fSPaolo Abeni	ip netns exec $NS_SRC ethtool -L veth$SRC rx 2 tx 2
197*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 2 tx 1
198*1ec2230fSPaolo Abeni}
199*1ec2230fSPaolo Abeni
200*1ec2230fSPaolo Abeniusage() {
201*1ec2230fSPaolo Abeni	echo "Usage: $0 [-h] [-s <seconds>]"
202*1ec2230fSPaolo Abeni	echo -e "\t-h: show this help"
203*1ec2230fSPaolo Abeni	echo -e "\t-s: run optional stress tests for the given amount of seconds"
204*1ec2230fSPaolo Abeni}
205*1ec2230fSPaolo Abeni
206*1ec2230fSPaolo AbeniSTRESS=0
207*1ec2230fSPaolo Abeniwhile getopts "hs:" option; do
208*1ec2230fSPaolo Abeni	case "$option" in
209*1ec2230fSPaolo Abeni	"h")
210*1ec2230fSPaolo Abeni		usage $0
211*1ec2230fSPaolo Abeni		exit 0
212*1ec2230fSPaolo Abeni		;;
213*1ec2230fSPaolo Abeni	"s")
214*1ec2230fSPaolo Abeni		STRESS=$OPTARG
215*1ec2230fSPaolo Abeni		;;
216*1ec2230fSPaolo Abeni	esac
217*1ec2230fSPaolo Abenidone
218*1ec2230fSPaolo Abeni
2191c3cadbeSPaolo Abeniif [ ! -f ../bpf/xdp_dummy.o ]; then
2201c3cadbeSPaolo Abeni	echo "Missing xdp_dummy helper. Build bpf selftest first"
2210fd158b8SAndrea Righi	exit 1
2221c3cadbeSPaolo Abenifi
2231c3cadbeSPaolo Abeni
224*1ec2230fSPaolo Abeni[ $CPUS -lt 2 ] && echo "Only one CPU available, some tests will be skipped"
225*1ec2230fSPaolo Abeni[ $STRESS -gt 0 -a $CPUS -lt 3 ] && echo " stress test will be skipped, too"
226*1ec2230fSPaolo Abeni
2271c3cadbeSPaolo Abenicreate_ns
2281c3cadbeSPaolo Abenichk_gro_flag "default - gro flag" $SRC off
2291c3cadbeSPaolo Abenichk_gro_flag "        - peer gro flag" $DST off
2301c3cadbeSPaolo Abenichk_tso_flag "        - tso flag" $SRC on
2311c3cadbeSPaolo Abenichk_tso_flag "        - peer tso flag" $DST on
2321c3cadbeSPaolo Abenichk_gro "        - aggregation" 1
2331c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
2341c3cadbeSPaolo Abenichk_gro "        - aggregation with TSO off" 10
2351c3cadbeSPaolo Abenicleanup
2361c3cadbeSPaolo Abeni
2371c3cadbeSPaolo Abenicreate_ns
2381c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on
2391c3cadbeSPaolo Abenichk_gro_flag "with gro on - gro flag" $DST on
2401c3cadbeSPaolo Abenichk_gro_flag "        - peer gro flag" $SRC off
2411c3cadbeSPaolo Abenichk_tso_flag "        - tso flag" $SRC on
2421c3cadbeSPaolo Abenichk_tso_flag "        - peer tso flag" $DST on
2431c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
2441c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
2451c3cadbeSPaolo Abenichk_gro "        - aggregation with TSO off" 1
2461c3cadbeSPaolo Abenicleanup
2471c3cadbeSPaolo Abeni
2481c3cadbeSPaolo Abenicreate_ns
249*1ec2230fSPaolo Abenichk_channels "default channels" $DST 1 1
250*1ec2230fSPaolo Abeni
2511c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down
2521c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on
2531c3cadbeSPaolo Abenichk_gro_flag "with gro enabled on link down - gro flag" $DST on
2541c3cadbeSPaolo Abenichk_gro_flag "        - peer gro flag" $SRC off
2551c3cadbeSPaolo Abenichk_tso_flag "        - tso flag" $SRC on
2561c3cadbeSPaolo Abenichk_tso_flag "        - peer tso flag" $DST on
2571c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up
2581c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
2591c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
2601c3cadbeSPaolo Abenichk_gro "        - aggregation with TSO off" 1
2611c3cadbeSPaolo Abenicleanup
2621c3cadbeSPaolo Abeni
2631c3cadbeSPaolo Abenicreate_ns
264*1ec2230fSPaolo Abeni
265*1ec2230fSPaolo AbeniCUR_TX=1
266*1ec2230fSPaolo AbeniCUR_RX=1
267*1ec2230fSPaolo Abeniif [ $CPUS -gt 1 ]; then
268*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST tx 2
269*1ec2230fSPaolo Abeni	chk_channels "setting tx channels" $DST 1 2
270*1ec2230fSPaolo Abeni	CUR_TX=2
271*1ec2230fSPaolo Abenifi
272*1ec2230fSPaolo Abeni
273*1ec2230fSPaolo Abeniif [ $CPUS -gt 2 ]; then
274*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 3 tx 3
275*1ec2230fSPaolo Abeni	chk_channels "setting both rx and tx channels" $DST 3 3
276*1ec2230fSPaolo Abeni	CUR_RX=3
277*1ec2230fSPaolo Abeni	CUR_TX=3
278*1ec2230fSPaolo Abenifi
279*1ec2230fSPaolo Abeni
280*1ec2230fSPaolo Abeniip netns exec $NS_DST ethtool -L veth$DST combined 2 2>/dev/null
281*1ec2230fSPaolo Abenichk_channels "bad setting: combined channels" $DST $CUR_RX $CUR_TX
282*1ec2230fSPaolo Abeni
283*1ec2230fSPaolo Abeniip netns exec $NS_DST ethtool -L veth$DST tx $((CPUS + 1)) 2>/dev/null
284*1ec2230fSPaolo Abenichk_channels "setting invalid channels nr" $DST $CUR_RX $CUR_TX
285*1ec2230fSPaolo Abeni
286*1ec2230fSPaolo Abeniif [ $CPUS -gt 1 ]; then
287*1ec2230fSPaolo Abeni	# this also tests queues nr reduction
288*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 1 tx 2 2>/dev/null
289*1ec2230fSPaolo Abeni	ip netns exec $NS_SRC ethtool -L veth$SRC rx 1 tx 2 2>/dev/null
290*1ec2230fSPaolo Abeni	printf "%-60s" "bad setting: XDP with RX nr less than TX"
291*1ec2230fSPaolo Abeni	ip -n $NS_DST link set dev veth$DST xdp object ../bpf/xdp_dummy.o \
292*1ec2230fSPaolo Abeni		section xdp_dummy 2>/dev/null &&\
293*1ec2230fSPaolo Abeni		echo "fail - set operation successful ?!?" || echo " ok "
294*1ec2230fSPaolo Abeni
295*1ec2230fSPaolo Abeni	# the following tests will run with multiple channels active
296*1ec2230fSPaolo Abeni	ip netns exec $NS_SRC ethtool -L veth$SRC rx 2
297*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 2
298*1ec2230fSPaolo Abeni	ip -n $NS_DST link set dev veth$DST xdp object ../bpf/xdp_dummy.o \
299*1ec2230fSPaolo Abeni		section xdp_dummy 2>/dev/null
300*1ec2230fSPaolo Abeni	printf "%-60s" "bad setting: reducing RX nr below peer TX with XDP set"
301*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST rx 1 2>/dev/null &&\
302*1ec2230fSPaolo Abeni		echo "fail - set operation successful ?!?" || echo " ok "
303*1ec2230fSPaolo Abeni	CUR_RX=2
304*1ec2230fSPaolo Abeni	CUR_TX=2
305*1ec2230fSPaolo Abenifi
306*1ec2230fSPaolo Abeni
307*1ec2230fSPaolo Abeniif [ $CPUS -gt 2 ]; then
308*1ec2230fSPaolo Abeni	printf "%-60s" "bad setting: increasing peer TX nr above RX with XDP set"
309*1ec2230fSPaolo Abeni	ip netns exec $NS_SRC ethtool -L veth$SRC tx 3 2>/dev/null &&\
310*1ec2230fSPaolo Abeni		echo "fail - set operation successful ?!?" || echo " ok "
311*1ec2230fSPaolo Abeni	chk_channels "setting invalid channels nr" $DST 2 2
312*1ec2230fSPaolo Abenifi
313*1ec2230fSPaolo Abeni
3141c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp object ../bpf/xdp_dummy.o section xdp_dummy 2>/dev/null
3151c3cadbeSPaolo Abenichk_gro_flag "with xdp attached - gro flag" $DST on
3161c3cadbeSPaolo Abenichk_gro_flag "        - peer gro flag" $SRC off
3171c3cadbeSPaolo Abenichk_tso_flag "        - tso flag" $SRC off
3181c3cadbeSPaolo Abenichk_tso_flag "        - peer tso flag" $DST on
3191c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
3201c3cadbeSPaolo Abenichk_gro "        - aggregation" 1
3211c3cadbeSPaolo Abeni
3221c3cadbeSPaolo Abeni
3231c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down
3241c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC down
3251c3cadbeSPaolo Abenichk_gro_flag "        - after dev off, flag" $DST on
3261c3cadbeSPaolo Abenichk_gro_flag "        - peer flag" $SRC off
3271c3cadbeSPaolo Abeni
3281c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on
3291c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp off
3301c3cadbeSPaolo Abenichk_gro_flag "        - after gro on xdp off, gro flag" $DST on
3311c3cadbeSPaolo Abenichk_gro_flag "        - peer gro flag" $SRC off
3321c3cadbeSPaolo Abenichk_tso_flag "        - tso flag" $SRC on
3331c3cadbeSPaolo Abenichk_tso_flag "        - peer tso flag" $DST on
334*1ec2230fSPaolo Abeni
335*1ec2230fSPaolo Abeniif [ $CPUS -gt 1 ]; then
336*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST tx 1
337*1ec2230fSPaolo Abeni	chk_channels "decreasing tx channels with device down" $DST 2 1
338*1ec2230fSPaolo Abenifi
339*1ec2230fSPaolo Abeni
3401c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up
3411c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC up
3421c3cadbeSPaolo Abenichk_gro "        - aggregation" 1
3431c3cadbeSPaolo Abeni
344*1ec2230fSPaolo Abeniif [ $CPUS -gt 1 ]; then
345*1ec2230fSPaolo Abeni	[ $STRESS -gt 0 -a $CPUS -gt 2 ] && do_stress
346*1ec2230fSPaolo Abeni
347*1ec2230fSPaolo Abeni	ip -n $NS_DST link set dev veth$DST down
348*1ec2230fSPaolo Abeni	ip -n $NS_SRC link set dev veth$SRC down
349*1ec2230fSPaolo Abeni	ip netns exec $NS_DST ethtool -L veth$DST tx 2
350*1ec2230fSPaolo Abeni	chk_channels "increasing tx channels with device down" $DST 2 2
351*1ec2230fSPaolo Abeni	ip -n $NS_DST link set dev veth$DST up
352*1ec2230fSPaolo Abeni	ip -n $NS_SRC link set dev veth$SRC up
353*1ec2230fSPaolo Abenifi
354*1ec2230fSPaolo Abeni
3551c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro off
3561c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
3571c3cadbeSPaolo Abenichk_gro "aggregation again with default and TSO off" 10
3581c3cadbeSPaolo Abeni
3591c3cadbeSPaolo Abeniexit $ret
360