diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2014-09-29 20:21:34 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2014-09-30 15:05:59 -0400 |
commit | 2a8a8ce651d3a88fdf83e2ed15633c8d19292108 (patch) | |
tree | ff98d7ff5d31ffeeacc117d910a63264a625efc7 /kernel/power | |
parent | e1253e5e3fcd61f1057ef8a39c8c64e6b82358b9 (diff) |
PM / sleep: Export dpm_suspend_late/noirq() and dpm_resume_early/noirq()
Subsequent change sets will add platform-related operations between
dpm_suspend_late() and dpm_suspend_noirq() as well as between
dpm_resume_noirq() and dpm_resume_early() in suspend_enter(), so
export these functions for suspend_enter() to be able to call them
separately and split the invocations of dpm_suspend_end() and
dpm_resume_start() in there accordingly.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'kernel/power')
-rw-r--r-- | kernel/power/suspend.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/kernel/power/suspend.c b/kernel/power/suspend.c index e837dd6783c6..58ae98b7dc2b 100644 --- a/kernel/power/suspend.c +++ b/kernel/power/suspend.c | |||
@@ -265,11 +265,16 @@ static int suspend_enter(suspend_state_t state, bool *wakeup) | |||
265 | if (error) | 265 | if (error) |
266 | goto Platform_finish; | 266 | goto Platform_finish; |
267 | 267 | ||
268 | error = dpm_suspend_end(PMSG_SUSPEND); | 268 | error = dpm_suspend_late(PMSG_SUSPEND); |
269 | if (error) { | 269 | if (error) { |
270 | printk(KERN_ERR "PM: Some devices failed to power down\n"); | 270 | printk(KERN_ERR "PM: late suspend of devices failed\n"); |
271 | goto Platform_finish; | 271 | goto Platform_finish; |
272 | } | 272 | } |
273 | error = dpm_suspend_noirq(PMSG_SUSPEND); | ||
274 | if (error) { | ||
275 | printk(KERN_ERR "PM: noirq suspend of devices failed\n"); | ||
276 | goto Devices_early_resume; | ||
277 | } | ||
273 | error = platform_suspend_prepare_late(state); | 278 | error = platform_suspend_prepare_late(state); |
274 | if (error) | 279 | if (error) |
275 | goto Platform_wake; | 280 | goto Platform_wake; |
@@ -319,7 +324,10 @@ static int suspend_enter(suspend_state_t state, bool *wakeup) | |||
319 | 324 | ||
320 | Platform_wake: | 325 | Platform_wake: |
321 | platform_suspend_wake(state); | 326 | platform_suspend_wake(state); |
322 | dpm_resume_start(PMSG_RESUME); | 327 | dpm_resume_noirq(PMSG_RESUME); |
328 | |||
329 | Devices_early_resume: | ||
330 | dpm_resume_early(PMSG_RESUME); | ||
323 | 331 | ||
324 | Platform_finish: | 332 | Platform_finish: |
325 | platform_suspend_finish(state); | 333 | platform_suspend_finish(state); |