#!/bin/bash # SPDX-License-Identifier: GPL-2.0 source lib.sh IP4=172.16.0.1/24 TGT4=172.16.0.2 IP6=2001:db8:1::1/64 TGT6=2001:db8:1::2 cleanup() { cleanup_ns $NS } trap cleanup EXIT # Namespaces setup_ns NS ip netns exec $NS sysctl -w net.ipv4.ping_group_range='0 2147483647' > /dev/null # Connectivity ip -netns $NS link add type dummy ip -netns $NS link set dev dummy0 up ip -netns $NS addr add $IP4 dev dummy0 ip -netns $NS addr add $IP6 dev dummy0 # Need FQ for TXTIME ip netns exec $NS tc qdisc replace dev dummy0 root fq # Test BAD=0 TOTAL=0 check_result() { ((TOTAL++)) if [ $1 -ne 0 ]; then echo " Case $4 returned $1, expected 0" ((BAD++)) elif [ "$2" != "$3" ]; then echo " Case $4 returned '$2', expected '$3'" ((BAD++)) fi } for i in "-4 $TGT4" "-6 $TGT6"; do for p in u i r; do [ $p == "u" ] && prot=UDPv${i:1:2} [ $p == "i" ] && prot=ICMPv${i:1:2} [ $p == "r" ] && prot=RAWv${i:1:2} ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234) check_result $? "$ts" "" "$prot - no options" ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t | wc -l) check_result $? "$ts" "2" "$prot - ts cnt" ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t | sed -n "s/.*SCHED ts0 [0-9].*/OK/p") check_result $? "$ts" "OK" "$prot - ts0 SCHED" ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t | sed -n "s/.*SND ts0 [0-9].*/OK/p") check_result $? "$ts" "OK" "$prot - ts0 SND" ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d 1000 | awk '/SND/ { if ($3 > 1000) print "OK"; }') check_result $? "$ts" "OK" "$prot - TXTIME abs" [ "$KSFT_MACHINE_SLOW" = yes ] && delay=8000 || delay=1000 ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d $delay | awk '/SND/ {snd=$3} /SCHED/ {sch=$3} END { if (snd - sch > '$((delay/2))') print "OK"; else print snd, "-", sch, "<", '$((delay/2))'; }') check_result $? "$ts" "OK" "$prot - TXTIME rel" done done # Summary if [ $BAD -ne 0 ]; then echo "FAIL - $BAD/$TOTAL cases failed" exit 1 else echo "OK" exit 0 fi