OSDN Git Service

scsi: ufs: Improve SCSI abort handling further
authorBart Van Assche <bvanassche@acm.org>
Fri, 3 Dec 2021 23:19:46 +0000 (15:19 -0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Tue, 7 Dec 2021 03:30:34 +0000 (22:30 -0500)
Release resources when aborting a command. Make sure that aborted commands
are completed once by clearing the corresponding tag bit from
hba->outstanding_reqs. This patch is an improved version of commit
3ff1f6b6ba6f ("scsi: ufs: core: Improve SCSI abort handling").

Link: https://lore.kernel.org/r/20211203231950.193369-14-bvanassche@acm.org
Fixes: 7a3e97b0dc4b ("[SCSI] ufshcd: UFS Host controller driver")
Tested-by: Bean Huo <beanhuo@micron.com>
Reviewed-by: Adrian Hunter <adrian.hunter@intel.com>
Reviewed-by: Bean Huo <beanhuo@micron.com>
Signed-off-by: Bart Van Assche <bvanassche@acm.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/ufs/ufshcd.c

index 5a64161..06954a6 100644 (file)
@@ -6984,6 +6984,7 @@ static int ufshcd_abort(struct scsi_cmnd *cmd)
        struct ufshcd_lrb *lrbp = &hba->lrb[tag];
        unsigned long flags;
        int err = FAILED;
+       bool outstanding;
        u32 reg;
 
        WARN_ONCE(tag < 0, "Invalid tag %d\n", tag);
@@ -7061,6 +7062,17 @@ static int ufshcd_abort(struct scsi_cmnd *cmd)
                goto release;
        }
 
+       /*
+        * Clear the corresponding bit from outstanding_reqs since the command
+        * has been aborted successfully.
+        */
+       spin_lock_irqsave(&hba->outstanding_lock, flags);
+       outstanding = __test_and_clear_bit(tag, &hba->outstanding_reqs);
+       spin_unlock_irqrestore(&hba->outstanding_lock, flags);
+
+       if (outstanding)
+               ufshcd_release_scsi_cmd(hba, lrbp);
+
        err = SUCCESS;
 
 release: