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