diff options
author | Ludwig Kormann <ludwig.kormann@ict42.de> | 2024-02-01 09:45:50 +0100 |
---|---|---|
committer | Andre Przywara <andre.przywara@arm.com> | 2024-03-03 23:43:43 +0000 |
commit | 3b08e66f69f3bb8a14f771483d3718f67e22709f (patch) | |
tree | 56af9bdb8c9a12037cf9fc2fc9b433e8da5daecb | |
parent | c93a6fc8f5313b2aa7081d53c3061c7c1b94afca (diff) | |
download | u-boot-3b08e66f69f3bb8a14f771483d3718f67e22709f.zip u-boot-3b08e66f69f3bb8a14f771483d3718f67e22709f.tar.gz u-boot-3b08e66f69f3bb8a14f771483d3718f67e22709f.tar.bz2 |
sunxi: sun4i: add missing sdelay() to clock_init_safe()
This delay is required after switching the clock source.
See “A20 Reference manual v1.4” Page 50 / section
“1.5.4.16. CPU/AHB/APB0 CLOCK RATIO”: “If the clock
source is changed, at most to wait for 8 present running
clock cycles.”
This is already implemented in clock_set_pll1(), but was
still missing in clock_init_safe().
Signed-off-by: Ludwig Kormann <ludwig.kormann@ict42.de>
Reviewed-by: Andre Przywara <andre.przywara@arm.com>
-rw-r--r-- | arch/arm/mach-sunxi/clock_sun4i.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/arm/mach-sunxi/clock_sun4i.c b/arch/arm/mach-sunxi/clock_sun4i.c index 8f1d1b6..ac3b7a8 100644 --- a/arch/arm/mach-sunxi/clock_sun4i.c +++ b/arch/arm/mach-sunxi/clock_sun4i.c @@ -25,6 +25,7 @@ void clock_init_safe(void) APB0_DIV_1 << APB0_DIV_SHIFT | CPU_CLK_SRC_OSC24M << CPU_CLK_SRC_SHIFT, &ccm->cpu_ahb_apb0_cfg); + sdelay(20); writel(PLL1_CFG_DEFAULT, &ccm->pll1_cfg); sdelay(200); writel(AXI_DIV_1 << AXI_DIV_SHIFT | @@ -32,6 +33,7 @@ void clock_init_safe(void) APB0_DIV_1 << APB0_DIV_SHIFT | CPU_CLK_SRC_PLL1 << CPU_CLK_SRC_SHIFT, &ccm->cpu_ahb_apb0_cfg); + sdelay(20); #ifdef CONFIG_MACH_SUN7I setbits_le32(&ccm->ahb_gate0, 0x1 << AHB_GATE_OFFSET_DMA); #endif |