aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/sh_clk.h
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2011-11-22 00:33:18 -0500
committerPaul Mundt <lethal@linux-sh.org>2011-11-24 03:15:23 -0500
commit56242a1fc595d158eddefbb4d6d76e82c2535f55 (patch)
tree78964e2ccde88e09ebb12412de26ab58f7b1417b /include/linux/sh_clk.h
parenta9098b372606a15745cdeb012de4ee91c0df82c4 (diff)
sh: clkfwk: setup clock parent from current register value
Some clocks can select its parent clock by CPG register. But it might have been modified by boot-loader or something. This patch removed fixed initial parent clock, and setup it from their current register settings. It works on div6 reparent clocks for now. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'include/linux/sh_clk.h')
-rw-r--r--include/linux/sh_clk.h9
1 files changed, 6 insertions, 3 deletions
diff --git a/include/linux/sh_clk.h b/include/linux/sh_clk.h
index a20831cf336a..e834304c0b6a 100644
--- a/include/linux/sh_clk.h
+++ b/include/linux/sh_clk.h
@@ -131,10 +131,9 @@ int sh_clk_div4_enable_register(struct clk *clks, int nr,
131int sh_clk_div4_reparent_register(struct clk *clks, int nr, 131int sh_clk_div4_reparent_register(struct clk *clks, int nr,
132 struct clk_div4_table *table); 132 struct clk_div4_table *table);
133 133
134#define SH_CLK_DIV6_EXT(_parent, _reg, _flags, _parents, \ 134#define SH_CLK_DIV6_EXT(_reg, _flags, _parents, \
135 _num_parents, _src_shift, _src_width) \ 135 _num_parents, _src_shift, _src_width) \
136{ \ 136{ \
137 .parent = _parent, \
138 .enable_reg = (void __iomem *)_reg, \ 137 .enable_reg = (void __iomem *)_reg, \
139 .flags = _flags, \ 138 .flags = _flags, \
140 .parent_table = _parents, \ 139 .parent_table = _parents, \
@@ -144,7 +143,11 @@ int sh_clk_div4_reparent_register(struct clk *clks, int nr,
144} 143}
145 144
146#define SH_CLK_DIV6(_parent, _reg, _flags) \ 145#define SH_CLK_DIV6(_parent, _reg, _flags) \
147 SH_CLK_DIV6_EXT(_parent, _reg, _flags, NULL, 0, 0, 0) 146{ \
147 .parent = _parent, \
148 .enable_reg = (void __iomem *)_reg, \
149 .flags = _flags, \
150}
148 151
149int sh_clk_div6_register(struct clk *clks, int nr); 152int sh_clk_div6_register(struct clk *clks, int nr);
150int sh_clk_div6_reparent_register(struct clk *clks, int nr); 153int sh_clk_div6_reparent_register(struct clk *clks, int nr);