summaryrefslogtreecommitdiffstats
path: root/sys/netinet6/in6_pcb.c
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2006-04-25 12:09:58 +0000
committerrwatson <rwatson@FreeBSD.org>2006-04-25 12:09:58 +0000
commit7c7c50f35d219bf0c7436881a1665e1cdf92d60e (patch)
tree011200dff73d659a24e0ad1366f3cbf766fe9876 /sys/netinet6/in6_pcb.c
parentdd8ff1c1c53cd3ecb91f7541d375de215477f888 (diff)
downloadFreeBSD-src-7c7c50f35d219bf0c7436881a1665e1cdf92d60e.zip
FreeBSD-src-7c7c50f35d219bf0c7436881a1665e1cdf92d60e.tar.gz
Move lock assertions to top of in6_pcbladdr(): we still want them to run
even if we're going to return an argument-based error. Assert pcbinfo lock in in6_pcblookup_local(), in6_pcblookup_hash(), since they walk pcbinfo inpcb lists. Assert inpcb and pcbinfo locks in in6_pcbsetport(), since port reservations are changing. MFC after: 3 months
Diffstat (limited to 'sys/netinet6/in6_pcb.c')
-rw-r--r--sys/netinet6/in6_pcb.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/sys/netinet6/in6_pcb.c b/sys/netinet6/in6_pcb.c
index 16b4810..e83d043 100644
--- a/sys/netinet6/in6_pcb.c
+++ b/sys/netinet6/in6_pcb.c
@@ -297,6 +297,9 @@ in6_pcbladdr(inp, nam, plocal_addr6)
struct ifnet *ifp = NULL;
int scope_ambiguous = 0;
+ INP_INFO_WLOCK_ASSERT(inp->inp_pcbinfo);
+ INP_LOCK_ASSERT(inp);
+
if (nam->sa_len != sizeof (*sin6))
return (EINVAL);
if (sin6->sin6_family != AF_INET6)
@@ -309,9 +312,6 @@ in6_pcbladdr(inp, nam, plocal_addr6)
if ((error = sa6_embedscope(sin6, ip6_use_defzone)) != 0)
return(error);
- INP_INFO_WLOCK_ASSERT(inp->inp_pcbinfo);
- INP_LOCK_ASSERT(inp);
-
if (in6_ifaddr) {
/*
* If the destination address is UNSPECIFIED addr,
@@ -723,6 +723,8 @@ in6_pcblookup_local(pcbinfo, laddr, lport_arg, wild_okay)
int matchwild = 3, wildcard;
u_short lport = lport_arg;
+ INP_INFO_WLOCK_ASSERT(pcbinfo);
+
if (!wild_okay) {
struct inpcbhead *head;
/*
@@ -888,6 +890,8 @@ in6_pcblookup_hash(pcbinfo, faddr, fport_arg, laddr, lport_arg, wildcard, ifp)
u_short fport = fport_arg, lport = lport_arg;
int faith;
+ INP_INFO_RLOCK_ASSERT(pcbinfo);
+
if (faithprefix_p != NULL)
faith = (*faithprefix_p)(laddr);
else
OpenPOWER on IntegriCloud