svn commit: r338586 - head/sys/cam/ctl

Edward Tomasz Napierala trasz at FreeBSD.org
Tue Sep 11 11:40:00 UTC 2018


Author: trasz
Date: Tue Sep 11 11:39:59 2018
New Revision: 338586
URL: https://svnweb.freebsd.org/changeset/base/338586

Log:
  Make the wait in cfiscsi_offline() interruptible.  This is the second half
  of the fix/workaround for the "ctld hanging on reload" problem.
  
  PR:		220175
  Reported by:	Eugene M. Zheganin <emz at norma.perm.ru>
  Tested by:	Eugene M. Zheganin <emz at norma.perm.ru>
  Approved by:	re (kib)
  MFC after:	2 weeks
  Sponsored by:	playkey.net

Modified:
  head/sys/cam/ctl/ctl_frontend_iscsi.c

Modified: head/sys/cam/ctl/ctl_frontend_iscsi.c
==============================================================================
--- head/sys/cam/ctl/ctl_frontend_iscsi.c	Tue Sep 11 10:10:25 2018	(r338585)
+++ head/sys/cam/ctl/ctl_frontend_iscsi.c	Tue Sep 11 11:39:59 2018	(r338586)
@@ -1434,7 +1434,7 @@ cfiscsi_offline(void *arg)
 	struct cfiscsi_softc *softc;
 	struct cfiscsi_target *ct;
 	struct cfiscsi_session *cs;
-	int online;
+	int error, online;
 
 	ct = (struct cfiscsi_target *)arg;
 	softc = ct->ct_softc;
@@ -1456,8 +1456,14 @@ cfiscsi_offline(void *arg)
 			if (cs->cs_target == ct)
 				break;
 		}
-		if (cs != NULL)
-			cv_wait(&softc->sessions_cv, &softc->lock);
+		if (cs != NULL) {
+			error = cv_wait_sig(&softc->sessions_cv, &softc->lock);
+			if (error != 0) {
+				CFISCSI_SESSION_DEBUG(cs,
+				    "cv_wait failed with error %d\n", error);
+				break;
+			}
+		}
 	} while (cs != NULL && ct->ct_online == 0);
 	mtx_unlock(&softc->lock);
 	if (online > 0)


More information about the svn-src-head mailing list