| #!/bin/bash |
| # SPDX-License-Identifier: GPL-2.0 |
| |
| # This test is for checking drop monitor functionality. |
| |
| ret=0 |
| # Kselftest framework requirement - SKIP code is 4. |
| ksft_skip=4 |
| |
| # all tests in this script. Can be overridden with -t option |
| TESTS=" |
| sw_drops |
| hw_drops |
| " |
| |
| IP="ip -netns ns1" |
| TC="tc -netns ns1" |
| DEVLINK="devlink -N ns1" |
| NS_EXEC="ip netns exec ns1" |
| NETDEVSIM_PATH=/sys/bus/netdevsim/ |
| DEV_ADDR=1337 |
| DEV=netdevsim${DEV_ADDR} |
| DEVLINK_DEV=netdevsim/${DEV} |
| |
| log_test() |
| { |
| local rc=$1 |
| local expected=$2 |
| local msg="$3" |
| |
| if [ ${rc} -eq ${expected} ]; then |
| printf " TEST: %-60s [ OK ]\n" "${msg}" |
| nsuccess=$((nsuccess+1)) |
| else |
| ret=1 |
| nfail=$((nfail+1)) |
| printf " TEST: %-60s [FAIL]\n" "${msg}" |
| fi |
| } |
| |
| setup() |
| { |
| modprobe netdevsim &> /dev/null |
| |
| set -e |
| ip netns add ns1 |
| $IP link add dummy10 up type dummy |
| |
| $NS_EXEC echo "$DEV_ADDR 1" > ${NETDEVSIM_PATH}/new_device |
| udevadm settle |
| local netdev=$($NS_EXEC ls ${NETDEVSIM_PATH}/devices/${DEV}/net/) |
| $IP link set dev $netdev up |
| |
| set +e |
| } |
| |
| cleanup() |
| { |
| $NS_EXEC echo "$DEV_ADDR" > ${NETDEVSIM_PATH}/del_device |
| ip netns del ns1 |
| } |
| |
| sw_drops_test() |
| { |
| echo |
| echo "Software drops test" |
| |
| setup |
| |
| local dir=$(mktemp -d) |
| |
| $TC qdisc add dev dummy10 clsact |
| $TC filter add dev dummy10 egress pref 1 handle 101 proto ip \ |
| flower dst_ip 192.0.2.10 action drop |
| |
| $NS_EXEC mausezahn dummy10 -a 00:11:22:33:44:55 -b 00:aa:bb:cc:dd:ee \ |
| -A 192.0.2.1 -B 192.0.2.10 -t udp sp=12345,dp=54321 -c 0 -q \ |
| -d 100msec & |
| timeout 5 dwdump -o sw -w ${dir}/packets.pcap |
| (( $(tshark -r ${dir}/packets.pcap \ |
| -Y 'ip.dst == 192.0.2.10' 2> /dev/null | wc -l) != 0)) |
| log_test $? 0 "Capturing active software drops" |
| |
| rm ${dir}/packets.pcap |
| |
| { kill %% && wait %%; } 2>/dev/null |
| timeout 5 dwdump -o sw -w ${dir}/packets.pcap |
| (( $(tshark -r ${dir}/packets.pcap \ |
| -Y 'ip.dst == 192.0.2.10' 2> /dev/null | wc -l) == 0)) |
| log_test $? 0 "Capturing inactive software drops" |
| |
| rm -r $dir |
| |
| cleanup |
| } |
| |
| hw_drops_test() |
| { |
| echo |
| echo "Hardware drops test" |
| |
| setup |
| |
| local dir=$(mktemp -d) |
| |
| $DEVLINK trap set $DEVLINK_DEV trap blackhole_route action trap |
| timeout 5 dwdump -o hw -w ${dir}/packets.pcap |
| (( $(tshark -r ${dir}/packets.pcap \ |
| -Y 'net_dm.hw_trap_name== blackhole_route' 2> /dev/null \ |
| | wc -l) != 0)) |
| log_test $? 0 "Capturing active hardware drops" |
| |
| rm ${dir}/packets.pcap |
| |
| $DEVLINK trap set $DEVLINK_DEV trap blackhole_route action drop |
| timeout 5 dwdump -o hw -w ${dir}/packets.pcap |
| (( $(tshark -r ${dir}/packets.pcap \ |
| -Y 'net_dm.hw_trap_name== blackhole_route' 2> /dev/null \ |
| | wc -l) == 0)) |
| log_test $? 0 "Capturing inactive hardware drops" |
| |
| rm -r $dir |
| |
| cleanup |
| } |
| |
| ################################################################################ |
| # usage |
| |
| usage() |
| { |
| cat <<EOF |
| usage: ${0##*/} OPTS |
| |
| -t <test> Test(s) to run (default: all) |
| (options: $TESTS) |
| EOF |
| } |
| |
| ################################################################################ |
| # main |
| |
| while getopts ":t:h" opt; do |
| case $opt in |
| t) TESTS=$OPTARG;; |
| h) usage; exit 0;; |
| *) usage; exit 1;; |
| esac |
| done |
| |
| if [ "$(id -u)" -ne 0 ];then |
| echo "SKIP: Need root privileges" |
| exit $ksft_skip; |
| fi |
| |
| if [ ! -x "$(command -v ip)" ]; then |
| echo "SKIP: Could not run test without ip tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v devlink)" ]; then |
| echo "SKIP: Could not run test without devlink tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v tshark)" ]; then |
| echo "SKIP: Could not run test without tshark tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v dwdump)" ]; then |
| echo "SKIP: Could not run test without dwdump tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v udevadm)" ]; then |
| echo "SKIP: Could not run test without udevadm tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v timeout)" ]; then |
| echo "SKIP: Could not run test without timeout tool" |
| exit $ksft_skip |
| fi |
| |
| if [ ! -x "$(command -v mausezahn)" ]; then |
| echo "SKIP: Could not run test without mausezahn tool" |
| exit $ksft_skip |
| fi |
| |
| tshark -G fields 2> /dev/null | grep -q net_dm |
| if [ $? -ne 0 ]; then |
| echo "SKIP: tshark too old, missing net_dm dissector" |
| exit $ksft_skip |
| fi |
| |
| # start clean |
| cleanup &> /dev/null |
| |
| for t in $TESTS |
| do |
| case $t in |
| sw_drops|sw) sw_drops_test;; |
| hw_drops|hw) hw_drops_test;; |
| |
| help) echo "Test names: $TESTS"; exit 0;; |
| esac |
| done |
| |
| if [ "$TESTS" != "none" ]; then |
| printf "\nTests passed: %3d\n" ${nsuccess} |
| printf "Tests failed: %3d\n" ${nfail} |
| fi |
| |
| exit $ret |