mmc: meson-gx: add support for HS400 mode
authorHeiner Kallweit <hkallweit1@gmail.com>
Tue, 7 Feb 2017 21:35:59 +0000 (22:35 +0100)
committerUlf Hansson <ulf.hansson@linaro.org>
Tue, 14 Feb 2017 08:10:58 +0000 (09:10 +0100)
Add support for HS400 mode.

The driver still misses support for tuning, therefore
highspeed modes like HS400 might not work under all
circumstances yet.

Successfully tested on a Odroid C2 (S905 GXBB).

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: Kevin Hilman <khilman@baylibre.com>
Tested-by: Kevin Hilman <khilman@baylibre.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
drivers/mmc/host/meson-gx-mmc.c

index 3cc6334acdb19141fbd89d17ead929ebde490127..5a959783304bc6fd97cd8edf9cdca6614413cc18 100644 (file)
@@ -83,6 +83,7 @@
 #define   CFG_RC_CC_MASK 0xf
 #define   CFG_STOP_CLOCK BIT(22)
 #define   CFG_CLK_ALWAYS_ON BIT(18)
+#define   CFG_CHK_DS BIT(20)
 #define   CFG_AUTO_CLK BIT(23)
 
 #define SD_EMMC_STATUS 0x48
@@ -408,6 +409,16 @@ static void meson_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
        val &= ~(CFG_RC_CC_MASK << CFG_RC_CC_SHIFT);
        val |= ilog2(SD_EMMC_CFG_CMD_GAP) << CFG_RC_CC_SHIFT;
 
+       val &= ~CFG_DDR;
+       if (ios->timing == MMC_TIMING_UHS_DDR50 ||
+           ios->timing == MMC_TIMING_MMC_DDR52 ||
+           ios->timing == MMC_TIMING_MMC_HS400)
+               val |= CFG_DDR;
+
+       val &= ~CFG_CHK_DS;
+       if (ios->timing == MMC_TIMING_MMC_HS400)
+               val |= CFG_CHK_DS;
+
        writel(val, host->regs + SD_EMMC_CFG);
 
        if (val != orig)