aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorAnil Gurumurthy <anil.gurumurthy@cavium.com>2018-07-18 17:29:55 -0400
committerMartin K. Petersen <martin.petersen@oracle.com>2018-07-19 22:02:34 -0400
commitb4146c4929ef61d5afca011474d59d0918a0cd82 (patch)
treea0934bba3d4b0703e922b17ff3f85a6bba83cf04 /drivers
parentb08abbd9f5996309f021684f9ca74da30dcca36a (diff)
scsi: qla2xxx: Return error when TMF returns
Propagate the task management completion status properly to avoid unnecessary waits for commands to complete. Fixes: faef62d13463 ("[SCSI] qla2xxx: Fix Task Management command asynchronous handling") Cc: <stable@vger.kernel.org> Signed-off-by: Anil Gurumurthy <anil.gurumurthy@cavium.com> Signed-off-by: Himanshu Madhani <himanshu.madhani@cavium.com> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/qla2xxx/qla_init.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c
index db0e3279e07a..1b19b954bbae 100644
--- a/drivers/scsi/qla2xxx/qla_init.c
+++ b/drivers/scsi/qla2xxx/qla_init.c
@@ -1489,11 +1489,10 @@ qla2x00_async_tm_cmd(fc_port_t *fcport, uint32_t flags, uint32_t lun,
1489 1489
1490 wait_for_completion(&tm_iocb->u.tmf.comp); 1490 wait_for_completion(&tm_iocb->u.tmf.comp);
1491 1491
1492 rval = tm_iocb->u.tmf.comp_status == CS_COMPLETE ? 1492 rval = tm_iocb->u.tmf.data;
1493 QLA_SUCCESS : QLA_FUNCTION_FAILED;
1494 1493
1495 if ((rval != QLA_SUCCESS) || tm_iocb->u.tmf.data) { 1494 if (rval != QLA_SUCCESS) {
1496 ql_dbg(ql_dbg_taskm, vha, 0x8030, 1495 ql_log(ql_log_warn, vha, 0x8030,
1497 "TM IOCB failed (%x).\n", rval); 1496 "TM IOCB failed (%x).\n", rval);
1498 } 1497 }
1499 1498