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