#!/bin/bash # SPDX-License-Identifier: GPL-2.0 # Regression Test: # Verify bond interface could up when set IPv6 link local address target. # # +----------------+ # | br0 | # | | | sw # | veth0 veth1 | # +---+-------+----+ # | | # +---+-------+----+ # | veth0 veth1 | # | | | host # | bond0 | # +----------------+ # # We use veths instead of physical interfaces REQUIRE_MZ=no NUM_NETIFS=0 lib_dir=$(dirname "$0") source "$lib_dir"/../../../net/forwarding/lib.sh sw="sw-$(mktemp -u XXXXXX)" host="ns-$(mktemp -u XXXXXX)" cleanup() { ip netns del $sw ip netns del $host } wait_lladdr_dad() { $@ | grep fe80 | grep -qv tentative } wait_bond_up() { $@ | grep -q 'state UP' } trap cleanup 0 1 2 ip netns add $sw ip netns add $host ip -n $host link add veth0 type veth peer name veth0 netns $sw ip -n $host link add veth1 type veth peer name veth1 netns $sw ip -n $sw link add br0 type bridge ip -n $sw link set br0 up sw_lladdr=$(ip -n $sw addr show br0 | awk '/fe80/{print $2}' | cut -d'/' -f1) # wait some time to make sure bridge lladdr pass DAD slowwait 2 wait_lladdr_dad ip -n $sw addr show br0 ip -n $host link add bond0 type bond mode 1 ns_ip6_target ${sw_lladdr} \ arp_validate 3 arp_interval 1000 # add a lladdr for bond to make sure there is a route to target ip -n $host addr add fe80::beef/64 dev bond0 ip -n $host link set bond0 up ip -n $host link set veth0 master bond0 ip -n $host link set veth1 master bond0 ip -n $sw link set veth0 master br0 ip -n $sw link set veth1 master br0 ip -n $sw link set veth0 up ip -n $sw link set veth1 up slowwait 5 wait_bond_up ip -n $host link show bond0 rc=0 if ip -n $host link show bond0 | grep -q LOWER_UP; then echo "PASS" else echo "FAIL" rc=1 fi exit $rc