A complete duplication of binding should be allowed if on both new and
duplicated sockets a multicast address is bound and either SO_REUSEPORT or SO_REUSEADDR is set. But actually it works for the following combinations: * SO_REUSEPORT is set for the fist socket and SO_REUSEPORT for the new; * SO_REUSEADDR is set for the fist socket and SO_REUSEADDR for the new; * SO_REUSEPORT is set for the fist socket and SO_REUSEADDR for the new; and fails for this: * SO_REUSEADDR is set for the fist socket and SO_REUSEPORT for the new. Fix the last case. PR: 179901 MFC after: 1 month
This commit is contained in:
parent
d323dc8e3a
commit
69ab640b6b
@ -554,7 +554,7 @@ in_pcbbind_setup(struct inpcb *inp, struct sockaddr *nam, in_addr_t *laddrp,
|
||||
* and a multicast address is bound on both
|
||||
* new and duplicated sockets.
|
||||
*/
|
||||
if (so->so_options & SO_REUSEADDR)
|
||||
if ((so->so_options & (SO_REUSEADDR|SO_REUSEPORT)) != 0)
|
||||
reuseport = SO_REUSEADDR|SO_REUSEPORT;
|
||||
} else if (sin->sin_addr.s_addr != INADDR_ANY) {
|
||||
sin->sin_port = 0; /* yech... */
|
||||
|
@ -156,7 +156,7 @@ in6_pcbbind(register struct inpcb *inp, struct sockaddr *nam,
|
||||
* and a multicast address is bound on both
|
||||
* new and duplicated sockets.
|
||||
*/
|
||||
if (so->so_options & SO_REUSEADDR)
|
||||
if ((so->so_options & (SO_REUSEADDR|SO_REUSEPORT)) != 0)
|
||||
reuseport = SO_REUSEADDR|SO_REUSEPORT;
|
||||
} else if (!IN6_IS_ADDR_UNSPECIFIED(&sin6->sin6_addr)) {
|
||||
struct ifaddr *ifa;
|
||||
|
Loading…
Reference in New Issue
Block a user