[PATCH 1/2] sunxi: mmc: Fix T113-s3 MMC clock divider
Peng Fan
peng.fan at nxp.com
Thu Feb 27 01:31:59 CET 2025
Hi Andre,
> Subject: [PATCH 1/2] sunxi: mmc: Fix T113-s3 MMC clock divider
>
> On the Allwinner D1/R528/T113-s3 SoCs the MMC clock source
> selected by mux value 1 is PLL_PERIPH0(1x), not (2x), as in the other
> SoCs.
> But we have still the hidden divisor of 2 in the MMC mod clock, so
> need to explicitly compensate for that on those SoCs.
>
> This leads to the actually programmed clock rate to be double
> compared to before, which increases the MMC performance on those
> SoCs.
>
> Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> Reported-by: Kuba Szczodrzyński <kuba at szczodrzynski.pl>
> ---
> drivers/mmc/sunxi_mmc.c | 7 +++++++
> 1 file changed, 7 insertions(+)
>
> diff --git a/drivers/mmc/sunxi_mmc.c b/drivers/mmc/sunxi_mmc.c
> index 0b56d1405be..8f72d758e46 100644
> --- a/drivers/mmc/sunxi_mmc.c
> +++ b/drivers/mmc/sunxi_mmc.c
> @@ -92,6 +92,13 @@ static int mmc_set_mod_clk(struct
> sunxi_mmc_priv *priv, unsigned int hz)
> pll = CCM_MMC_CTRL_PLL6;
> pll_hz = clock_get_pll6();
> #endif
> + /*
> + * On the D1/R528/T113 mux source 1 refers to
> PLL_PERIPH0(1x),
> + * like for the older SoCs. However we still have the
> hidden
> + * divider of 2x, so compensate for that here.
> + */
> + if (IS_ENABLED(CONFIG_MACH_SUN8I_R528))
Use CONFIG_IS_ENABLED(MACH_SUN8I_R528)?
Regards,
Peng.
> + pll_hz /= 2;
> }
>
> div = pll_hz / hz;
> --
> 2.25.1
More information about the U-Boot
mailing list