aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/clock.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-omap2/clock.c')
-rw-r--r--arch/arm/mach-omap2/clock.c35
1 files changed, 21 insertions, 14 deletions
diff --git a/arch/arm/mach-omap2/clock.c b/arch/arm/mach-omap2/clock.c
index 21fbe29810ac..8c09711d2eaf 100644
--- a/arch/arm/mach-omap2/clock.c
+++ b/arch/arm/mach-omap2/clock.c
@@ -264,16 +264,10 @@ static void omap2_clk_wait_ready(struct clk *clk)
264 omap2_wait_clock_ready(st_reg, bit, clk->name); 264 omap2_wait_clock_ready(st_reg, bit, clk->name);
265} 265}
266 266
267/* Enables clock without considering parent dependencies or use count 267static int omap2_dflt_clk_enable_wait(struct clk *clk)
268 * REVISIT: Maybe change this to use clk->enable like on omap1?
269 */
270int _omap2_clk_enable(struct clk *clk)
271{ 268{
272 u32 regval32; 269 u32 regval32;
273 270
274 if (clk->ops && clk->ops->enable)
275 return clk->ops->enable(clk);
276
277 if (unlikely(clk->enable_reg == NULL)) { 271 if (unlikely(clk->enable_reg == NULL)) {
278 printk(KERN_ERR "clock.c: Enable for %s without enable code\n", 272 printk(KERN_ERR "clock.c: Enable for %s without enable code\n",
279 clk->name); 273 clk->name);
@@ -293,16 +287,10 @@ int _omap2_clk_enable(struct clk *clk)
293 return 0; 287 return 0;
294} 288}
295 289
296/* Disables clock without considering parent dependencies or use count */ 290static void omap2_dflt_clk_disable(struct clk *clk)
297void _omap2_clk_disable(struct clk *clk)
298{ 291{
299 u32 regval32; 292 u32 regval32;
300 293
301 if (clk->ops && clk->ops->disable) {
302 clk->ops->disable(clk);
303 return;
304 }
305
306 if (clk->enable_reg == NULL) { 294 if (clk->enable_reg == NULL) {
307 /* 295 /*
308 * 'Independent' here refers to a clock which is not 296 * 'Independent' here refers to a clock which is not
@@ -322,6 +310,25 @@ void _omap2_clk_disable(struct clk *clk)
322 wmb(); 310 wmb();
323} 311}
324 312
313const struct clkops clkops_omap2_dflt_wait = {
314 .enable = omap2_dflt_clk_enable_wait,
315 .disable = omap2_dflt_clk_disable,
316};
317
318/* Enables clock without considering parent dependencies or use count
319 * REVISIT: Maybe change this to use clk->enable like on omap1?
320 */
321static int _omap2_clk_enable(struct clk *clk)
322{
323 return clk->ops->enable(clk);
324}
325
326/* Disables clock without considering parent dependencies or use count */
327static void _omap2_clk_disable(struct clk *clk)
328{
329 clk->ops->disable(clk);
330}
331
325void omap2_clk_disable(struct clk *clk) 332void omap2_clk_disable(struct clk *clk)
326{ 333{
327 if (clk->usecount > 0 && !(--clk->usecount)) { 334 if (clk->usecount > 0 && !(--clk->usecount)) {