Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 13 Oct 2009 04:26:05 +0000 (UTC)
From:      Kip Macy <kmacy@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-user@freebsd.org
Subject:   svn commit: r198016 - user/kmacy/releng_8_fcs/sys/kern
Message-ID:  <200910130426.n9D4Q59x094646@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: kmacy
Date: Tue Oct 13 04:26:04 2009
New Revision: 198016
URL: http://svn.freebsd.org/changeset/base/198016

Log:
  continue to wait until the residual ref is dropped

Modified:
  user/kmacy/releng_8_fcs/sys/kern/uipc_socket.c

Modified: user/kmacy/releng_8_fcs/sys/kern/uipc_socket.c
==============================================================================
--- user/kmacy/releng_8_fcs/sys/kern/uipc_socket.c	Tue Oct 13 04:14:48 2009	(r198015)
+++ user/kmacy/releng_8_fcs/sys/kern/uipc_socket.c	Tue Oct 13 04:26:04 2009	(r198016)
@@ -624,9 +624,10 @@ sofree(struct socket *so)
 	if (bg_sendfile_enable) {
 		SOCKBUF_LOCK(&so->so_snd);
 		if ((so->so_snd.sb_flags & (SB_SENDING|SB_SENDING_TASK)) ==
-		    (SB_SENDING|SB_SENDING_TASK))
-			sbwait(&so->so_snd);
-		else if (so->so_snd.sb_flags & SB_SENDING)
+		    (SB_SENDING|SB_SENDING_TASK)) {
+			while (so->so_snd.sb_flags & SB_SENDING)
+				sbwait(&so->so_snd);
+		} else if (so->so_snd.sb_flags & SB_SENDING)
 			sosendingwakeup(&so->so_snd);
 		SOCKBUF_UNLOCK(&so->so_snd);
 	}



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200910130426.n9D4Q59x094646>