diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2012-07-19 12:39:21 +0400 |
---|---|---|
committer | Rafael J. Wysocki <rjw@sisk.pl> | 2012-07-19 12:39:21 +0400 |
commit | 382e1596197be46b73aed08be05acf5b5ae8ce49 (patch) | |
tree | c0e886e45c1513710ac20c2cd945e5bc41fe8b90 /drivers/base | |
parent | bd798b7a88069b6ad273214ca3901d988104db71 (diff) | |
parent | 064b021fbe470ecc9ca10f9f87af48c0fc0865fb (diff) | |
download | linux-382e1596197be46b73aed08be05acf5b5ae8ce49.tar.xz |
Merge branch 'pm-sleep'
* pm-sleep:
PM / Sleep: call early resume handlers when suspend_noirq fails
Diffstat (limited to 'drivers/base')
-rw-r--r-- | drivers/base/power/main.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c index 61a891dda380..0113adc310dc 100644 --- a/drivers/base/power/main.c +++ b/drivers/base/power/main.c @@ -991,8 +991,16 @@ static int dpm_suspend_late(pm_message_t state) int dpm_suspend_end(pm_message_t state) { int error = dpm_suspend_late(state); + if (error) + return error; - return error ? : dpm_suspend_noirq(state); + error = dpm_suspend_noirq(state); + if (error) { + dpm_resume_early(state); + return error; + } + + return 0; } EXPORT_SYMBOL_GPL(dpm_suspend_end); |