diff options
| author | Robert Watson <rwatson@FreeBSD.org> | 2008-01-23 23:40:22 +0000 |
|---|---|---|
| committer | Robert Watson <rwatson@FreeBSD.org> | 2008-01-23 23:40:22 +0000 |
| commit | c909e6c520701f07a27dcd621ca404c38396254f (patch) | |
| tree | a86d677a2482254396c93310a8c8a19831d6d37f | |
| parent | 192942a8ca9840d0456aa8fd899695040dadd4da (diff) | |
Notes
| -rw-r--r-- | sys/netinet/tcp_usrreq.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/sys/netinet/tcp_usrreq.c b/sys/netinet/tcp_usrreq.c index 77413cb6fb6d..f3f836ce312d 100644 --- a/sys/netinet/tcp_usrreq.c +++ b/sys/netinet/tcp_usrreq.c @@ -603,6 +603,7 @@ tcp_usr_accept(struct socket *so, struct sockaddr **nam) inp = sotoinpcb(so); KASSERT(inp != NULL, ("tcp_usr_accept: inp == NULL")); + INP_INFO_RLOCK(&tcbinfo); INP_LOCK(inp); if (inp->inp_vflag & (INP_TIMEWAIT | INP_DROPPED)) { error = ECONNABORTED; @@ -622,6 +623,7 @@ tcp_usr_accept(struct socket *so, struct sockaddr **nam) out: TCPDEBUG2(PRU_ACCEPT); INP_UNLOCK(inp); + INP_INFO_RUNLOCK(&tcbinfo); if (error == 0) *nam = in_sockaddr(port, &addr); return error; |
