aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi
diff options
context:
space:
mode:
authorZang Leigang <zangleigang@hisilicon.com>2017-04-04 15:32:20 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-04-12 06:41:19 -0400
commita17bddc4a78102ab55c7dbf76018b91e85694b07 (patch)
tree87a6f02eb90ac1140809e478f5412e4e1d56de34 /drivers/scsi
parente94ed347105dff7619d52e24bb8c298c6d5d06fd (diff)
scsi: ufs: introduce a new ufshcd_statea UFSHCD_STATE_EH_SCHEDULED
[ Upstream commit 141f81651037ea109188a6bafdc5c9a318bd5a46 ] Add a new ufshcd_state, indicats that an err handler may get to run immediately. Use UFSHCD_STATE_ERROR here looks not literaly correct. 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> Signed-off-by: Sasha Levin <alexander.levin@verizon.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/scsi')
-rw-r--r--drivers/scsi/ufs/ufshcd.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c
index 6c75f2a0636d..926b58b99811 100644
--- a/drivers/scsi/ufs/ufshcd.c
+++ b/drivers/scsi/ufs/ufshcd.c
@@ -123,6 +123,7 @@ enum {
123 UFSHCD_STATE_RESET, 123 UFSHCD_STATE_RESET,
124 UFSHCD_STATE_ERROR, 124 UFSHCD_STATE_ERROR,
125 UFSHCD_STATE_OPERATIONAL, 125 UFSHCD_STATE_OPERATIONAL,
126 UFSHCD_STATE_EH_SCHEDULED,
126}; 127};
127 128
128/* UFSHCD error handling flags */ 129/* UFSHCD error handling flags */
@@ -1439,6 +1440,7 @@ static int ufshcd_queuecommand(struct Scsi_Host *host, struct scsi_cmnd *cmd)
1439 switch (hba->ufshcd_state) { 1440 switch (hba->ufshcd_state) {
1440 case UFSHCD_STATE_OPERATIONAL: 1441 case UFSHCD_STATE_OPERATIONAL:
1441 break; 1442 break;
1443 case UFSHCD_STATE_EH_SCHEDULED:
1442 case UFSHCD_STATE_RESET: 1444 case UFSHCD_STATE_RESET:
1443 err = SCSI_MLQUEUE_HOST_BUSY; 1445 err = SCSI_MLQUEUE_HOST_BUSY;
1444 goto out_unlock; 1446 goto out_unlock;
@@ -4196,7 +4198,7 @@ static void ufshcd_check_errors(struct ufs_hba *hba)
4196 /* block commands from scsi mid-layer */ 4198 /* block commands from scsi mid-layer */
4197 scsi_block_requests(hba->host); 4199 scsi_block_requests(hba->host);
4198 4200
4199 hba->ufshcd_state = UFSHCD_STATE_ERROR; 4201 hba->ufshcd_state = UFSHCD_STATE_EH_SCHEDULED;
4200 schedule_work(&hba->eh_work); 4202 schedule_work(&hba->eh_work);
4201 } 4203 }
4202 } 4204 }