io_uring_zerocopy_tx.sh 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. #!/bin/bash
  2. #
  3. # Send data between two processes across namespaces
  4. # Run twice: once without and once with zerocopy
  5. set -e
  6. readonly DEV="veth0"
  7. readonly DEV_MTU=65535
  8. readonly BIN_TX="./io_uring_zerocopy_tx"
  9. readonly BIN_RX="./msg_zerocopy"
  10. readonly RAND="$(mktemp -u XXXXXX)"
  11. readonly NSPREFIX="ns-${RAND}"
  12. readonly NS1="${NSPREFIX}1"
  13. readonly NS2="${NSPREFIX}2"
  14. readonly SADDR4='192.168.1.1'
  15. readonly DADDR4='192.168.1.2'
  16. readonly SADDR6='fd::1'
  17. readonly DADDR6='fd::2'
  18. readonly path_sysctl_mem="net.core.optmem_max"
  19. # No arguments: automated test
  20. if [[ "$#" -eq "0" ]]; then
  21. IPs=( "4" "6" )
  22. for IP in "${IPs[@]}"; do
  23. for mode in $(seq 1 3); do
  24. $0 "$IP" udp -m "$mode" -t 1 -n 32
  25. $0 "$IP" tcp -m "$mode" -t 1 -n 1
  26. done
  27. done
  28. echo "OK. All tests passed"
  29. exit 0
  30. fi
  31. # Argument parsing
  32. if [[ "$#" -lt "2" ]]; then
  33. echo "Usage: $0 [4|6] [tcp|udp|raw|raw_hdrincl|packet|packet_dgram] <args>"
  34. exit 1
  35. fi
  36. readonly IP="$1"
  37. shift
  38. readonly TXMODE="$1"
  39. shift
  40. readonly EXTRA_ARGS="$@"
  41. # Argument parsing: configure addresses
  42. if [[ "${IP}" == "4" ]]; then
  43. readonly SADDR="${SADDR4}"
  44. readonly DADDR="${DADDR4}"
  45. elif [[ "${IP}" == "6" ]]; then
  46. readonly SADDR="${SADDR6}"
  47. readonly DADDR="${DADDR6}"
  48. else
  49. echo "Invalid IP version ${IP}"
  50. exit 1
  51. fi
  52. # Argument parsing: select receive mode
  53. #
  54. # This differs from send mode for
  55. # - packet: use raw recv, because packet receives skb clones
  56. # - raw_hdrinc: use raw recv, because hdrincl is a tx-only option
  57. case "${TXMODE}" in
  58. 'packet' | 'packet_dgram' | 'raw_hdrincl')
  59. RXMODE='raw'
  60. ;;
  61. *)
  62. RXMODE="${TXMODE}"
  63. ;;
  64. esac
  65. # Start of state changes: install cleanup handler
  66. cleanup() {
  67. ip netns del "${NS2}"
  68. ip netns del "${NS1}"
  69. }
  70. trap cleanup EXIT
  71. # Create virtual ethernet pair between network namespaces
  72. ip netns add "${NS1}"
  73. ip netns add "${NS2}"
  74. # Configure system settings
  75. ip netns exec "${NS1}" sysctl -w -q "${path_sysctl_mem}=1000000"
  76. ip netns exec "${NS2}" sysctl -w -q "${path_sysctl_mem}=1000000"
  77. ip link add "${DEV}" mtu "${DEV_MTU}" netns "${NS1}" type veth \
  78. peer name "${DEV}" mtu "${DEV_MTU}" netns "${NS2}"
  79. # Bring the devices up
  80. ip -netns "${NS1}" link set "${DEV}" up
  81. ip -netns "${NS2}" link set "${DEV}" up
  82. # Set fixed MAC addresses on the devices
  83. ip -netns "${NS1}" link set dev "${DEV}" address 02:02:02:02:02:02
  84. ip -netns "${NS2}" link set dev "${DEV}" address 06:06:06:06:06:06
  85. # Add fixed IP addresses to the devices
  86. ip -netns "${NS1}" addr add 192.168.1.1/24 dev "${DEV}"
  87. ip -netns "${NS2}" addr add 192.168.1.2/24 dev "${DEV}"
  88. ip -netns "${NS1}" addr add fd::1/64 dev "${DEV}" nodad
  89. ip -netns "${NS2}" addr add fd::2/64 dev "${DEV}" nodad
  90. # Optionally disable sg or csum offload to test edge cases
  91. # ip netns exec "${NS1}" ethtool -K "${DEV}" sg off
  92. do_test() {
  93. local readonly ARGS="$1"
  94. echo "ipv${IP} ${TXMODE} ${ARGS}"
  95. ip netns exec "${NS2}" "${BIN_RX}" "-${IP}" -t 2 -C 2 -S "${SADDR}" -D "${DADDR}" -r "${RXMODE}" &
  96. sleep 0.2
  97. ip netns exec "${NS1}" "${BIN_TX}" "-${IP}" -t 1 -D "${DADDR}" ${ARGS} "${TXMODE}"
  98. wait
  99. }
  100. do_test "${EXTRA_ARGS}"
  101. echo ok