scsi: qla2xxx: Check for FW started flag before aborting
authorHimanshu Madhani <hmadhani@marvell.com>
Fri, 15 Feb 2019 22:37:15 +0000 (14:37 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 19 Feb 2019 23:58:36 +0000 (18:58 -0500)
For FC-NVMe, if the fw_started flag is not set or fcport is deleted, then
do not send Abort command

Signed-off-by: Himanshu Madhani <hmadhani@marvell.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/qla2xxx/qla_nvme.c

index 232b987e79dd506f66aa14e1aabd9f5bb03fd1ed..41c85da3ab32a272cb4920d593cdf8349c7e6375 100644 (file)
@@ -185,6 +185,14 @@ static void qla_nvme_abort_work(struct work_struct *work)
        struct qla_hw_data *ha = fcport->vha->hw;
        int rval;
 
+       if (fcport)
+               ql_dbg(ql_dbg_io, fcport->vha, 0xffff,
+                   "%s called for sp=%p, hndl=%x on fcport=%p deleted=%d\n",
+                   __func__, sp, sp->handle, fcport, fcport->deleted);
+
+       if (!ha->flags.fw_started && (fcport && fcport->deleted))
+               return;
+
        rval = ha->isp_ops->abort_command(sp);
 
        ql_dbg(ql_dbg_io, fcport->vha, 0x212b,