[PATCH v1 1/3] ufs: host: mediatek: check link status after exit hibern8
Chun-Hung Wu (巫駿宏)
Chun-hung.Wu at mediatek.com
Sun Dec 24 23:20:15 PST 2023
On Thu, 2023-12-21 at 19:04 +0800, peter.wang at mediatek.com wrote:
> From: Peter Wang <peter.wang at mediatek.com>
>
> To prevent SSU(Active) error, check link status after exit hibern8.
> If link is not VS_LINK_UP, return error and do ufshcd_link_recovery.
>
> Signed-off-by: Peter Wang <peter.wang at mediatek.com>
> ---
> drivers/ufs/host/ufs-mediatek.c | 13 ++++++++++---
> 1 file changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/ufs/host/ufs-mediatek.c b/drivers/ufs/host/ufs-
> mediatek.c
> index fc61790d289b..104354a4d899 100644
> --- a/drivers/ufs/host/ufs-mediatek.c
> +++ b/drivers/ufs/host/ufs-mediatek.c
> @@ -1208,11 +1208,18 @@ static int ufs_mtk_link_set_hpm(struct
> ufs_hba *hba)
> return err;
>
> err = ufshcd_uic_hibern8_exit(hba);
> - if (!err)
> - ufshcd_set_link_active(hba);
> - else
> + if (err)
> return err;
>
> + /* Check link state to make sure exit h8 success */
> + ufs_mtk_wait_idle_state(hba, 5);
> + err = ufs_mtk_wait_link_state(hba, VS_LINK_UP, 100);
> + if (err) {
> + dev_warn(hba->dev, "exit h8 state fail, err=%d\n",
> err);
> + return err;
> + }
> + ufshcd_set_link_active(hba);
> +
> if (!hba->mcq_enabled) {
> err = ufshcd_make_hba_operational(hba);
> } else {
Reviewed-by: Chun-Hung Wu <chun-hung.wu at mediatek.com>
Chun-Hung
More information about the Linux-mediatek
mailing list