HomeFreeBSD

tcp: allow connections to IPv6 anycast address

Description

tcp: allow connections to IPv6 anycast address

currently, we reject incoming TCP connections to an IPv6 anycast address
based on IETF I-D "draft-itojun-ipv6-tcp-to-anycast-01"[0]. the
rationale is that since RFC2373 prohibits sending IPv6 packets with an
anycast address as the source address, it would be impossible to
establish a TCP connection to such an address since the destination host
could not send any replies.

however, this restriction was lifted in RFC4291 and it is no longer
forbidden to send packets from an anycast address; therefore, it's both
possible and permitted to establish a TCP connection using an anycast
address as src or dst address (or both).

based on the above, delete this restriction and allow people to do this.

while there are certain operational reasons to avoid TCP anycast (such
as the risk of the route changing while the connection is open), these
also apply to IPv4 anycast and are specific to the local environment;
for example, it's perfectly valid to have an anycast address which is
only ever assigned to one node.

[0] https://www.ietf.org/archive/id/draft-itojun-ipv6-tcp-to-anycast-01.txt

Reviewed by: tuexen, kevans, adrian
Approved by: kevans (mentor), des (mentor)
Differential Revision: https://reviews.freebsd.org/D50019

Details

Provenance
ivyAuthored on May 19 2025, 12:33 PM
Reviewer
tuexen
Differential Revision
D50019: tcp: allow connections to IPv6 anycast address
Parents
rG28d74f18f1c2: OptionalObsoleteFiles: etc/rc.d/powerd is used/useful without ACPI/APM
Branches
Unknown
Tags
Unknown