diff options
author | Abel Vesa <abel.vesa@nxp.com> | 2019-05-29 15:26:44 +0300 |
---|---|---|
committer | Shawn Guo <shawnguo@kernel.org> | 2019-06-07 03:36:32 +0300 |
commit | 2597b39ed1f5d2b8d079e64c309a766dce4ea26b (patch) | |
tree | 31b9458475e45ed8408baafcdb0cad65f0f276fd /drivers/clk/imx/clk-fixup-div.c | |
parent | dfc148b32a795293e032dcc1bbe52829f07c2fe4 (diff) | |
download | linux-2597b39ed1f5d2b8d079e64c309a766dce4ea26b.tar.xz |
clk: imx: clk-fixup-div: Switch to clk_hw based API
Switch the imx_clk_fixup_divider function to clk_hw based API, rename
accordingly and add a macro for clk based legacy. This allows us to
move closer to a clear split between consumer and provider clk APIs.
Signed-off-by: Abel Vesa <abel.vesa@nxp.com>
Reviewed-by: Stephen Boyd <sboyd@kernel.org>
Signed-off-by: Shawn Guo <shawnguo@kernel.org>
Diffstat (limited to 'drivers/clk/imx/clk-fixup-div.c')
-rw-r--r-- | drivers/clk/imx/clk-fixup-div.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/clk/imx/clk-fixup-div.c b/drivers/clk/imx/clk-fixup-div.c index ce5722732715..287539baa301 100644 --- a/drivers/clk/imx/clk-fixup-div.c +++ b/drivers/clk/imx/clk-fixup-div.c @@ -91,13 +91,14 @@ static const struct clk_ops clk_fixup_div_ops = { .set_rate = clk_fixup_div_set_rate, }; -struct clk *imx_clk_fixup_divider(const char *name, const char *parent, +struct clk_hw *imx_clk_hw_fixup_divider(const char *name, const char *parent, void __iomem *reg, u8 shift, u8 width, void (*fixup)(u32 *val)) { struct clk_fixup_div *fixup_div; - struct clk *clk; + struct clk_hw *hw; struct clk_init_data init; + int ret; if (!fixup) return ERR_PTR(-EINVAL); @@ -120,9 +121,13 @@ struct clk *imx_clk_fixup_divider(const char *name, const char *parent, fixup_div->ops = &clk_divider_ops; fixup_div->fixup = fixup; - clk = clk_register(NULL, &fixup_div->divider.hw); - if (IS_ERR(clk)) + hw = &fixup_div->divider.hw; + + ret = clk_hw_register(NULL, hw); + if (ret) { kfree(fixup_div); + return ERR_PTR(ret); + } - return clk; + return hw; } |