diff options
author | Shriram Rajagopalan <rshriram@cs.ubc.ca> | 2011-02-22 14:59:06 -0800 |
---|---|---|
committer | Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> | 2011-03-16 13:42:56 -0400 |
commit | b3e96c0c756211e805c6941d4a6e5f6e1995cb6b (patch) | |
tree | 1e11a95ae6d234f98e20f40dcc89cf28df229ca4 /include/linux/string_helpers.h | |
parent | c7853aea57d8e850b0979e7bdcbcabdcbbdd9e37 (diff) | |
download | linux-stable-b3e96c0c756211e805c6941d4a6e5f6e1995cb6b.tar.gz linux-stable-b3e96c0c756211e805c6941d4a6e5f6e1995cb6b.tar.bz2 linux-stable-b3e96c0c756211e805c6941d4a6e5f6e1995cb6b.zip |
xen: use freeze/restore/thaw PM events for suspend/resume/chkpt
Use PM_FREEZE, PM_THAW and PM_RESTORE power events for
suspend/resume/checkpoint functionality, instead of PM_SUSPEND
and PM_RESUME. Use of these pm events fixes the Xen Guest hangup
when taking checkpoints. When a suspend event is cancelled
(while taking checkpoints once/continuously), we use PM_THAW
instead of PM_RESUME. PM_RESTORE is used when suspend is not
cancelled. See Documentation/power/devices.txt and linux/pm.h
for more info about freeze, thaw and restore. The sequence of
pm events in a suspend-resume scenario is shown below.
dpm_suspend_start(PMSG_FREEZE);
dpm_suspend_noirq(PMSG_FREEZE);
sysdev_suspend(PMSG_FREEZE);
cancelled = suspend_hypercall()
sysdev_resume();
dpm_resume_noirq(cancelled ? PMSG_THAW : PMSG_RESTORE);
dpm_resume_end(cancelled ? PMSG_THAW : PMSG_RESTORE);
Acked-by: Ian Campbell <ian.campbell@citrix.com>
Signed-off-by: Shriram Rajagopalan <rshriram@cs.ubc.ca>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Diffstat (limited to 'include/linux/string_helpers.h')
0 files changed, 0 insertions, 0 deletions