Skip to content

Commit 724620b

Browse files
committed
clk: renesas: rcar-gen4: Add support for variable fractional PLLs
The custom clock driver that models PLL clocks on R-Car Gen4 supports PLL2 on R-Car V4H/V4M only, while PLL3, PLL4, and PLL6 use the same control register layout. Extend the existing support to PLL3, PLL4, and PLL6, and introduce a new clock type and helper macro to describe these PLLs. Signed-off-by: Geert Uytterhoeven <[email protected]> Reviewed-by: Yoshihiro Shimoda <[email protected]> Link: https://lore.kernel.org/84ead759782560ec5643711e6bdd787a751053ce.1721648548.git.geert+renesas@glider.be
1 parent 1b131e0 commit 724620b

File tree

2 files changed

+18
-7
lines changed

2 files changed

+18
-7
lines changed

drivers/clk/renesas/rcar-gen4-cpg.c

Lines changed: 14 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -188,13 +188,16 @@ static const struct clk_ops cpg_pll_v8_25_clk_ops = {
188188
static struct clk * __init cpg_pll_clk_register(const char *name,
189189
const char *parent_name,
190190
void __iomem *base,
191-
unsigned int cr0_offset,
192-
unsigned int cr1_offset,
193191
unsigned int index)
194-
195192
{
196-
struct cpg_pll_clk *pll_clk;
193+
static const struct { u16 cr0, cr1; } pll_cr_offsets[] __initconst = {
194+
[2 - 2] = { CPG_PLL2CR0, CPG_PLL2CR1 },
195+
[3 - 2] = { CPG_PLL3CR0, CPG_PLL3CR1 },
196+
[4 - 2] = { CPG_PLL4CR0, CPG_PLL4CR1 },
197+
[6 - 2] = { CPG_PLL6CR0, CPG_PLL6CR1 },
198+
};
197199
struct clk_init_data init = {};
200+
struct cpg_pll_clk *pll_clk;
198201
struct clk *clk;
199202

200203
pll_clk = kzalloc(sizeof(*pll_clk), GFP_KERNEL);
@@ -207,8 +210,8 @@ static struct clk * __init cpg_pll_clk_register(const char *name,
207210
init.num_parents = 1;
208211

209212
pll_clk->hw.init = &init;
210-
pll_clk->pllcr0_reg = base + cr0_offset;
211-
pll_clk->pllcr1_reg = base + cr1_offset;
213+
pll_clk->pllcr0_reg = base + pll_cr_offsets[index - 2].cr0;
214+
pll_clk->pllcr1_reg = base + pll_cr_offsets[index - 2].cr1;
212215
pll_clk->pllecr_reg = base + CPG_PLLECR;
213216
pll_clk->pllecr_pllst_mask = CPG_PLLECR_PLLST(index);
214217

@@ -410,7 +413,7 @@ struct clk * __init rcar_gen4_cpg_clk_register(struct device *dev,
410413
* modes.
411414
*/
412415
return cpg_pll_clk_register(core->name, __clk_get_name(parent),
413-
base, CPG_PLL2CR0, CPG_PLL2CR1, 2);
416+
base, 2);
414417

415418
case CLK_TYPE_GEN4_PLL2:
416419
mult = cpg_pll_config->pll2_mult;
@@ -442,6 +445,10 @@ struct clk * __init rcar_gen4_cpg_clk_register(struct device *dev,
442445
mult = (FIELD_GET(CPG_PLLxCR_STC, value) + 1) * 2;
443446
break;
444447

448+
case CLK_TYPE_GEN4_PLL_V8_25:
449+
return cpg_pll_clk_register(core->name, __clk_get_name(parent),
450+
base, core->offset);
451+
445452
case CLK_TYPE_GEN4_Z:
446453
return cpg_z_clk_register(core->name, __clk_get_name(parent),
447454
base, core->div, core->offset);

drivers/clk/renesas/rcar-gen4-cpg.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ enum rcar_gen4_clk_types {
1919
CLK_TYPE_GEN4_PLL4,
2020
CLK_TYPE_GEN4_PLL5,
2121
CLK_TYPE_GEN4_PLL6,
22+
CLK_TYPE_GEN4_PLL_V8_25, /* Variable fractional 8.25 PLL */
2223
CLK_TYPE_GEN4_SDSRC,
2324
CLK_TYPE_GEN4_SDH,
2425
CLK_TYPE_GEN4_SD,
@@ -47,6 +48,9 @@ enum rcar_gen4_clk_types {
4748
#define DEF_GEN4_OSC(_name, _id, _parent, _div) \
4849
DEF_BASE(_name, _id, CLK_TYPE_GEN4_OSC, _parent, .div = _div)
4950

51+
#define DEF_GEN4_PLL_V8_25(_name, _idx, _id, _parent) \
52+
DEF_BASE(_name, _id, CLK_TYPE_GEN4_PLL_V8_25, _parent, .offset = _idx)
53+
5054
#define DEF_GEN4_Z(_name, _id, _type, _parent, _div, _offset) \
5155
DEF_BASE(_name, _id, _type, _parent, .div = _div, .offset = _offset)
5256

0 commit comments

Comments
 (0)