diff options
author | Linus Walleij <linus.walleij@linaro.org> | 2012-06-12 13:19:01 -0400 |
---|---|---|
committer | Wim Van Sebroeck <wim@iguana.be> | 2012-07-23 06:46:49 -0400 |
commit | c362cb597b5c30a32f4228136e0dfd9bf4c5d65b (patch) | |
tree | 6c9aa0dac7dd924e14c2e7214a220d1c21f49031 /drivers/watchdog | |
parent | 3017020dc73a3ae222db2cda9b5952f0e4cf7a09 (diff) |
watchdog: coh901327_wdt: use clk_prepare/unprepare
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>
Diffstat (limited to 'drivers/watchdog')
-rw-r--r-- | drivers/watchdog/coh901327_wdt.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/watchdog/coh901327_wdt.c b/drivers/watchdog/coh901327_wdt.c index 6876430a9f5..cb5da5c3ece 100644 --- a/drivers/watchdog/coh901327_wdt.c +++ b/drivers/watchdog/coh901327_wdt.c | |||
@@ -263,6 +263,7 @@ static int __exit coh901327_remove(struct platform_device *pdev) | |||
263 | watchdog_unregister_device(&coh901327_wdt); | 263 | watchdog_unregister_device(&coh901327_wdt); |
264 | coh901327_disable(); | 264 | coh901327_disable(); |
265 | free_irq(irq, pdev); | 265 | free_irq(irq, pdev); |
266 | clk_unprepare(clk); | ||
266 | clk_put(clk); | 267 | clk_put(clk); |
267 | iounmap(virtbase); | 268 | iounmap(virtbase); |
268 | release_mem_region(phybase, physize); | 269 | release_mem_region(phybase, physize); |
@@ -300,9 +301,9 @@ static int __init coh901327_probe(struct platform_device *pdev) | |||
300 | dev_err(&pdev->dev, "could not get clock\n"); | 301 | dev_err(&pdev->dev, "could not get clock\n"); |
301 | goto out_no_clk; | 302 | goto out_no_clk; |
302 | } | 303 | } |
303 | ret = clk_enable(clk); | 304 | ret = clk_prepare_enable(clk); |
304 | if (ret) { | 305 | if (ret) { |
305 | dev_err(&pdev->dev, "could not enable clock\n"); | 306 | dev_err(&pdev->dev, "could not prepare and enable clock\n"); |
306 | goto out_no_clk_enable; | 307 | goto out_no_clk_enable; |
307 | } | 308 | } |
308 | 309 | ||
@@ -369,7 +370,7 @@ static int __init coh901327_probe(struct platform_device *pdev) | |||
369 | out_no_wdog: | 370 | out_no_wdog: |
370 | free_irq(irq, pdev); | 371 | free_irq(irq, pdev); |
371 | out_no_irq: | 372 | out_no_irq: |
372 | clk_disable(clk); | 373 | clk_disable_unprepare(clk); |
373 | out_no_clk_enable: | 374 | out_no_clk_enable: |
374 | clk_put(clk); | 375 | clk_put(clk); |
375 | out_no_clk: | 376 | out_no_clk: |