]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - arch/arm/mach-omap2/clock.c
OMAP2/3 clock: omap2_clk_enable(): refactor usecount check
[linux-2.6-omap-h63xx.git] / arch / arm / mach-omap2 / clock.c
index 1979d5fc9ccef60494bb8cc4a0a3b7190ae80ea0..3f8354da62a3f88c5024b69d717c9616d0eb747b 100644 (file)
@@ -485,26 +485,27 @@ int omap2_clk_enable(struct clk *clk)
 {
        int ret = 0;
 
-       if (clk->usecount++ == 0) {
-               if (clk->parent)
-                       ret = omap2_clk_enable(clk->parent);
+       if (++clk->usecount > 1)
+               return 0;
 
-               if (ret != 0) {
-                       clk->usecount--;
-                       return ret;
-               }
+       if (clk->parent)
+               ret = omap2_clk_enable(clk->parent);
+
+       if (ret != 0) {
+               clk->usecount--;
+               return ret;
+       }
 
-               omap2_clkdm_clk_enable(clk->clkdm.ptr, clk);
+       omap2_clkdm_clk_enable(clk->clkdm.ptr, clk);
 
-               ret = _omap2_clk_enable(clk);
+       ret = _omap2_clk_enable(clk);
 
-               if (ret != 0) {
-                       omap2_clkdm_clk_disable(clk->clkdm.ptr, clk);
+       if (ret != 0) {
+               omap2_clkdm_clk_disable(clk->clkdm.ptr, clk);
 
-                       if (clk->parent) {
-                               omap2_clk_disable(clk->parent);
-                               clk->usecount--;
-                       }
+               if (clk->parent) {
+                       omap2_clk_disable(clk->parent);
+                       clk->usecount--;
                }
        }