]> www.infradead.org Git - nvme.git/commitdiff
clk: samsung: Pass actual CPU clock registers base to CPU_CLK()
authorSam Protsenko <semen.protsenko@linaro.org>
Sat, 24 Feb 2024 20:20:45 +0000 (14:20 -0600)
committerKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Sun, 25 Feb 2024 15:57:18 +0000 (16:57 +0100)
The documentation for struct exynos_cpuclk says .ctrl_base field should
contain the controller base address. There are two different problems
with that:

1. All Exynos clock drivers are actually passing CPU_SRC register offset
   via CPU_CLK() macro, which in turn gets assigned to mentioned
   .ctrl_base field. Because CPU_SRC register usually already has 0x200
   offset from controller's base, all other register offsets in
   clk-cpu.c (like DIVs and MUXes) are specified as offsets from CPU_SRC
   offset, and not from controller's base. That makes things confusing
   and inconsistent with register offsets provided in Exynos clock
   drivers, also breaking the contract for .ctrl_base field as described
   in struct exynos_cpuclk doc.

2. Furthermore, some Exynos chips have an additional offset for the
   start of CPU clock registers block (inside of the CMU). There might
   be different reasons for that, e.g.:

   - The CMU contains clocks for two different CPUs (like in Exynos5420)
   - The CMU contains also non-CPU clocks as well (like in Exynos4)
   - The CPU CMU exists as a dedicated hardware block in the SoC layout,
     but is modelled as a part of bigger CMU in the driver (like in case
     of Exynos3250)

   That means the .ctrl_base field is actually not a controller's base,
   but instead it's a start address of the CPU clock registers inside of
   the CMU.

Rework all register offsets in clk-cpu.c to be actual offsets from the
CPU clock register block start, and fix offsets provided to CPU_CLK()
macro in all Exynos clock drivers. Also clarify the .ctrl_base field
documentation and rename it to just .base, because it doesn't really
contain the CMU base.

No functional change.

Signed-off-by: Sam Protsenko <semen.protsenko@linaro.org>
Link: https://lore.kernel.org/r/20240224202053.25313-8-semen.protsenko@linaro.org
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
drivers/clk/samsung/clk-cpu.c
drivers/clk/samsung/clk-exynos3250.c
drivers/clk/samsung/clk-exynos4.c
drivers/clk/samsung/clk-exynos5250.c
drivers/clk/samsung/clk-exynos5420.c
drivers/clk/samsung/clk-exynos5433.c

