202 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			202 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
#!/bin/bash
 | 
						|
# SPDX-License-Identifier: GPL-2.0
 | 
						|
#
 | 
						|
# Test that blackhole routes are marked as offloaded and that packets hitting
 | 
						|
# them are dropped by the ASIC and not by the kernel.
 | 
						|
#
 | 
						|
# +---------------------------------+
 | 
						|
# | H1 (vrf)                        |
 | 
						|
# |    + $h1                        |
 | 
						|
# |    | 192.0.2.1/24               |
 | 
						|
# |    | 2001:db8:1::1/64           |
 | 
						|
# |    |                            |
 | 
						|
# |    |  default via 192.0.2.2     |
 | 
						|
# |    |  default via 2001:db8:1::2 |
 | 
						|
# +----|----------------------------+
 | 
						|
#      |
 | 
						|
# +----|----------------------------------------------------------------------+
 | 
						|
# | SW |                                                                      |
 | 
						|
# |    + $rp1                                                                 |
 | 
						|
# |        192.0.2.2/24                                                       |
 | 
						|
# |        2001:db8:1::2/64                                                   |
 | 
						|
# |                                                                           |
 | 
						|
# |        2001:db8:2::2/64                                                   |
 | 
						|
# |        198.51.100.2/24                                                    |
 | 
						|
# |    + $rp2                                                                 |
 | 
						|
# |    |                                                                      |
 | 
						|
# +----|----------------------------------------------------------------------+
 | 
						|
#      |
 | 
						|
# +----|----------------------------+
 | 
						|
# |    |  default via 198.51.100.2  |
 | 
						|
# |    |  default via 2001:db8:2::2 |
 | 
						|
# |    |                            |
 | 
						|
# |    | 2001:db8:2::1/64           |
 | 
						|
# |    | 198.51.100.1/24            |
 | 
						|
# |    + $h2                        |
 | 
						|
# | H2 (vrf)                        |
 | 
						|
# +---------------------------------+
 | 
						|
 | 
						|
lib_dir=$(dirname $0)/../../../net/forwarding
 | 
						|
 | 
						|
ALL_TESTS="
 | 
						|
	ping_ipv4
 | 
						|
	ping_ipv6
 | 
						|
	blackhole_ipv4
 | 
						|
	blackhole_ipv6
 | 
						|
"
 | 
						|
NUM_NETIFS=4
 | 
						|
: ${TIMEOUT:=20000} # ms
 | 
						|
source $lib_dir/tc_common.sh
 | 
						|
source $lib_dir/lib.sh
 | 
						|
 | 
						|
h1_create()
 | 
						|
{
 | 
						|
	simple_if_init $h1 192.0.2.1/24 2001:db8:1::1/64
 | 
						|
 | 
						|
	ip -4 route add default vrf v$h1 nexthop via 192.0.2.2
 | 
						|
	ip -6 route add default vrf v$h1 nexthop via 2001:db8:1::2
 | 
						|
}
 | 
						|
 | 
						|
h1_destroy()
 | 
						|
{
 | 
						|
	ip -6 route del default vrf v$h1 nexthop via 2001:db8:1::2
 | 
						|
	ip -4 route del default vrf v$h1 nexthop via 192.0.2.2
 | 
						|
 | 
						|
	simple_if_fini $h1 192.0.2.1/24 2001:db8:1::1/64
 | 
						|
}
 | 
						|
 | 
						|
h2_create()
 | 
						|
{
 | 
						|
	simple_if_init $h2 198.51.100.1/24 2001:db8:2::1/64
 | 
						|
 | 
						|
	ip -4 route add default vrf v$h2 nexthop via 198.51.100.2
 | 
						|
	ip -6 route add default vrf v$h2 nexthop via 2001:db8:2::2
 | 
						|
}
 | 
						|
 | 
						|
h2_destroy()
 | 
						|
{
 | 
						|
	ip -6 route del default vrf v$h2 nexthop via 2001:db8:2::2
 | 
						|
	ip -4 route del default vrf v$h2 nexthop via 198.51.100.2
 | 
						|
 | 
						|
	simple_if_fini $h2 198.51.100.1/24 2001:db8:2::1/64
 | 
						|
}
 | 
						|
 | 
						|
router_create()
 | 
						|
{
 | 
						|
	ip link set dev $rp1 up
 | 
						|
	ip link set dev $rp2 up
 | 
						|
 | 
						|
	tc qdisc add dev $rp1 clsact
 | 
						|
 | 
						|
	__addr_add_del $rp1 add 192.0.2.2/24 2001:db8:1::2/64
 | 
						|
	__addr_add_del $rp2 add 198.51.100.2/24 2001:db8:2::2/64
 | 
						|
}
 | 
						|
 | 
						|
