summaryrefslogtreecommitdiffstats
path: root/drivers/power
diff options
context:
space:
mode:
authorDmitry Baryshkov <dbaryshkov@gmail.com>2008-01-13 02:35:43 +0300
committerAnton Vorontsov <cbouatmailru@gmail.com>2008-02-02 02:43:00 +0300
commit8f8e9b387e07cbb96f10936cc455229d7aff4790 (patch)
tree5daf38a1242967c64c2c627f0a2b4c984cc5fbb9 /drivers/power
parentc7cc930f9a5c26385a08cd7dc28cb5e3ed186d72 (diff)
downloadkernel-crypto-8f8e9b387e07cbb96f10936cc455229d7aff4790.tar.gz
kernel-crypto-8f8e9b387e07cbb96f10936cc455229d7aff4790.tar.xz
kernel-crypto-8f8e9b387e07cbb96f10936cc455229d7aff4790.zip
pda_power: add suspend/resume support
Add suspend/resume/wakeup support for pda_power. Signed-off-by: Dmitry Baryshkov <dbaryshkov@gmail.com> Signed-off-by: Anton Vorontsov <cbou@mail.ru>
Diffstat (limited to 'drivers/power')
-rw-r--r--drivers/power/pda_power.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/drivers/power/pda_power.c b/drivers/power/pda_power.c
index d98622f9f31..35dc25973f3 100644
--- a/drivers/power/pda_power.c
+++ b/drivers/power/pda_power.c
@@ -207,6 +207,8 @@ static int pda_power_probe(struct platform_device *pdev)
}
}
+ device_init_wakeup(&pdev->dev, 1);
+
return 0;
usb_irq_failed:
@@ -239,12 +241,43 @@ static int pda_power_remove(struct platform_device *pdev)
return 0;
}
+#ifdef CONFIG_PM
+static int pda_power_suspend(struct platform_device *pdev, pm_message_t state)
+{
+ if (device_may_wakeup(&pdev->dev)) {
+ if (ac_irq)
+ enable_irq_wake(ac_irq->start);
+ if (usb_irq)
+ enable_irq_wake(usb_irq->start);
+ }
+
+ return 0;
+}
+
+static int pda_power_resume(struct platform_device *pdev)
+{
+ if (device_may_wakeup(&pdev->dev)) {
+ if (usb_irq)
+ disable_irq_wake(usb_irq->start);
+ if (ac_irq)
+ disable_irq_wake(ac_irq->start);
+ }
+
+ return 0;
+}
+#else
+#define pda_power_suspend NULL
+#define pda_power_resume NULL
+#endif /* CONFIG_PM */
+
static struct platform_driver pda_power_pdrv = {
.driver = {
.name = "pda-power",
},
.probe = pda_power_probe,
.remove = pda_power_remove,
+ .suspend = pda_power_suspend,
+ .resume = pda_power_resume,
};
static int __init pda_power_init(void)