diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-omap2/dpll3xxx.c | 113 |
1 files changed, 58 insertions, 55 deletions
diff --git a/arch/arm/mach-omap2/dpll3xxx.c b/arch/arm/mach-omap2/dpll3xxx.c index f6055b493294..2b559fc64855 100644 --- a/arch/arm/mach-omap2/dpll3xxx.c +++ b/arch/arm/mach-omap2/dpll3xxx.c | |||
@@ -44,17 +44,7 @@ | |||
44 | 44 | ||
45 | #define MAX_DPLL_WAIT_TRIES 1000000 | 45 | #define MAX_DPLL_WAIT_TRIES 1000000 |
46 | 46 | ||
47 | 47 | /* Private functions */ | |
48 | /** | ||
49 | * omap3_dpll_recalc - recalculate DPLL rate | ||
50 | * @clk: DPLL struct clk | ||
51 | * | ||
52 | * Recalculate and propagate the DPLL rate. | ||
53 | */ | ||
54 | unsigned long omap3_dpll_recalc(struct clk *clk) | ||
55 | { | ||
56 | return omap2_get_dpll_rate(clk); | ||
57 | } | ||
58 | 48 | ||
59 | /* _omap3_dpll_write_clken - write clken_bits arg to a DPLL's enable bits */ | 49 | /* _omap3_dpll_write_clken - write clken_bits arg to a DPLL's enable bits */ |
60 | static void _omap3_dpll_write_clken(struct clk *clk, u8 clken_bits) | 50 | static void _omap3_dpll_write_clken(struct clk *clk, u8 clken_bits) |
@@ -136,8 +126,6 @@ static u16 _omap3_dpll_compute_freqsel(struct clk *clk, u8 n) | |||
136 | return f; | 126 | return f; |
137 | } | 127 | } |
138 | 128 | ||
139 | /* Non-CORE DPLL (e.g., DPLLs that do not control SDRC) clock functions */ | ||
140 | |||
141 | /* | 129 | /* |
142 | * _omap3_noncore_dpll_lock - instruct a DPLL to lock and wait for readiness | 130 | * _omap3_noncore_dpll_lock - instruct a DPLL to lock and wait for readiness |
143 | * @clk: pointer to a DPLL struct clk | 131 | * @clk: pointer to a DPLL struct clk |
@@ -237,6 +225,63 @@ static int _omap3_noncore_dpll_stop(struct clk *clk) | |||
237 | return 0; | 225 | return 0; |
238 | } | 226 | } |
239 | 227 | ||
228 | /* | ||
229 | * _omap3_noncore_dpll_program - set non-core DPLL M,N values directly | ||
230 | * @clk: struct clk * of DPLL to set | ||
231 | * @m: DPLL multiplier to set | ||
232 | * @n: DPLL divider to set | ||
233 | * @freqsel: FREQSEL value to set | ||
234 | * | ||
235 | * Program the DPLL with the supplied M, N values, and wait for the DPLL to | ||
236 | * lock.. Returns -EINVAL upon error, or 0 upon success. | ||
237 | */ | ||
238 | static int omap3_noncore_dpll_program(struct clk *clk, u16 m, u8 n, u16 freqsel) | ||
239 | { | ||
240 | struct dpll_data *dd = clk->dpll_data; | ||
241 | u32 v; | ||
242 | |||
243 | /* 3430 ES2 TRM: 4.7.6.9 DPLL Programming Sequence */ | ||
244 | _omap3_noncore_dpll_bypass(clk); | ||
245 | |||
246 | /* Set jitter correction */ | ||
247 | if (!cpu_is_omap44xx()) { | ||
248 | v = __raw_readl(dd->control_reg); | ||
249 | v &= ~dd->freqsel_mask; | ||
250 | v |= freqsel << __ffs(dd->freqsel_mask); | ||
251 | __raw_writel(v, dd->control_reg); | ||
252 | } | ||
253 | |||
254 | /* Set DPLL multiplier, divider */ | ||
255 | v = __raw_readl(dd->mult_div1_reg); | ||
256 | v &= ~(dd->mult_mask | dd->div1_mask); | ||
257 | v |= m << __ffs(dd->mult_mask); | ||
258 | v |= (n - 1) << __ffs(dd->div1_mask); | ||
259 | __raw_writel(v, dd->mult_div1_reg); | ||
260 | |||
261 | /* We let the clock framework set the other output dividers later */ | ||
262 | |||
263 | /* REVISIT: Set ramp-up delay? */ | ||
264 | |||
265 | _omap3_noncore_dpll_lock(clk); | ||
266 | |||
267 | return 0; | ||
268 | } | ||
269 | |||
270 | /* Public functions */ | ||
271 | |||
272 | /** | ||
273 | * omap3_dpll_recalc - recalculate DPLL rate | ||
274 | * @clk: DPLL struct clk | ||
275 | * | ||
276 | * Recalculate and propagate the DPLL rate. | ||
277 | */ | ||
278 | unsigned long omap3_dpll_recalc(struct clk *clk) | ||
279 | { | ||
280 | return omap2_get_dpll_rate(clk); | ||
281 | } | ||
282 | |||
283 | /* Non-CORE DPLL (e.g., DPLLs that do not control SDRC) clock functions */ | ||
284 | |||
240 | /** | 285 | /** |
241 | * omap3_noncore_dpll_enable - instruct a DPLL to enter bypass or lock mode | 286 | * omap3_noncore_dpll_enable - instruct a DPLL to enter bypass or lock mode |
242 | * @clk: pointer to a DPLL struct clk | 287 | * @clk: pointer to a DPLL struct clk |
@@ -292,48 +337,6 @@ void omap3_noncore_dpll_disable(struct clk *clk) | |||
292 | 337 | ||
293 | /* Non-CORE DPLL rate set code */ | 338 | /* Non-CORE DPLL rate set code */ |
294 | 339 | ||
295 | /* | ||
296 | * omap3_noncore_dpll_program - set non-core DPLL M,N values directly | ||
297 | * @clk: struct clk * of DPLL to set | ||
298 | * @m: DPLL multiplier to set | ||
299 | * @n: DPLL divider to set | ||
300 | * @freqsel: FREQSEL value to set | ||
301 | * | ||
302 | * Program the DPLL with the supplied M, N values, and wait for the DPLL to | ||
303 | * lock.. Returns -EINVAL upon error, or 0 upon success. | ||
304 | */ | ||
305 | int omap3_noncore_dpll_program(struct clk *clk, u16 m, u8 n, u16 freqsel) | ||
306 | { | ||
307 | struct dpll_data *dd = clk->dpll_data; | ||
308 | u32 v; | ||
309 | |||
310 | /* 3430 ES2 TRM: 4.7.6.9 DPLL Programming Sequence */ | ||
311 | _omap3_noncore_dpll_bypass(clk); | ||
312 | |||
313 | /* Set jitter correction */ | ||
314 | if (!cpu_is_omap44xx()) { | ||
315 | v = __raw_readl(dd->control_reg); | ||
316 | v &= ~dd->freqsel_mask; | ||
317 | v |= freqsel << __ffs(dd->freqsel_mask); | ||
318 | __raw_writel(v, dd->control_reg); | ||
319 | } | ||
320 | |||
321 | /* Set DPLL multiplier, divider */ | ||
322 | v = __raw_readl(dd->mult_div1_reg); | ||
323 | v &= ~(dd->mult_mask | dd->div1_mask); | ||
324 | v |= m << __ffs(dd->mult_mask); | ||
325 | v |= (n - 1) << __ffs(dd->div1_mask); | ||
326 | __raw_writel(v, dd->mult_div1_reg); | ||
327 | |||
328 | /* We let the clock framework set the other output dividers later */ | ||
329 | |||
330 | /* REVISIT: Set ramp-up delay? */ | ||
331 | |||
332 | _omap3_noncore_dpll_lock(clk); | ||
333 | |||
334 | return 0; | ||
335 | } | ||
336 | |||
337 | /** | 340 | /** |
338 | * omap3_noncore_dpll_set_rate - set non-core DPLL rate | 341 | * omap3_noncore_dpll_set_rate - set non-core DPLL rate |
339 | * @clk: struct clk * of DPLL to set | 342 | * @clk: struct clk * of DPLL to set |