166 lines
3.5 KiB
Bash
Executable File
166 lines
3.5 KiB
Bash
Executable File
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
source net_helper.sh
|
|
|
|
NSIM_SV_ID=$((256 + RANDOM % 256))
|
|
NSIM_SV_SYS=/sys/bus/netdevsim/devices/netdevsim$NSIM_SV_ID
|
|
NSIM_CL_ID=$((512 + RANDOM % 256))
|
|
NSIM_CL_SYS=/sys/bus/netdevsim/devices/netdevsim$NSIM_CL_ID
|
|
|
|
NSIM_DEV_SYS_NEW=/sys/bus/netdevsim/new_device
|
|
NSIM_DEV_SYS_DEL=/sys/bus/netdevsim/del_device
|
|
NSIM_DEV_SYS_LINK=/sys/bus/netdevsim/link_device
|
|
NSIM_DEV_SYS_UNLINK=/sys/bus/netdevsim/unlink_device
|
|
|
|
SERVER_IP=192.168.1.1
|
|
CLIENT_IP=192.168.1.2
|
|
SERVER_PORT=48675
|
|
|
|
# busy poll config
|
|
MAX_EVENTS=8
|
|
BUSY_POLL_USECS=0
|
|
BUSY_POLL_BUDGET=16
|
|
PREFER_BUSY_POLL=1
|
|
|
|
# IRQ deferral config
|
|
NAPI_DEFER_HARD_IRQS=100
|
|
GRO_FLUSH_TIMEOUT=50000
|
|
SUSPEND_TIMEOUT=20000000
|
|
|
|
setup_ns()
|
|
{
|
|
set -e
|
|
ip netns add nssv
|
|
ip netns add nscl
|
|
|
|
NSIM_SV_NAME=$(find $NSIM_SV_SYS/net -maxdepth 1 -type d ! \
|
|
-path $NSIM_SV_SYS/net -exec basename {} \;)
|
|
NSIM_CL_NAME=$(find $NSIM_CL_SYS/net -maxdepth 1 -type d ! \
|
|
-path $NSIM_CL_SYS/net -exec basename {} \;)
|
|
|
|
# ensure the server has 1 queue
|
|
ethtool -L $NSIM_SV_NAME combined 1 2>/dev/null
|
|
|
|
ip link set $NSIM_SV_NAME netns nssv
|
|
ip link set $NSIM_CL_NAME netns nscl
|
|
|
|
ip netns exec nssv ip addr add "${SERVER_IP}/24" dev $NSIM_SV_NAME
|
|
ip netns exec nscl ip addr add "${CLIENT_IP}/24" dev $NSIM_CL_NAME
|
|
|
|
ip netns exec nssv ip link set dev $NSIM_SV_NAME up
|
|
ip netns exec nscl ip link set dev $NSIM_CL_NAME up
|
|
|
|
set +e
|
|
}
|
|
|
|
cleanup_ns()
|
|
{
|
|
ip netns del nscl
|
|
ip netns del nssv
|
|
}
|
|
|
|
test_busypoll()
|
|
{
|
|
suspend_value=${1:-0}
|
|
tmp_file=$(mktemp)
|
|
out_file=$(mktemp)
|
|
|
|
# fill a test file with random data
|
|
dd if=/dev/urandom of=${tmp_file} bs=1M count=1 2> /dev/null
|
|
|
|
timeout -k 1s 30s ip netns exec nssv ./busy_poller \
|
|
-p${SERVER_PORT} \
|
|
-b${SERVER_IP} \
|
|
-m${MAX_EVENTS} \
|
|
-u${BUSY_POLL_USECS} \
|
|
-P${PREFER_BUSY_POLL} \
|
|
-g${BUSY_POLL_BUDGET} \
|
|
-i${NSIM_SV_IFIDX} \
|
|
-s${suspend_value} \
|
|
-o${out_file}&
|
|
|
|
wait_local_port_listen nssv ${SERVER_PORT} tcp
|
|
|
|
ip netns exec nscl socat -u $tmp_file TCP:${SERVER_IP}:${SERVER_PORT}
|
|
|
|
wait
|
|
|
|
tmp_file_md5sum=$(md5sum $tmp_file | cut -f1 -d' ')
|
|
out_file_md5sum=$(md5sum $out_file | cut -f1 -d' ')
|
|
|
|
if [ "$tmp_file_md5sum" = "$out_file_md5sum" ]; then
|
|
res=0
|
|
else
|
|
echo "md5sum mismatch"
|
|
echo "input file md5sum: ${tmp_file_md5sum}";
|
|
echo "output file md5sum: ${out_file_md5sum}";
|
|
res=1
|
|
fi
|
|
|
|
rm $out_file $tmp_file
|
|
|
|
return $res
|
|
}
|
|
|
|
test_busypoll_with_suspend()
|
|
{
|
|
test_busypoll ${SUSPEND_TIMEOUT}
|
|
|
|
return $?
|
|
}
|
|
|
|
###
|
|
### Code start
|
|
###
|
|
|
|
modprobe netdevsim
|
|
|
|
# linking
|
|
|
|
echo $NSIM_SV_ID > $NSIM_DEV_SYS_NEW
|
|
echo $NSIM_CL_ID > $NSIM_DEV_SYS_NEW
|
|
udevadm settle
|
|
|
|
setup_ns
|
|
|
|
NSIM_SV_FD=$((256 + RANDOM % 256))
|
|
exec {NSIM_SV_FD}</var/run/netns/nssv
|
|
NSIM_SV_IFIDX=$(ip netns exec nssv cat /sys/class/net/$NSIM_SV_NAME/ifindex)
|
|
|
|
NSIM_CL_FD=$((256 + RANDOM % 256))
|
|
exec {NSIM_CL_FD}</var/run/netns/nscl
|
|
NSIM_CL_IFIDX=$(ip netns exec nscl cat /sys/class/net/$NSIM_CL_NAME/ifindex)
|
|
|
|
echo "$NSIM_SV_FD:$NSIM_SV_IFIDX $NSIM_CL_FD:$NSIM_CL_IFIDX" > \
|
|
$NSIM_DEV_SYS_LINK
|
|
|
|
if [ $? -ne 0 ]; then
|
|
echo "linking netdevsim1 with netdevsim2 should succeed"
|
|
cleanup_ns
|
|
exit 1
|
|
fi
|
|
|
|
test_busypoll
|
|
if [ $? -ne 0 ]; then
|
|
echo "test_busypoll failed"
|
|
cleanup_ns
|
|
exit 1
|
|
fi
|
|
|
|
test_busypoll_with_suspend
|
|
if [ $? -ne 0 ]; then
|
|
echo "test_busypoll_with_suspend failed"
|
|
cleanup_ns
|
|
exit 1
|
|
fi
|
|
|
|
echo "$NSIM_SV_FD:$NSIM_SV_IFIDX" > $NSIM_DEV_SYS_UNLINK
|
|
|
|
echo $NSIM_CL_ID > $NSIM_DEV_SYS_DEL
|
|
|
|
cleanup_ns
|
|
|
|
modprobe -r netdevsim
|
|
|
|
exit 0
|