提交 eb378df7 编写于 作者: C Chen-Yu Tsai 提交者: Maxime Ripard

clk: sunxi: Add a common setup function for mmc module clocks

The only difference between module clocks on different platforms is the
width of the mux register bits and the valid values, which are passed in
through struct factors_data. The phase clocks parts are identical.

This patch generalizes the setup function, so most of the code can be
reused when adding sun9i support, which has a wider mux register.
Signed-off-by: NChen-Yu Tsai <wens@csie.org>
Signed-off-by: NMaxime Ripard <maxime.ripard@free-electrons.com>
上级 a7d19057
...@@ -272,9 +272,16 @@ static const struct clk_ops mmc_clk_ops = { ...@@ -272,9 +272,16 @@ static const struct clk_ops mmc_clk_ops = {
.set_phase = mmc_set_phase, .set_phase = mmc_set_phase,
}; };
static DEFINE_SPINLOCK(sun4i_a10_mmc_lock); /*
* sunxi_mmc_setup - Common setup function for mmc module clocks
static void __init sun4i_a10_mmc_setup(struct device_node *node) *
* The only difference between module clocks on different platforms is the
* width of the mux register bits and the valid values, which are passed in
* through struct factors_data. The phase clocks parts are identical.
*/
static void __init sunxi_mmc_setup(struct device_node *node,
const struct factors_data *data,
spinlock_t *lock)
{ {
struct clk_onecell_data *clk_data; struct clk_onecell_data *clk_data;
const char *parent; const char *parent;
...@@ -296,9 +303,7 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node) ...@@ -296,9 +303,7 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node)
goto err_free_data; goto err_free_data;
clk_data->clk_num = 3; clk_data->clk_num = 3;
clk_data->clks[0] = sunxi_factors_register(node, clk_data->clks[0] = sunxi_factors_register(node, data, lock, reg);
&sun4i_a10_mod0_data,
&sun4i_a10_mmc_lock, reg);
if (!clk_data->clks[0]) if (!clk_data->clks[0])
goto err_free_clks; goto err_free_clks;
...@@ -318,7 +323,7 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node) ...@@ -318,7 +323,7 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node)
phase->hw.init = &init; phase->hw.init = &init;
phase->reg = reg; phase->reg = reg;
phase->lock = &sun4i_a10_mmc_lock; phase->lock = lock;
if (i == 1) if (i == 1)
phase->offset = 8; phase->offset = 8;
...@@ -345,4 +350,11 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node) ...@@ -345,4 +350,11 @@ static void __init sun4i_a10_mmc_setup(struct device_node *node)
err_free_data: err_free_data:
kfree(clk_data); kfree(clk_data);
} }
static DEFINE_SPINLOCK(sun4i_a10_mmc_lock);
static void __init sun4i_a10_mmc_setup(struct device_node *node)
{
sunxi_mmc_setup(node, &sun4i_a10_mod0_data, &sun4i_a10_mmc_lock);
}
CLK_OF_DECLARE(sun4i_a10_mmc, "allwinner,sun4i-a10-mmc-clk", sun4i_a10_mmc_setup); CLK_OF_DECLARE(sun4i_a10_mmc, "allwinner,sun4i-a10-mmc-clk", sun4i_a10_mmc_setup);
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册