Skip to content

Commit

Permalink
netns: test 4 parallel streams
Browse files Browse the repository at this point in the history
In order to test ndo_start_xmit being called in parallel, explicitly add
4 separate tests, which should all run on different cores. This should
help tease out bugs associated with queueing up packets from different
cores in parallel. Currently, it hasn't found those types of bugs, but
given future planned work, this is a useful regression to avoid.

Signed-off-by: Jason A. Donenfeld <[email protected]>
  • Loading branch information
zx2c4 committed Feb 8, 2021
1 parent 8420c79 commit aaad5ba
Showing 1 changed file with 17 additions and 1 deletion.
18 changes: 17 additions & 1 deletion src/tests/netns.sh
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ ip0() { pretty 0 "ip $*"; ip -n $netns0 "$@"; }
ip1() { pretty 1 "ip $*"; ip -n $netns1 "$@"; }
ip2() { pretty 2 "ip $*"; ip -n $netns2 "$@"; }
sleep() { read -t "$1" -N 1 || true; }
waitiperf() { pretty "${1//*-}" "wait for iperf:5201 pid $2"; while [[ $(ss -N "$1" -tlpH 'sport = 5201') != *\"iperf3\",pid=$2,fd=* ]]; do sleep 0.1; done; }
waitiperf() { pretty "${1//*-}" "wait for iperf:${3:-5201} pid $2"; while [[ $(ss -N "$1" -tlpH "sport = ${3:-5201}") != *\"iperf3\",pid=$2,fd=* ]]; do sleep 0.1; done; }
waitncatudp() { pretty "${1//*-}" "wait for udp:1111 pid $2"; while [[ $(ss -N "$1" -ulpH 'sport = 1111') != *\"ncat\",pid=$2,fd=* ]]; do sleep 0.1; done; }
waitiface() { pretty "${1//*-}" "wait for $2 to come up"; ip netns exec "$1" bash -c "while [[ \$(< \"/sys/class/net/$2/operstate\") != up ]]; do read -t .1 -N 0 || true; done;"; }

Expand Down Expand Up @@ -142,6 +142,22 @@ tests() {
n2 iperf3 -s -1 -B fd00::2 &
waitiperf $netns2 $!
n1 iperf3 -Z -t 3 -b 0 -u -c fd00::2

# TCP over IPv4 x 4
local pids=( )
n2 iperf3 -p 5201 -s -1 -B 192.168.241.2 &
pids+=( $! ); waitiperf $netns2 $! 5201
n2 iperf3 -p 5202 -s -1 -B 192.168.241.2 &
pids+=( $! ); waitiperf $netns2 $! 5202
n2 iperf3 -p 5203 -s -1 -B 192.168.241.2 &
pids+=( $! ); waitiperf $netns2 $! 5203
n2 iperf3 -p 5204 -s -1 -B 192.168.241.2 &
pids+=( $! ); waitiperf $netns2 $! 5204
n1 iperf3 -Z -t 5 -p 5201 -c 192.168.241.2 &
n1 iperf3 -Z -t 5 -p 5202 -c 192.168.241.2 &
n1 iperf3 -Z -t 5 -p 5203 -c 192.168.241.2 &
n1 iperf3 -Z -t 5 -p 5204 -c 192.168.241.2 &
wait "${pids[@]}"
}

[[ $(ip1 link show dev wg0) =~ mtu\ ([0-9]+) ]] && orig_mtu="${BASH_REMATCH[1]}"
Expand Down

0 comments on commit aaad5ba

Please sign in to comment.