]> git.baikalelectronics.ru Git - kernel.git/commit
bonding: add all node mcast address when slave up
authorHangbin Liu <liuhangbin@gmail.com>
Tue, 30 Aug 2022 09:37:21 +0000 (17:37 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 5 Sep 2022 09:07:05 +0000 (10:07 +0100)
commit6a7550c490015ab1b6022866b32180af9c6420b1
tree5b90cbff96e46f2a12547a5a3035df29a9cad600
parentc765165dee2a9a286c68e1319441c1d15d1bb9c2
bonding: add all node mcast address when slave up

When a link is enslave to bond, it need to set the interface down first.
This makes the slave remove mac multicast address 33:33:00:00:00:01(The
IPv6 multicast address ff02::1 is kept even when the interface down). When
bond set the slave up, ipv6_mc_up() was not called due to commit bc43c5cd188c
("bonding / ipv6: no addrconf for slaves separately from master").

This is not an issue before we adding the lladdr target feature for bonding,
as the mac multicast address will be added back when bond interface up and
join group ff02::1.

But after adding lladdr target feature for bonding. When user set a lladdr
target, the unsolicited NA message with all-nodes multicast dest will be
dropped as the slave interface never add 33:33:00:00:00:01 back.

Fix this by calling ipv6_mc_up() to add 33:33:00:00:00:01 back when
the slave interface up.

Reported-by: LiLiang <liali@redhat.com>
Fixes: 880632c7e38e ("bonding: NS target should accept link local address")
Signed-off-by: Hangbin Liu <liuhangbin@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv6/addrconf.c