Skip to content

Commit 1bc6f6d

Browse files
aford173geertu
authored andcommitted
clk: renesas: rcar-gen3: Add support for ZG clock
A clock used for the 3D graphics appears to be common among multiple SoC's, so add a generic gen3 clock for clocking the graphics. This is similar to the cpg_z_clk, with a different frequency control register and different flags. Instead of duplicating the code, make cpg_z_clk_register into a helper function and call the help function with the FCR and flags as a parameter. Signed-off-by: Adam Ford <aford173@gmail.com> Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be> Link: https://lore.kernel.org/r/20230617150302.38477-1-aford173@gmail.com Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
1 parent 06c2afb commit 1bc6f6d

File tree

2 files changed

+32
-4
lines changed

2 files changed

+32
-4
lines changed

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

Lines changed: 31 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -264,11 +264,13 @@ static const struct clk_ops cpg_z_clk_ops = {
264264
.set_rate = cpg_z_clk_set_rate,
265265
};
266266

267-
static struct clk * __init cpg_z_clk_register(const char *name,
267+
static struct clk * __init __cpg_z_clk_register(const char *name,
268268
const char *parent_name,
269269
void __iomem *reg,
270270
unsigned int div,
271-
unsigned int offset)
271+
unsigned int offset,
272+
unsigned int fcr,
273+
unsigned int flags)
272274
{
273275
struct clk_init_data init = {};
274276
struct cpg_z_clk *zclk;
@@ -280,11 +282,11 @@ static struct clk * __init cpg_z_clk_register(const char *name,
280282

281283
init.name = name;
282284
init.ops = &cpg_z_clk_ops;
283-
init.flags = CLK_SET_RATE_PARENT;
285+
init.flags = flags;
284286
init.parent_names = &parent_name;
285287
init.num_parents = 1;
286288

287-
zclk->reg = reg + CPG_FRQCRC;
289+
zclk->reg = reg + fcr;
288290
zclk->kick_reg = reg + CPG_FRQCRB;
289291
zclk->hw.init = &init;
290292
zclk->mask = GENMASK(offset + 4, offset);
@@ -301,6 +303,27 @@ static struct clk * __init cpg_z_clk_register(const char *name,
301303
return clk;
302304
}
303305

306+
static struct clk * __init cpg_z_clk_register(const char *name,
307+
const char *parent_name,
308+
void __iomem *reg,
309+
unsigned int div,
310+
unsigned int offset)
311+
{
312+
return __cpg_z_clk_register(name, parent_name, reg, div, offset,
313+
CPG_FRQCRC, CLK_SET_RATE_PARENT);
314+
}
315+
316+
static struct clk * __init cpg_zg_clk_register(const char *name,
317+
const char *parent_name,
318+
void __iomem *reg,
319+
unsigned int div,
320+
unsigned int offset)
321+
{
322+
return __cpg_z_clk_register(name, parent_name, reg, div, offset,
323+
CPG_FRQCRB, 0);
324+
325+
}
326+
304327
static const struct clk_div_table cpg_rpcsrc_div_table[] = {
305328
{ 2, 5 }, { 3, 6 }, { 0, 0 },
306329
};
@@ -438,6 +461,10 @@ struct clk * __init rcar_gen3_cpg_clk_register(struct device *dev,
438461
return cpg_z_clk_register(core->name, __clk_get_name(parent),
439462
base, core->div, core->offset);
440463

464+
case CLK_TYPE_GEN3_ZG:
465+
return cpg_zg_clk_register(core->name, __clk_get_name(parent),
466+
base, core->div, core->offset);
467+
441468
case CLK_TYPE_GEN3_OSC:
442469
/*
443470
* Clock combining OSC EXTAL predivider and a fixed divider

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

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@ enum rcar_gen3_clk_types {
2222
CLK_TYPE_GEN3_R,
2323
CLK_TYPE_GEN3_MDSEL, /* Select parent/divider using mode pin */
2424
CLK_TYPE_GEN3_Z,
25+
CLK_TYPE_GEN3_ZG,
2526
CLK_TYPE_GEN3_OSC, /* OSC EXTAL predivider and fixed divider */
2627
CLK_TYPE_GEN3_RCKSEL, /* Select parent/divider using RCKCR.CKSEL */
2728
CLK_TYPE_GEN3_RPCSRC,

0 commit comments

Comments
 (0)