]> Git Repo - linux.git/blob - tools/testing/selftests/net/cmsg_time.sh
Linux 6.14-rc3
[linux.git] / tools / testing / selftests / net / cmsg_time.sh
1 #!/bin/bash
2 # SPDX-License-Identifier: GPL-2.0
3
4 source lib.sh
5
6 IP4=172.16.0.1/24
7 TGT4=172.16.0.2
8 IP6=2001:db8:1::1/64
9 TGT6=2001:db8:1::2
10
11 cleanup()
12 {
13     cleanup_ns $NS
14 }
15
16 trap cleanup EXIT
17
18 # Namespaces
19 setup_ns NS
20
21 ip netns exec $NS sysctl -w net.ipv4.ping_group_range='0 2147483647' > /dev/null
22
23 # Connectivity
24 ip -netns $NS link add type dummy
25 ip -netns $NS link set dev dummy0 up
26 ip -netns $NS addr add $IP4 dev dummy0
27 ip -netns $NS addr add $IP6 dev dummy0
28
29 # Need FQ for TXTIME
30 ip netns exec $NS tc qdisc replace dev dummy0 root fq
31
32 # Test
33 BAD=0
34 TOTAL=0
35
36 check_result() {
37     local ret=$1
38     local got=$2
39     local exp=$3
40     local case=$4
41     local xfail=$5
42     local xf=
43     local inc=
44
45     if [ "$xfail" == "xfail" ]; then
46         xf="(XFAIL)"
47         inc=0
48     else
49         inc=1
50     fi
51
52     ((TOTAL++))
53     if [ $ret -ne 0 ]; then
54         echo "  Case $case returned $ret, expected 0 $xf"
55         ((BAD+=inc))
56     elif [ "$2" != "$3" ]; then
57         echo "  Case $case returned '$got', expected '$exp' $xf"
58         ((BAD+=inc))
59     fi
60 }
61
62 for i in "-4 $TGT4" "-6 $TGT6"; do
63     for p in u i r; do
64         [ $p == "u" ] && prot=UDPv${i:1:2}
65         [ $p == "i" ] && prot=ICMPv${i:1:2}
66         [ $p == "r" ] && prot=RAWv${i:1:2}
67
68         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234)
69         check_result $? "$ts" "" "$prot - no options"
70
71         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t | wc -l)
72         check_result $? "$ts" "2" "$prot - ts cnt"
73         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t |
74                  sed -n "s/.*SCHED ts0 [0-9].*/OK/p")
75         check_result $? "$ts" "OK" "$prot - ts0 SCHED"
76         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t |
77                  sed -n "s/.*SND ts0 [0-9].*/OK/p")
78         check_result $? "$ts" "OK" "$prot - ts0 SND"
79
80         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d 1000 |
81                  awk '/SND/ { if ($3 > 1000) print "OK"; }')
82         check_result $? "$ts" "OK" "$prot - TXTIME abs"
83
84         [ "$KSFT_MACHINE_SLOW" = yes ] && xfail=xfail
85
86         ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d 1000 |
87                  awk '/SND/ {snd=$3}
88                       /SCHED/ {sch=$3}
89                       END { if (snd - sch > 500) print "OK";
90                             else print snd, "-", sch, "<", 500; }')
91         check_result $? "$ts" "OK" "$prot - TXTIME rel" $xfail
92     done
93 done
94
95 # Summary
96 if [ $BAD -ne 0 ]; then
97     echo "FAIL - $BAD/$TOTAL cases failed"
98     exit 1
99 else
100     echo "OK"
101     exit 0
102 fi
This page took 0.035377 seconds and 4 git commands to generate.