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 161c3cadbeSPaolo Abenireadonly NPROCS=`nproc` 171c3cadbeSPaolo Abeniret=0 181c3cadbeSPaolo Abeni 191c3cadbeSPaolo Abenicleanup() { 201c3cadbeSPaolo Abeni local ns 21*0fd158b8SAndrea Righi local jobs 22*0fd158b8SAndrea 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 781c3cadbeSPaolo Abenichk_gro() { 791c3cadbeSPaolo Abeni local msg="$1" 801c3cadbeSPaolo Abeni local expected=$2 811c3cadbeSPaolo Abeni 821c3cadbeSPaolo Abeni ip netns exec $BASE$SRC ping -qc 1 $BM_NET_V4$DST >/dev/null 831c3cadbeSPaolo Abeni NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat -n 841c3cadbeSPaolo Abeni 851c3cadbeSPaolo Abeni printf "%-60s" "$msg" 861c3cadbeSPaolo Abeni ip netns exec $BASE$DST ./udpgso_bench_rx -C 1000 -R 10 & 871c3cadbeSPaolo Abeni local spid=$! 881c3cadbeSPaolo Abeni sleep 0.1 891c3cadbeSPaolo Abeni 901c3cadbeSPaolo Abeni ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 13000 -S 1300 -M 1 -D $BM_NET_V4$DST 911c3cadbeSPaolo Abeni local retc=$? 921c3cadbeSPaolo Abeni wait $spid 931c3cadbeSPaolo Abeni local rets=$? 941c3cadbeSPaolo Abeni if [ ${rets} -ne 0 ] || [ ${retc} -ne 0 ]; then 951c3cadbeSPaolo Abeni echo " fail client exit code $retc, server $rets" 961c3cadbeSPaolo Abeni ret=1 971c3cadbeSPaolo Abeni return 981c3cadbeSPaolo Abeni fi 991c3cadbeSPaolo Abeni 1001c3cadbeSPaolo Abeni local pkts=`NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat IpInReceives | \ 1011c3cadbeSPaolo Abeni awk '{print $2}' | tail -n 1` 1021c3cadbeSPaolo Abeni if [ "$pkts" = "$expected" ]; then 1031c3cadbeSPaolo Abeni echo " ok " 1041c3cadbeSPaolo Abeni else 1051c3cadbeSPaolo Abeni echo " fail - got $pkts packets, expected $expected " 1061c3cadbeSPaolo Abeni ret=1 1071c3cadbeSPaolo Abeni fi 1081c3cadbeSPaolo Abeni} 1091c3cadbeSPaolo Abeni 1101c3cadbeSPaolo Abeniif [ ! -f ../bpf/xdp_dummy.o ]; then 1111c3cadbeSPaolo Abeni echo "Missing xdp_dummy helper. Build bpf selftest first" 112*0fd158b8SAndrea Righi exit 1 1131c3cadbeSPaolo Abenifi 1141c3cadbeSPaolo Abeni 1151c3cadbeSPaolo Abenicreate_ns 1161c3cadbeSPaolo Abenichk_gro_flag "default - gro flag" $SRC off 1171c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $DST off 1181c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 1191c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 1201c3cadbeSPaolo Abenichk_gro " - aggregation" 1 1211c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 1221c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 10 1231c3cadbeSPaolo Abenicleanup 1241c3cadbeSPaolo Abeni 1251c3cadbeSPaolo Abenicreate_ns 1261c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 1271c3cadbeSPaolo Abenichk_gro_flag "with gro on - gro flag" $DST on 1281c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 1291c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 1301c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 1311c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 1321c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 1331c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 1 1341c3cadbeSPaolo Abenicleanup 1351c3cadbeSPaolo Abeni 1361c3cadbeSPaolo Abenicreate_ns 1371c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down 1381c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 1391c3cadbeSPaolo Abenichk_gro_flag "with gro enabled on link down - gro flag" $DST on 1401c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 1411c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 1421c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 1431c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up 1441c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 1451c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 1461c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 1 1471c3cadbeSPaolo Abenicleanup 1481c3cadbeSPaolo Abeni 1491c3cadbeSPaolo Abenicreate_ns 1501c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp object ../bpf/xdp_dummy.o section xdp_dummy 2>/dev/null 1511c3cadbeSPaolo Abenichk_gro_flag "with xdp attached - gro flag" $DST on 1521c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 1531c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC off 1541c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 1551c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 1561c3cadbeSPaolo Abenichk_gro " - aggregation" 1 1571c3cadbeSPaolo Abeni 1581c3cadbeSPaolo Abeni 1591c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down 1601c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC down 1611c3cadbeSPaolo Abenichk_gro_flag " - after dev off, flag" $DST on 1621c3cadbeSPaolo Abenichk_gro_flag " - peer flag" $SRC off 1631c3cadbeSPaolo Abeni 1641c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 1651c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp off 1661c3cadbeSPaolo Abenichk_gro_flag " - after gro on xdp off, gro flag" $DST on 1671c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 1681c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 1691c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 1701c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up 1711c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC up 1721c3cadbeSPaolo Abenichk_gro " - aggregation" 1 1731c3cadbeSPaolo Abeni 1741c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro off 1751c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 1761c3cadbeSPaolo Abenichk_gro "aggregation again with default and TSO off" 10 1771c3cadbeSPaolo Abeni 1781c3cadbeSPaolo Abeniexit $ret 179