snic: LUN goes offline due to scsi cmd timeouts
authorNarsimhulu Musini <nmusini@cisco.com>
Thu, 17 Mar 2016 07:51:11 +0000 (00:51 -0700)
committerMartin K. Petersen <martin.petersen@oracle.com>
Mon, 11 Apr 2016 20:57:09 +0000 (16:57 -0400)
- LUN goes offline if there are at least two scsi command timeouts
  Completing the IO with scsi_done() fixes the issue.

Signed-off-by: Narsimhulu Musini <nmusini@cisco.com>
Signed-off-by: Sesidhar Baddela <sebaddel@cisco.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/snic/snic_scsi.c

index e423eaacb926b7846eb48a422c902abe2ee4885b..5a709ebdb282a3f8a5fddd449a4d5afc1d3d3474 100644 (file)
@@ -1465,11 +1465,19 @@ snic_abort_finish(struct snic *snic, struct scsi_cmnd *sc)
        case SNIC_STAT_IO_SUCCESS:
        case SNIC_STAT_IO_NOT_FOUND:
                ret = SUCCESS;
+               /*
+                * If abort path doesn't call scsi_done(),
+                * the # IO timeouts == 2, will cause the LUN offline.
+                * Call scsi_done to complete the IO.
+                */
+               sc->result = (DID_ERROR << 16);
+               sc->scsi_done(sc);
                break;
 
        default:
                /* Firmware completed abort with error */
                ret = FAILED;
+               rqi = NULL;
                break;
        }
 
@@ -1842,6 +1850,9 @@ snic_dr_clean_single_req(struct snic *snic,
 
        snic_release_req_buf(snic, rqi, sc);
 
+       sc->result = (DID_ERROR << 16);
+       sc->scsi_done(sc);
+
        ret = 0;
 
        return ret;
@@ -2396,6 +2407,13 @@ snic_cmpl_pending_tmreq(struct snic *snic, struct scsi_cmnd *sc)
                      "Completing Pending TM Req sc %p, state %s flags 0x%llx\n",
                      sc, snic_io_status_to_str(CMD_STATE(sc)), CMD_FLAGS(sc));
 
+       /*
+        * CASE : FW didn't post itmf completion due to PCIe Errors.
+        * Marking the abort status as Success to call scsi completion
+        * in snic_abort_finish()
+        */
+       CMD_ABTS_STATUS(sc) = SNIC_STAT_IO_SUCCESS;
+
        rqi = (struct snic_req_info *) CMD_SP(sc);
        if (!rqi)
                return;