diff options
author | Robert Jarzmik <robert.jarzmik@free.fr> | 2008-08-11 16:22:27 -0400 |
---|---|---|
committer | Anton Vorontsov <cbouatmailru@gmail.com> | 2008-08-31 18:10:06 -0400 |
commit | e82374fd1a804e197fc2a54c3930e70c5d300abc (patch) | |
tree | daceef0ed1c611e38b016ba400890873c65cce26 /drivers/power/pda_power.c | |
parent | bef69ea0dcce574a425feb0a5aa4c63dd108b9a6 (diff) |
pda_power: Check and handle return value of set_irq_wake
The recent change in commit 2db873211ba47ef704c301f9ecf4a33413a0b649
forces the calls enable_irq_wake() and disable_irq_wake() to
be balanced. But if in pda_power_suspend() the call to
enable_irq_wake() fails (because attached gpio cannot wake
up the CPU), the corresponding disable_irq_wake will WARN().
Fix it by storing success/failure of enable_irq_wake().
Signed-off-by: Robert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: Anton Vorontsov <cbouatmailru@gmail.com>
Diffstat (limited to 'drivers/power/pda_power.c')
-rw-r--r-- | drivers/power/pda_power.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/power/pda_power.c b/drivers/power/pda_power.c index 0471ec743ab9..d30bb766fcef 100644 --- a/drivers/power/pda_power.c +++ b/drivers/power/pda_power.c | |||
@@ -334,13 +334,16 @@ static int pda_power_remove(struct platform_device *pdev) | |||
334 | } | 334 | } |
335 | 335 | ||
336 | #ifdef CONFIG_PM | 336 | #ifdef CONFIG_PM |
337 | static int ac_wakeup_enabled; | ||
338 | static int usb_wakeup_enabled; | ||
339 | |||
337 | static int pda_power_suspend(struct platform_device *pdev, pm_message_t state) | 340 | static int pda_power_suspend(struct platform_device *pdev, pm_message_t state) |
338 | { | 341 | { |
339 | if (device_may_wakeup(&pdev->dev)) { | 342 | if (device_may_wakeup(&pdev->dev)) { |
340 | if (ac_irq) | 343 | if (ac_irq) |
341 | enable_irq_wake(ac_irq->start); | 344 | ac_wakeup_enabled = !enable_irq_wake(ac_irq->start); |
342 | if (usb_irq) | 345 | if (usb_irq) |
343 | enable_irq_wake(usb_irq->start); | 346 | usb_wakeup_enabled = !enable_irq_wake(usb_irq->start); |
344 | } | 347 | } |
345 | 348 | ||
346 | return 0; | 349 | return 0; |
@@ -349,9 +352,9 @@ static int pda_power_suspend(struct platform_device *pdev, pm_message_t state) | |||
349 | static int pda_power_resume(struct platform_device *pdev) | 352 | static int pda_power_resume(struct platform_device *pdev) |
350 | { | 353 | { |
351 | if (device_may_wakeup(&pdev->dev)) { | 354 | if (device_may_wakeup(&pdev->dev)) { |
352 | if (usb_irq) | 355 | if (usb_irq && usb_wakeup_enabled) |
353 | disable_irq_wake(usb_irq->start); | 356 | disable_irq_wake(usb_irq->start); |
354 | if (ac_irq) | 357 | if (ac_irq && ac_wakeup_enabled) |
355 | disable_irq_wake(ac_irq->start); | 358 | disable_irq_wake(ac_irq->start); |
356 | } | 359 | } |
357 | 360 | ||