mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-16 23:45:31 +08:00
89abe62837
The gro.sh test-case relay on the gro_flush_timeout to ensure
that all the segments belonging to any given batch are properly
aggregated.
The other end, the sender is a user-space program transmitting
each packet with a separate write syscall. A busy host and/or
stracing the sender program can make the relevant segments reach
the GRO engine after the flush timeout triggers.
Give the GRO flush timeout more slack, to avoid sporadic self-tests
failures.
Fixes: 9af771d2ec
("selftests/net: allow GRO coalesce test on veth")
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Tested-by: Eric Dumazet <edumazet@google.com>
Link: https://lore.kernel.org/r/bffec2beab3a5672dd13ecabe4fad81d2155b367.1706206101.git.pabeni@redhat.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
45 lines
1.0 KiB
Bash
45 lines
1.0 KiB
Bash
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
readonly server_ns=$(mktemp -u server-XXXXXXXX)
|
|
readonly client_ns=$(mktemp -u client-XXXXXXXX)
|
|
|
|
setup_veth_ns() {
|
|
local -r link_dev="$1"
|
|
local -r ns_name="$2"
|
|
local -r ns_dev="$3"
|
|
local -r ns_mac="$4"
|
|
|
|
[[ -e /var/run/netns/"${ns_name}" ]] || ip netns add "${ns_name}"
|
|
echo 1000000 > "/sys/class/net/${ns_dev}/gro_flush_timeout"
|
|
ip link set dev "${ns_dev}" netns "${ns_name}" mtu 65535
|
|
ip -netns "${ns_name}" link set dev "${ns_dev}" up
|
|
|
|
ip netns exec "${ns_name}" ethtool -K "${ns_dev}" gro on tso off
|
|
}
|
|
|
|
setup_ns() {
|
|
# Set up server_ns namespace and client_ns namespace
|
|
ip link add name server type veth peer name client
|
|
|
|
setup_veth_ns "${dev}" ${server_ns} server "${SERVER_MAC}"
|
|
setup_veth_ns "${dev}" ${client_ns} client "${CLIENT_MAC}"
|
|
}
|
|
|
|
cleanup_ns() {
|
|
local ns_name
|
|
|
|
for ns_name in ${client_ns} ${server_ns}; do
|
|
[[ -e /var/run/netns/"${ns_name}" ]] && ip netns del "${ns_name}"
|
|
done
|
|
}
|
|
|
|
setup() {
|
|
# no global init setup step needed
|
|
:
|
|
}
|
|
|
|
cleanup() {
|
|
cleanup_ns
|
|
}
|