1*1c3cadbeSPaolo Abeni#!/bin/sh 2*1c3cadbeSPaolo Abeni# SPDX-License-Identifier: GPL-2.0 3*1c3cadbeSPaolo Abeni 4*1c3cadbeSPaolo Abenireadonly STATS="$(mktemp -p /tmp ns-XXXXXX)" 5*1c3cadbeSPaolo Abenireadonly BASE=`basename $STATS` 6*1c3cadbeSPaolo Abenireadonly SRC=2 7*1c3cadbeSPaolo Abenireadonly DST=1 8*1c3cadbeSPaolo Abenireadonly DST_NAT=100 9*1c3cadbeSPaolo Abenireadonly NS_SRC=$BASE$SRC 10*1c3cadbeSPaolo Abenireadonly NS_DST=$BASE$DST 11*1c3cadbeSPaolo Abeni 12*1c3cadbeSPaolo Abeni# "baremetal" network used for raw UDP traffic 13*1c3cadbeSPaolo Abenireadonly BM_NET_V4=192.168.1. 14*1c3cadbeSPaolo Abenireadonly BM_NET_V6=2001:db8:: 15*1c3cadbeSPaolo Abeni 16*1c3cadbeSPaolo Abenireadonly NPROCS=`nproc` 17*1c3cadbeSPaolo Abeniret=0 18*1c3cadbeSPaolo Abeni 19*1c3cadbeSPaolo Abenicleanup() { 20*1c3cadbeSPaolo Abeni local ns 21*1c3cadbeSPaolo Abeni local -r jobs="$(jobs -p)" 22*1c3cadbeSPaolo Abeni [ -n "${jobs}" ] && kill -1 ${jobs} 2>/dev/null 23*1c3cadbeSPaolo Abeni rm -f $STATS 24*1c3cadbeSPaolo Abeni 25*1c3cadbeSPaolo Abeni for ns in $NS_SRC $NS_DST; do 26*1c3cadbeSPaolo Abeni ip netns del $ns 2>/dev/null 27*1c3cadbeSPaolo Abeni done 28*1c3cadbeSPaolo Abeni} 29*1c3cadbeSPaolo Abeni 30*1c3cadbeSPaolo Abenitrap cleanup EXIT 31*1c3cadbeSPaolo Abeni 32*1c3cadbeSPaolo Abenicreate_ns() { 33*1c3cadbeSPaolo Abeni local ns 34*1c3cadbeSPaolo Abeni 35*1c3cadbeSPaolo Abeni for ns in $NS_SRC $NS_DST; do 36*1c3cadbeSPaolo Abeni ip netns add $ns 37*1c3cadbeSPaolo Abeni ip -n $ns link set dev lo up 38*1c3cadbeSPaolo Abeni done 39*1c3cadbeSPaolo Abeni 40*1c3cadbeSPaolo Abeni ip link add name veth$SRC type veth peer name veth$DST 41*1c3cadbeSPaolo Abeni 42*1c3cadbeSPaolo Abeni for ns in $SRC $DST; do 43*1c3cadbeSPaolo Abeni ip link set dev veth$ns netns $BASE$ns up 44*1c3cadbeSPaolo Abeni ip -n $BASE$ns addr add dev veth$ns $BM_NET_V4$ns/24 45*1c3cadbeSPaolo Abeni ip -n $BASE$ns addr add dev veth$ns $BM_NET_V6$ns/64 nodad 46*1c3cadbeSPaolo Abeni done 47*1c3cadbeSPaolo Abeni echo "#kernel" > $BASE 48*1c3cadbeSPaolo Abeni chmod go-rw $BASE 49*1c3cadbeSPaolo Abeni} 50*1c3cadbeSPaolo Abeni 51*1c3cadbeSPaolo Abeni__chk_flag() { 52*1c3cadbeSPaolo Abeni local msg="$1" 53*1c3cadbeSPaolo Abeni local target=$2 54*1c3cadbeSPaolo Abeni local expected=$3 55*1c3cadbeSPaolo Abeni local flagname=$4 56*1c3cadbeSPaolo Abeni 57*1c3cadbeSPaolo Abeni local flag=`ip netns exec $BASE$target ethtool -k veth$target |\ 58*1c3cadbeSPaolo Abeni grep $flagname | awk '{print $2}'` 59*1c3cadbeSPaolo Abeni 60*1c3cadbeSPaolo Abeni printf "%-60s" "$msg" 61*1c3cadbeSPaolo Abeni if [ "$flag" = "$expected" ]; then 62*1c3cadbeSPaolo Abeni echo " ok " 63*1c3cadbeSPaolo Abeni else 64*1c3cadbeSPaolo Abeni echo " fail - expected $expected found $flag" 65*1c3cadbeSPaolo Abeni ret=1 66*1c3cadbeSPaolo Abeni fi 67*1c3cadbeSPaolo Abeni} 68*1c3cadbeSPaolo Abeni 69*1c3cadbeSPaolo Abenichk_gro_flag() { 70*1c3cadbeSPaolo Abeni __chk_flag "$1" $2 $3 generic-receive-offload 71*1c3cadbeSPaolo Abeni} 72*1c3cadbeSPaolo Abeni 73*1c3cadbeSPaolo Abenichk_tso_flag() { 74*1c3cadbeSPaolo Abeni __chk_flag "$1" $2 $3 tcp-segmentation-offload 75*1c3cadbeSPaolo Abeni} 76*1c3cadbeSPaolo Abeni 77*1c3cadbeSPaolo Abenichk_gro() { 78*1c3cadbeSPaolo Abeni local msg="$1" 79*1c3cadbeSPaolo Abeni local expected=$2 80*1c3cadbeSPaolo Abeni 81*1c3cadbeSPaolo Abeni ip netns exec $BASE$SRC ping -qc 1 $BM_NET_V4$DST >/dev/null 82*1c3cadbeSPaolo Abeni NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat -n 83*1c3cadbeSPaolo Abeni 84*1c3cadbeSPaolo Abeni printf "%-60s" "$msg" 85*1c3cadbeSPaolo Abeni ip netns exec $BASE$DST ./udpgso_bench_rx -C 1000 -R 10 & 86*1c3cadbeSPaolo Abeni local spid=$! 87*1c3cadbeSPaolo Abeni sleep 0.1 88*1c3cadbeSPaolo Abeni 89*1c3cadbeSPaolo Abeni ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 13000 -S 1300 -M 1 -D $BM_NET_V4$DST 90*1c3cadbeSPaolo Abeni local retc=$? 91*1c3cadbeSPaolo Abeni wait $spid 92*1c3cadbeSPaolo Abeni local rets=$? 93*1c3cadbeSPaolo Abeni if [ ${rets} -ne 0 ] || [ ${retc} -ne 0 ]; then 94*1c3cadbeSPaolo Abeni echo " fail client exit code $retc, server $rets" 95*1c3cadbeSPaolo Abeni ret=1 96*1c3cadbeSPaolo Abeni return 97*1c3cadbeSPaolo Abeni fi 98*1c3cadbeSPaolo Abeni 99*1c3cadbeSPaolo Abeni local pkts=`NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat IpInReceives | \ 100*1c3cadbeSPaolo Abeni awk '{print $2}' | tail -n 1` 101*1c3cadbeSPaolo Abeni if [ "$pkts" = "$expected" ]; then 102*1c3cadbeSPaolo Abeni echo " ok " 103*1c3cadbeSPaolo Abeni else 104*1c3cadbeSPaolo Abeni echo " fail - got $pkts packets, expected $expected " 105*1c3cadbeSPaolo Abeni ret=1 106*1c3cadbeSPaolo Abeni fi 107*1c3cadbeSPaolo Abeni} 108*1c3cadbeSPaolo Abeni 109*1c3cadbeSPaolo Abeniif [ ! -f ../bpf/xdp_dummy.o ]; then 110*1c3cadbeSPaolo Abeni echo "Missing xdp_dummy helper. Build bpf selftest first" 111*1c3cadbeSPaolo Abeni exit -1 112*1c3cadbeSPaolo Abenifi 113*1c3cadbeSPaolo Abeni 114*1c3cadbeSPaolo Abenicreate_ns 115*1c3cadbeSPaolo Abenichk_gro_flag "default - gro flag" $SRC off 116*1c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $DST off 117*1c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 118*1c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 119*1c3cadbeSPaolo Abenichk_gro " - aggregation" 1 120*1c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 121*1c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 10 122*1c3cadbeSPaolo Abenicleanup 123*1c3cadbeSPaolo Abeni 124*1c3cadbeSPaolo Abenicreate_ns 125*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 126*1c3cadbeSPaolo Abenichk_gro_flag "with gro on - gro flag" $DST on 127*1c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 128*1c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 129*1c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 130*1c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 131*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 132*1c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 1 133*1c3cadbeSPaolo Abenicleanup 134*1c3cadbeSPaolo Abeni 135*1c3cadbeSPaolo Abenicreate_ns 136*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down 137*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 138*1c3cadbeSPaolo Abenichk_gro_flag "with gro enabled on link down - gro flag" $DST on 139*1c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 140*1c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 141*1c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 142*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up 143*1c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 144*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 145*1c3cadbeSPaolo Abenichk_gro " - aggregation with TSO off" 1 146*1c3cadbeSPaolo Abenicleanup 147*1c3cadbeSPaolo Abeni 148*1c3cadbeSPaolo Abenicreate_ns 149*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp object ../bpf/xdp_dummy.o section xdp_dummy 2>/dev/null 150*1c3cadbeSPaolo Abenichk_gro_flag "with xdp attached - gro flag" $DST on 151*1c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 152*1c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC off 153*1c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 154*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on 155*1c3cadbeSPaolo Abenichk_gro " - aggregation" 1 156*1c3cadbeSPaolo Abeni 157*1c3cadbeSPaolo Abeni 158*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST down 159*1c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC down 160*1c3cadbeSPaolo Abenichk_gro_flag " - after dev off, flag" $DST on 161*1c3cadbeSPaolo Abenichk_gro_flag " - peer flag" $SRC off 162*1c3cadbeSPaolo Abeni 163*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro on 164*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST xdp off 165*1c3cadbeSPaolo Abenichk_gro_flag " - after gro on xdp off, gro flag" $DST on 166*1c3cadbeSPaolo Abenichk_gro_flag " - peer gro flag" $SRC off 167*1c3cadbeSPaolo Abenichk_tso_flag " - tso flag" $SRC on 168*1c3cadbeSPaolo Abenichk_tso_flag " - peer tso flag" $DST on 169*1c3cadbeSPaolo Abeniip -n $NS_DST link set dev veth$DST up 170*1c3cadbeSPaolo Abeniip -n $NS_SRC link set dev veth$SRC up 171*1c3cadbeSPaolo Abenichk_gro " - aggregation" 1 172*1c3cadbeSPaolo Abeni 173*1c3cadbeSPaolo Abeniip netns exec $NS_DST ethtool -K veth$DST gro off 174*1c3cadbeSPaolo Abeniip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off 175*1c3cadbeSPaolo Abenichk_gro "aggregation again with default and TSO off" 10 176*1c3cadbeSPaolo Abeni 177*1c3cadbeSPaolo Abeniexit $ret 178