xref: /openbmc/linux/tools/testing/selftests/net/veth.sh (revision 1c3cadbe02420e6c85251c416a78a16f17761231)
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