All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ian Campbell <Ian.Campbell@citrix.com>
To: Shriram Rajagopalan <rshriram@cs.ubc.ca>
Cc: "linux-pm@lists.linux-foundation.org"
	<linux-pm@lists.linux-foundation.org>,
	"xen-devel@lists.xensource.com" <xen-devel@lists.xensource.com>
Subject: Re: [Xen-devel] [PATCH] update comments in pm.h describing Xen Guest save/restore/checkpoint use case
Date: Thu, 17 Feb 2011 10:56:09 +0000	[thread overview]
Message-ID: <1297940169.16356.1511.camel__47342.0926522978$1297961443$gmane$org@zakaz.uk.xensource.com> (raw)
In-Reply-To: <1297929363-27183-1-git-send-email-rshriram@cs.ubc.ca>

On Thu, 2011-02-17 at 07:56 +0000, Shriram Rajagopalan wrote:
> Add documentation to pm.h on how xen uses PM events (freeze,
> thaw, restore) to implement Guest VM save/checkpoint/restore
> functionality.

The change to freeze/thaw/restore instead of suspend/resume raises the
question of what the correct .config option for Xen to key off is.

Currently the Xen suspend functionality in drivers/xen/manage.c is keyed
off CONFIG_PM_SLEEP (which depends on SUSPEND || HIBERNATION ||
XEN_SAVE_RESTORE).

Since PMSG_{SUSPEND,RESUME} are covered by CONFIG_SUSPEND in pm_op()
this already seems incorrect before this change, since PM_SLEEP can be
enabled without SUSPEND, and is equally incorrect after changing to
PMSG_{FREEZE,THAW,RESUME}, which are covered by CONFIG_HIBERNATION.

Is the correct fix to update pm_op to include
	|| defined(CONFIG_XEN_SAVE_RESTORE)
where appropriate in pm_op()? 

Or should we be looking to adjust the Kconfig and/or code on the Xen
side? Having Xen depend on HIBERNATION ="Hibernation (aka 'suspend to
disk')" seems semantically incorrect.

Ian.

> 
> Signed-off-by: Shriram Rajagopalan <rshriram@cs.ubc.ca>
> ---
>  include/linux/pm.h |   19 +++++++++++++++++++
>  1 files changed, 19 insertions(+), 0 deletions(-)
> 
> diff --git a/include/linux/pm.h b/include/linux/pm.h
> index dd9c7ab..2ddd9d3 100644
> --- a/include/linux/pm.h
> +++ b/include/linux/pm.h
> @@ -516,6 +516,25 @@ extern void update_pm_runtime_accounting(struct device *dev);
>   * well as during system sleep states like PM_SUSPEND_STANDBY.  They may
>   * be able to use wakeup events to exit from runtime low-power states,
>   * or from system low-power states such as standby or suspend-to-RAM.
> + *
> + * Xen Guest Kernels use PM_FREEZE, PM_RESTORE and PM_THAW to implement
> + * VM save/restore/checkpoint functionality. Save and Restore are somewhat
> + * similar to hibernate functionality. The sequence of events 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);
> + *
> + * If the syspend_hypercall returns 1, it means that the VM was merely
> + * checkpointed (akin to THAW). If it returns 0, it means the system has been
> + * fully restored from its on-disk snapshot (akin to RESTORE).
>   */
>  
>  #ifdef CONFIG_PM_SLEEP

  reply	other threads:[~2011-02-17 10:56 UTC|newest]

