svn commit: r235022 - projects/iscsi_opt/sys/dev/iscsi/initiator

Kip Macy kmacy at FreeBSD.org
Fri May 4 18:12:54 UTC 2012


Author: kmacy
Date: Fri May  4 18:12:53 2012
New Revision: 235022
URL: http://svn.freebsd.org/changeset/base/235022

Log:
  unfreeze and run queue from isc_out context

Modified:
  projects/iscsi_opt/sys/dev/iscsi/initiator/isc_sm.c
  projects/iscsi_opt/sys/dev/iscsi/initiator/iscsivar.h

Modified: projects/iscsi_opt/sys/dev/iscsi/initiator/isc_sm.c
==============================================================================
--- projects/iscsi_opt/sys/dev/iscsi/initiator/isc_sm.c	Fri May  4 17:18:02 2012	(r235021)
+++ projects/iscsi_opt/sys/dev/iscsi/initiator/isc_sm.c	Fri May  4 18:12:53 2012	(r235022)
@@ -370,14 +370,17 @@ isc_so_snd_upcall(struct socket *so, voi
 		if (sp->cam_sim->devq->send_queue.qfrozen_cnt[0] != 0) 
 			printf("qfrozen_cnt went to bad value %d\n",
 			    sp->cam_sim->devq->send_queue.qfrozen_cnt[0]);
-		sp->cam_sim->devq->send_queue.qfrozen_cnt[0] = 1;
 	}
-	if (sp->cam_sim->devq->send_queue.qfrozen_cnt[0] > 0)
-		xpt_release_simq(sp->cam_sim, 0);
-	else
+	if (sp->cam_sim->devq->send_queue.qfrozen_cnt[0] > 0) {
+		sp->flags |= ISC_QUNFREEZE;
+
+		mtx_lock(&sp->io_mtx);
+		if (sp->flags & ISC_OWAITING)
+			wakeup(&sp->flags);
+		mtx_unlock(&sp->io_mtx);
+	} else
 		printf("queue already released !!! %d\n",
 		    sp->cam_sim->devq->send_queue.qfrozen_cnt[0]);
-	sp->cam_flags &= ~ISC_QFROZEN;
 	mtx_unlock(sp->cam_sim->mtx);
 
 	return (SU_OK);
@@ -643,6 +646,12 @@ ism_out(void *vp)
      sp->flags |= ISC_SM_RUNNING;
      sdebug(3, "started sp->flags=%x", sp->flags);
      do {
+	     CAM_LOCK(sp);
+	     if  (sp->flags & ISC_QUNFREEZE) {
+		     xpt_release_simq(sp->cam_sim, 1);
+		     sp->flags &= ~(ISC_QUNFREEZE|ISC_QFROZEN);
+	     }
+	     CAM_UNLOCK(sp);
          if((sp->flags & ISC_HOLD) == 0) {
 		 error = 0;
 		 if (sx_try_xlock(&sp->tx_sx)) {

Modified: projects/iscsi_opt/sys/dev/iscsi/initiator/iscsivar.h
==============================================================================
--- projects/iscsi_opt/sys/dev/iscsi/initiator/iscsivar.h	Fri May  4 17:18:02 2012	(r235021)
+++ projects/iscsi_opt/sys/dev/iscsi/initiator/iscsivar.h	Fri May  4 18:12:53 2012	(r235022)
@@ -199,7 +199,10 @@ typedef struct isc_session {
      struct cam_sim	*cam_sim;
      struct cam_path	*cam_path;
      struct mtx		cam_mtx;
-#define ISC_QFROZEN   0x1
+#define ISC_QFROZEN     0x1
+#define ISC_QUNFREEZE   0x2
+
+
      int cam_flags;
      /*
       | sysctl stuff


More information about the svn-src-projects mailing list