The branch stable/13 has been updated by markj: URL: https://cgit.FreeBSD.org/src/commit/?id=14f7dd4744e4ff0e4447fb6b07aea24dbfbda31c
commit 14f7dd4744e4ff0e4447fb6b07aea24dbfbda31c Author: Mark Johnston <[email protected]> AuthorDate: 2022-06-14 15:27:38 +0000 Commit: Mark Johnston <[email protected]> CommitDate: 2022-06-21 12:53:34 +0000 rip6: Fix a lock order reversal in rip6_bind() See also commit 71a1539e3783. Reported by: [email protected] Reported by: [email protected] Reviewed by: glebius Sponsored by: The FreeBSD Foundation (cherry picked from commit a14465e1b9a53d6abf58f42e113c1888ffeebe42) --- sys/netinet6/raw_ip6.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/sys/netinet6/raw_ip6.c b/sys/netinet6/raw_ip6.c index aaba91c6d5e7..445912c965ba 100644 --- a/sys/netinet6/raw_ip6.c +++ b/sys/netinet6/raw_ip6.c @@ -791,11 +791,11 @@ rip6_bind(struct socket *so, struct sockaddr *nam, struct thread *td) return (EADDRNOTAVAIL); } NET_EPOCH_EXIT(et); - INP_INFO_WLOCK(&V_ripcbinfo); INP_WLOCK(inp); + INP_INFO_WLOCK(&V_ripcbinfo); inp->in6p_laddr = addr->sin6_addr; - INP_WUNLOCK(inp); INP_INFO_WUNLOCK(&V_ripcbinfo); + INP_WUNLOCK(inp); return (0); }
