[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <20210205013633.16243-3-dh0421.hwang@samsung.com>
Date: Fri, 5 Feb 2021 10:36:33 +0900
From: DooHyun Hwang <dh0421.hwang@...sung.com>
To: linux-scsi@...r.kernel.org, linux-kernel@...r.kernel.org,
alim.akhtar@...sung.com, avri.altman@....com, jejb@...ux.ibm.com,
martin.petersen@...cle.com, stanley.chu@...iatek.com,
cang@...eaurora.org, asutoshd@...eaurora.org, beanhuo@...ron.com,
jaegeuk@...nel.org, adrian.hunter@...el.com, satyat@...gle.com
Cc: grant.jung@...sung.com, jt77.jang@...sung.com,
junwoo80.lee@...sung.com, jangsub.yi@...sung.com,
sh043.lee@...sung.com, cw9316.lee@...sung.com,
sh8267.baek@...sung.com, wkon.kim@...sung.com,
DooHyun Hwang <dh0421.hwang@...sung.com>
Subject: [PATCH 3/3] scsi: ufs: reset the ufs device before link startup
retry
If the link startup command fails, trigger hardware reset to reset
the UFS device before link startup retry.
Signed-off-by: DooHyun Hwang <dh0421.hwang@...sung.com>
---
drivers/scsi/ufs/ufshcd.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c
index 32cb3b0dcbcf..a87e98631a72 100644
--- a/drivers/scsi/ufs/ufshcd.c
+++ b/drivers/scsi/ufs/ufshcd.c
@@ -4644,7 +4644,15 @@ static int ufshcd_link_startup(struct ufs_hba *hba)
(u32)ret);
if (link_startup_again) {
+ int err = 0;
+
link_startup_again = false;
+
+ /* Reset the attached device before retrying */
+ err = ufshcd_vops_device_reset(hba);
+ if (err && (err != -EOPNOTSUPP))
+ ufshcd_update_evt_hist(hba, UFS_EVT_DEV_RESET, err);
+
retries = DME_LINKSTARTUP_RETRIES;
goto link_startup;
}
--
2.29.0
Powered by blists - more mailing lists