summaryrefslogtreecommitdiffstats
path: root/sys/netinet/tcp_input.c
diff options
context:
space:
mode:
authortanimura <tanimura@FreeBSD.org>2002-04-27 08:24:29 +0000
committertanimura <tanimura@FreeBSD.org>2002-04-27 08:24:29 +0000
commitdbb4756491715a06ce4578841f6eba43fc62fa70 (patch)
tree982f8e96f9de9e219deaa4ea138a8334dc086c3c /sys/netinet/tcp_input.c
parentbcaaa89ad095d7a175927dd7e531fa6f278ed18e (diff)
downloadFreeBSD-src-dbb4756491715a06ce4578841f6eba43fc62fa70.zip
FreeBSD-src-dbb4756491715a06ce4578841f6eba43fc62fa70.tar.gz
Add a global sx sigio_lock to protect the pointer to the sigio object
of a socket. This avoids lock order reversal caused by locking a process in pgsigio(). sowakeup() and the callers of it (sowwakeup, soisconnected, etc.) now require sigio_lock to be locked. Provide sowwakeup_locked(), soisconnected_locked(), and so on in case where we have to modify a socket and wake up a process atomically.
Diffstat (limited to 'sys/netinet/tcp_input.c')
-rw-r--r--sys/netinet/tcp_input.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/sys/netinet/tcp_input.c b/sys/netinet/tcp_input.c
index c7533e6..09be5d2 100644
--- a/sys/netinet/tcp_input.c
+++ b/sys/netinet/tcp_input.c
@@ -1842,10 +1842,14 @@ process_ACK:
* specification, but if we don't get a FIN
* we'll hang forever.
*/
+ SIGIO_SLOCK();
if (so->so_state & SS_CANTRCVMORE) {
- soisdisconnected(so);
+ soisdisconnected_locked(so);
+ SIGIO_SUNLOCK();
callout_reset(tp->tt_2msl, tcp_maxidle,
tcp_timer_2msl, tp);
+ } else {
+ SIGIO_SUNLOCK();
}
tp->t_state = TCPS_FIN_WAIT_2;
}
OpenPOWER on IntegriCloud