[PATCH] mmc: meson-gx: add support for HS400 mode

Neil Armstrong narmstrong at baylibre.com
Mon Feb 6 01:32:41 PST 2017


On 01/27/2017 07:55 PM, Kevin Hilman wrote:
> Heiner Kallweit <hkallweit1 at gmail.com> writes:
> 
>> Add support for HS400 mode.
>>
>> Successfully tested on a Odroid C2 (S905 GXBB).
>>
>> Signed-off-by: Heiner Kallweit <hkallweit1 at gmail.com>
> 
> Excellent!  Thanks for the patch.
> 
> Reviewed-by: Kevin Hilman <khilman at baylibre.com>
> Tested-by: Kevin Hilman <khilman at baylibre.com>
> 
> Some folks on IRC had reported that eMMC wasn't working on some boards
> (like Amlogic P200) and with this patch, it's working again for me on P200.
> 
> @Andreas: does this patch fix your R-box Pro?
> 
> Kevin

Hi Heiner,

Actually activating HS400 and DDR modes should need DT attributes to actually enable them
in the MMC core code, and it seems the hardware needs some timings adjustment to use these
modes. If you consider they are enabled by U-boot, good but it won't always be the case !

Ulf, what is exactly needed to support these modes ?
In other drivers and Amlogic own driver, they have support for the some calibration
commands handling.

Neil

> 
>> ---
>>  drivers/mmc/host/meson-gx-mmc.c | 11 +++++++++++
>>  1 file changed, 11 insertions(+)
>>
>> diff --git a/drivers/mmc/host/meson-gx-mmc.c b/drivers/mmc/host/meson-gx-mmc.c
>> index 030425be..be45d57d 100644
>> --- a/drivers/mmc/host/meson-gx-mmc.c
>> +++ b/drivers/mmc/host/meson-gx-mmc.c
>> @@ -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
>> @@ -412,6 +413,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)




More information about the linux-arm-kernel mailing list