mfd: Properly free t7l66xb clk32k clock source
authorAxel Lin <axel.lin@gmail.com>
Thu, 1 Jul 2010 09:43:50 +0000 (17:43 +0800)
committerSamuel Ortiz <sameo@linux.intel.com>
Thu, 12 Aug 2010 09:27:23 +0000 (11:27 +0200)
This patch includes below fixes to properly free clk32k clock source:
1. remove a redundant clk_put in t7l66xb_probe error path
2. add missing clk_disable(t7l66xb->clk32k) and clk_put(t7l66xb->clk32k)
   to properly free the clock source.

Signed-off-by: Axel Lin <axel.lin@gmail.com>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
drivers/mfd/t7l66xb.c

index 5041d33adf0babf3db03c2eb34688a2f77883479..006c121f3f0d2f2bca2a87f05f6c65ca3a063987 100644 (file)
@@ -350,7 +350,6 @@ static int t7l66xb_probe(struct platform_device *dev)
        t7l66xb->clk48m = clk_get(&dev->dev, "CLK_CK48M");
        if (IS_ERR(t7l66xb->clk48m)) {
                ret = PTR_ERR(t7l66xb->clk48m);
-               clk_put(t7l66xb->clk32k);
                goto err_clk48m_get;
        }
 
@@ -425,6 +424,8 @@ static int t7l66xb_remove(struct platform_device *dev)
        ret = pdata->disable(dev);
        clk_disable(t7l66xb->clk48m);
        clk_put(t7l66xb->clk48m);
+       clk_disable(t7l66xb->clk32k);
+       clk_put(t7l66xb->clk32k);
        t7l66xb_detach_irq(dev);
        iounmap(t7l66xb->scr);
        release_resource(&t7l66xb->rscr);