diff options
Diffstat (limited to 'arch/sh/kernel/cpu')
-rw-r--r-- | arch/sh/kernel/cpu/sh4a/clock-sh7343.c | 102 |
1 files changed, 56 insertions, 46 deletions
diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7343.c b/arch/sh/kernel/cpu/sh4a/clock-sh7343.c index a066c438b404..72acbe4625a3 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7343.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7343.c | |||
@@ -145,51 +145,61 @@ struct clk div6_clks[DIV6_NR] = { | |||
145 | #define MSTP(_str, _parent, _reg, _bit, _flags) \ | 145 | #define MSTP(_str, _parent, _reg, _bit, _flags) \ |
146 | SH_CLK_MSTP32(_str, -1, _parent, _reg, _bit, _flags) | 146 | SH_CLK_MSTP32(_str, -1, _parent, _reg, _bit, _flags) |
147 | 147 | ||
148 | static struct clk mstp_clks[] = { | 148 | enum { MSTP031, MSTP030, MSTP029, MSTP028, MSTP026, |
149 | MSTP("tlb0", &div4_clks[DIV4_I], MSTPCR0, 31, CLK_ENABLE_ON_INIT), | 149 | MSTP023, MSTP022, MSTP021, MSTP020, MSTP019, MSTP018, MSTP017, MSTP016, |
150 | MSTP("ic0", &div4_clks[DIV4_I], MSTPCR0, 30, CLK_ENABLE_ON_INIT), | 150 | MSTP015, MSTP014, MSTP013, MSTP012, MSTP011, MSTP010, |
151 | MSTP("oc0", &div4_clks[DIV4_I], MSTPCR0, 29, CLK_ENABLE_ON_INIT), | 151 | MSTP007, MSTP006, MSTP005, MSTP004, MSTP003, MSTP002, MSTP001, |
152 | MSTP("uram0", &div4_clks[DIV4_U], MSTPCR0, 28, CLK_ENABLE_ON_INIT), | 152 | MSTP109, MSTP108, MSTP100, |
153 | MSTP("xymem0", &div4_clks[DIV4_B], MSTPCR0, 26, CLK_ENABLE_ON_INIT), | 153 | MSTP225, MSTP224, MSTP218, MSTP217, MSTP216, |
154 | MSTP("intc3", &div4_clks[DIV4_P], MSTPCR0, 23, 0), | 154 | MSTP214, MSTP213, MSTP212, MSTP211, MSTP208, |
155 | MSTP("intc0", &div4_clks[DIV4_P], MSTPCR0, 22, 0), | 155 | MSTP206, MSTP205, MSTP204, MSTP203, MSTP202, MSTP201, MSTP200, |
156 | MSTP("dmac0", &div4_clks[DIV4_P], MSTPCR0, 21, 0), | 156 | MSTP_NR }; |
157 | MSTP("sh0", &div4_clks[DIV4_P], MSTPCR0, 20, 0), | 157 | |
158 | MSTP("hudi0", &div4_clks[DIV4_P], MSTPCR0, 19, 0), | 158 | static struct clk mstp_clks[MSTP_NR] = { |
159 | MSTP("ubc0", &div4_clks[DIV4_P], MSTPCR0, 17, 0), | 159 | [MSTP031] = MSTP("tlb0", &div4_clks[DIV4_I], MSTPCR0, 31, CLK_ENABLE_ON_INIT), |
160 | MSTP("tmu_fck", &div4_clks[DIV4_P], MSTPCR0, 15, 0), | 160 | [MSTP030] = MSTP("ic0", &div4_clks[DIV4_I], MSTPCR0, 30, CLK_ENABLE_ON_INIT), |
161 | MSTP("cmt_fck", &r_clk, MSTPCR0, 14, 0), | 161 | [MSTP029] = MSTP("oc0", &div4_clks[DIV4_I], MSTPCR0, 29, CLK_ENABLE_ON_INIT), |
162 | MSTP("rwdt0", &r_clk, MSTPCR0, 13, 0), | 162 | [MSTP028] = MSTP("uram0", &div4_clks[DIV4_U], MSTPCR0, 28, CLK_ENABLE_ON_INIT), |
163 | MSTP("mfi0", &div4_clks[DIV4_P], MSTPCR0, 11, 0), | 163 | [MSTP026] = MSTP("xymem0", &div4_clks[DIV4_B], MSTPCR0, 26, CLK_ENABLE_ON_INIT), |
164 | MSTP("flctl0", &div4_clks[DIV4_P], MSTPCR0, 10, 0), | 164 | [MSTP023] = MSTP("intc3", &div4_clks[DIV4_P], MSTPCR0, 23, 0), |
165 | SH_CLK_MSTP32("sci_fck", 0, &div4_clks[DIV4_P], MSTPCR0, 7, 0), | 165 | [MSTP022] = MSTP("intc0", &div4_clks[DIV4_P], MSTPCR0, 22, 0), |
166 | SH_CLK_MSTP32("sci_fck", 1, &div4_clks[DIV4_P], MSTPCR0, 6, 0), | 166 | [MSTP021] = MSTP("dmac0", &div4_clks[DIV4_P], MSTPCR0, 21, 0), |
167 | SH_CLK_MSTP32("sci_fck", 2, &div4_clks[DIV4_P], MSTPCR0, 5, 0), | 167 | [MSTP020] = MSTP("sh0", &div4_clks[DIV4_P], MSTPCR0, 20, 0), |
168 | SH_CLK_MSTP32("sci_fck", 3, &div4_clks[DIV4_P], MSTPCR0, 4, 0), | 168 | [MSTP019] = MSTP("hudi0", &div4_clks[DIV4_P], MSTPCR0, 19, 0), |
169 | MSTP("sio0", &div4_clks[DIV4_P], MSTPCR0, 3, 0), | 169 | [MSTP017] = MSTP("ubc0", &div4_clks[DIV4_P], MSTPCR0, 17, 0), |
170 | MSTP("siof0", &div4_clks[DIV4_P], MSTPCR0, 2, 0), | 170 | [MSTP015] = MSTP("tmu_fck", &div4_clks[DIV4_P], MSTPCR0, 15, 0), |
171 | MSTP("siof1", &div4_clks[DIV4_P], MSTPCR0, 1, 0), | 171 | [MSTP014] = MSTP("cmt_fck", &r_clk, MSTPCR0, 14, 0), |
172 | 172 | [MSTP013] = MSTP("rwdt0", &r_clk, MSTPCR0, 13, 0), | |
173 | MSTP("i2c0", &div4_clks[DIV4_P], MSTPCR1, 9, 0), | 173 | [MSTP011] = MSTP("mfi0", &div4_clks[DIV4_P], MSTPCR0, 11, 0), |
174 | MSTP("i2c1", &div4_clks[DIV4_P], MSTPCR1, 8, 0), | 174 | [MSTP010] = MSTP("flctl0", &div4_clks[DIV4_P], MSTPCR0, 10, 0), |
175 | 175 | [MSTP007] = SH_CLK_MSTP32("sci_fck", 0, &div4_clks[DIV4_P], MSTPCR0, 7, 0), | |
176 | MSTP("tpu0", &div4_clks[DIV4_P], MSTPCR2, 25, 0), | 176 | [MSTP006] = SH_CLK_MSTP32("sci_fck", 1, &div4_clks[DIV4_P], MSTPCR0, 6, 0), |
177 | MSTP("irda0", &div4_clks[DIV4_P], MSTPCR2, 24, 0), | 177 | [MSTP005] = SH_CLK_MSTP32("sci_fck", 2, &div4_clks[DIV4_P], MSTPCR0, 5, 0), |
178 | MSTP("sdhi0", &div4_clks[DIV4_P], MSTPCR2, 18, 0), | 178 | [MSTP004] = SH_CLK_MSTP32("sci_fck", 3, &div4_clks[DIV4_P], MSTPCR0, 4, 0), |
179 | MSTP("mmcif0", &div4_clks[DIV4_P], MSTPCR2, 17, 0), | 179 | [MSTP003] = MSTP("sio0", &div4_clks[DIV4_P], MSTPCR0, 3, 0), |
180 | MSTP("sim0", &div4_clks[DIV4_P], MSTPCR2, 16, 0), | 180 | [MSTP002] = MSTP("siof0", &div4_clks[DIV4_P], MSTPCR0, 2, 0), |
181 | MSTP("keysc0", &r_clk, MSTPCR2, 14, 0), | 181 | [MSTP001] = MSTP("siof1", &div4_clks[DIV4_P], MSTPCR0, 1, 0), |
182 | MSTP("tsif0", &div4_clks[DIV4_P], MSTPCR2, 13, 0), | 182 | |
183 | MSTP("s3d40", &div4_clks[DIV4_P], MSTPCR2, 12, 0), | 183 | [MSTP109] = MSTP("i2c0", &div4_clks[DIV4_P], MSTPCR1, 9, 0), |
184 | MSTP("usbf0", &div4_clks[DIV4_P], MSTPCR2, 11, 0), | 184 | [MSTP108] = MSTP("i2c1", &div4_clks[DIV4_P], MSTPCR1, 8, 0), |
185 | MSTP("siu0", &div4_clks[DIV4_B], MSTPCR2, 8, 0), | 185 | |
186 | MSTP("jpu0", &div4_clks[DIV4_B], MSTPCR2, 6, CLK_ENABLE_ON_INIT), | 186 | [MSTP225] = MSTP("tpu0", &div4_clks[DIV4_P], MSTPCR2, 25, 0), |
187 | MSTP("vou0", &div4_clks[DIV4_B], MSTPCR2, 5, 0), | 187 | [MSTP224] = MSTP("irda0", &div4_clks[DIV4_P], MSTPCR2, 24, 0), |
188 | MSTP("beu0", &div4_clks[DIV4_B], MSTPCR2, 4, 0), | 188 | [MSTP218] = MSTP("sdhi0", &div4_clks[DIV4_P], MSTPCR2, 18, 0), |
189 | MSTP("ceu0", &div4_clks[DIV4_B], MSTPCR2, 3, 0), | 189 | [MSTP217] = MSTP("mmcif0", &div4_clks[DIV4_P], MSTPCR2, 17, 0), |
190 | MSTP("veu0", &div4_clks[DIV4_B], MSTPCR2, 2, CLK_ENABLE_ON_INIT), | 190 | [MSTP216] = MSTP("sim0", &div4_clks[DIV4_P], MSTPCR2, 16, 0), |
191 | MSTP("vpu0", &div4_clks[DIV4_B], MSTPCR2, 1, CLK_ENABLE_ON_INIT), | 191 | [MSTP214] = MSTP("keysc0", &r_clk, MSTPCR2, 14, 0), |
192 | MSTP("lcdc0", &div4_clks[DIV4_B], MSTPCR2, 0, 0), | 192 | [MSTP213] = MSTP("tsif0", &div4_clks[DIV4_P], MSTPCR2, 13, 0), |
193 | [MSTP212] = MSTP("s3d40", &div4_clks[DIV4_P], MSTPCR2, 12, 0), | ||
194 | [MSTP211] = MSTP("usbf0", &div4_clks[DIV4_P], MSTPCR2, 11, 0), | ||
195 | [MSTP208] = MSTP("siu0", &div4_clks[DIV4_B], MSTPCR2, 8, 0), | ||
196 | [MSTP206] = MSTP("jpu0", &div4_clks[DIV4_B], MSTPCR2, 6, CLK_ENABLE_ON_INIT), | ||
197 | [MSTP205] = MSTP("vou0", &div4_clks[DIV4_B], MSTPCR2, 5, 0), | ||
198 | [MSTP204] = MSTP("beu0", &div4_clks[DIV4_B], MSTPCR2, 4, 0), | ||
199 | [MSTP203] = MSTP("ceu0", &div4_clks[DIV4_B], MSTPCR2, 3, 0), | ||
200 | [MSTP202] = MSTP("veu0", &div4_clks[DIV4_B], MSTPCR2, 2, CLK_ENABLE_ON_INIT), | ||
201 | [MSTP201] = MSTP("vpu0", &div4_clks[DIV4_B], MSTPCR2, 1, CLK_ENABLE_ON_INIT), | ||
202 | [MSTP200] = MSTP("lcdc0", &div4_clks[DIV4_B], MSTPCR2, 0, 0), | ||
193 | }; | 203 | }; |
194 | 204 | ||
195 | #define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } | 205 | #define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } |
@@ -221,7 +231,7 @@ int __init arch_clk_init(void) | |||
221 | ret = sh_clk_div6_register(div6_clks, DIV6_NR); | 231 | ret = sh_clk_div6_register(div6_clks, DIV6_NR); |
222 | 232 | ||
223 | if (!ret) | 233 | if (!ret) |
224 | ret = sh_clk_mstp32_register(mstp_clks, ARRAY_SIZE(mstp_clks)); | 234 | ret = sh_clk_mstp32_register(mstp_clks, MSTP_NR); |
225 | 235 | ||
226 | return ret; | 236 | return ret; |
227 | } | 237 | } |