veth.sh 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390
  1. #!/bin/sh
  2. # SPDX-License-Identifier: GPL-2.0
  3. BPF_FILE="lib/xdp_dummy.bpf.o"
  4. readonly STATS="$(mktemp -p /tmp ns-XXXXXX)"
  5. readonly BASE=`basename $STATS`
  6. readonly SRC=2
  7. readonly DST=1
  8. readonly DST_NAT=100
  9. readonly NS_SRC=$BASE$SRC
  10. readonly NS_DST=$BASE$DST
  11. # "baremetal" network used for raw UDP traffic
  12. readonly BM_NET_V4=192.168.1.
  13. readonly BM_NET_V6=2001:db8::
  14. readonly CPUS=`nproc`
  15. ret=0
  16. cleanup() {
  17. local ns
  18. local jobs
  19. readonly jobs="$(jobs -p)"
  20. [ -n "${jobs}" ] && kill -1 ${jobs} 2>/dev/null
  21. rm -f $STATS
  22. for ns in $NS_SRC $NS_DST; do
  23. ip netns del $ns 2>/dev/null
  24. done
  25. }
  26. trap cleanup EXIT
  27. create_ns() {
  28. local ns
  29. for ns in $NS_SRC $NS_DST; do
  30. ip netns add $ns
  31. ip -n $ns link set dev lo up
  32. done
  33. ip link add name veth$SRC type veth peer name veth$DST
  34. for ns in $SRC $DST; do
  35. ip link set dev veth$ns netns $BASE$ns up
  36. ip -n $BASE$ns addr add dev veth$ns $BM_NET_V4$ns/24
  37. ip -n $BASE$ns addr add dev veth$ns $BM_NET_V6$ns/64 nodad
  38. done
  39. }
  40. __chk_flag() {
  41. local msg="$1"
  42. local target=$2
  43. local expected=$3
  44. local flagname=$4
  45. local flag=`ip netns exec $BASE$target ethtool -k veth$target |\
  46. grep $flagname | awk '{print $2}'`
  47. printf "%-60s" "$msg"
  48. if [ "$flag" = "$expected" ]; then
  49. echo " ok "
  50. else
  51. echo " fail - expected $expected found $flag"
  52. ret=1
  53. fi
  54. }
  55. chk_gro_flag() {
  56. __chk_flag "$1" $2 $3 generic-receive-offload
  57. }
  58. chk_tso_flag() {
  59. __chk_flag "$1" $2 $3 tcp-segmentation-offload
  60. }
  61. chk_channels() {
  62. local msg="$1"
  63. local target=$2
  64. local rx=$3
  65. local tx=$4
  66. local dev=veth$target
  67. local cur_rx=`ip netns exec $BASE$target ethtool -l $dev |\
  68. grep RX: | tail -n 1 | awk '{print $2}' `
  69. local cur_tx=`ip netns exec $BASE$target ethtool -l $dev |\
  70. grep TX: | tail -n 1 | awk '{print $2}'`
  71. local cur_combined=`ip netns exec $BASE$target ethtool -l $dev |\
  72. grep Combined: | tail -n 1 | awk '{print $2}'`
  73. printf "%-60s" "$msg"
  74. if [ "$cur_rx" = "$rx" -a "$cur_tx" = "$tx" -a "$cur_combined" = "n/a" ]; then
  75. echo " ok "
  76. else
  77. echo " fail rx:$rx:$cur_rx tx:$tx:$cur_tx combined:n/a:$cur_combined"
  78. fi
  79. }
  80. chk_gro() {
  81. local msg="$1"
  82. local expected=$2
  83. ip netns exec $BASE$SRC ping -qc 1 $BM_NET_V4$DST >/dev/null
  84. NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat -n
  85. printf "%-60s" "$msg"
  86. ip netns exec $BASE$DST ./udpgso_bench_rx -C 1000 -R 10 &
  87. local spid=$!
  88. sleep 0.1
  89. ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 13000 -S 1300 -M 1 -D $BM_NET_V4$DST
  90. local retc=$?
  91. wait $spid
  92. local rets=$?
  93. if [ ${rets} -ne 0 ] || [ ${retc} -ne 0 ]; then
  94. echo " fail client exit code $retc, server $rets"
  95. ret=1
  96. return
  97. fi
  98. local pkts=`NSTAT_HISTORY=$STATS ip netns exec $NS_DST nstat IpInReceives | \
  99. awk '{print $2}' | tail -n 1`
  100. if [ "$pkts" = "$expected" ]; then
  101. echo " ok "
  102. else
  103. echo " fail - got $pkts packets, expected $expected "
  104. ret=1
  105. fi
  106. }
  107. __change_channels()
  108. {
  109. local cur_cpu
  110. local end=$1
  111. local cur
  112. local i
  113. while true; do
  114. printf -v cur '%(%s)T'
  115. [ $cur -le $end ] || break
  116. for i in `seq 1 $CPUS`; do
  117. ip netns exec $NS_SRC ethtool -L veth$SRC rx $i tx $i
  118. ip netns exec $NS_DST ethtool -L veth$DST rx $i tx $i
  119. done
  120. for i in `seq 1 $((CPUS - 1))`; do
  121. cur_cpu=$((CPUS - $i))
  122. ip netns exec $NS_SRC ethtool -L veth$SRC rx $cur_cpu tx $cur_cpu
  123. ip netns exec $NS_DST ethtool -L veth$DST rx $cur_cpu tx $cur_cpu
  124. done
  125. done
  126. }
  127. __send_data() {
  128. local end=$1
  129. while true; do
  130. printf -v cur '%(%s)T'
  131. [ $cur -le $end ] || break
  132. ip netns exec $NS_SRC ./udpgso_bench_tx -4 -s 1000 -M 300 -D $BM_NET_V4$DST
  133. done
  134. }
  135. do_stress() {
  136. local end
  137. printf -v end '%(%s)T'
  138. end=$((end + $STRESS))
  139. ip netns exec $NS_SRC ethtool -L veth$SRC rx 3 tx 3
  140. ip netns exec $NS_DST ethtool -L veth$DST rx 3 tx 3
  141. ip netns exec $NS_DST ./udpgso_bench_rx &
  142. local rx_pid=$!
  143. echo "Running stress test for $STRESS seconds..."
  144. __change_channels $end &
  145. local ch_pid=$!
  146. __send_data $end &
  147. local data_pid_1=$!
  148. __send_data $end &
  149. local data_pid_2=$!
  150. __send_data $end &
  151. local data_pid_3=$!
  152. __send_data $end &
  153. local data_pid_4=$!
  154. wait $ch_pid $data_pid_1 $data_pid_2 $data_pid_3 $data_pid_4
  155. kill -9 $rx_pid
  156. echo "done"
  157. # restore previous setting
  158. ip netns exec $NS_SRC ethtool -L veth$SRC rx 2 tx 2
  159. ip netns exec $NS_DST ethtool -L veth$DST rx 2 tx 1
  160. }
  161. usage() {
  162. echo "Usage: $0 [-h] [-s <seconds>]"
  163. echo -e "\t-h: show this help"
  164. echo -e "\t-s: run optional stress tests for the given amount of seconds"
  165. }
  166. STRESS=0
  167. while getopts "hs:" option; do
  168. case "$option" in
  169. "h")
  170. usage $0
  171. exit 0
  172. ;;
  173. "s")
  174. STRESS=$OPTARG
  175. ;;
  176. esac
  177. done
  178. if [ ! -f ${BPF_FILE} ]; then
  179. echo "Missing ${BPF_FILE}. Run 'make' first"
  180. exit 1
  181. fi
  182. [ $CPUS -lt 2 ] && echo "Only one CPU available, some tests will be skipped"
  183. [ $STRESS -gt 0 -a $CPUS -lt 3 ] && echo " stress test will be skipped, too"
  184. create_ns
  185. chk_gro_flag "default - gro flag" $SRC off
  186. chk_gro_flag " - peer gro flag" $DST off
  187. chk_tso_flag " - tso flag" $SRC on
  188. chk_tso_flag " - peer tso flag" $DST on
  189. chk_gro " - aggregation" 1
  190. ip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
  191. chk_gro " - aggregation with TSO off" 10
  192. cleanup
  193. create_ns
  194. ip netns exec $NS_DST ethtool -K veth$DST gro on
  195. chk_gro_flag "with gro on - gro flag" $DST on
  196. chk_gro_flag " - peer gro flag" $SRC off
  197. chk_tso_flag " - tso flag" $SRC on
  198. chk_tso_flag " - peer tso flag" $DST on
  199. ip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
  200. ip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
  201. chk_gro " - aggregation with TSO off" 1
  202. cleanup
  203. create_ns
  204. ip -n $NS_DST link set dev veth$DST up
  205. ip -n $NS_DST link set dev veth$DST xdp object ${BPF_FILE} section xdp
  206. chk_gro_flag "gro vs xdp while down - gro flag off" $DST off
  207. ip -n $NS_DST link set dev veth$DST down
  208. chk_gro_flag " - after down" $DST off
  209. ip -n $NS_DST link set dev veth$DST xdp off
  210. chk_gro_flag " - after xdp off" $DST off
  211. ip -n $NS_DST link set dev veth$DST up
  212. chk_gro_flag " - after up" $DST off
  213. ip -n $NS_SRC link set dev veth$SRC xdp object ${BPF_FILE} section xdp
  214. chk_gro_flag " - after peer xdp" $DST off
  215. cleanup
  216. create_ns
  217. ip -n $NS_DST link set dev veth$DST up
  218. ip -n $NS_DST link set dev veth$DST xdp object ${BPF_FILE} section xdp
  219. ip netns exec $NS_DST ethtool -K veth$DST generic-receive-offload on
  220. chk_gro_flag "gro vs xdp while down - gro flag on" $DST on
  221. ip -n $NS_DST link set dev veth$DST down
  222. chk_gro_flag " - after down" $DST on
  223. ip -n $NS_DST link set dev veth$DST xdp off
  224. chk_gro_flag " - after xdp off" $DST on
  225. ip -n $NS_DST link set dev veth$DST up
  226. chk_gro_flag " - after up" $DST on
  227. ip -n $NS_SRC link set dev veth$SRC xdp object ${BPF_FILE} section xdp
  228. chk_gro_flag " - after peer xdp" $DST on
  229. cleanup
  230. create_ns
  231. chk_channels "default channels" $DST 1 1
  232. ip -n $NS_DST link set dev veth$DST down
  233. ip netns exec $NS_DST ethtool -K veth$DST gro on
  234. chk_gro_flag "with gro enabled on link down - gro flag" $DST on
  235. chk_gro_flag " - peer gro flag" $SRC off
  236. chk_tso_flag " - tso flag" $SRC on
  237. chk_tso_flag " - peer tso flag" $DST on
  238. ip -n $NS_DST link set dev veth$DST up
  239. ip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
  240. ip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
  241. chk_gro " - aggregation with TSO off" 1
  242. cleanup
  243. create_ns
  244. CUR_TX=1
  245. CUR_RX=1
  246. if [ $CPUS -gt 1 ]; then
  247. ip netns exec $NS_DST ethtool -L veth$DST tx 2
  248. chk_channels "setting tx channels" $DST 1 2
  249. CUR_TX=2
  250. fi
  251. if [ $CPUS -gt 2 ]; then
  252. ip netns exec $NS_DST ethtool -L veth$DST rx 3 tx 3
  253. chk_channels "setting both rx and tx channels" $DST 3 3
  254. CUR_RX=3
  255. CUR_TX=3
  256. fi
  257. ip netns exec $NS_DST ethtool -L veth$DST combined 2 2>/dev/null
  258. chk_channels "bad setting: combined channels" $DST $CUR_RX $CUR_TX
  259. ip netns exec $NS_DST ethtool -L veth$DST tx $((CPUS + 1)) 2>/dev/null
  260. chk_channels "setting invalid channels nr" $DST $CUR_RX $CUR_TX
  261. if [ $CPUS -gt 1 ]; then
  262. # this also tests queues nr reduction
  263. ip netns exec $NS_DST ethtool -L veth$DST rx 1 tx 2 2>/dev/null
  264. ip netns exec $NS_SRC ethtool -L veth$SRC rx 1 tx 2 2>/dev/null
  265. printf "%-60s" "bad setting: XDP with RX nr less than TX"
  266. ip -n $NS_DST link set dev veth$DST xdp object ${BPF_FILE} \
  267. section xdp 2>/dev/null &&\
  268. echo "fail - set operation successful ?!?" || echo " ok "
  269. # the following tests will run with multiple channels active
  270. ip netns exec $NS_SRC ethtool -L veth$SRC rx 2
  271. ip netns exec $NS_DST ethtool -L veth$DST rx 2
  272. ip -n $NS_DST link set dev veth$DST xdp object ${BPF_FILE} \
  273. section xdp 2>/dev/null
  274. printf "%-60s" "bad setting: reducing RX nr below peer TX with XDP set"
  275. ip netns exec $NS_DST ethtool -L veth$DST rx 1 2>/dev/null &&\
  276. echo "fail - set operation successful ?!?" || echo " ok "
  277. CUR_RX=2
  278. CUR_TX=2
  279. fi
  280. if [ $CPUS -gt 2 ]; then
  281. printf "%-60s" "bad setting: increasing peer TX nr above RX with XDP set"
  282. ip netns exec $NS_SRC ethtool -L veth$SRC tx 3 2>/dev/null &&\
  283. echo "fail - set operation successful ?!?" || echo " ok "
  284. chk_channels "setting invalid channels nr" $DST 2 2
  285. fi
  286. ip -n $NS_DST link set dev veth$DST xdp object ${BPF_FILE} section xdp 2>/dev/null
  287. chk_gro_flag "with xdp attached - gro flag" $DST off
  288. chk_gro_flag " - peer gro flag" $SRC off
  289. chk_tso_flag " - tso flag" $SRC off
  290. chk_tso_flag " - peer tso flag" $DST on
  291. ip netns exec $NS_DST ethtool -K veth$DST rx-udp-gro-forwarding on
  292. chk_gro " - no aggregation" 10
  293. ip netns exec $NS_DST ethtool -K veth$DST generic-receive-offload on
  294. chk_gro_flag " - gro flag with GRO on" $DST on
  295. chk_gro " - aggregation" 1
  296. ip -n $NS_DST link set dev veth$DST down
  297. ip -n $NS_SRC link set dev veth$SRC down
  298. chk_gro_flag " - after dev off, flag" $DST on
  299. chk_gro_flag " - peer flag" $SRC off
  300. ip netns exec $NS_DST ethtool -K veth$DST gro on
  301. ip -n $NS_DST link set dev veth$DST xdp off
  302. chk_gro_flag " - after gro on xdp off, gro flag" $DST on
  303. chk_gro_flag " - peer gro flag" $SRC off
  304. chk_tso_flag " - tso flag" $SRC on
  305. chk_tso_flag " - peer tso flag" $DST on
  306. if [ $CPUS -gt 1 ]; then
  307. ip netns exec $NS_DST ethtool -L veth$DST tx 1
  308. chk_channels "decreasing tx channels with device down" $DST 2 1
  309. fi
  310. ip -n $NS_DST link set dev veth$DST up
  311. ip -n $NS_SRC link set dev veth$SRC up
  312. chk_gro " - aggregation" 1
  313. if [ $CPUS -gt 1 ]; then
  314. [ $STRESS -gt 0 -a $CPUS -gt 2 ] && do_stress
  315. ip -n $NS_DST link set dev veth$DST down
  316. ip -n $NS_SRC link set dev veth$SRC down
  317. ip netns exec $NS_DST ethtool -L veth$DST tx 2
  318. chk_channels "increasing tx channels with device down" $DST 2 2
  319. ip -n $NS_DST link set dev veth$DST up
  320. ip -n $NS_SRC link set dev veth$SRC up
  321. fi
  322. ip netns exec $NS_DST ethtool -K veth$DST gro off
  323. ip netns exec $NS_SRC ethtool -K veth$SRC tx-udp-segmentation off
  324. chk_gro "aggregation again with default and TSO off" 10
  325. exit $ret