[SCSI] iscsi_tcp: don't fire conn error if pdu init fails
If a command's scsi cmd pdu setup fails then we can just fail the IO to the scsi layer. If a DATA_OUT for a R2T fails then we will want to drop the session, because it means we got a bad request from the target (iscsi protocol error). This patch has us propogate the error upwards so libiscsi_tcp or libiscsi can decide what the best action is to take. It also fixes a bug where we could try to grab the session lock while holding it, because if iscsi_tcp drops the session in the pdu setup callout the session lock is held when setting up the scsi cmd pdu. Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com>
This commit is contained in:
parent
70932935b6
commit
9a6510eb3f
@ -463,7 +463,7 @@ static int iscsi_sw_tcp_pdu_init(struct iscsi_task *task,
|
||||
}
|
||||
|
||||
if (err) {
|
||||
iscsi_conn_failure(conn, err);
|
||||
/* got invalid offset/len */
|
||||
return -EIO;
|
||||
}
|
||||
return 0;
|
||||
|
@ -1036,8 +1036,11 @@ flush:
|
||||
|
||||
rc = conn->session->tt->init_pdu(task, r2t->data_offset + r2t->sent,
|
||||
r2t->data_count);
|
||||
if (rc)
|
||||
if (rc) {
|
||||
iscsi_conn_failure(conn, ISCSI_ERR_XMIT_FAILED);
|
||||
return rc;
|
||||
}
|
||||
|
||||
r2t->sent += r2t->data_count;
|
||||
goto flush;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user