check_value max_macs initial 32 32
check_value test1 initial true Y
param_set max_macs 16
check_err $? "Failed to set max_macs param value"
param_set test1 false
check_err $? "Failed to set test1 param value"
check_value max_macs post-set 16 32
check_value test1 post-set false Y
devlink dev reload $DL_HANDLE
check_value max_macs post-reload 16 16
check_value test1 post-reload false N
log_test "params test"
}
check_region_size()
{
local name=$1
local size
size=$(devlink region show $DL_HANDLE/$name -j | jq -e -r '.[][].size')
check_err $? "Failed to get $name region size"
[ $size -eq 32768 ]
check_err $? "Invalid $name region size"
}
check_region_snapshot_count()
{
local name=$1
local phase_name=$2
local expected_count=$3
local count
devlink region dump $DL_HANDLE/dummy snapshot 25 >> /dev/null
check_err $? "Failed to dump snapshot with id 25"
devlink region read $DL_HANDLE/dummy snapshot 25 addr 0 len 1 >> /dev/null
check_err $? "Failed to read snapshot with id 25 (1 byte)"
devlink region read $DL_HANDLE/dummy snapshot 25 addr 128 len 128 >> /dev/null
check_err $? "Failed to read snapshot with id 25 (128 bytes)"
devlink region read $DL_HANDLE/dummy snapshot 25 addr 128 len $((1<<32)) >> /dev/null
check_err $? "Failed to read snapshot with id 25 (oversized)"
devlink region read $DL_HANDLE/dummy snapshot 25 addr $((1<<32)) len 128 >> /dev/null 2>&1
check_fail $? "Bad read of snapshot with id 25 did not fail"
devlink region del $DL_HANDLE/dummy snapshot 25
check_err $? "Failed to delete snapshot with id 25"
ip netns add testns1
check_err $? "Failed add netns \"testns1\""
ip netns add testns2
check_err $? "Failed add netns \"testns2\""
devlink dev reload $DL_HANDLE netns testns1
check_err $? "Failed to reload into netns \"testns1\""
# Create dummy dev to add the address and routes on.
ip -n testns1 link add name $DUMMYDEV type dummy
check_err $? "Failed create dummy device"
ip -n testns1 link set $DUMMYDEV up
check_err $? "Failed bring up dummy device"
ip -n testns1 a a 192.0.1.1/24 dev $DUMMYDEV
check_err $? "Failed add an IP address to dummy device"
local occ=$(res_val_get testns1 IPv4 fib occ)
local limit=$((occ+1))
# Set fib size limit to handle one another route only.
devlink -N testns1 resource set $DL_HANDLE path IPv4/fib size $limit
check_err $? "Failed to set IPv4/fib resource size"
local size_new=$(res_val_get testns1 IPv4 fib size_new)
[ "$size_new" -eq "$limit" ]
check_err $? "Unexpected \"size_new\" value (got $size_new, expected $limit)"
devlink -N testns1 dev reload $DL_HANDLE
check_err $? "Failed to reload"
local size=$(res_val_get testns1 IPv4 fib size)
[ "$size" -eq "$limit" ]
check_err $? "Unexpected \"size\" value (got $size, expected $limit)"
# Insert 2 routes, the first is going to be inserted, # the second is expected to fail to be inserted.
ip -n testns1 r a 192.0.2.0/24 via 192.0.1.2
check_err $? "Failed to add route"
ip -n testns1 r a 192.0.3.0/24 via 192.0.1.2
check_fail $? "Unexpected successful route add over limit"
# Now create another dummy in second network namespace and # insert two routes. That is over the limit of the netdevsim # instance in the first namespace. Move the netdevsim instance # into the second namespace and expect it to fail.
ip -n testns2 link add name $DUMMYDEV type dummy
check_err $? "Failed create dummy device"
ip -n testns2 link set $DUMMYDEV up
check_err $? "Failed bring up dummy device"
ip -n testns2 a a 192.0.1.1/24 dev $DUMMYDEV
check_err $? "Failed add an IP address to dummy device"
ip -n testns2 r a 192.0.2.0/24 via 192.0.1.2
check_err $? "Failed to add route"
ip -n testns2 r a 192.0.3.0/24 via 192.0.1.2
check_err $? "Failed to add route"
devlink -N testns1 dev reload $DL_HANDLE netns testns2
check_fail $? "Unexpected successful reload from netns \"testns1\" into netns \"testns2\""
devlink -N testns2 resource set $DL_HANDLE path IPv4/fib size ' -1'
check_err $? "Failed to reset IPv4/fib resource size"
devlink -N testns2 dev reload $DL_HANDLE netns 1
check_err $? "Failed to reload devlink back"
ip netns del testns2
ip netns del testns1
# Wait until netns async cleanup is done.
devlink_wait 2000
log_test "resource test"
}
info_get()
{
local name=$1
cmd_jq "devlink dev info $DL_HANDLE -j"".[][][\"$name\"]""-e"
}
dev_info_test()
{
RET=0
driver=$(info_get "driver")
check_err $? "Failed to get driver name"
[ "$driver" == "netdevsim" ]
check_err $? "Unexpected driver name $driver"
log_test "dev_info test"
}
empty_reporter_test()
{
RET=0
devlink health show $DL_HANDLE reporter empty >/dev/null
check_err $? "Failed show empty reporter"
devlink health dump show $DL_HANDLE reporter empty >/dev/null
check_err $? "Failed show dump of empty reporter"
check_reporter_info()
{
local name=$1
local expected_state=$2
local expected_error=$3
local expected_recover=$4
local expected_grace_period=$5
local expected_auto_recover=$6
local show=$(devlink health show $DL_HANDLE reporter $name -j | jq -e -r ".[][][]")
check_err $? "Failed show $name reporter"
echo 8192 > $DEBUGFS_DIR/health/binary_len
check_err $? "Failed set dummy reporter binary len to 8192"
local dump=$(devlink health dump show $DL_HANDLE reporter dummy -j)
check_err $? "Failed show dump of dummy reporter"
devlink health dump clear $DL_HANDLE reporter dummy
check_err $? "Failed clear dump of dummy reporter"
log_test "dummy reporter test"
}
rate_leafs_get()
{
local handle=$1
cmd_jq "devlink port function rate show -j" \ '.[] | to_entries | .[] | select(.value.type == "leaf") | .key | select(contains("'$handle'"))'
}
rate_nodes_get()
{
local handle=$1
cmd_jq "devlink port function rate show -j" \ '.[] | to_entries | .[] | select(.value.type == "node") | .key | select(contains("'$handle'"))'
}
rate_attr_set()
{
local handle=$1
local name=$2
local value=$3
local units=$4
devlink port function rate set $handle $name $value$units
}
rate_attr_get()
{
local handle=$1
local name=$2
cmd_jq "devlink port function rate show $handle -j"'.[][].'$name
}
rate_attr_tx_rate_check()
{
local handle=$1
local name=$2
local rate=$3
local debug_file=$4
rate_attr_set $handle $name $rate mbit
check_err $? "Failed to set $name value"
local debug_value=$(cat $debug_file)
check_err $? "Failed to read $name value from debugfs"
[ "$debug_value" == "$rate" ]
check_err $? "Unexpected $name debug value $debug_value != $rate"
local api_value=$(( $(rate_attr_get $handle $name) * 8 / 1000000 ))
check_err $? "Failed to get $name attr value"
[ "$api_value" == "$rate" ]
check_err $? "Unexpected $name attr value $api_value != $rate"
}
rate_attr_parent_check()
{
local handle=$1
local parent=$2
local debug_file=$3
rate_attr_set $handle parent $parent
check_err $? "Failed to set parent"
debug_value=$(cat $debug_file)
check_err $? "Failed to get parent debugfs value"
[ "$debug_value" == "$parent" ]
check_err $? "Unexpected parent debug value $debug_value != $parent"
api_value=$(rate_attr_get $r_obj parent)
check_err $? "Failed to get parent attr value"
[ "$api_value" == "$parent" ]
check_err $? "Unexpected parent attr value $api_value != $parent"
}
rate_attr_tc_bw_check()
{
local handle=$1
local tc_bw=$2
local debug_file=$3
local tc_bw_str="" for bw in $tc_bw; do
local tc=${bw%%:*}
local value=${bw##*:}
tc_bw_str="$tc_bw_str $tc:$value" done
tc_bw_str=${tc_bw_str# }
rate_attr_set "$handle" tc-bw "$tc_bw_str"
check_err $? "Failed to set tc-bw values"
for bw in $tc_bw; do
local tc=${bw%%:*}
local value=${bw##*:}
local debug_value
debug_value=$(cat"$debug_file"/tc"${tc}"_bw)
check_err $? "Failed to read tc-bw value from debugfs for tc$tc"
[ "$debug_value" == "$value" ]
check_err $? "Unexpected tc-bw debug value for tc$tc: $debug_value != $value" done
for bw in $tc_bw; do
local tc=${bw%%:*}
local expected_value=${bw##*:}
local api_value
api_value=$(rate_attr_get "$handle" tc_"$tc") if [ "$api_value" = "null" ]; then
api_value=0 fi
[ "$api_value" == "$expected_value" ]
check_err $? "Unexpected tc-bw value for tc$tc: $api_value != $expected_value" done
}
rate_node_add()
{
local handle=$1
devlink port function rate add $handle
}
rate_node_del()
{
local handle=$1
devlink port function rate del $handle
}
rate_test()
{
RET=0
echo $VF_COUNT > /sys/bus/netdevsim/devices/$DEV_NAME/sriov_numvfs
devlink dev eswitch set $DL_HANDLE mode switchdev
local leafs=`rate_leafs_get $DL_HANDLE`
local num_leafs=`echo $leafs | wc -w`
[ "$num_leafs" == "$VF_COUNT" ]
check_err $? "Expected $VF_COUNT rate leafs but got $num_leafs"
rate=10 for r_obj in $leafs do
rate_attr_tx_rate_check $r_obj tx_share $rate \
$DEBUGFS_DIR/ports/${r_obj##*/}/tx_share
rate=$(($rate+10)) done
rate=100 for r_obj in $leafs do
rate_attr_tx_rate_check $r_obj tx_max $rate \
$DEBUGFS_DIR/ports/${r_obj##*/}/tx_max
rate=$(($rate+100)) done
local tc_bw="0:0 1:40 2:0 3:0 4:0 5:0 6:60 7:0" for r_obj in $leafs do
rate_attr_tc_bw_check "$r_obj""$tc_bw" \ "$DEBUGFS_DIR"/ports/"${r_obj##*/}" done
local node1_name='group1'
local node1="$DL_HANDLE/$node1_name"
rate_node_add "$node1"
check_err $? "Failed to add node $node1"
local num_nodes=`rate_nodes_get $DL_HANDLE | wc -w`
[ $num_nodes == 1 ]
check_err $? "Expected 1 rate node in output but got $num_nodes"
local node_tx_share=10
rate_attr_tx_rate_check $node1 tx_share $node_tx_share \
$DEBUGFS_DIR/rate_nodes/${node1##*/}/tx_share
local node_tx_max=100
rate_attr_tx_rate_check $node1 tx_max $node_tx_max \
$DEBUGFS_DIR/rate_nodes/${node1##*/}/tx_max
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.