linux/tools/testing/selftests/net/hsr/hsr_redbox.sh

#!/bin/bash
# SPDX-License-Identifier: GPL-2.0

ipv6=false

source ./hsr_common.sh

do_complete_ping_test()
{
	echo "INFO: Initial validation ping (HSR-SAN/RedBox)."
	# Each node has to be able to reach each one.
	do_ping "${ns1}" 100.64.0.2
	do_ping "${ns2}" 100.64.0.1
	# Ping between SANs (test bridge)
	do_ping "${ns4}" 100.64.0.51
	do_ping "${ns5}" 100.64.0.41
	# Ping from SANs to hsr1 (via hsr2) (and opposite)
	do_ping "${ns3}" 100.64.0.1
	do_ping "${ns1}" 100.64.0.3
	do_ping "${ns1}" 100.64.0.41
	do_ping "${ns4}" 100.64.0.1
	do_ping "${ns1}" 100.64.0.51
	do_ping "${ns5}" 100.64.0.1
	stop_if_error "Initial validation failed."

	# Wait for MGNT HSR frames being received and nodes being
	# merged.
	sleep 5

	echo "INFO: Longer ping test (HSR-SAN/RedBox)."
	# Ping from SAN to hsr1 (via hsr2)
	do_ping_long "${ns3}" 100.64.0.1
	# Ping from hsr1 (via hsr2) to SANs (and opposite)
	do_ping_long "${ns1}" 100.64.0.3
	do_ping_long "${ns1}" 100.64.0.41
	do_ping_long "${ns4}" 100.64.0.1
	do_ping_long "${ns1}" 100.64.0.51
	do_ping_long "${ns5}" 100.64.0.1
	stop_if_error "Longer ping test failed."

	echo "INFO: All good."
}

setup_hsr_interfaces()
{
	local HSRv="$1"

	echo "INFO: preparing interfaces for HSRv${HSRv} (HSR-SAN/RedBox)."
#
# IPv4 addresses (100.64.X.Y/24), and [X.Y] is presented on below diagram:
#
#
# |NS1                     |               |NS4                |
# |       [0.1]            |               |                   |
# |    /-- hsr1 --\        |               |    [0.41]         |
# | ns1eth1     ns1eth2    |               |    ns4eth1 (SAN)  |
# |------------------------|               |-------------------|
#      |            |                                |
#      |            |                                |
#      |            |                                |
# |------------------------|   |-------------------------------|
# | ns2eth1     ns2eth2    |   |                  ns3eth2      |
# |    \-- hsr2 --/        |   |                 /             |
# |      [0.2] \           |   |                /              |  |------------|
# |             ns2eth3    |---| ns3eth1 -- ns3br1 -- ns3eth3--|--| ns5eth1    |
# |             (interlink)|   | [0.3]      [0.11]             |  | [0.51]     |
# |NS2 (RedBOX)            |   |NS3 (BR)                       |  | NS5 (SAN)  |
#
#
	# Check if iproute2 supports adding interlink port to hsrX device
	ip link help hsr | grep -q INTERLINK
	[ $? -ne 0 ] && { echo "iproute2: HSR interlink interface not supported!"; exit 0; }

	# Create interfaces for name spaces
	ip link add ns1eth1 netns "${ns1}" type veth peer name ns2eth1 netns "${ns2}"
	ip link add ns1eth2 netns "${ns1}" type veth peer name ns2eth2 netns "${ns2}"
	ip link add ns2eth3 netns "${ns2}" type veth peer name ns3eth1 netns "${ns3}"
	ip link add ns3eth2 netns "${ns3}" type veth peer name ns4eth1 netns "${ns4}"
	ip link add ns3eth3 netns "${ns3}" type veth peer name ns5eth1 netns "${ns5}"

	sleep 1

	ip -n "${ns1}" link set ns1eth1 up
	ip -n "${ns1}" link set ns1eth2 up

	ip -n "${ns2}" link set ns2eth1 up
	ip -n "${ns2}" link set ns2eth2 up
	ip -n "${ns2}" link set ns2eth3 up

	ip -n "${ns3}" link add name ns3br1 type bridge
	ip -n "${ns3}" link set ns3br1 up
	ip -n "${ns3}" link set ns3eth1 master ns3br1 up
	ip -n "${ns3}" link set ns3eth2 master ns3br1 up
	ip -n "${ns3}" link set ns3eth3 master ns3br1 up

	ip -n "${ns4}" link set ns4eth1 up
	ip -n "${ns5}" link set ns5eth1 up

	ip -net "$ns1" link set address 00:11:22:00:01:01 dev ns1eth1
	ip -net "$ns1" link set address 00:11:22:00:01:02 dev ns1eth2

	ip -net "$ns2" link set address 00:11:22:00:02:01 dev ns2eth1
	ip -net "$ns2" link set address 00:11:22:00:02:02 dev ns2eth2
	ip -net "$ns2" link set address 00:11:22:00:02:03 dev ns2eth3

	ip -net "$ns3" link set address 00:11:22:00:03:11 dev ns3eth1
	ip -net "$ns3" link set address 00:11:22:00:03:11 dev ns3eth2
	ip -net "$ns3" link set address 00:11:22:00:03:11 dev ns3eth3
	ip -net "$ns3" link set address 00:11:22:00:03:11 dev ns3br1

	ip -net "$ns4" link set address 00:11:22:00:04:01 dev ns4eth1
	ip -net "$ns5" link set address 00:11:22:00:05:01 dev ns5eth1

	ip -net "${ns1}" link add name hsr1 type hsr slave1 ns1eth1 slave2 ns1eth2 supervision 45 version ${HSRv} proto 0
	ip -net "${ns2}" link add name hsr2 type hsr slave1 ns2eth1 slave2 ns2eth2 interlink ns2eth3 supervision 45 version ${HSRv} proto 0

	ip -n "${ns1}" addr add 100.64.0.1/24 dev hsr1
	ip -n "${ns2}" addr add 100.64.0.2/24 dev hsr2
	ip -n "${ns3}" addr add 100.64.0.11/24 dev ns3br1
	ip -n "${ns3}" addr add 100.64.0.3/24 dev ns3eth1
	ip -n "${ns4}" addr add 100.64.0.41/24 dev ns4eth1
	ip -n "${ns5}" addr add 100.64.0.51/24 dev ns5eth1

	ip -n "${ns1}" link set hsr1 up
	ip -n "${ns2}" link set hsr2 up
}

check_prerequisites
setup_ns ns1 ns2 ns3 ns4 ns5

trap cleanup_all_ns EXIT

setup_hsr_interfaces 1
do_complete_ping_test

exit $ret