]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
scsi: ufs: ufs-mediatek: fix TX LCC disabling timing
authorStanley Chu <stanley.chu@mediatek.com>
Fri, 7 Feb 2020 07:03:56 +0000 (15:03 +0800)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 13 Feb 2020 00:27:15 +0000 (19:27 -0500)
MediaTek UFS host requires TX LCC to be disabled on both host and device
sides. This can be done by disabling host's local TX LCC before link
startup. Correct TX LCC disabling timing in MediaTek UFS driver.

Link: https://lore.kernel.org/r/20200207070357.17169-2-stanley.chu@mediatek.com
Reviewed-by: Avri Altman <avri.altman@wdc.com>
Signed-off-by: Stanley Chu <stanley.chu@mediatek.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/ufs/ufs-mediatek.c

index 0ce08872d6718a0549129bf9da6172d35e99fa9e..8f73c860f423f4e6176e612a39c0601ee0f37e1a 100644 (file)
@@ -313,6 +313,15 @@ static int ufs_mtk_pre_link(struct ufs_hba *hba)
 
        ufs_mtk_unipro_powerdown(hba, 0);
 
+       /*
+        * Setting PA_Local_TX_LCC_Enable to 0 before link startup
+        * to make sure that both host and device TX LCC are disabled
+        * once link startup is completed.
+        */
+       ret = ufshcd_dme_set(hba, UIC_ARG_MIB(PA_LOCAL_TX_LCC_ENABLE), 0);
+       if (ret)
+               return ret;
+
        /* disable deep stall */
        ret = ufshcd_dme_get(hba, UIC_ARG_MIB(VS_SAVEPOWERCONTROL), &tmp);
        if (ret)
@@ -344,9 +353,6 @@ static void ufs_mtk_setup_clk_gating(struct ufs_hba *hba)
 
 static int ufs_mtk_post_link(struct ufs_hba *hba)
 {
-       /* disable device LCC */
-       ufshcd_dme_set(hba, UIC_ARG_MIB(PA_LOCAL_TX_LCC_ENABLE), 0);
-
        /* enable unipro clock gating feature */
        ufs_mtk_cfg_unipro_cg(hba, true);