cmsg_time.sh 2.2 KB

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