router_destroy()
 | 
						|
{
 | 
						|
	__addr_add_del $rp2 del 198.51.100.2/24 2001:db8:2::2/64
 | 
						|
	__addr_add_del $rp1 del 192.0.2.2/24 2001:db8:1::2/64
 | 
						|
 | 
						|
	tc qdisc del dev $rp1 clsact
 | 
						|
 | 
						|
	ip link set dev $rp2 down
 | 
						|
	ip link set dev $rp1 down
 | 
						|
}
 | 
						|
 | 
						|
ping_ipv4()
 | 
						|
{
 | 
						|
	ping_test $h1 198.51.100.1 ": h1->h2"
 | 
						|
}
 | 
						|
 | 
						|
ping_ipv6()
 | 
						|
{
 | 
						|
	ping6_test $h1 2001:db8:2::1 ": h1->h2"
 | 
						|
}
 | 
						|
 | 
						|
blackhole_ipv4()
 | 
						|
{
 | 
						|
	# Transmit packets from H1 to H2 and make sure they are dropped by the
 | 
						|
	# ASIC and not by the kernel
 | 
						|
	RET=0
 | 
						|
 | 
						|
	ip -4 route add blackhole 198.51.100.0/30
 | 
						|
	tc filter add dev $rp1 ingress protocol ip pref 1 handle 101 flower \
 | 
						|
		skip_hw dst_ip 198.51.100.1 src_ip 192.0.2.1 ip_proto icmp \
 | 
						|
		action pass
 | 
						|
 | 
						|
	busywait "$TIMEOUT" wait_for_offload ip -4 route show 198.51.100.0/30
 | 
						|
	check_err $? "route not marked as offloaded when should"
 | 
						|
 | 
						|
	ping_do $h1 198.51.100.1
 | 
						|
	check_fail $? "ping passed when should not"
 | 
						|
 | 
						|
	tc_check_packets "dev $rp1 ingress" 101 0
 | 
						|
	check_err $? "packets trapped and not dropped by ASIC"
 | 
						|
 | 
						|
	log_test "IPv4 blackhole route"
 | 
						|
 | 
						|
	tc filter del dev $rp1 ingress protocol ip pref 1 handle 101 flower
 | 
						|
	ip -4 route del blackhole 198.51.100.0/30
 | 
						|
}
 | 
						|
 | 
						|
blackhole_ipv6()
 | 
						|
{
 | 
						|
	RET=0
 | 
						|
 | 
						|
	ip -6 route add blackhole 2001:db8:2::/120
 | 
						|
	tc filter add dev $rp1 ingress protocol ipv6 pref 1 handle 101 flower \
 | 
						|
		skip_hw dst_ip 2001:db8:2::1 src_ip 2001:db8:1::1 \
 | 
						|
		ip_proto icmpv6 action pass
 | 
						|
 | 
						|
	busywait "$TIMEOUT" wait_for_offload ip -6 route show 2001:db8:2::/120
 | 
						|
	check_err $? "route not marked as offloaded when should"
 | 
						|
 | 
						|
	ping6_do $h1 2001:db8:2::1
 | 
						|
	check_fail $? "ping passed when should not"
 | 
						|
 | 
						|
	tc_check_packets "dev $rp1 ingress" 101 0
 | 
						|
	check_err $? "packets trapped and not dropped by ASIC"
 | 
						|
 | 
						|
	log_test "IPv6 blackhole route"
 | 
						|
 | 
						|
	tc filter del dev $rp1 ingress protocol ipv6 pref 1 handle 101 flower
 | 
						|
	ip -6 route del blackhole 2001:db8:2::/120
 | 
						|
}
 | 
						|
 | 
						|
setup_prepare()
 | 
						|
{
 | 
						|
	h1=${NETIFS[p1]}
 | 
						|
	rp1=${NETIFS[p2]}
 | 
						|
 | 
						|
	rp2=${NETIFS[p3]}
 | 
						|
	h2=${NETIFS[p4]}
 | 
						|
 | 
						|
	vrf_prepare
 | 
						|
	forwarding_enable
 | 
						|
 | 
						|
	h1_create
 | 
						|
	h2_create
 | 
						|
	router_create
 | 
						|
}
 | 
						|
 | 
						|
cleanup()
 | 
						|
{
 | 
						|
	pre_cleanup
 | 
						|
 | 
						|
	router_destroy
 | 
						|
	h2_destroy
 | 
						|
	h1_destroy
 | 
						|
 | 
						|
	forwarding_restore
 | 
						|
	vrf_cleanup
 | 
						|
}
 | 
						|
 | 
						|
trap cleanup EXIT
 | 
						|
 | 
						|
setup_prepare
 | 
						|
setup_wait
 | 
						|
 | 
						|
tests_run
 | 
						|
 | 
						|
exit $EXIT_STATUS
 |