watchdog: coh901327_wdt: use clk_prepare/unprepare
authorLinus Walleij <linus.walleij@linaro.org>
Tue, 12 Jun 2012 17:19:01 +0000 (19:19 +0200)
committerWim Van Sebroeck <wim@iguana.be>
Mon, 23 Jul 2012 10:46:49 +0000 (12:46 +0200)
Make sure we prepare/unprepare the COH901327 watchdog timer
as is required by the clk API especially if you use common
clock.

Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Reviewed-by : Pankaj Jangra <jangra.pankaj9@gmail.com>
Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
drivers/watchdog/coh901327_wdt.c

index 6876430a9f5e49a62eb1b755ee0c68a9e89c94e8..cb5da5c3ece28c34e0cacc23a397dfe74439954d 100644 (file)
@@ -263,6 +263,7 @@ static int __exit coh901327_remove(struct platform_device *pdev)
        watchdog_unregister_device(&coh901327_wdt);
        coh901327_disable();
        free_irq(irq, pdev);
+       clk_unprepare(clk);
        clk_put(clk);
        iounmap(virtbase);
        release_mem_region(phybase, physize);
@@ -300,9 +301,9 @@ static int __init coh901327_probe(struct platform_device *pdev)
                dev_err(&pdev->dev, "could not get clock\n");
                goto out_no_clk;
        }
-       ret = clk_enable(clk);
+       ret = clk_prepare_enable(clk);
        if (ret) {
-               dev_err(&pdev->dev, "could not enable clock\n");
+               dev_err(&pdev->dev, "could not prepare and enable clock\n");
                goto out_no_clk_enable;
        }
 
@@ -369,7 +370,7 @@ static int __init coh901327_probe(struct platform_device *pdev)
 out_no_wdog:
        free_irq(irq, pdev);
 out_no_irq:
-       clk_disable(clk);
+       clk_disable_unprepare(clk);
 out_no_clk_enable:
        clk_put(clk);
 out_no_clk: