cmsg_time.sh 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. NS=ns
  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. ip netns del $NS
  11. }
  12. trap cleanup EXIT
  13. # Namespaces
  14. ip netns add $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. ((TOTAL++))
  28. if [ $1 -ne 0 ]; then
  29. echo " Case $4 returned $1, expected 0"
  30. ((BAD++))
  31. elif [ "$2" != "$3" ]; then
  32. echo " Case $4 returned '$2', expected '$3'"
  33. ((BAD++))
  34. fi
  35. }
  36. for i in "-4 $TGT4" "-6 $TGT6"; do
  37. for p in u i r; do
  38. [ $p == "u" ] && prot=UDPv${i:1:2}
  39. [ $p == "i" ] && prot=ICMPv${i:1:2}
  40. [ $p == "r" ] && prot=RAWv${i:1:2}
  41. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234)
  42. check_result $? "$ts" "" "$prot - no options"
  43. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t | wc -l)
  44. check_result $? "$ts" "2" "$prot - ts cnt"
  45. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t |
  46. sed -n "s/.*SCHED ts0 [0-9].*/OK/p")
  47. check_result $? "$ts" "OK" "$prot - ts0 SCHED"
  48. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t |
  49. sed -n "s/.*SND ts0 [0-9].*/OK/p")
  50. check_result $? "$ts" "OK" "$prot - ts0 SND"
  51. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d 1000 |
  52. awk '/SND/ { if ($3 > 1000) print "OK"; }')
  53. check_result $? "$ts" "OK" "$prot - TXTIME abs"
  54. ts=$(ip netns exec $NS ./cmsg_sender -p $p $i 1234 -t -d 1000 |
  55. awk '/SND/ {snd=$3}
  56. /SCHED/ {sch=$3}
  57. END { if (snd - sch > 500) print "OK"; }')
  58. check_result $? "$ts" "OK" "$prot - TXTIME rel"
  59. done
  60. done
  61. # Summary
  62. if [ $BAD -ne 0 ]; then
  63. echo "FAIL - $BAD/$TOTAL cases failed"
  64. exit 1
  65. else
  66. echo "OK"
  67. exit 0
  68. fi