]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
clk: renesas: Add R8A77970 SD0H/SD0 clocks for SDHI
authorHai Pham <hai.pham.ud@renesas.com>
Thu, 26 Jan 2023 20:06:06 +0000 (21:06 +0100)
committerMarek Vasut <marek.vasut+renesas@gmail.com>
Thu, 2 Feb 2023 00:49:20 +0000 (01:49 +0100)
On R-Car V3M (AKA R8A77970), the SD0CKCR is laid out differently than on
the other R-Car gen3 SoCs. Hence, new clock types are introduced
respectively.

Based on Linux commit 381081ffc294 ("clk: renesas: r8a77970: Add SD0H/SD0
clocks for SDHI") by Sergei Shtylyov <sergei.shtylyov@cogentembedded.com>

Signed-off-by: Hai Pham <hai.pham.ud@renesas.com>
Signed-off-by: Marek Vasut <marek.vasut+renesas@mailbox.org>
Marek: - Fix missing ~ in GENMASK(a, b), use clrsetbits_le32 instead
       - Do not modify r8a77970-cpg-mssr.c much, drop enum r8a77970_clk_types
         which is now part of common clock types in rcar-gen3-cpg.h instead

drivers/clk/renesas/clk-rcar-gen3.c
drivers/clk/renesas/r8a77970-cpg-mssr.c
drivers/clk/renesas/rcar-gen3-cpg.h

index 53f16dfb1e0a9f89bc974daede1512d1b49c641f..f8a23623223507d0ce3ab6ccccf619cd31fe231f 100644 (file)
@@ -57,6 +57,18 @@ static const struct clk_div_table cpg_sd_div_table[] = {
        { 0, 2 }, { 1, 4 }, { 0, 0 },
 };
 
+static const struct clk_div_table r8a77970_cpg_sd0h_div_table[] = {
+       {  0,  2 }, {  1,  3 }, {  2,  4 }, {  3,  6 },
+       {  4,  8 }, {  5, 12 }, {  6, 16 }, {  7, 18 },
+       {  8, 24 }, { 10, 36 }, { 11, 48 }, {  0,  0 },
+};
+
+static const struct clk_div_table r8a77970_cpg_sd0_div_table[] = {
+       {  4,  8 }, {  5, 12 }, {  6, 16 }, {  7, 18 },
+       {  8, 24 }, { 10, 36 }, { 11, 48 }, { 12, 10 },
+       {  0,  0 },
+};
+
 static unsigned int rcar_clk_get_table_div(const struct clk_div_table *table,
                                           const u32 value)
 {
@@ -205,6 +217,19 @@ static int gen3_clk_setup_sdif_div(struct clk *clk, ulong rate)
                debug("%s[%i] SD clk: parent=%i offset=%x div=%u rate=%lu => val=%u\n",
                      __func__, __LINE__, core->parent, core->offset, div, rate, value);
                break;
+
+       case CLK_TYPE_R8A77970_SD0:
+               div = gen3_clk_get_rate64(&grandparent) / rate;
+               value = rcar_clk_get_table_val(cpg_sd_div_table, div);
+               if (!value)
+                       return -EINVAL;
+
+               clrsetbits_le32(priv->base + core->offset,
+                               GENMASK(7, 4), value << 4);
+
+               debug("%s[%i] SD clk: parent=%i offset=%x div=%u rate=%lu => val=%u\n",
+                     __func__, __LINE__, core->parent, core->offset, div, rate, value);
+               break;
        }
 
        return 0;
@@ -358,6 +383,13 @@ static u64 gen3_clk_get_rate64(struct clk *clk)
                                                     GENMASK(9, 5),
                                                     cpg_sdh_div_table, "SDH");
 
+       case CLK_TYPE_R8A77970_SD0H:
+               return rcar_clk_get_rate64_div_table(core->parent,
+                                                    gen3_clk_get_rate64(&parent),
+                                                    priv->base + core->offset,
+                                                    CPG_SDCKCR_SDHFC_MASK,
+                                                    r8a77970_cpg_sd0h_div_table, "SDH");
+
        case CLK_TYPE_GEN3_SD:
                fallthrough;
        case CLK_TYPE_GEN4_SD:
@@ -367,6 +399,13 @@ static u64 gen3_clk_get_rate64(struct clk *clk)
                                                     CPG_SDCKCR_FC_MASK,
                                                     cpg_sd_div_table, "SD");
 
+       case CLK_TYPE_R8A77970_SD0:
+               return rcar_clk_get_rate64_div_table(core->parent,
+                                                    gen3_clk_get_rate64(&parent),
+                                                    priv->base + core->offset,
+                                                    CPG_SDCKCR_SD0FC_MASK,
+                                                    r8a77970_cpg_sd0_div_table, "SD");
+
        case CLK_TYPE_GEN3_RPCSRC:
                return rcar_clk_get_rate64_div_table(core->parent,
                                                     gen3_clk_get_rate64(&parent),
index 4d72ec1fae8554f8d06bd873eef32bb7b8103405..f5d77df42335365b13ec4586506bf63fd730ca1f 100644 (file)
 
 #define CPG_SD0CKCR            0x0074
 
-enum r8a77970_clk_types {
-       CLK_TYPE_R8A77970_SD0H = CLK_TYPE_GEN3_SOC_BASE,
-       CLK_TYPE_R8A77970_SD0,
-};
-
 enum clk_ids {
        /* Core Clock Outputs exported to DT */
        LAST_DT_CORE_CLK = R8A77970_CLK_OSC,
index 008e8928e596083ced8430be03c51dd0cc4dd247..200e4adb90655d542875e4729990ab080945b79f 100644 (file)
@@ -18,7 +18,9 @@ enum rcar_gen3_clk_types {
        CLK_TYPE_GEN3_PLL3,
        CLK_TYPE_GEN3_PLL4,
        CLK_TYPE_GEN3_SDH,
+       CLK_TYPE_R8A77970_SD0H,
        CLK_TYPE_GEN3_SD,
+       CLK_TYPE_R8A77970_SD0,
        CLK_TYPE_GEN3_R,
        CLK_TYPE_GEN3_MDSEL,    /* Select parent/divider using mode pin */
        CLK_TYPE_GEN3_Z,
@@ -115,6 +117,9 @@ struct rcar_gen3_cpg_pll_config {
 #define CPG_SDCKCR_STPnCK              BIT(8)
 #define CPG_SDCKCR_SRCFC_MASK          GENMASK(4, 2)
 #define CPG_SDCKCR_FC_MASK             GENMASK(1, 0)
+/* V3M specifics */
+#define CPG_SDCKCR_SDHFC_MASK          GENMASK(11, 8)
+#define CPG_SDCKCR_SD0FC_MASK          GENMASK(7, 4)
 
 #define CPG_RPCCKCR    0x238
 #define CPG_RPCCKCR_DIV_POST_MASK      GENMASK(4, 3)