index d550a4bb632f03853aa1383a23c275311fcf24f1..82d54b0c90402ef86a592a78f92505b8223a58f4 100644 (file)
@@ -48,7 +48,7 @@ typedef int (*exynos_rate_change_fn_t)(struct clk_notifier_data *ndata,
  * @hw:                handle between CCF and CPU clock
  * @alt_parent:        alternate parent clock to use when switching the speed
  *             of the primary parent clock
- * @ctrl_base: base address of the clock controller
+ * @base:      start address of the CPU clock registers block
  * @lock:      cpu clock domain register access lock
  * @cfg:       cpu clock rate configuration data
  * @num_cfgs:  number of array elements in @cfg array
@@ -64,7 +64,7 @@ typedef int (*exynos_rate_change_fn_t)(struct clk_notifier_data *ndata,
 struct exynos_cpuclk {
        struct clk_hw                           hw;
        const struct clk_hw                     *alt_parent;
-       void __iomem                            *ctrl_base;
+       void __iomem                            *base;
        spinlock_t                              *lock;
        const struct exynos_cpuclk_cfg_data     *cfg;
        const unsigned long                     num_cfgs;
@@ -125,12 +125,12 @@ static void wait_until_mux_stable(void __iomem *mux_reg, u32 mux_pos,
 
 /* ---- Exynos 3/4/5 -------------------------------------------------------- */
 
-#define E4210_SRC_CPU          0x0
-#define E4210_STAT_CPU         0x200
-#define E4210_DIV_CPU0         0x300
-#define E4210_DIV_CPU1         0x304
-#define E4210_DIV_STAT_CPU0    0x400
-#define E4210_DIV_STAT_CPU1    0x404
+#define E4210_SRC_CPU          0x200
+#define E4210_STAT_CPU         0x400
+#define E4210_DIV_CPU0         0x500
+#define E4210_DIV_CPU1         0x504
+#define E4210_DIV_STAT_CPU0    0x600
+#define E4210_DIV_STAT_CPU1    0x604
 
 #define E4210_DIV0_RATIO0_MASK GENMASK(2, 0)
 #define E4210_DIV1_HPM_MASK    GENMASK(6, 4)
@@ -160,7 +160,7 @@ static int exynos_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
                                         struct exynos_cpuclk *cpuclk)
 {
        const struct exynos_cpuclk_cfg_data *cfg_data = cpuclk->cfg;
-       void __iomem *base = cpuclk->ctrl_base;
+       void __iomem *base = cpuclk->base;
        unsigned long alt_prate = clk_hw_get_rate(cpuclk->alt_parent);
        unsigned long div0, div1 = 0, mux_reg;
        unsigned long flags;
@@ -238,7 +238,7 @@ static int exynos_cpuclk_post_rate_change(struct clk_notifier_data *ndata,
                                          struct exynos_cpuclk *cpuclk)
 {
        const struct exynos_cpuclk_cfg_data *cfg_data = cpuclk->cfg;
-       void __iomem *base = cpuclk->ctrl_base;
+       void __iomem *base = cpuclk->base;
        unsigned long div = 0, div_mask = DIV_MASK;
        unsigned long mux_reg;
        unsigned long flags;
@@ -271,12 +271,12 @@ static int exynos_cpuclk_post_rate_change(struct clk_notifier_data *ndata,
 
 /* ---- Exynos5433 ---------------------------------------------------------- */
 
-#define E5433_MUX_SEL2         0x008
-#define E5433_MUX_STAT2                0x208
-#define E5433_DIV_CPU0         0x400
-#define E5433_DIV_CPU1         0x404
-#define E5433_DIV_STAT_CPU0    0x500
-#define E5433_DIV_STAT_CPU1    0x504
+#define E5433_MUX_SEL2         0x208
+#define E5433_MUX_STAT2                0x408
+#define E5433_DIV_CPU0         0x600
+#define E5433_DIV_CPU1         0x604
+#define E5433_DIV_STAT_CPU0    0x700
+#define E5433_DIV_STAT_CPU1    0x704
 
 /*
  * Helper function to set the 'safe' dividers for the CPU clock. The parameters
@@ -299,7 +299,7 @@ static int exynos5433_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
                                             struct exynos_cpuclk *cpuclk)
 {
        const struct exynos_cpuclk_cfg_data *cfg_data = cpuclk->cfg;
-       void __iomem *base = cpuclk->ctrl_base;
+       void __iomem *base = cpuclk->base;
        unsigned long alt_prate = clk_hw_get_rate(cpuclk->alt_parent);
        unsigned long div0, div1 = 0, mux_reg;
        unsigned long flags;
@@ -359,7 +359,7 @@ static int exynos5433_cpuclk_pre_rate_change(struct clk_notifier_data *ndata,
 static int exynos5433_cpuclk_post_rate_change(struct clk_notifier_data *ndata,
                                              struct exynos_cpuclk *cpuclk)
 {
-       void __iomem *base = cpuclk->ctrl_base;
+       void __iomem *base = cpuclk->base;
        unsigned long div = 0, div_mask = DIV_MASK;
        unsigned long mux_reg;
        unsigned long flags;
@@ -461,7 +461,7 @@ static int __init exynos_register_cpu_clock(struct samsung_clk_provider *ctx,
 
        cpuclk->alt_parent = alt_parent;
        cpuclk->hw.init = &init;
-       cpuclk->ctrl_base = ctx->reg_base + clk_data->offset;
+       cpuclk->base = ctx->reg_base + clk_data->offset;
        cpuclk->lock = &ctx->lock;
        cpuclk->flags = clk_data->flags;
        cpuclk->clk_nb.notifier_call = exynos_cpuclk_notifier_cb;
index a024616676640dc1c9033df641381afb14a3f7ff..bf149fae04c37bad551e40516fc53c74c3abd798 100644 (file)
@@ -775,7 +775,7 @@ static const struct exynos_cpuclk_cfg_data e3250_armclk_d[] __initconst = {
 
 static const struct samsung_cpu_clock exynos3250_cpu_clks[] __initconst = {
        CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MPLL_USER_C,
-                       CLK_CPU_HAS_DIV1, 0x14200, e3250_armclk_d),
+               CLK_CPU_HAS_DIV1, 0x14000, e3250_armclk_d),
 };
 
 static void __init exynos3_core_down_clock(void __iomem *reg_base)
index 4ec41221e68f4229db3ea08df1c6c101df4d1b45..d5b1e9f49d8bd78de8281cc02088b78305404068 100644 (file)
@@ -1252,17 +1252,20 @@ static const struct exynos_cpuclk_cfg_data e4412_armclk_d[] __initconst = {
 
 static const struct samsung_cpu_clock exynos4210_cpu_clks[] __initconst = {
        CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_SCLK_MPLL,
-                       CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14200, e4210_armclk_d),
+               CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14000,
+               e4210_armclk_d),
 };
 
 static const struct samsung_cpu_clock exynos4212_cpu_clks[] __initconst = {
        CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MPLL_USER_C,
-               CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14200, e4212_armclk_d),
+               CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14000,
+               e4212_armclk_d),
 };
 
 static const struct samsung_cpu_clock exynos4412_cpu_clks[] __initconst = {
        CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MPLL_USER_C,
-                       CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14200, e4412_armclk_d),
+               CLK_CPU_NEEDS_DEBUG_ALT_DIV | CLK_CPU_HAS_DIV1, 0x14000,
+               e4412_armclk_d),
 };
 
 /* register exynos4 clocks */
index 8ebe6155d8b7064cbeb8b7a8c5a0128a790f26ee..58df80de52effb1dd5d16521f4d8deff278a80a2 100644 (file)
@@ -776,8 +776,8 @@ static const struct exynos_cpuclk_cfg_data exynos5250_armclk_d[] __initconst = {
 };
 
 static const struct samsung_cpu_clock exynos5250_cpu_clks[] __initconst = {
-       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MPLL, CLK_CPU_HAS_DIV1, 0x200,
-                       exynos5250_armclk_d),
+       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MPLL,
+               CLK_CPU_HAS_DIV1, 0x0, exynos5250_armclk_d),
 };
 
 static const struct of_device_id ext_clk_match[] __initconst = {
index 199843f12ae5688522abc4c1190453ee82ff4669..bd7b304d2c002d312c257ae878b5ad07165cf7c6 100644 (file)
@@ -1555,17 +1555,17 @@ static const struct exynos_cpuclk_cfg_data exynos5420_kfcclk_d[] __initconst = {
 };
 
 static const struct samsung_cpu_clock exynos5420_cpu_clks[] __initconst = {
-       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MSPLL_CPU, 0, 0x200,
-                       exynos5420_eglclk_d),
-       CPU_CLK(CLK_KFC_CLK, "kfcclk", CLK_MOUT_KPLL, CLK_MOUT_MSPLL_KFC, 0, 0x28200,
-                       exynos5420_kfcclk_d),
+       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MSPLL_CPU, 0,
+               0x0, exynos5420_eglclk_d),
+       CPU_CLK(CLK_KFC_CLK, "kfcclk", CLK_MOUT_KPLL, CLK_MOUT_MSPLL_KFC, 0,
+               0x28000, exynos5420_kfcclk_d),
 };
 
 static const struct samsung_cpu_clock exynos5800_cpu_clks[] __initconst = {
-       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MSPLL_CPU, 0, 0x200,
-                       exynos5800_eglclk_d),
-       CPU_CLK(CLK_KFC_CLK, "kfcclk", CLK_MOUT_KPLL, CLK_MOUT_MSPLL_KFC, 0, 0x28200,
-                       exynos5420_kfcclk_d),
+       CPU_CLK(CLK_ARM_CLK, "armclk", CLK_MOUT_APLL, CLK_MOUT_MSPLL_CPU, 0,
+               0x0, exynos5800_eglclk_d),
+       CPU_CLK(CLK_KFC_CLK, "kfcclk", CLK_MOUT_KPLL, CLK_MOUT_MSPLL_KFC, 0,
+               0x28000, exynos5420_kfcclk_d),
 };
 
 static const struct of_device_id ext_clk_match[] __initconst = {
index 6bfc5d0cd92478fd0a4982c40a34fe70b59ed35e..d3779eefb438a8a2ae98835fc70cd952153a761f 100644 (file)
@@ -3700,9 +3700,8 @@ static const struct exynos_cpuclk_cfg_data exynos5433_apolloclk_d[] __initconst
 
 static const struct samsung_cpu_clock apollo_cpu_clks[] __initconst = {
        CPU_CLK(CLK_SCLK_APOLLO, "apolloclk", CLK_MOUT_APOLLO_PLL,
-                       CLK_MOUT_BUS_PLL_APOLLO_USER,
-                       CLK_CPU_HAS_E5433_REGS_LAYOUT, 0x200,
-                       exynos5433_apolloclk_d),
+               CLK_MOUT_BUS_PLL_APOLLO_USER, CLK_CPU_HAS_E5433_REGS_LAYOUT,
+               0x0, exynos5433_apolloclk_d),
 };
 
 static const struct samsung_cmu_info apollo_cmu_info __initconst = {
@@ -3945,9 +3944,8 @@ static const struct exynos_cpuclk_cfg_data exynos5433_atlasclk_d[] __initconst =
 
 static const struct samsung_cpu_clock atlas_cpu_clks[] __initconst = {
        CPU_CLK(CLK_SCLK_ATLAS, "atlasclk", CLK_MOUT_ATLAS_PLL,
-                       CLK_MOUT_BUS_PLL_ATLAS_USER,
-                       CLK_CPU_HAS_E5433_REGS_LAYOUT, 0x200,
-                       exynos5433_atlasclk_d),
+               CLK_MOUT_BUS_PLL_ATLAS_USER, CLK_CPU_HAS_E5433_REGS_LAYOUT,
+               0x0, exynos5433_atlasclk_d),
 };
 
 static const struct samsung_cmu_info atlas_cmu_info __initconst = {