diff options
| author | Zang Leigang <zangleigang@hisilicon.com> | 2017-04-04 15:32:20 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-04-12 06:41:19 -0400 |
| commit | a17bddc4a78102ab55c7dbf76018b91e85694b07 (patch) | |
| tree | 87a6f02eb90ac1140809e478f5412e4e1d56de34 /drivers/scsi | |
| parent | e94ed347105dff7619d52e24bb8c298c6d5d06fd (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.c | 4 |
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 | } |
