118 lines
2.8 KiB
Bash
Executable File
118 lines
2.8 KiB
Bash
Executable File
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
source ethtool-common.sh
|
|
|
|
NSIM_NETDEV=$(make_netdev)
|
|
MACSEC_NETDEV=macsec_nsim
|
|
|
|
set -o pipefail
|
|
|
|
if ! ethtool -k $NSIM_NETDEV | grep -q 'macsec-hw-offload: on'; then
|
|
echo "SKIP: netdevsim doesn't support MACsec offload"
|
|
exit 4
|
|
fi
|
|
|
|
if ! ip link add link $NSIM_NETDEV $MACSEC_NETDEV type macsec offload mac 2>/dev/null; then
|
|
echo "SKIP: couldn't create macsec device"
|
|
exit 4
|
|
fi
|
|
ip link del $MACSEC_NETDEV
|
|
|
|
#
|
|
# test macsec offload API
|
|
#
|
|
|
|
ip link add link $NSIM_NETDEV "${MACSEC_NETDEV}" type macsec port 4 offload mac
|
|
check $?
|
|
|
|
ip link add link $NSIM_NETDEV "${MACSEC_NETDEV}2" type macsec address "aa:bb:cc:dd:ee:ff" port 5 offload mac
|
|
check $?
|
|
|
|
ip link add link $NSIM_NETDEV "${MACSEC_NETDEV}3" type macsec sci abbacdde01020304 offload mac
|
|
check $?
|
|
|
|
ip link add link $NSIM_NETDEV "${MACSEC_NETDEV}4" type macsec port 8 offload mac 2> /dev/null
|
|
check $? '' '' 1
|
|
|
|
ip macsec add "${MACSEC_NETDEV}" tx sa 0 pn 1024 on key 01 12345678901234567890123456789012
|
|
check $?
|
|
|
|
ip macsec add "${MACSEC_NETDEV}" rx port 1234 address "1c:ed:de:ad:be:ef"
|
|
check $?
|
|
|
|
ip macsec add "${MACSEC_NETDEV}" rx port 1234 address "1c:ed:de:ad:be:ef" sa 0 pn 1 on \
|
|
key 00 0123456789abcdef0123456789abcdef
|
|
check $?
|
|
|
|
ip macsec add "${MACSEC_NETDEV}" rx port 1235 address "1c:ed:de:ad:be:ef" 2> /dev/null
|
|
check $? '' '' 1
|
|
|
|
# can't disable macsec offload when SAs are configured
|
|
ip link set "${MACSEC_NETDEV}" type macsec offload off 2> /dev/null
|
|
check $? '' '' 1
|
|
|
|
ip macsec offload "${MACSEC_NETDEV}" off 2> /dev/null
|
|
check $? '' '' 1
|
|
|
|
# toggle macsec offload via rtnetlink
|
|
ip link set "${MACSEC_NETDEV}2" type macsec offload off
|
|
check $?
|
|
|
|
ip link set "${MACSEC_NETDEV}2" type macsec offload mac
|
|
check $?
|
|
|
|
# toggle macsec offload via genetlink
|
|
ip macsec offload "${MACSEC_NETDEV}2" off
|
|
check $?
|
|
|
|
ip macsec offload "${MACSEC_NETDEV}2" mac
|
|
check $?
|
|
|
|
for dev in ${MACSEC_NETDEV}{,2,3} ; do
|
|
ip link del $dev
|
|
check $?
|
|
done
|
|
|
|
|
|
#
|
|
# test ethtool features when toggling offload
|
|
#
|
|
|
|
ip link add link $NSIM_NETDEV $MACSEC_NETDEV type macsec offload mac
|
|
TMP_FEATS_ON_1="$(ethtool -k $MACSEC_NETDEV)"
|
|
|
|
ip link set $MACSEC_NETDEV type macsec offload off
|
|
TMP_FEATS_OFF_1="$(ethtool -k $MACSEC_NETDEV)"
|
|
|
|
ip link set $MACSEC_NETDEV type macsec offload mac
|
|
TMP_FEATS_ON_2="$(ethtool -k $MACSEC_NETDEV)"
|
|
|
|
[ "$TMP_FEATS_ON_1" = "$TMP_FEATS_ON_2" ]
|
|
check $?
|
|
|
|
ip link del $MACSEC_NETDEV
|
|
|
|
ip link add link $NSIM_NETDEV $MACSEC_NETDEV type macsec
|
|
check $?
|
|
|
|
TMP_FEATS_OFF_2="$(ethtool -k $MACSEC_NETDEV)"
|
|
[ "$TMP_FEATS_OFF_1" = "$TMP_FEATS_OFF_2" ]
|
|
check $?
|
|
|
|
ip link set $MACSEC_NETDEV type macsec offload mac
|
|
check $?
|
|
|
|
TMP_FEATS_ON_3="$(ethtool -k $MACSEC_NETDEV)"
|
|
[ "$TMP_FEATS_ON_1" = "$TMP_FEATS_ON_3" ]
|
|
check $?
|
|
|
|
|
|
if [ $num_errors -eq 0 ]; then
|
|
echo "PASSED all $((num_passes)) checks"
|
|
exit 0
|
|
else
|
|
echo "FAILED $num_errors/$((num_errors+num_passes)) checks"
|
|
exit 1
|
|
fi
|