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

Kip Macy kmacy at FreeBSD.org
Fri May 4 17:02:34 UTC 2012


Author: kmacy
Date: Fri May  4 17:02:34 2012
New Revision: 235019
URL: http://svn.freebsd.org/changeset/base/235019

Log:
  queue freeze count may not be zero initially

Modified:
  projects/iscsi_opt/sys/dev/iscsi/initiator/isc_cam.c

Modified: projects/iscsi_opt/sys/dev/iscsi/initiator/isc_cam.c
==============================================================================
--- projects/iscsi_opt/sys/dev/iscsi/initiator/isc_cam.c	Fri May  4 16:53:43 2012	(r235018)
+++ projects/iscsi_opt/sys/dev/iscsi/initiator/isc_cam.c	Fri May  4 17:02:34 2012	(r235019)
@@ -251,14 +251,14 @@ ic_action(struct cam_sim *sim, union ccb
 
 	  if (rc == EWOULDBLOCK) {
 		  if ((sp->cam_flags & ISC_QFROZEN) == 0) {
-			  xpt_freeze_simq(sim, 1);
+			  int freeze_count = xpt_freeze_simq(sim, 1);
 			  sp->cam_flags |= ISC_QFROZEN;
 			  CAM_UNLOCK(sp);
 			  SOCKBUF_LOCK(&sp->soc->so_snd);
 			  CAM_LOCK(sp);
-			  if (sp->cam_sim->devq->send_queue.qfrozen_cnt[0] != 1) {
-				  printf("lost race when acquiring socket buffer lock qfrozen_cnt=%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] != freeze_count) {
+			    printf("lost race when acquiring socket buffer lock qfrozen_cnt=%d freeze_count=%d\n", sp->cam_sim->devq->send_queue.qfrozen_cnt[0], freeze_count);
+				  sp->cam_sim->devq->send_queue.qfrozen_cnt[0] = freeze_count;
 			  }
 			  soupcall_set(sp->soc, SO_SND, isc_so_snd_upcall, sp);
 			  SOCKBUF_UNLOCK(&sp->soc->so_snd);


More information about the svn-src-projects mailing list