[PATCH v2 04/10] clock: a733: implement support for mmc/uart
Yixun Lan
dlan at gentoo.org
Sun Nov 30 22:45:13 CET 2025
Add clock initialization support to set UART/I2C/MMC clock frequency.
Signed-off-by: Yixun Lan <dlan at gentoo.org>
---
arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h | 31 +++++++++++++++++++
arch/arm/include/asm/arch-sunxi/cpu_sunxi_ncat2.h | 36 +++++++++++++++++++++++
arch/arm/mach-sunxi/clock_sun50i_h6.c | 14 ++++++---
3 files changed, 77 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 45fa4ab6e57..3783e5fc0e0 100644
--- a/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h
+++ b/arch/arm/include/asm/arch-sunxi/clock_sun50i_h6.h
@@ -32,6 +32,25 @@
#define CCU_H6_UART_GATE_RESET 0x90c
#define CCU_H6_I2C_GATE_RESET 0x91c
+/* A733 CCU register offsets */
+#define CCU_A733_PLL6_CFG 0x0a0
+#define CCU_A733_APB_UART_CLK_CFG 0x538
+#define CCU_A733_UART_GATE_RESET 0xe00
+
+#ifdef CONFIG_MACH_SUN60I_A733 /* A733 */
+
+#define CCU_PLL6_CFG CCU_A733_PLL6_CFG
+#define CCU_UART_CLK_CFG CCU_A733_APB_UART_CLK_CFG
+#define CCU_UART_GATE_RESET CCU_A733_UART_GATE_RESET
+
+#else /* H6 */
+
+#define CCU_PLL6_CFG CCU_H6_PLL6_CFG
+#define CCU_UART_CLK_CFG CCU_H6_APB2_CFG
+#define CCU_UART_GATE_RESET CCU_H6_UART_GATE_RESET
+
+#endif
+
/* A523 CPU PLL offsets */
#define CPC_CPUA_PLL_CTRL 0x04
#define CPC_DSU_PLL_CTRL 0x08
@@ -65,7 +84,11 @@
#define CCM_PLL5_CTRL_DIV2(div0) ((div0) << 1)
/* pll6 bit field */
+#ifdef CONFIG_MACH_SUN60I_A733
+#define CCM_PLL6_CTRL_P0_SHIFT 20
+#else
#define CCM_PLL6_CTRL_P0_SHIFT 16
+#endif
#define CCM_PLL6_CTRL_P0_MASK (0x7 << CCM_PLL6_CTRL_P0_SHIFT)
#define CCM_PLL6_CTRL_N_SHIFT 8
#define CCM_PLL6_CTRL_N_MASK (0xff << CCM_PLL6_CTRL_N_SHIFT)
@@ -115,6 +138,14 @@
#define CCM_PSI_AHB1_AHB2_DEFAULT 0x03000002 /* 200 MHz */
#define CCM_APB1_DEFAULT 0x03000005 /* APB0 really */
#define CCM_APB2_DEFAULT 0x03000005 /* APB1 really */
+
+#elif CONFIG_MACH_SUN60I_A733 /* A733 */
+
+#define CCM_PLL6_DEFAULT 0xee126310 /* 1200/800/480 MHz */
+#define CCM_PSI_AHB1_AHB2_DEFAULT 0x03000002 /* 200 MHz */
+#define CCM_APB1_DEFAULT 0x03000005 /* APB0 really */
+#define CCM_APB2_DEFAULT 0x03000005 /* APB1 really */
+
#endif
/* apb2 bit field */
diff --git a/arch/arm/include/asm/arch-sunxi/cpu_sunxi_ncat2.h b/arch/arm/include/asm/arch-sunxi/cpu_sunxi_ncat2.h
index bcfdc0a41c5..e12a8c18c8f 100644
--- a/arch/arm/include/asm/arch-sunxi/cpu_sunxi_ncat2.h
+++ b/arch/arm/include/asm/arch-sunxi/cpu_sunxi_ncat2.h
@@ -7,6 +7,18 @@
#ifndef _SUNXI_CPU_SUNXI_NCAT2_H
#define _SUNXI_CPU_SUNXI_NCAT2_H
+#ifdef CONFIG_MACH_SUN60I_A733
+
+#define SUNXI_CCM_BASE 0x02002000
+#define SUNXI_TIMER_BASE 0x02052000
+
+#define SUNXI_TWI0_BASE 0x02510000
+#define SUNXI_TWI1_BASE 0x02511000
+#define SUNXI_TWI2_BASE 0x02512000
+#define SUNXI_TWI3_BASE 0x02513000
+
+#else
+
#define SUNXI_CCM_BASE 0x02001000
#define SUNXI_TIMER_BASE 0x02050000
@@ -15,11 +27,15 @@
#define SUNXI_TWI2_BASE 0x02502800
#define SUNXI_TWI3_BASE 0x02502C00
+#endif
+
#define SUNXI_SRAMC_BASE 0x03000000
/* SID address space starts at 0x03006000, but e-fuse is at offset 0x200 */
#define SUNXI_SIDC_BASE 0x03006000
#define SUNXI_SID_BASE 0x03006200
+#ifndef CONFIG_MACH_SUN60I_A733
#define SUNXI_GIC400_BASE 0x03020000
+#endif
#ifdef CONFIG_MACH_SUN55I_A523
#define SUNXI_DRAM_COM_BASE 0x03120000
@@ -27,10 +43,28 @@
#define SUNXI_DRAM_PHY0_BASE 0x03140000
#endif
+#ifdef CONFIG_MACH_SUN60I_A733
+#define SUNXI_GIC600_BASE 0x03400000
+#endif
+
#define SUNXI_MMC0_BASE 0x04020000
#define SUNXI_MMC1_BASE 0x04021000
#define SUNXI_MMC2_BASE 0x04022000
+#ifdef CONFIG_MACH_SUN60I_A733
+
+#define SUNXI_PRCM_BASE 0x07010000
+#define SUNXI_R_WDOG_BASE 0x07021000
+#define SUNXI_R_CPUCFG_BASE 0x07050000
+#define SUNXI_R_TWI_BASE 0x07083000
+#define SUNXI_RTC_BASE 0x07090000
+
+#define SUNXI_CPUCFG_BASE 0x08860000
+
+#define SUNXI_CPU_PLL_CFG_BASE 0x08870000
+
+#else /* CONFIG_MACH_SUN60I_A733 */
+
#ifndef CONFIG_MACH_SUN55I_A523
#define SUNXI_R_CPUCFG_BASE 0x07000400
#endif
@@ -50,6 +84,8 @@
#define SUNXI_CPU_PLL_CFG_BASE 0x08817000
+#endif /* !CONFIG_MACH_SUN60I_A733 */
+
#ifndef __ASSEMBLY__
void sunxi_board_init(void);
void sunxi_reset(void);
diff --git a/arch/arm/mach-sunxi/clock_sun50i_h6.c b/arch/arm/mach-sunxi/clock_sun50i_h6.c
index 80004f13a1e..5ea27fc56c5 100644
--- a/arch/arm/mach-sunxi/clock_sun50i_h6.c
+++ b/arch/arm/mach-sunxi/clock_sun50i_h6.c
@@ -16,6 +16,10 @@ void clock_init_safe(void)
void *const ccm = (void *)SUNXI_CCM_BASE;
void *const prcm = (void *)SUNXI_PRCM_BASE;
+ /* skip clock init for A733 for now */
+ if (IS_ENABLED(CONFIG_MACH_SUN60I_A733))
+ return;
+
if (IS_ENABLED(CONFIG_MACH_SUN50I_H616))
setbits_le32(prcm + CCU_PRCM_SYS_PWROFF_GATING, 0x10);
if (IS_ENABLED(CONFIG_MACH_SUN55I_A523))
@@ -82,14 +86,14 @@ void clock_init_uart(void)
writel(APB2_CLK_SRC_OSC24M|
APB2_CLK_RATE_N_1|
APB2_CLK_RATE_M(1),
- ccm + CCU_H6_APB2_CFG);
+ ccm + CCU_UART_CLK_CFG);
/* open the clock for uart */
- setbits_le32(ccm + CCU_H6_UART_GATE_RESET,
+ setbits_le32(ccm + CCU_UART_GATE_RESET,
1 << (CONFIG_CONS_INDEX - 1));
/* deassert uart reset */
- setbits_le32(ccm + CCU_H6_UART_GATE_RESET,
+ setbits_le32(ccm + CCU_UART_GATE_RESET,
1 << (RESET_SHIFT + CONFIG_CONS_INDEX - 1));
}
@@ -236,7 +240,7 @@ int clock_twi_onoff(int port, int state)
unsigned int clock_get_pll6(void)
{
void *const ccm = (void *)SUNXI_CCM_BASE;
- uint32_t rval = readl(ccm + CCU_H6_PLL6_CFG);
+ u32 rval = readl(ccm + CCU_PLL6_CFG);
int n = ((rval & CCM_PLL6_CTRL_N_MASK) >> CCM_PLL6_CTRL_N_SHIFT) + 1;
int div2 = ((rval & CCM_PLL6_CTRL_DIV2_MASK) >>
CCM_PLL6_CTRL_DIV2_SHIFT) + 1;
@@ -257,6 +261,8 @@ unsigned int clock_get_pll6(void)
*/
if (IS_ENABLED(CONFIG_MACH_SUN50I_H6))
m = 4;
+ else if (IS_ENABLED(CONFIG_MACH_SUN60I_A733))
+ m = 1;
else
m = 2;
--
2.51.2
More information about the U-Boot
mailing list