65 lines
2.6 KiB
Diff
65 lines
2.6 KiB
Diff
|
From 8bd521470df1cb6324520babf9d3a2e96bc7b96e Mon Sep 17 00:00:00 2001
|
||
|
From: Andre Przywara <andre.przywara@arm.com>
|
||
|
Date: Wed, 5 May 2021 09:57:47 +0100
|
||
|
Subject: [PATCH 03/29] mmc: sunxi: Fix MMC clock parent selection
|
||
|
|
||
|
Most Allwinner SoCs which use the so called "new timing mode" in their
|
||
|
MMC controllers actually use the double-rate PLL6/PERIPH0 clock as their
|
||
|
parent input clock. This is interestingly enough compensated by a hidden
|
||
|
"by 2" post-divider in the mod clock, so the divider and actual output
|
||
|
rate stay the same.
|
||
|
|
||
|
Even though for the H6 and H616 (but only for them!) we use the doubled
|
||
|
input clock for the divider computation, we never accounted for the
|
||
|
implicit post-divider, so the clock was only half the speed on those SoCs.
|
||
|
|
||
|
Clean up the code around that selection, to always use the normal PLL6
|
||
|
(PERIPH0(1x)) clock as an input. As the rate and divider are the same,
|
||
|
that makes no difference.
|
||
|
Explain the hardware differences in a comment.
|
||
|
|
||
|
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
|
||
|
---
|
||
|
arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h | 2 +-
|
||
|
drivers/mmc/sunxi_mmc.c | 10 +++++++---
|
||
|
2 files changed, 8 insertions(+), 4 deletions(-)
|
||
|
|
||
|
diff --git a/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h b/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h
|
||
|
index 62abfc4ef6..e000f78ff4 100644
|
||
|
--- a/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h
|
||
|
+++ b/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h
|
||
|
@@ -326,7 +326,7 @@ struct sunxi_ccm_reg {
|
||
|
#define CCM_MMC_CTRL_M(x) ((x) - 1)
|
||
|
#define CCM_MMC_CTRL_N(x) ((x) << 8)
|
||
|
#define CCM_MMC_CTRL_OSCM24 (0x0 << 24)
|
||
|
-#define CCM_MMC_CTRL_PLL6X2 (0x1 << 24)
|
||
|
+#define CCM_MMC_CTRL_PLL6 (0x1 << 24)
|
||
|
#define CCM_MMC_CTRL_PLL_PERIPH2X2 (0x2 << 24)
|
||
|
#define CCM_MMC_CTRL_ENABLE (0x1 << 31)
|
||
|
/* H6 doesn't have these delays */
|
||
|
diff --git a/drivers/mmc/sunxi_mmc.c b/drivers/mmc/sunxi_mmc.c
|
||
|
index 869af993d3..bc68debdad 100644
|
||
|
--- a/drivers/mmc/sunxi_mmc.c
|
||
|
+++ b/drivers/mmc/sunxi_mmc.c
|
||
|
@@ -124,10 +124,14 @@ static int mmc_set_mod_clk(struct sunxi_mmc_priv *priv, unsigned int hz)
|
||
|
#ifdef CONFIG_MACH_SUN9I
|
||
|
pll = CCM_MMC_CTRL_PLL_PERIPH0;
|
||
|
pll_hz = clock_get_pll4_periph0();
|
||
|
-#elif defined(CONFIG_SUN50I_GEN_H6)
|
||
|
- pll = CCM_MMC_CTRL_PLL6X2;
|
||
|
- pll_hz = clock_get_pll6() * 2;
|
||
|
#else
|
||
|
+ /*
|
||
|
+ * SoCs since the A64 (H5, H6, H616) actually use the doubled
|
||
|
+ * rate of PLL6/PERIPH0 as an input clock, but compensate for
|
||
|
+ * that with a fixed post-divider of 2 in the mod clock.
|
||
|
+ * This cancels each other out, so for simplicity we just
|
||
|
+ * pretend it's always PLL6 without a post divider here.
|
||
|
+ */
|
||
|
pll = CCM_MMC_CTRL_PLL6;
|
||
|
pll_hz = clock_get_pll6();
|
||
|
#endif
|
||
|
--
|
||
|
2.31.1
|
||
|
|