Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 24 Sep 2013 09:33:31 +0000 (UTC)
From:      Edward Tomasz Napierala <trasz@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r255837 - head/sys/cam/ctl
Message-ID:  <201309240933.r8O9XVUq071471@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: trasz
Date: Tue Sep 24 09:33:31 2013
New Revision: 255837
URL: http://svnweb.freebsd.org/changeset/base/255837

Log:
  Fix a few instances of M_WAITOK in threads marked as prohibited from sleep,
  missed in r255824.
  
  Approved by:	re (kib)
  Sponsored by:	FreeBSD Foundation

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 24 08:40:41 2013	(r255836)
+++ head/sys/cam/ctl/ctl_frontend_iscsi.c	Tue Sep 24 09:33:31 2013	(r255837)
@@ -2306,6 +2306,7 @@ cfiscsi_datamove(union ctl_io *io)
 				if (response == NULL) {
 					CFISCSI_SESSION_WARN(cs, "failed to "
 					    "allocate memory; dropping connection");
+					icl_pdu_free(request);
 					cfiscsi_session_terminate(cs);
 					return;
 				}
@@ -2337,6 +2338,7 @@ cfiscsi_datamove(union ctl_io *io)
 			if (error != 0) {
 				CFISCSI_SESSION_WARN(cs, "failed to "
 				    "allocate memory; dropping connection");
+				icl_pdu_free(request);
 				icl_pdu_free(response);
 				cfiscsi_session_terminate(cs);
 				return;
@@ -2406,7 +2408,13 @@ cfiscsi_datamove(union ctl_io *io)
 		    "task tag 0x%x, target transfer tag 0x%x",
 		    bhssc->bhssc_initiator_task_tag, target_transfer_tag);
 #endif
-		cdw = uma_zalloc(cfiscsi_data_wait_zone, M_WAITOK | M_ZERO);
+		cdw = uma_zalloc(cfiscsi_data_wait_zone, M_NOWAIT | M_ZERO);
+		if (cdw == NULL) {
+			CFISCSI_SESSION_WARN(cs, "failed to "
+			    "allocate memory; dropping connection");
+			icl_pdu_free(request);
+			cfiscsi_session_terminate(cs);
+		}
 		cdw->cdw_ctl_io = io;
 		cdw->cdw_target_transfer_tag = htonl(target_transfer_tag);
 		cdw->cdw_initiator_task_tag = bhssc->bhssc_initiator_task_tag;
@@ -2435,7 +2443,13 @@ cfiscsi_datamove(union ctl_io *io)
 		 * XXX: We should limit the number of outstanding R2T PDUs
 		 * 	per task to MaxOutstandingR2T.
 		 */
-		response = cfiscsi_pdu_new_response(request, M_WAITOK);
+		response = cfiscsi_pdu_new_response(request, M_NOWAIT);
+		if (response == NULL) {
+			CFISCSI_SESSION_WARN(cs, "failed to "
+			    "allocate memory; dropping connection");
+			icl_pdu_free(request);
+			cfiscsi_session_terminate(cs);
+		}
 		bhsr2t = (struct iscsi_bhs_r2t *)response->ip_bhs;
 		bhsr2t->bhsr2t_opcode = ISCSI_BHS_OPCODE_R2T;
 		bhsr2t->bhsr2t_flags = 0x80;



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