Page MenuHomeFreeBSD

ip6+carp: revise the generation of ND6 NA
ClosedPublic

Authored by ae on Oct 1 2025, 12:17 PM.
Tags
None
Referenced Files
F135206046: D52825.id163415.diff
Fri, Nov 7, 12:12 PM
Unknown Object (File)
Wed, Nov 5, 3:00 AM
Unknown Object (File)
Tue, Nov 4, 4:55 PM
Unknown Object (File)
Mon, Nov 3, 7:51 AM
Unknown Object (File)
Sun, Nov 2, 5:02 AM
Unknown Object (File)
Tue, Oct 28, 5:26 AM
Unknown Object (File)
Sat, Oct 25, 12:59 PM
Unknown Object (File)
Fri, Oct 24, 9:58 PM

Details

Summary
  • use ND_NA_FLAG_ROUTER flag in carp_send_na() when we work as router
  • use in6addr_any as destination address for nd6_na_output(), then it will use ipv6-all-nodes multicast address.
  • add in6_selectsrc_nbr() function that accepts additional argument ip6_moptions. Use this function from ND6 code to avoid cases when nd6_na_output/nd6_ns_output can not find source address for multicast destinations:
kernel: carp: 83@vlan524: BACKUP -> MASTER (master will time out)
kernel: nd6_na_output: source can't be determined: dst=ff02::1, error=51
  • add some comments from RFC2461 for better understanding.
  • use tlladdr argument as flags and use ND6_NA_OPT_LLA when we need to add target link-layer address option, and ND6_NA_CARP_MASTER when we know that target address is CARP master. Then we can call carp_macmatch6() if target address is CARP master and ND6 NA packet will have correct mac address.
  • move blocks of code where multicast options is initialized and use it when destination address is multicast. Thus we can set M_MCAST flag and prepare ip6_moptions for correct IPv6 source address selection.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable