Commit 62413bac authored by Maya Erez's avatar Maya Erez Committed by Greg Kroah-Hartman

scsi: ufs: fix exception event handling

[ Upstream commit 2e3611e9 ]

The device can set the exception event bit in one of the response UPIU,
for example to notify the need for urgent BKOPs operation.  In such a
case, the host driver calls ufshcd_exception_event_handler to handle
this notification.  When trying to check the exception event status (for
finding the cause for the exception event), the device may be busy with
additional SCSI commands handling and may not respond within the 100ms
timeout.

To prevent that, we need to block SCSI commands during handling of
exception events and allow retransmissions of the query requests, in
case of timeout.
Signed-off-by: default avatarSubhash Jadavani <subhashj@codeaurora.org>
Signed-off-by: default avatarMaya Erez <merez@codeaurora.org>
Signed-off-by: default avatarCan Guo <cang@codeaurora.org>
Signed-off-by: default avatarAsutosh Das <asutoshd@codeaurora.org>
Reviewed-by: default avatarSubhash Jadavani <subhashj@codeaurora.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: default avatarSasha Levin <alexander.levin@microsoft.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3ce14632
...@@ -4012,6 +4012,7 @@ static void ufshcd_exception_event_handler(struct work_struct *work) ...@@ -4012,6 +4012,7 @@ static void ufshcd_exception_event_handler(struct work_struct *work)
hba = container_of(work, struct ufs_hba, eeh_work); hba = container_of(work, struct ufs_hba, eeh_work);
pm_runtime_get_sync(hba->dev); pm_runtime_get_sync(hba->dev);
scsi_block_requests(hba->host);
err = ufshcd_get_ee_status(hba, &status); err = ufshcd_get_ee_status(hba, &status);
if (err) { if (err) {
dev_err(hba->dev, "%s: failed to get exception status %d\n", dev_err(hba->dev, "%s: failed to get exception status %d\n",
...@@ -4025,6 +4026,7 @@ static void ufshcd_exception_event_handler(struct work_struct *work) ...@@ -4025,6 +4026,7 @@ static void ufshcd_exception_event_handler(struct work_struct *work)
ufshcd_bkops_exception_event_handler(hba); ufshcd_bkops_exception_event_handler(hba);
out: out:
scsi_unblock_requests(hba->host);
pm_runtime_put_sync(hba->dev); pm_runtime_put_sync(hba->dev);
return; return;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment