Commit e92f7cca authored by Michael Turquette's avatar Michael Turquette

clk: meson8b: clean up fixed rate clocks

Remove the fixed_rate registration function and helpers from clkc.[ch].
Replace unnecessary configuration struct with static initialization of
the desired clock type.

While we're here, begin the transition to a proper platform_driver and
call of_clk_add_hw_provider with a shiny new struct clk_hw_onecell_data.
Tested-by: default avatarKevin Hilman <khilman@baylibre.com>
Signed-off-by: default avatarMichael Turquette <mturquette@baylibre.com>
parent 89ef4b62
...@@ -167,36 +167,6 @@ meson_clk_register_fixed_factor(const struct clk_conf *clk_conf, ...@@ -167,36 +167,6 @@ meson_clk_register_fixed_factor(const struct clk_conf *clk_conf,
return clk; return clk;
} }
static struct clk * __init
meson_clk_register_fixed_rate(const struct clk_conf *clk_conf,
void __iomem *clk_base)
{
struct clk *clk;
const struct fixed_rate_conf *fixed_rate_conf;
const struct parm *r;
unsigned long rate;
u32 reg;
fixed_rate_conf = &clk_conf->conf.fixed_rate;
rate = fixed_rate_conf->rate;
if (!rate) {
r = &fixed_rate_conf->rate_parm;
reg = readl(clk_base + clk_conf->reg_off + r->reg_off);
rate = PARM_GET(r->width, r->shift, reg);
}
rate *= 1000000;
clk = clk_register_fixed_rate(NULL,
clk_conf->clk_name,
clk_conf->num_parents
? clk_conf->clks_parent[0] : NULL,
clk_conf->flags, rate);
return clk;
}
void __init meson_clk_register_clks(const struct clk_conf *clk_confs, void __init meson_clk_register_clks(const struct clk_conf *clk_confs,
unsigned int nr_confs, unsigned int nr_confs,
void __iomem *clk_base) void __iomem *clk_base)
...@@ -208,10 +178,6 @@ void __init meson_clk_register_clks(const struct clk_conf *clk_confs, ...@@ -208,10 +178,6 @@ void __init meson_clk_register_clks(const struct clk_conf *clk_confs,
const struct clk_conf *clk_conf = &clk_confs[i]; const struct clk_conf *clk_conf = &clk_confs[i];
switch (clk_conf->clk_type) { switch (clk_conf->clk_type) {
case CLK_FIXED_RATE:
clk = meson_clk_register_fixed_rate(clk_conf,
clk_base);
break;
case CLK_FIXED_FACTOR: case CLK_FIXED_FACTOR:
clk = meson_clk_register_fixed_factor(clk_conf, clk = meson_clk_register_fixed_factor(clk_conf,
clk_base); clk_base);
......
...@@ -69,11 +69,6 @@ struct fixed_fact_conf { ...@@ -69,11 +69,6 @@ struct fixed_fact_conf {
struct parm mult_parm; struct parm mult_parm;
}; };
struct fixed_rate_conf {
unsigned long rate;
struct parm rate_parm;
};
struct composite_conf { struct composite_conf {
struct parm mux_parm; struct parm mux_parm;
struct parm div_parm; struct parm div_parm;
...@@ -89,7 +84,6 @@ struct composite_conf { ...@@ -89,7 +84,6 @@ struct composite_conf {
enum clk_type { enum clk_type {
CLK_FIXED_FACTOR, CLK_FIXED_FACTOR,
CLK_FIXED_RATE,
CLK_COMPOSITE, CLK_COMPOSITE,
CLK_CPU, CLK_CPU,
CLK_PLL, CLK_PLL,
...@@ -105,32 +99,12 @@ struct clk_conf { ...@@ -105,32 +99,12 @@ struct clk_conf {
unsigned long flags; unsigned long flags;
union { union {
struct fixed_fact_conf fixed_fact; struct fixed_fact_conf fixed_fact;
struct fixed_rate_conf fixed_rate;
const struct composite_conf *composite; const struct composite_conf *composite;
struct pll_conf *pll; struct pll_conf *pll;
const struct clk_div_table *div_table; const struct clk_div_table *div_table;
} conf; } conf;
}; };
#define FIXED_RATE_P(_ro, _ci, _cn, _f, _c) \
{ \
.reg_off = (_ro), \
.clk_type = CLK_FIXED_RATE, \
.clk_id = (_ci), \
.clk_name = (_cn), \
.flags = (_f), \
.conf.fixed_rate.rate_parm = _c, \
} \
#define FIXED_RATE(_ci, _cn, _f, _r) \
{ \
.clk_type = CLK_FIXED_RATE, \
.clk_id = (_ci), \
.clk_name = (_cn), \
.flags = (_f), \
.conf.fixed_rate.rate = (_r), \
} \
#define PLL(_ro, _ci, _cn, _cp, _f, _c) \ #define PLL(_ro, _ci, _cn, _cp, _f, _c) \
{ \ { \
.reg_off = (_ro), \ .reg_off = (_ro), \
......
...@@ -33,7 +33,6 @@ ...@@ -33,7 +33,6 @@
* *
* [0] http://dn.odroid.com/S805/Datasheet/S805_Datasheet%20V0.8%2020150126.pdf * [0] http://dn.odroid.com/S805/Datasheet/S805_Datasheet%20V0.8%2020150126.pdf
*/ */
#define MESON8B_REG_CTL0_ADDR 0x0000
#define MESON8B_REG_SYS_CPU_CNTL1 0x015c /* 0x57 offset in data sheet */ #define MESON8B_REG_SYS_CPU_CNTL1 0x015c /* 0x57 offset in data sheet */
#define MESON8B_REG_HHI_MPEG 0x0174 /* 0x5d offset in data sheet */ #define MESON8B_REG_HHI_MPEG 0x0174 /* 0x5d offset in data sheet */
#define MESON8B_REG_MALI 0x01b0 /* 0x6c offset in data sheet */ #define MESON8B_REG_MALI 0x01b0 /* 0x6c offset in data sheet */
...@@ -149,12 +148,25 @@ static const struct composite_conf mali_conf __initconst = { ...@@ -149,12 +148,25 @@ static const struct composite_conf mali_conf __initconst = {
.gate_parm = PARM(0x00, 8, 1), .gate_parm = PARM(0x00, 8, 1),
}; };
static const struct clk_conf meson8b_xtal_conf __initconst = static struct clk_fixed_rate meson8b_xtal = {
FIXED_RATE_P(MESON8B_REG_CTL0_ADDR, CLKID_XTAL, "xtal", 0, .fixed_rate = 24000000,
PARM(0x00, 4, 7)); .hw.init = &(struct clk_init_data){
.name = "xtal",
.num_parents = 0,
.ops = &clk_fixed_rate_ops,
},
};
static struct clk_fixed_rate meson8b_zero = {
.fixed_rate = 0,
.hw.init = &(struct clk_init_data){
.name = "zero",
.num_parents = 0,
.ops = &clk_fixed_rate_ops,
},
};
static const struct clk_conf meson8b_clk_confs[] __initconst = { static const struct clk_conf meson8b_clk_confs[] __initconst = {
FIXED_RATE(CLKID_ZERO, "zero", 0, 0),
PLL(MESON8B_REG_PLL_FIXED, CLKID_PLL_FIXED, "fixed_pll", PLL(MESON8B_REG_PLL_FIXED, CLKID_PLL_FIXED, "fixed_pll",
p_xtal, 0, &pll_confs), p_xtal, 0, &pll_confs),
PLL(MESON8B_REG_PLL_VID, CLKID_PLL_VID, "vid_pll", PLL(MESON8B_REG_PLL_VID, CLKID_PLL_VID, "vid_pll",
...@@ -174,23 +186,29 @@ static const struct clk_conf meson8b_clk_confs[] __initconst = { ...@@ -174,23 +186,29 @@ static const struct clk_conf meson8b_clk_confs[] __initconst = {
CLK_IGNORE_UNUSED, &mali_conf), CLK_IGNORE_UNUSED, &mali_conf),
}; };
/*
* FIXME we cannot register two providers w/o breaking things. Luckily only
* clk81 is actually used by any drivers. Convert clk81 to use
* clk_hw_onecell_data last and flip the switch to call of_clk_add_hw_provider
* instead of of_clk_add_provider in the clk81 conversion patch to keep from
* breaking bisect. Then delete this comment ;-)
*/
static struct clk_hw_onecell_data meson8b_hw_onecell_data = {
.hws = {
[CLKID_XTAL] = &meson8b_xtal.hw,
[CLKID_ZERO] = &meson8b_zero.hw,
},
.num = CLK_NR_CLKS,
};
static void __init meson8b_clkc_init(struct device_node *np) static void __init meson8b_clkc_init(struct device_node *np)
{ {
void __iomem *clk_base; void __iomem *clk_base;
int ret, clkid;
if (!meson_clk_init(np, CLK_NR_CLKS)) if (!meson_clk_init(np, CLK_NR_CLKS))
return; return;
/* XTAL */
clk_base = of_iomap(np, 0);
if (!clk_base) {
pr_err("%s: Unable to map xtal base\n", __func__);
return;
}
meson_clk_register_clks(&meson8b_xtal_conf, 1, clk_base);
iounmap(clk_base);
/* Generic clocks and PLLs */ /* Generic clocks and PLLs */
clk_base = of_iomap(np, 1); clk_base = of_iomap(np, 1);
if (!clk_base) { if (!clk_base) {
...@@ -198,8 +216,29 @@ static void __init meson8b_clkc_init(struct device_node *np) ...@@ -198,8 +216,29 @@ static void __init meson8b_clkc_init(struct device_node *np)
return; return;
} }
/*
* register all clks
* CLKID_UNUSED = 0, so skip it and start with CLKID_XTAL = 1
*/
for (clkid = CLKID_XTAL; clkid < CLK_NR_CLKS; clkid++) {
/* array might be sparse */
if (!meson8b_hw_onecell_data.hws[clkid])
continue;
/* FIXME convert to devm_clk_register */
ret = clk_hw_register(NULL, meson8b_hw_onecell_data.hws[clkid]);
if (ret)
goto unregister;
}
meson_clk_register_clks(meson8b_clk_confs, meson_clk_register_clks(meson8b_clk_confs,
ARRAY_SIZE(meson8b_clk_confs), ARRAY_SIZE(meson8b_clk_confs),
clk_base); clk_base);
return;
/* FIXME remove after converting to platform_driver/devm_clk_register */
unregister:
for (clkid = CLK_NR_CLKS - 1; clkid >= 0; clkid--)
clk_hw_unregister(meson8b_hw_onecell_data.hws[clkid]);
} }
CLK_OF_DECLARE(meson8b_clock, "amlogic,meson8b-clkc", meson8b_clkc_init); CLK_OF_DECLARE(meson8b_clock, "amlogic,meson8b-clkc", meson8b_clkc_init);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment