mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-06 04:33:58 +08:00
mmc: sdhci_am654: Enable tuning for SDR50
According to the SW tuning App note[1], tuning is required for all UHS speed modes. Tuning for SDR50 is not enabled in Capabilities by default so enable it from the CTL_CFG registers. [1] https://www.ti.com/lit/pdf/spract9 Signed-off-by: Faiz Abbas <faiz_abbas@ti.com> Link: https://lore.kernel.org/r/20200923105206.7988-7-faiz_abbas@ti.com Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
This commit is contained in:
parent
13ebeae68a
commit
764384d064
@ -19,9 +19,11 @@
|
|||||||
|
|
||||||
/* CTL_CFG Registers */
|
/* CTL_CFG Registers */
|
||||||
#define CTL_CFG_2 0x14
|
#define CTL_CFG_2 0x14
|
||||||
|
#define CTL_CFG_3 0x18
|
||||||
|
|
||||||
#define SLOTTYPE_MASK GENMASK(31, 30)
|
#define SLOTTYPE_MASK GENMASK(31, 30)
|
||||||
#define SLOTTYPE_EMBEDDED BIT(30)
|
#define SLOTTYPE_EMBEDDED BIT(30)
|
||||||
|
#define TUNINGFORSDR50_MASK BIT(13)
|
||||||
|
|
||||||
/* PHY Registers */
|
/* PHY Registers */
|
||||||
#define PHY_CTRL1 0x100
|
#define PHY_CTRL1 0x100
|
||||||
@ -646,6 +648,10 @@ static int sdhci_am654_init(struct sdhci_host *host)
|
|||||||
regmap_update_bits(sdhci_am654->base, CTL_CFG_2, SLOTTYPE_MASK,
|
regmap_update_bits(sdhci_am654->base, CTL_CFG_2, SLOTTYPE_MASK,
|
||||||
ctl_cfg_2);
|
ctl_cfg_2);
|
||||||
|
|
||||||
|
/* Enable tuning for SDR50 */
|
||||||
|
regmap_update_bits(sdhci_am654->base, CTL_CFG_3, TUNINGFORSDR50_MASK,
|
||||||
|
TUNINGFORSDR50_MASK);
|
||||||
|
|
||||||
ret = sdhci_setup_host(host);
|
ret = sdhci_setup_host(host);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user