aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/power
diff options
context:
space:
mode:
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>2014-09-29 20:21:34 -0400
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2014-09-30 15:05:59 -0400
commit2a8a8ce651d3a88fdf83e2ed15633c8d19292108 (patch)
treeff98d7ff5d31ffeeacc117d910a63264a625efc7 /kernel/power
parente1253e5e3fcd61f1057ef8a39c8c64e6b82358b9 (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.c14
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);