mmc: sdhci-esdhci-imx: disable DLL delay line settings explicitly
authorDong Aisheng <aisheng.dong@freescale.com>
Tue, 12 Jul 2016 07:46:14 +0000 (15:46 +0800)
committerUlf Hansson <ulf.hansson@linaro.org>
Mon, 25 Jul 2016 08:34:54 +0000 (10:34 +0200)
Disable DLL delay line settings explicitly during driver initialization
in case ROM/uBoot had set an invalid delay.
e.g. MX6DL ROM has set the default delay line(DLLCTRL) to 0x1000021,
the uSDHC clock timing will become marginal when works on DDR mode
due to default delay and will possibly see CRC errors in case the board
is not perfectly designed on the eMMC chip layout.

Acked-by: Adrian Hunter <adrian.hunter@intel.com>
Signed-off-by: Dong Aisheng <aisheng.dong@nxp.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/sdhci-esdhc-imx.c

index 91c6a68..874d510 100644 (file)
@@ -1187,6 +1187,9 @@ static int sdhci_esdhc_imx_probe(struct platform_device *pdev)
                */
                writel(readl(host->ioaddr + 0x6c) | BIT(7),
                        host->ioaddr + 0x6c);
+
+               /* disable DLL_CTRL delay line settings */
+               writel(0x0, host->ioaddr + ESDHC_DLL_CTRL);
        }
 
        if (imx_data->socdata->flags & ESDHC_FLAG_MAN_TUNING)