Thread overview: 58+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-02-07  9:07 [PATCH 0/2] Fix hangup after creating checkpoint on Xen SUZUKI, Kazuhiro
2011-02-07  9:08 ` [PATCH 1/2] " SUZUKI, Kazuhiro
2011-02-07  9:08 ` SUZUKI, Kazuhiro
2011-02-07  9:08 ` [PATCH 2/2] " SUZUKI, Kazuhiro
2011-02-07  9:08 ` SUZUKI, Kazuhiro
2011-02-07  9:35 ` [PATCH 0/2] " Rafael J. Wysocki
2011-02-08 11:22   ` Ian Campbell
2011-02-08 11:22     ` Ian Campbell
2011-02-08 16:46     ` Alan Stern
2011-02-08 16:46     ` [linux-pm] " Alan Stern
2011-02-08 16:46       ` Alan Stern
2011-02-08 17:35       ` Ian Campbell
2011-02-08 17:35         ` Ian Campbell
2011-02-09 23:16         ` Brendan Cully
2011-02-09 23:16           ` Brendan Cully
2011-02-09 23:42           ` Alan Stern
2011-02-09 23:42             ` Alan Stern
2011-02-10 11:40             ` [Xen-devel] " Ian Campbell
2011-02-10 11:40             ` [Xen-devel] Re: [linux-pm] " Ian Campbell
2011-02-10 11:40               ` Ian Campbell
2011-02-10 16:00               ` [Xen-devel] " Alan Stern
2011-02-10 16:00               ` [Xen-devel] Re: [linux-pm] " Alan Stern
2011-02-10 16:00                 ` Alan Stern
2011-02-10 16:26                 ` [Xen-devel] " Rafael J. Wysocki
2011-02-10 16:26                   ` Rafael J. Wysocki
2011-02-10 16:26                 ` [Xen-devel] " Rafael J. Wysocki
2011-02-10 16:34                 ` Ian Campbell
2011-02-10 16:34                 ` [Xen-devel] Re: [linux-pm] " Ian Campbell
2011-02-10 16:34                   ` Ian Campbell
2011-02-10 17:01                   ` [Xen-devel] " Rafael J. Wysocki
2011-02-10 17:01                     ` Rafael J. Wysocki
2011-02-17  7:56                     ` [PATCH] update comments in pm.h describing Xen Guest save/restore/checkpoint use case Shriram Rajagopalan
2011-02-17  7:56                     ` Shriram Rajagopalan
2011-02-17 10:56                       ` Ian Campbell [this message]
2011-02-17 10:56                       ` Ian Campbell
2011-02-10 17:01                   ` [Xen-devel] Re: [PATCH 0/2] Fix hangup after creating checkpoint on Xen Rafael J. Wysocki
2011-02-10 18:56                   ` [Xen-devel] Re: [linux-pm] " Alan Stern
2011-02-10 18:56                     ` Alan Stern
2011-02-10 18:56                   ` [Xen-devel] " Alan Stern
2011-02-09 23:42           ` Alan Stern
2011-02-10 11:31           ` [Xen-devel] Re: [linux-pm] " Ian Campbell
2011-02-10 11:31             ` Ian Campbell
2011-02-10 12:40             ` Ian Campbell
2011-02-10 19:31               ` Brendan Cully
2011-02-11  9:14                 ` Ian Campbell
2011-02-11  9:37                   ` Pasi Kärkkäinen
2011-02-11  9:51                 ` Ian Campbell
2011-02-11 18:13                   ` Shriram Rajagopalan
2011-02-14  9:15                     ` Ian Campbell
2011-02-14  9:27                       ` Ian Campbell
2011-02-10 17:53             ` [Xen-devel] " Brendan Cully
2011-02-10 17:53             ` [Xen-devel] Re: [linux-pm] " Brendan Cully
2011-02-10 17:53               ` Brendan Cully
2011-02-10 11:31           ` [Xen-devel] " Ian Campbell
2011-02-09 23:16         ` Brendan Cully
2011-02-08 17:35       ` Ian Campbell
2011-02-08 11:22   ` Ian Campbell
2011-02-07  9:35 ` Rafael J. Wysocki

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='1297940169.16356.1511.camel__47342.0926522978$1297961443$gmane$org@zakaz.uk.xensource.com' \
    --to=ian.campbell@citrix.com \
    --cc=linux-pm@lists.linux-foundation.org \
    --cc=rshriram@cs.ubc.ca \
    --cc=xen-devel@lists.xensource.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.