]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
sunxi: spl: Fix H616 clock initialization
authorJernej Skrabec <jernej.skrabec@siol.net>
Mon, 1 Feb 2021 17:25:57 +0000 (18:25 +0100)
committerAndre Przywara <andre.przywara@arm.com>
Fri, 19 Feb 2021 23:28:50 +0000 (23:28 +0000)
It turns out that there is a magic bit in PRCM region which seemingly
makes PLLs work if it's enabled. Sadly, there is no documentation what
it does exactly, so we'll just mimick BSP boot0 behaviour and enable it
before any clock is set up.

Fixes: b18bd53d6cde ("sunxi: introduce support for H616 clocks")
Signed-off-by: Jernej Skrabec <jernej.skrabec@siol.net>
Reviewed-by: Andre Przywara <andre.przywara@arm.com>
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
arch/arm/mach-sunxi/clock_sun50i_h6.c

index 06d84eb158d734e9ba29ef2165ad6a51bb5433fd..492fc4a3fca8ab8c018634149991bda052444336 100644 (file)
@@ -9,6 +9,11 @@ void clock_init_safe(void)
 {
        struct sunxi_ccm_reg *const ccm =
                (struct sunxi_ccm_reg *)SUNXI_CCM_BASE;
+
+       /* this seems to enable PLLs on H616 */
+       if (IS_ENABLED(CONFIG_MACH_SUN50I_H616))
+               setbits_le32(SUNXI_PRCM_BASE + 0x250, 0x10);
+
        clock_set_pll1(408000000);
 
        writel(CCM_PLL6_DEFAULT, &ccm->pll6_cfg);