Loading...
1#!/bin/sh
2# SPDX-License-Identifier: GPL-2.0
3# Copyright (c) 2018 Facebook
4# Copyright (c) 2019 Cloudflare
5
6set -eu
7readonly NS1="ns1-$(mktemp -u XXXXXX)"
8
9wait_for_ip()
10{
11 local _i
12 printf "Wait for IP %s to become available " "$1"
13 for _i in $(seq ${MAX_PING_TRIES}); do
14 printf "."
15 if ns1_exec ping -c 1 -W 1 "$1" >/dev/null 2>&1; then
16 echo " OK"
17 return
18 fi
19 sleep 1
20 done
21 echo 1>&2 "ERROR: Timeout waiting for test IP to become available."
22 exit 1
23}
24
25get_prog_id()
26{
27 awk '/ id / {sub(/.* id /, "", $0); print($1)}'
28}
29
30ns1_exec()
31{
32 ip netns exec ${NS1} "$@"
33}
34
35setup()
36{
37 ip netns add ${NS1}
38 ns1_exec ip link set lo up
39
40 ns1_exec sysctl -w net.ipv4.tcp_syncookies=2
41 ns1_exec sysctl -w net.ipv4.tcp_window_scaling=0
42 ns1_exec sysctl -w net.ipv4.tcp_timestamps=0
43 ns1_exec sysctl -w net.ipv4.tcp_sack=0
44
45 wait_for_ip 127.0.0.1
46 wait_for_ip ::1
47}
48
49cleanup()
50{
51 ip netns del ns1 2>/dev/null || :
52}
53
54main()
55{
56 trap cleanup EXIT 2 3 6 15
57 setup
58
59 printf "Testing clsact..."
60 ns1_exec tc qdisc add dev "${TEST_IF}" clsact
61 ns1_exec tc filter add dev "${TEST_IF}" ingress \
62 bpf obj "${BPF_PROG_OBJ}" sec "${CLSACT_SECTION}" da
63
64 BPF_PROG_ID=$(ns1_exec tc filter show dev "${TEST_IF}" ingress | \
65 get_prog_id)
66 ns1_exec "${PROG}" "${BPF_PROG_ID}"
67 ns1_exec tc qdisc del dev "${TEST_IF}" clsact
68
69 printf "Testing XDP..."
70 ns1_exec ip link set "${TEST_IF}" xdp \
71 object "${BPF_PROG_OBJ}" section "${XDP_SECTION}"
72 BPF_PROG_ID=$(ns1_exec ip link show "${TEST_IF}" | get_prog_id)
73 ns1_exec "${PROG}" "${BPF_PROG_ID}"
74}
75
76DIR=$(dirname $0)
77TEST_IF=lo
78MAX_PING_TRIES=5
79BPF_PROG_OBJ="${DIR}/test_tcp_check_syncookie_kern.bpf.o"
80CLSACT_SECTION="tc"
81XDP_SECTION="xdp"
82BPF_PROG_ID=0
83PROG="${DIR}/test_tcp_check_syncookie_user"
84
85main
1#!/bin/sh
2# SPDX-License-Identifier: GPL-2.0
3# Copyright (c) 2018 Facebook
4# Copyright (c) 2019 Cloudflare
5
6set -eu
7
8wait_for_ip()
9{
10 local _i
11 printf "Wait for IP %s to become available " "$1"
12 for _i in $(seq ${MAX_PING_TRIES}); do
13 printf "."
14 if ns1_exec ping -c 1 -W 1 "$1" >/dev/null 2>&1; then
15 echo " OK"
16 return
17 fi
18 sleep 1
19 done
20 echo 1>&2 "ERROR: Timeout waiting for test IP to become available."
21 exit 1
22}
23
24get_prog_id()
25{
26 awk '/ id / {sub(/.* id /, "", $0); print($1)}'
27}
28
29ns1_exec()
30{
31 ip netns exec ns1 "$@"
32}
33
34setup()
35{
36 ip netns add ns1
37 ns1_exec ip link set lo up
38
39 ns1_exec sysctl -w net.ipv4.tcp_syncookies=2
40 ns1_exec sysctl -w net.ipv4.tcp_window_scaling=0
41 ns1_exec sysctl -w net.ipv4.tcp_timestamps=0
42 ns1_exec sysctl -w net.ipv4.tcp_sack=0
43
44 wait_for_ip 127.0.0.1
45 wait_for_ip ::1
46}
47
48cleanup()
49{
50 ip netns del ns1 2>/dev/null || :
51}
52
53main()
54{
55 trap cleanup EXIT 2 3 6 15
56 setup
57
58 printf "Testing clsact..."
59 ns1_exec tc qdisc add dev "${TEST_IF}" clsact
60 ns1_exec tc filter add dev "${TEST_IF}" ingress \
61 bpf obj "${BPF_PROG_OBJ}" sec "${CLSACT_SECTION}" da
62
63 BPF_PROG_ID=$(ns1_exec tc filter show dev "${TEST_IF}" ingress | \
64 get_prog_id)
65 ns1_exec "${PROG}" "${BPF_PROG_ID}"
66 ns1_exec tc qdisc del dev "${TEST_IF}" clsact
67
68 printf "Testing XDP..."
69 ns1_exec ip link set "${TEST_IF}" xdp \
70 object "${BPF_PROG_OBJ}" section "${XDP_SECTION}"
71 BPF_PROG_ID=$(ns1_exec ip link show "${TEST_IF}" | get_prog_id)
72 ns1_exec "${PROG}" "${BPF_PROG_ID}"
73}
74
75DIR=$(dirname $0)
76TEST_IF=lo
77MAX_PING_TRIES=5
78BPF_PROG_OBJ="${DIR}/test_tcp_check_syncookie_kern.o"
79CLSACT_SECTION="clsact/check_syncookie"
80XDP_SECTION="xdp/check_syncookie"
81BPF_PROG_ID=0
82PROG="${DIR}/test_tcp_check_syncookie_user"
83
84main