Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net
Conflicts were all overlapping changes. Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -10,10 +10,7 @@ if ! grep -q function_graph available_tracers; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
do_reset() {
|
||||
if [ -e /proc/sys/kernel/stack_tracer_enabled ]; then
|
||||
|
@@ -9,6 +9,8 @@ if ! grep -q function_graph available_tracers; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
fail() { # msg
|
||||
echo $1
|
||||
exit_fail
|
||||
|
@@ -9,6 +9,8 @@ if ! grep -q function available_tracers; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
disable_tracing
|
||||
clear_trace
|
||||
|
||||
|
@@ -15,10 +15,7 @@ if [ ! -f set_ftrace_notrace_pid ]; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is function tracer not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
do_function_fork=1
|
||||
|
||||
|
@@ -16,10 +16,7 @@ if [ ! -f set_ftrace_pid ]; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is function tracer not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
do_function_fork=1
|
||||
|
||||
|
@@ -3,7 +3,7 @@
|
||||
# description: ftrace - stacktrace filter command
|
||||
# flags: instance
|
||||
|
||||
[ ! -f set_ftrace_filter ] && exit_unsupported
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
echo _do_fork:stacktrace >> set_ftrace_filter
|
||||
|
||||
|
@@ -11,10 +11,7 @@
|
||||
#
|
||||
|
||||
# The triggers are set within the set_ftrace_filter file
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
do_reset() {
|
||||
reset_ftrace_filter
|
||||
|
@@ -2,7 +2,7 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# description: ftrace - function trace on module
|
||||
|
||||
[ ! -f set_ftrace_filter ] && exit_unsupported
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
: "mod: allows to filter a non exist function"
|
||||
echo 'non_exist_func:mod:non_exist_module' > set_ftrace_filter
|
||||
|
@@ -18,10 +18,7 @@ if ! grep -q function_graph available_tracers; then
|
||||
exit_unsupported;
|
||||
fi
|
||||
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
if [ ! -f function_profile_enabled ]; then
|
||||
echo "function_profile_enabled not found, function profiling enabled?"
|
||||
|
@@ -10,10 +10,7 @@
|
||||
#
|
||||
|
||||
# The triggers are set within the set_ftrace_filter file
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
fail() { # mesg
|
||||
echo $1
|
||||
|
@@ -8,6 +8,8 @@ if [ ! -f stack_trace ]; then
|
||||
exit_unsupported
|
||||
fi
|
||||
|
||||
check_filter_file stack_trace_filter
|
||||
|
||||
echo > stack_trace_filter
|
||||
echo 0 > stack_max_size
|
||||
echo 1 > /proc/sys/kernel/stack_tracer_enabled
|
||||
|
@@ -11,10 +11,7 @@
|
||||
#
|
||||
|
||||
# The triggers are set within the set_ftrace_filter file
|
||||
if [ ! -f set_ftrace_filter ]; then
|
||||
echo "set_ftrace_filter not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
fail() { # mesg
|
||||
echo $1
|
||||
|
@@ -1,3 +1,9 @@
|
||||
check_filter_file() { # check filter file introduced by dynamic ftrace
|
||||
if [ ! -f "$1" ]; then
|
||||
echo "$1 not found? Is dynamic ftrace not set?"
|
||||
exit_unsupported
|
||||
fi
|
||||
}
|
||||
|
||||
clear_trace() { # reset trace output
|
||||
echo > trace
|
||||
|
@@ -38,7 +38,7 @@ for width in 64 32 16 8; do
|
||||
echo 0 > events/kprobes/testprobe/enable
|
||||
|
||||
: "Confirm the arguments is recorded in given types correctly"
|
||||
ARGS=`grep "testprobe" trace | sed -e 's/.* arg1=\(.*\) arg2=\(.*\) arg3=\(.*\) arg4=\(.*\)/\1 \2 \3 \4/'`
|
||||
ARGS=`grep "testprobe" trace | head -n 1 | sed -e 's/.* arg1=\(.*\) arg2=\(.*\) arg3=\(.*\) arg4=\(.*\)/\1 \2 \3 \4/'`
|
||||
check_types $ARGS $width
|
||||
|
||||
: "Clear event for next loop"
|
||||
|
@@ -5,6 +5,8 @@
|
||||
[ -f kprobe_events ] || exit_unsupported # this is configurable
|
||||
grep "function" available_tracers || exit_unsupported # this is configurable
|
||||
|
||||
check_filter_file set_ftrace_filter
|
||||
|
||||
# prepare
|
||||
echo nop > current_tracer
|
||||
echo _do_fork > set_ftrace_filter
|
||||
|
@@ -1,13 +1,13 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
|
||||
MOUNT_CFLAGS := $(shell pkg-config --cflags mount 2>/dev/null)
|
||||
MOUNT_LDLIBS := $(shell pkg-config --libs mount 2>/dev/null)
|
||||
ifeq ($(MOUNT_LDLIBS),)
|
||||
MOUNT_LDLIBS := -lmount -I/usr/include/libmount
|
||||
VAR_CFLAGS := $(shell pkg-config --cflags mount 2>/dev/null)
|
||||
VAR_LDLIBS := $(shell pkg-config --libs mount 2>/dev/null)
|
||||
ifeq ($(VAR_LDLIBS),)
|
||||
VAR_LDLIBS := -lmount -I/usr/include/libmount
|
||||
endif
|
||||
|
||||
CFLAGS += -O2 -g -std=gnu99 -Wall -I../../../../usr/include/ $(MOUNT_CFLAGS)
|
||||
LDLIBS += $(MOUNT_LDLIBS)
|
||||
CFLAGS += -O2 -g -std=gnu99 -Wall -I../../../../usr/include/ $(VAR_CFLAGS)
|
||||
LDLIBS += $(VAR_LDLIBS)
|
||||
|
||||
TEST_PROGS := gpio-mockup.sh
|
||||
TEST_FILES := gpio-mockup-sysfs.sh
|
||||
|
@@ -1,6 +1,6 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
CFLAGS := $(CFLAGS) -Wall -D_GNU_SOURCE
|
||||
LDLIBS := $(LDLIBS) -lm
|
||||
LDLIBS += -lm
|
||||
|
||||
uname_M := $(shell uname -m 2>/dev/null || echo not)
|
||||
ARCH ?= $(shell echo $(uname_M) | sed -e s/i.86/x86/ -e s/x86_64/x86/)
|
||||
|
272
tools/testing/selftests/kselftest_deps.sh
Executable file
272
tools/testing/selftests/kselftest_deps.sh
Executable file
@@ -0,0 +1,272 @@
|
||||
#!/bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# kselftest_deps.sh
|
||||
#
|
||||
# Checks for kselftest build dependencies on the build system.
|
||||
# Copyright (c) 2020 Shuah Khan <skhan@linuxfoundation.org>
|
||||
#
|
||||
#
|
||||
|
||||
usage()
|
||||
{
|
||||
|
||||
echo -e "Usage: $0 -[p] <compiler> [test_name]\n"
|
||||
echo -e "\tkselftest_deps.sh [-p] gcc"
|
||||
echo -e "\tkselftest_deps.sh [-p] gcc vm"
|
||||
echo -e "\tkselftest_deps.sh [-p] aarch64-linux-gnu-gcc"
|
||||
echo -e "\tkselftest_deps.sh [-p] aarch64-linux-gnu-gcc vm\n"
|
||||
echo "- Should be run in selftests directory in the kernel repo."
|
||||
echo "- Checks if Kselftests can be built/cross-built on a system."
|
||||
echo "- Parses all test/sub-test Makefile to find library dependencies."
|
||||
echo "- Runs compile test on a trivial C file with LDLIBS specified"
|
||||
echo " in the test Makefiles to identify missing library dependencies."
|
||||
echo "- Prints suggested target list for a system filtering out tests"
|
||||
echo " failed the build dependency check from the TARGETS in Selftests"
|
||||
echo " main Makefile when optional -p is specified."
|
||||
echo "- Prints pass/fail dependency check for each tests/sub-test."
|
||||
echo "- Prints pass/fail targets and libraries."
|
||||
echo "- Default: runs dependency checks on all tests."
|
||||
echo "- Optional test name can be specified to check dependencies for it."
|
||||
exit 1
|
||||
|
||||
}
|
||||
|
||||
# Start main()
|
||||
main()
|
||||
{
|
||||
|
||||
base_dir=`pwd`
|
||||
# Make sure we're in the selftests top-level directory.
|
||||
if [ $(basename "$base_dir") != "selftests" ]; then
|
||||
echo -e "\tPlease run $0 in"
|
||||
echo -e "\ttools/testing/selftests directory ..."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
print_targets=0
|
||||
|
||||
while getopts "p" arg; do
|
||||
case $arg in
|
||||
p)
|
||||
print_targets=1
|
||||
shift;;
|
||||
esac
|
||||
done
|
||||
|
||||
if [ $# -eq 0 ]
|
||||
then
|
||||
usage
|
||||
fi
|
||||
|
||||
# Compiler
|
||||
CC=$1
|
||||
|
||||
tmp_file=$(mktemp).c
|
||||
trap "rm -f $tmp_file.o $tmp_file $tmp_file.bin" EXIT
|
||||
#echo $tmp_file
|
||||
|
||||
pass=$(mktemp).out
|
||||
trap "rm -f $pass" EXIT
|
||||
#echo $pass
|
||||
|
||||
fail=$(mktemp).out
|
||||
trap "rm -f $fail" EXIT
|
||||
#echo $fail
|
||||
|
||||
# Generate tmp source fire for compile test
|
||||
cat << "EOF" > $tmp_file
|
||||
int main()
|
||||
{
|
||||
}
|
||||
EOF
|
||||
|
||||
# Save results
|
||||
total_cnt=0
|
||||
fail_trgts=()
|
||||
fail_libs=()
|
||||
fail_cnt=0
|
||||
pass_trgts=()
|
||||
pass_libs=()
|
||||
pass_cnt=0
|
||||
|
||||
# Get all TARGETS from selftests Makefile
|
||||
targets=$(egrep "^TARGETS +|^TARGETS =" Makefile | cut -d "=" -f2)
|
||||
|
||||
# Single test case
|
||||
if [ $# -eq 2 ]
|
||||
then
|
||||
test=$2/Makefile
|
||||
|
||||
l1_test $test
|
||||
l2_test $test
|
||||
l3_test $test
|
||||
|
||||
print_results $1 $2
|
||||
exit $?
|
||||
fi
|
||||
|
||||
# Level 1: LDLIBS set static.
|
||||
#
|
||||
# Find all LDLIBS set statically for all executables built by a Makefile
|
||||
# and filter out VAR_LDLIBS to discard the following:
|
||||
# gpio/Makefile:LDLIBS += $(VAR_LDLIBS)
|
||||
# Append space at the end of the list to append more tests.
|
||||
|
||||
l1_tests=$(grep -r --include=Makefile "^LDLIBS" | \
|
||||
grep -v "VAR_LDLIBS" | awk -F: '{print $1}')
|
||||
|
||||
# Level 2: LDLIBS set dynamically.
|
||||
#
|
||||
# Level 2
|
||||
# Some tests have multiple valid LDLIBS lines for individual sub-tests
|
||||
# that need dependency checks. Find them and append them to the tests
|
||||
# e.g: vm/Makefile:$(OUTPUT)/userfaultfd: LDLIBS += -lpthread
|
||||
# Filter out VAR_LDLIBS to discard the following:
|
||||
# memfd/Makefile:$(OUTPUT)/fuse_mnt: LDLIBS += $(VAR_LDLIBS)
|
||||
# Append space at the end of the list to append more tests.
|
||||
|
||||
l2_tests=$(grep -r --include=Makefile ": LDLIBS" | \
|
||||
grep -v "VAR_LDLIBS" | awk -F: '{print $1}')
|
||||
|
||||
# Level 3
|
||||
# gpio, memfd and others use pkg-config to find mount and fuse libs
|
||||
# respectively and save it in VAR_LDLIBS. If pkg-config doesn't find
|
||||
# any, VAR_LDLIBS set to default.
|
||||
# Use the default value and filter out pkg-config for dependency check.
|
||||
# e.g:
|
||||
# gpio/Makefile
|
||||
# VAR_LDLIBS := $(shell pkg-config --libs mount) 2>/dev/null)
|
||||
# memfd/Makefile
|
||||
# VAR_LDLIBS := $(shell pkg-config fuse --libs 2>/dev/null)
|
||||
|
||||
l3_tests=$(grep -r --include=Makefile "^VAR_LDLIBS" | \
|
||||
grep -v "pkg-config" | awk -F: '{print $1}')
|
||||
|
||||
#echo $l1_tests
|
||||
#echo $l2_1_tests
|
||||
#echo $l3_tests
|
||||
|
||||
all_tests
|
||||
print_results $1 $2
|
||||
|
||||
exit $?
|
||||
}
|
||||
# end main()
|
||||
|
||||
all_tests()
|
||||
{
|
||||
for test in $l1_tests; do
|
||||
l1_test $test
|
||||
done
|
||||
|
||||
for test in $l2_tests; do
|
||||
l2_test $test
|
||||
done
|
||||
|
||||
for test in $l3_tests; do
|
||||
l3_test $test
|
||||
done
|
||||
}
|
||||
|
||||
# Use same parsing used for l1_tests and pick libraries this time.
|
||||
l1_test()
|
||||
{
|
||||
test_libs=$(grep --include=Makefile "^LDLIBS" $test | \
|
||||
grep -v "VAR_LDLIBS" | \
|
||||
sed -e 's/\:/ /' | \
|
||||
sed -e 's/+/ /' | cut -d "=" -f 2)
|
||||
|
||||
check_libs $test $test_libs
|
||||
}
|
||||
|
||||
# Use same parsing used for l2__tests and pick libraries this time.
|
||||
l2_test()
|
||||
{
|
||||
test_libs=$(grep --include=Makefile ": LDLIBS" $test | \
|
||||
grep -v "VAR_LDLIBS" | \
|
||||
sed -e 's/\:/ /' | sed -e 's/+/ /' | \
|
||||
cut -d "=" -f 2)
|
||||
|
||||
check_libs $test $test_libs
|
||||
}
|
||||
|
||||
l3_test()
|
||||
{
|
||||
test_libs=$(grep --include=Makefile "^VAR_LDLIBS" $test | \
|
||||
grep -v "pkg-config" | sed -e 's/\:/ /' |
|
||||
sed -e 's/+/ /' | cut -d "=" -f 2)
|
||||
|
||||
check_libs $test $test_libs
|
||||
}
|
||||
|
||||
check_libs()
|
||||
{
|
||||
|
||||
if [[ ! -z "${test_libs// }" ]]
|
||||
then
|
||||
|
||||
#echo $test_libs
|
||||
|
||||
for lib in $test_libs; do
|
||||
|
||||
let total_cnt+=1
|
||||
$CC -o $tmp_file.bin $lib $tmp_file > /dev/null 2>&1
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "FAIL: $test dependency check: $lib" >> $fail
|
||||
let fail_cnt+=1
|
||||
fail_libs+="$lib "
|
||||
fail_target=$(echo "$test" | cut -d "/" -f1)
|
||||
fail_trgts+="$fail_target "
|
||||
targets=$(echo "$targets" | grep -v "$fail_target")
|
||||
else
|
||||
echo "PASS: $test dependency check passed $lib" >> $pass
|
||||
let pass_cnt+=1
|
||||
pass_libs+="$lib "
|
||||
pass_trgts+="$(echo "$test" | cut -d "/" -f1) "
|
||||
fi
|
||||
|
||||
done
|
||||
fi
|
||||
}
|
||||
|
||||
print_results()
|
||||
{
|
||||
echo -e "========================================================";
|
||||
echo -e "Kselftest Dependency Check for [$0 $1 $2] results..."
|
||||
|
||||
if [ $print_targets -ne 0 ]
|
||||
then
|
||||
echo -e "Suggested Selftest Targets for your configuration:"
|
||||
echo -e "$targets";
|
||||
fi
|
||||
|
||||
echo -e "========================================================";
|
||||
echo -e "Checked tests defining LDLIBS dependencies"
|
||||
echo -e "--------------------------------------------------------";
|
||||
echo -e "Total tests with Dependencies:"
|
||||
echo -e "$total_cnt Pass: $pass_cnt Fail: $fail_cnt";
|
||||
|
||||
if [ $pass_cnt -ne 0 ]; then
|
||||
echo -e "--------------------------------------------------------";
|
||||
cat $pass
|
||||
echo -e "--------------------------------------------------------";
|
||||
echo -e "Targets passed build dependency check on system:"
|
||||
echo -e "$(echo "$pass_trgts" | xargs -n1 | sort -u | xargs)"
|
||||
fi
|
||||
|
||||
if [ $fail_cnt -ne 0 ]; then
|
||||
echo -e "--------------------------------------------------------";
|
||||
cat $fail
|
||||
echo -e "--------------------------------------------------------";
|
||||
echo -e "Targets failed build dependency check on system:"
|
||||
echo -e "$(echo "$fail_trgts" | xargs -n1 | sort -u | xargs)"
|
||||
echo -e "--------------------------------------------------------";
|
||||
echo -e "Missing libraries system"
|
||||
echo -e "$(echo "$fail_libs" | xargs -n1 | sort -u | xargs)"
|
||||
fi
|
||||
|
||||
echo -e "--------------------------------------------------------";
|
||||
echo -e "========================================================";
|
||||
}
|
||||
|
||||
main "$@"
|
@@ -8,11 +8,21 @@ TEST_GEN_PROGS := memfd_test
|
||||
TEST_PROGS := run_fuse_test.sh run_hugetlbfs_test.sh
|
||||
TEST_GEN_FILES := fuse_test fuse_mnt
|
||||
|
||||
fuse_mnt.o: CFLAGS += $(shell pkg-config fuse --cflags)
|
||||
VAR_CFLAGS := $(shell pkg-config fuse --cflags 2>/dev/null)
|
||||
ifeq ($(VAR_CFLAGS),)
|
||||
VAR_CFLAGS := -D_FILE_OFFSET_BITS=64 -I/usr/include/fuse
|
||||
endif
|
||||
|
||||
VAR_LDLIBS := $(shell pkg-config fuse --libs 2>/dev/null)
|
||||
ifeq ($(VAR_LDLIBS),)
|
||||
VAR_LDLIBS := -lfuse -pthread
|
||||
endif
|
||||
|
||||
fuse_mnt.o: CFLAGS += $(VAR_CFLAGS)
|
||||
|
||||
include ../lib.mk
|
||||
|
||||
$(OUTPUT)/fuse_mnt: LDLIBS += $(shell pkg-config fuse --libs)
|
||||
$(OUTPUT)/fuse_mnt: LDLIBS += $(VAR_LDLIBS)
|
||||
|
||||
$(OUTPUT)/memfd_test: memfd_test.c common.c
|
||||
$(OUTPUT)/fuse_test: fuse_test.c common.c
|
||||
|
@@ -165,9 +165,10 @@ void *child_thread(void *arg)
|
||||
socklen_t zc_len = sizeof(zc);
|
||||
int res;
|
||||
|
||||
memset(&zc, 0, sizeof(zc));
|
||||
zc.address = (__u64)((unsigned long)addr);
|
||||
zc.length = chunk_size;
|
||||
zc.recv_skip_hint = 0;
|
||||
|
||||
res = getsockopt(fd, IPPROTO_TCP, TCP_ZEROCOPY_RECEIVE,
|
||||
&zc, &zc_len);
|
||||
if (res == -1)
|
||||
@@ -281,12 +282,14 @@ static void setup_sockaddr(int domain, const char *str_addr,
|
||||
static void do_accept(int fdlisten)
|
||||
{
|
||||
pthread_attr_t attr;
|
||||
int rcvlowat;
|
||||
|
||||
pthread_attr_init(&attr);
|
||||
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
|
||||
|
||||
rcvlowat = chunk_size;
|
||||
if (setsockopt(fdlisten, SOL_SOCKET, SO_RCVLOWAT,
|
||||
&chunk_size, sizeof(chunk_size)) == -1) {
|
||||
&rcvlowat, sizeof(rcvlowat)) == -1) {
|
||||
perror("setsockopt SO_RCVLOWAT");
|
||||
}
|
||||
|
||||
|
@@ -48,8 +48,11 @@ cleanup() {
|
||||
exec 2>/dev/null
|
||||
printf "$orig_message_cost" > /proc/sys/net/core/message_cost
|
||||
ip0 link del dev wg0
|
||||
ip0 link del dev wg1
|
||||
ip1 link del dev wg0
|
||||
ip1 link del dev wg1
|
||||
ip2 link del dev wg0
|
||||
ip2 link del dev wg1
|
||||
local to_kill="$(ip netns pids $netns0) $(ip netns pids $netns1) $(ip netns pids $netns2)"
|
||||
[[ -n $to_kill ]] && kill $to_kill
|
||||
pp ip netns del $netns1
|
||||
@@ -77,18 +80,20 @@ ip0 link set wg0 netns $netns2
|
||||
key1="$(pp wg genkey)"
|
||||
key2="$(pp wg genkey)"
|
||||
key3="$(pp wg genkey)"
|
||||
key4="$(pp wg genkey)"
|
||||
pub1="$(pp wg pubkey <<<"$key1")"
|
||||
pub2="$(pp wg pubkey <<<"$key2")"
|
||||
pub3="$(pp wg pubkey <<<"$key3")"
|
||||
pub4="$(pp wg pubkey <<<"$key4")"
|
||||
psk="$(pp wg genpsk)"
|
||||
[[ -n $key1 && -n $key2 && -n $psk ]]
|
||||
|
||||
configure_peers() {
|
||||
ip1 addr add 192.168.241.1/24 dev wg0
|
||||
ip1 addr add fd00::1/24 dev wg0
|
||||
ip1 addr add fd00::1/112 dev wg0
|
||||
|
||||
ip2 addr add 192.168.241.2/24 dev wg0
|
||||
ip2 addr add fd00::2/24 dev wg0
|
||||
ip2 addr add fd00::2/112 dev wg0
|
||||
|
||||
n1 wg set wg0 \
|
||||
private-key <(echo "$key1") \
|
||||
@@ -230,9 +235,38 @@ n1 ping -W 1 -c 1 192.168.241.2
|
||||
n1 wg set wg0 private-key <(echo "$key3")
|
||||
n2 wg set wg0 peer "$pub3" preshared-key <(echo "$psk") allowed-ips 192.168.241.1/32 peer "$pub1" remove
|
||||
n1 ping -W 1 -c 1 192.168.241.2
|
||||
n2 wg set wg0 peer "$pub3" remove
|
||||
|
||||
ip1 link del wg0
|
||||
# Test that we can route wg through wg
|
||||
ip1 addr flush dev wg0
|
||||
ip2 addr flush dev wg0
|
||||
ip1 addr add fd00::5:1/112 dev wg0
|
||||
ip2 addr add fd00::5:2/112 dev wg0
|
||||
n1 wg set wg0 private-key <(echo "$key1") peer "$pub2" preshared-key <(echo "$psk") allowed-ips fd00::5:2/128 endpoint 127.0.0.1:2
|
||||
n2 wg set wg0 private-key <(echo "$key2") listen-port 2 peer "$pub1" preshared-key <(echo "$psk") allowed-ips fd00::5:1/128 endpoint 127.212.121.99:9998
|
||||
ip1 link add wg1 type wireguard
|
||||
ip2 link add wg1 type wireguard
|
||||
ip1 addr add 192.168.241.1/24 dev wg1
|
||||
ip1 addr add fd00::1/112 dev wg1
|
||||
ip2 addr add 192.168.241.2/24 dev wg1
|
||||
ip2 addr add fd00::2/112 dev wg1
|
||||
ip1 link set mtu 1340 up dev wg1
|
||||
ip2 link set mtu 1340 up dev wg1
|
||||
n1 wg set wg1 listen-port 5 private-key <(echo "$key3") peer "$pub4" allowed-ips 192.168.241.2/32,fd00::2/128 endpoint [fd00::5:2]:5
|
||||
n2 wg set wg1 listen-port 5 private-key <(echo "$key4") peer "$pub3" allowed-ips 192.168.241.1/32,fd00::1/128 endpoint [fd00::5:1]:5
|
||||
tests
|
||||
# Try to set up a routing loop between the two namespaces
|
||||
ip1 link set netns $netns0 dev wg1
|
||||
ip0 addr add 192.168.241.1/24 dev wg1
|
||||
ip0 link set up dev wg1
|
||||
n0 ping -W 1 -c 1 192.168.241.2
|
||||
n1 wg set wg0 peer "$pub2" endpoint 192.168.241.2:7
|
||||
ip2 link del wg0
|
||||
ip2 link del wg1
|
||||
! n0 ping -W 1 -c 10 -f 192.168.241.2 || false # Should not crash kernel
|
||||
|
||||
ip0 link del wg1
|
||||
ip1 link del wg0
|
||||
|
||||
# Test using NAT. We now change the topology to this:
|
||||
# ┌────────────────────────────────────────┐ ┌────────────────────────────────────────────────┐ ┌────────────────────────────────────────┐
|
||||
@@ -282,6 +316,20 @@ pp sleep 3
|
||||
n2 ping -W 1 -c 1 192.168.241.1
|
||||
n1 wg set wg0 peer "$pub2" persistent-keepalive 0
|
||||
|
||||
# Test that onion routing works, even when it loops
|
||||
n1 wg set wg0 peer "$pub3" allowed-ips 192.168.242.2/32 endpoint 192.168.241.2:5
|
||||
ip1 addr add 192.168.242.1/24 dev wg0
|
||||
ip2 link add wg1 type wireguard
|
||||
ip2 addr add 192.168.242.2/24 dev wg1
|
||||
n2 wg set wg1 private-key <(echo "$key3") listen-port 5 peer "$pub1" allowed-ips 192.168.242.1/32
|
||||
ip2 link set wg1 up
|
||||
n1 ping -W 1 -c 1 192.168.242.2
|
||||
ip2 link del wg1
|
||||
n1 wg set wg0 peer "$pub3" endpoint 192.168.242.2:5
|
||||
! n1 ping -W 1 -c 1 192.168.242.2 || false # Should not crash kernel
|
||||
n1 wg set wg0 peer "$pub3" remove
|
||||
ip1 addr del 192.168.242.1/24 dev wg0
|
||||
|
||||
# Do a wg-quick(8)-style policy routing for the default route, making sure vethc has a v6 address to tease out bugs.
|
||||
ip1 -6 addr add fc00::9/96 dev vethc
|
||||
ip1 -6 route add default via fc00::1
|
||||
|
@@ -10,3 +10,4 @@ CONFIG_CMDLINE_BOOL=y
|
||||
CONFIG_CMDLINE="console=hvc0 wg.success=hvc1"
|
||||
CONFIG_SECTION_MISMATCH_WARN_ONLY=y
|
||||
CONFIG_FRAME_WARN=1280
|
||||
CONFIG_THREAD_SHIFT=14
|
||||
|
Reference in New Issue
Block a user