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