watchdog: ath79_wdt: convert to use devm_clk_get
authorGabor Juhos <juhosg@openwrt.org>
Thu, 27 Dec 2012 14:38:24 +0000 (15:38 +0100)
committerWim Van Sebroeck <wim@iguana.be>
Fri, 1 Mar 2013 11:21:24 +0000 (12:21 +0100)
Use the managed version of clk_get. This allows to
simplify the probe/remove functions a bit.

Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
drivers/watchdog/ath79_wdt.c

index 38a999e60c0d7f26f03b2eac77f39e4b2296413a..dcd18ec1821b9a65e616b5c49625d4ed80bb7231 100644 (file)
@@ -229,13 +229,13 @@ static int ath79_wdt_probe(struct platform_device *pdev)
        u32 ctrl;
        int err;
 
-       wdt_clk = clk_get(&pdev->dev, "wdt");
+       wdt_clk = devm_clk_get(&pdev->dev, "wdt");
        if (IS_ERR(wdt_clk))
                return PTR_ERR(wdt_clk);
 
        err = clk_enable(wdt_clk);
        if (err)
-               goto err_clk_put;
+               return err;
 
        wdt_freq = clk_get_rate(wdt_clk);
        if (!wdt_freq) {
@@ -265,8 +265,6 @@ static int ath79_wdt_probe(struct platform_device *pdev)
 
 err_clk_disable:
        clk_disable(wdt_clk);
-err_clk_put:
-       clk_put(wdt_clk);
        return err;
 }
 
@@ -274,7 +272,6 @@ static int ath79_wdt_remove(struct platform_device *pdev)
 {
        misc_deregister(&ath79_wdt_miscdev);
        clk_disable(wdt_clk);
-       clk_put(wdt_clk);
        return 0;
 }