* [PATCH] sh_rtc: use set_irq_wake()
@ 2009-04-01 14:45 Magnus Damm
0 siblings, 0 replies; only message in thread
From: Magnus Damm @ 2009-04-01 14:45 UTC (permalink / raw)
To: linux-sh
From: Magnus Damm <damm@igel.co.jp>
Modify the sh_rtc driver to use set_irq_wake() during suspend
and resume. These functions are used to enable the rtc interrupts
in the interrupt controller so the rtc can be used to wakeup the
system from suspend.
Signed-off-by: Magnus Damm <damm@igel.co.jp>
---
drivers/rtc/rtc-sh.c | 36 ++++++++++++++++++++++++++++++++++++
1 file changed, 36 insertions(+)
--- 0001/drivers/rtc/rtc-sh.c
+++ work/drivers/rtc/rtc-sh.c 2009-04-01 22:57:15.000000000 +0900
@@ -795,10 +795,46 @@ static int __devexit sh_rtc_remove(struc
return 0;
}
+
+static void sh_rtc_set_irq_wake(struct device *dev, int enabled)
+{
+ struct platform_device *pdev = to_platform_device(dev);
+ struct sh_rtc *rtc = platform_get_drvdata(pdev);
+
+ set_irq_wake(rtc->periodic_irq, enabled);
+ if (rtc->carry_irq > 0) {
+ set_irq_wake(rtc->carry_irq, enabled);
+ set_irq_wake(rtc->alarm_irq, enabled);
+ }
+
+}
+
+static int sh_rtc_suspend(struct device *dev)
+{
+ if (device_may_wakeup(dev))
+ sh_rtc_set_irq_wake(dev, 1);
+
+ return 0;
+}
+
+static int sh_rtc_resume(struct device *dev)
+{
+ if (device_may_wakeup(dev))
+ sh_rtc_set_irq_wake(dev, 0);
+
+ return 0;
+}
+
+static struct dev_pm_ops sh_rtc_dev_pm_ops = {
+ .suspend = sh_rtc_suspend,
+ .resume = sh_rtc_resume,
+};
+
static struct platform_driver sh_rtc_platform_driver = {
.driver = {
.name = DRV_NAME,
.owner = THIS_MODULE,
+ .pm = &sh_rtc_dev_pm_ops,
},
.probe = sh_rtc_probe,
.remove = __devexit_p(sh_rtc_remove),
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2009-04-01 14:45 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-04-01 14:45 [PATCH] sh_rtc: use set_irq_wake() Magnus Damm
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox