On Thu, 2023-12-21 at 19:04 +0800, peter.wang@xxxxxxxxxxxx wrote: > From: Peter Wang <peter.wang@xxxxxxxxxxxx> > > 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@xxxxxxxxxxxx> > --- > 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@xxxxxxxxxxxx> Chun-Hung