watchdog: shwdt: Preliminary runtime PM support.
authorPaul Mundt <lethal@linux-sh.org>
Thu, 10 May 2012 07:08:35 +0000 (16:08 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Thu, 10 May 2012 07:08:35 +0000 (16:08 +0900)
This plugs in some trivial runtime PM support in the probe/remove and
start/stop paths.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
drivers/watchdog/shwdt.c

index 380ada4e5d661d065fb355b269175d501843c1b1..b11104702d2377e021b270502c77b5bcc9171ebe 100644 (file)
@@ -28,6 +28,7 @@
 #include <linux/spinlock.h>
 #include <linux/miscdevice.h>
 #include <linux/watchdog.h>
+#include <linux/pm_runtime.h>
 #include <linux/fs.h>
 #include <linux/mm.h>
 #include <linux/slab.h>
@@ -87,6 +88,8 @@ static int sh_wdt_start(struct watchdog_device *wdt_dev)
        unsigned long flags;
        u8 csr;
 
+       pm_runtime_get_sync(wdt->dev);
+
        spin_lock_irqsave(&wdt->lock, flags);
 
        next_heartbeat = jiffies + (heartbeat * HZ);
@@ -137,6 +140,8 @@ static int sh_wdt_stop(struct watchdog_device *wdt_dev)
 
        spin_unlock_irqrestore(&wdt->lock, flags);
 
+       pm_runtime_put_sync(wdt->dev);
+
        return 0;
 }
 
@@ -283,6 +288,8 @@ static int __devinit sh_wdt_probe(struct platform_device *pdev)
 
        dev_info(&pdev->dev, "initialized.\n");
 
+       pm_runtime_enable(&pdev->dev);
+
        return 0;
 
 out_disable:
@@ -300,6 +307,7 @@ static int __devexit sh_wdt_remove(struct platform_device *pdev)
 
        watchdog_unregister_device(&sh_wdt_dev);
 
+       pm_runtime_disable(&pdev->dev);
        clk_disable(wdt->clk);
        clk_put(wdt->clk);