summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZang Leigang <zangleigang@hisilicon.com>2017-06-24 19:14:32 +0800
committerMartin K. Petersen <martin.petersen@oracle.com>2017-07-01 16:51:23 -0400
commit8dc0da7981a3f9680c873e92e3ec17308377e3b9 (patch)
tree885428a5fe47f61a6867ee9dc7dd91623ae479a4
parent578079fab3f89eda73d7f3bb3bdfdf650ab1b8ec (diff)
downloadlinux-8dc0da7981a3f9680c873e92e3ec17308377e3b9.tar.bz2
scsi: ufs: flush eh_work when eh_work scheduled.
Forget a condition: eh_work scheduled but do not start to work. Signed-off-by: Zang Leigang <zangleigang@hisilicon.com> Reviewed-by: Subhash Jadavani <subhashj@codeaurora.org> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r--drivers/scsi/ufs/ufshcd.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c
index 88ccd63f83c1..5bc9dc14e075 100644
--- a/drivers/scsi/ufs/ufshcd.c
+++ b/drivers/scsi/ufs/ufshcd.c
@@ -5809,7 +5809,8 @@ static int ufshcd_eh_host_reset_handler(struct scsi_cmnd *cmd)
do {
spin_lock_irqsave(hba->host->host_lock, flags);
if (!(work_pending(&hba->eh_work) ||
- hba->ufshcd_state == UFSHCD_STATE_RESET))
+ hba->ufshcd_state == UFSHCD_STATE_RESET ||
+ hba->ufshcd_state == UFSHCD_STATE_EH_SCHEDULED))
break;
spin_unlock_irqrestore(hba->host->host_lock, flags);
dev_dbg(hba->dev, "%s: reset in progress\n", __func__);