scsi: qla2xxx: Fix early srb free on abort
Task abort can take 2 paths: 1) serial/synchronous abort where the calling
thread will put to sleep, wait for completion and free cmd resource. 2) async
abort where the cmd free will be free by the completion thread. For path 2,
driver is freeing the SRB too early.
Fixes: f6145e86d2
("scsi: qla2xxx: Fix race between switch cmd completion and timeout")
Cc: stable@vger.kernel.org # 4.19
Signed-off-by: Quinn Tran <quinn.tran@cavium.com>
Signed-off-by: Himanshu Madhani <himanshu.madhani@cavium.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
0645cb8350
commit
8235f4b5ae
|
@ -1850,6 +1850,8 @@ qla24xx_async_abort_cmd(srb_t *cmd_sp, bool wait)
|
||||||
wait_for_completion(&abt_iocb->u.abt.comp);
|
wait_for_completion(&abt_iocb->u.abt.comp);
|
||||||
rval = abt_iocb->u.abt.comp_status == CS_COMPLETE ?
|
rval = abt_iocb->u.abt.comp_status == CS_COMPLETE ?
|
||||||
QLA_SUCCESS : QLA_FUNCTION_FAILED;
|
QLA_SUCCESS : QLA_FUNCTION_FAILED;
|
||||||
|
} else {
|
||||||
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
done_free_sp:
|
done_free_sp:
|
||||||
|
|
Loading…
Reference in New Issue