aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/target/iscsi/iscsi_target.c
diff options
context:
space:
mode:
authorMike Christie <michaelc@cs.wisc.edu>2015-04-10 03:47:27 -0400
committerNicholas Bellinger <nab@linux-iscsi.org>2015-04-10 15:33:55 -0400
commitb815fc12d4dd2b5586184fb4f867caff05a810d4 (patch)
treea166cf4883b28f3cd3f6f10b3bfa3216a4daadf4 /drivers/target/iscsi/iscsi_target.c
parent1997e625963e24994a81070fef169e78965f6496 (diff)
iscsi target: fix oops when adding reject pdu
This fixes a oops due to a double list add when adding a reject PDU for iscsit_allocate_iovecs allocation failures. The cmd has already been added to the conn_cmd_list in iscsit_setup_scsi_cmd, so this has us call iscsit_reject_cmd. Note that for ERL0 the reject PDU is not actually sent, so this patch is not completely tested. Just verified we do not oops. The problem is the add reject functions return -1 which is returned all the way up to iscsi_target_rx_thread which for ERL0 will drop the connection. Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> Cc: <stable@vger.kernel.org> # v3.10+ Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Diffstat (limited to 'drivers/target/iscsi/iscsi_target.c')
-rw-r--r--drivers/target/iscsi/iscsi_target.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/target/iscsi/iscsi_target.c b/drivers/target/iscsi/iscsi_target.c
index d5f66be6988e..77d64251af40 100644
--- a/drivers/target/iscsi/iscsi_target.c
+++ b/drivers/target/iscsi/iscsi_target.c
@@ -1181,7 +1181,7 @@ iscsit_handle_scsi_cmd(struct iscsi_conn *conn, struct iscsi_cmd *cmd,
1181 * traditional iSCSI block I/O. 1181 * traditional iSCSI block I/O.
1182 */ 1182 */
1183 if (iscsit_allocate_iovecs(cmd) < 0) { 1183 if (iscsit_allocate_iovecs(cmd) < 0) {
1184 return iscsit_add_reject_cmd(cmd, 1184 return iscsit_reject_cmd(cmd,
1185 ISCSI_REASON_BOOKMARK_NO_RESOURCES, buf); 1185 ISCSI_REASON_BOOKMARK_NO_RESOURCES, buf);
1186 } 1186 }
1187 immed_data = cmd->immediate_data; 1187 immed_data = cmd->immediate_data;