1#!/bin/bash
2# SPDX-License-Identifier: GPL-2.0
3
4ALL_TESTS="
5	ping_ipv4
6	ecn_test
7	ecn_test_perband
8	ecn_nodrop_test
9	red_test
10	mc_backlog_test
11	red_mirror_test
12	red_trap_test
13	ecn_mirror_test
14"
15: ${QDISC:=ets}
16source sch_red_core.sh
17
18# do_ecn_test first build 2/3 of the requested backlog and expects no marking,
19# and then builds 3/2 of it and does expect marking. The values of $BACKLOG1 and
20# $BACKLOG2 are far enough not to overlap, so that we can assume that if we do
21# see (do not see) marking, it is actually due to the configuration of that one
22# TC, and not due to configuration of the other TC leaking over.
23BACKLOG1=200000
24BACKLOG2=500000
25
26install_root_qdisc()
27{
28	tc qdisc add dev $swp3 root handle 10: $QDISC \
29	   bands 8 priomap 7 6 5 4 3 2 1 0
30}
31
32install_qdisc_tc0()
33{
34	local -a args=("$@")
35
36	tc qdisc add dev $swp3 parent 10:8 handle 108: red \
37	   limit 1000000 min $BACKLOG1 max $((BACKLOG1 + 1)) \
38	   probability 1.0 avpkt 8000 burst 38 "${args[@]}"
39}
40
41install_qdisc_tc1()
42{
43	local -a args=("$@")
44
45	tc qdisc add dev $swp3 parent 10:7 handle 107: red \
46	   limit 1000000 min $BACKLOG2 max $((BACKLOG2 + 1)) \
47	   probability 1.0 avpkt 8000 burst 63 "${args[@]}"
48}
49
50install_qdisc()
51{
52	install_root_qdisc
53	install_qdisc_tc0 "$@"
54	install_qdisc_tc1 "$@"
55	sleep 1
56}
57
58uninstall_qdisc_tc0()
59{
60	tc qdisc del dev $swp3 parent 10:8
61}
62
63uninstall_qdisc_tc1()
64{
65	tc qdisc del dev $swp3 parent 10:7
66}
67
68uninstall_root_qdisc()
69{
70	tc qdisc del dev $swp3 root
71}
72
73uninstall_qdisc()
74{
75	uninstall_qdisc_tc0
76	uninstall_qdisc_tc1
77	uninstall_root_qdisc
78}
79
80ecn_test()
81{
82	install_qdisc ecn
83
84	do_ecn_test 10 $BACKLOG1
85	do_ecn_test 11 $BACKLOG2
86
87	uninstall_qdisc
88}
89
90ecn_test_perband()
91{
92	install_qdisc ecn
93
94	do_ecn_test_perband 10 $BACKLOG1
95	do_ecn_test_perband 11 $BACKLOG2
96
97	uninstall_qdisc
98}
99
100ecn_nodrop_test()
101{
102	install_qdisc ecn nodrop
103
104	do_ecn_nodrop_test 10 $BACKLOG1
105	do_ecn_nodrop_test 11 $BACKLOG2
106
107	uninstall_qdisc
108}
109
110red_test()
111{
112	install_qdisc
113
114	# Make sure that we get the non-zero value if there is any.
115	local cur=$(busywait 1100 until_counter_is "> 0" \
116			    qdisc_stats_get $swp3 10: .backlog)
117	(( cur == 0 ))
118	check_err $? "backlog of $cur observed on non-busy qdisc"
119	log_test "$QDISC backlog properly cleaned"
120
121	do_red_test 10 $BACKLOG1
122	do_red_test 11 $BACKLOG2
123
124	uninstall_qdisc
125}
126
127mc_backlog_test()
128{
129	install_qdisc
130
131	# Note that the backlog numbers here do not correspond to RED
132	# configuration, but are arbitrary.
133	do_mc_backlog_test 10 $BACKLOG1
134	do_mc_backlog_test 11 $BACKLOG2
135
136	uninstall_qdisc
137}
138
139red_mirror_test()
140{
141	install_qdisc qevent early_drop block 10
142
143	do_drop_mirror_test 10 $BACKLOG1 early_drop
144	do_drop_mirror_test 11 $BACKLOG2 early_drop
145
146	uninstall_qdisc
147}
148
149red_trap_test()
150{
151	install_qdisc qevent early_drop block 10
152
153	do_drop_trap_test 10 $BACKLOG1 early_drop
154	do_drop_trap_test 11 $BACKLOG2 early_drop
155
156	uninstall_qdisc
157}
158
159ecn_mirror_test()
160{
161	install_qdisc ecn qevent mark block 10
162
163	do_mark_mirror_test 10 $BACKLOG1
164	do_mark_mirror_test 11 $BACKLOG2
165
166	uninstall_qdisc
167}
168
169trap cleanup EXIT
170
171setup_prepare
172setup_wait
173
174bail_on_lldpad
175tests_run
176
177exit $EXIT_STATUS
178