aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorMike Christie <michaelc@cs.wisc.edu>2006-08-31 18:09:34 -0400
committerJames Bottomley <jejb@mulgrave.il.steeleye.com>2006-09-02 14:37:40 -0400
commite648f63c6520d6e572573149c16a64d2c5ad7ec5 (patch)
tree4561ce970213236ec2c3ee732a053a8ae5917e99 /drivers/scsi
parentf47f2cf5d4acf929a3aaa6957c3fc4622c358703 (diff)
[SCSI] libiscsi: don't call into lld to cleanup task
In the normal IO path we should not be calling back into the LLD since the LLD will have cleaned up the task before or after calling complete pdu. For the fail_command path we still need to do this to force the cleanup. Signed-off-by: Mike Christie <michaelc@cs.wisc.edu> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/libiscsi.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c
index 12b5c180074..c542d0e95e6 100644
--- a/drivers/scsi/libiscsi.c
+++ b/drivers/scsi/libiscsi.c
@@ -213,12 +213,8 @@ static void iscsi_get_ctask(struct iscsi_cmd_task *ctask)
213 213
214static void __iscsi_put_ctask(struct iscsi_cmd_task *ctask) 214static void __iscsi_put_ctask(struct iscsi_cmd_task *ctask)
215{ 215{
216 struct iscsi_conn *conn = ctask->conn; 216 if (atomic_dec_and_test(&ctask->refcount))
217
218 if (atomic_dec_and_test(&ctask->refcount)) {
219 conn->session->tt->cleanup_cmd_task(conn, ctask);
220 iscsi_complete_command(ctask); 217 iscsi_complete_command(ctask);
221 }
222} 218}
223 219
224static void iscsi_put_ctask(struct iscsi_cmd_task *ctask) 220static void iscsi_put_ctask(struct iscsi_cmd_task *ctask)
@@ -1129,10 +1125,13 @@ static void fail_command(struct iscsi_conn *conn, struct iscsi_cmd_task *ctask,
1129 sc = ctask->sc; 1125 sc = ctask->sc;
1130 if (!sc) 1126 if (!sc)
1131 return; 1127 return;
1128
1129 conn->session->tt->cleanup_cmd_task(conn, ctask);
1132 iscsi_ctask_mtask_cleanup(ctask); 1130 iscsi_ctask_mtask_cleanup(ctask);
1133 1131
1134 sc->result = err; 1132 sc->result = err;
1135 sc->resid = sc->request_bufflen; 1133 sc->resid = sc->request_bufflen;
1134 /* release ref from queuecommand */
1136 __iscsi_put_ctask(ctask); 1135 __iscsi_put_ctask(ctask);
1137} 1136}
1138 1137