From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: Zhang Rui <rui.zhang@intel.com>
Cc: linux-power-mgmt <linux-power-mgmt@linux.intel.com>,
linux-acpi <linux-acpi@vger.kernel.org>,
Len Brown <lenb@kernel.org>, "Li, Shaohua" <shaohua.li@intel.com>
Subject: Re: [RFC] [PATCH 1/3] ACPI: save/restore ACPI NVS memory during hibernation
Date: Wed, 25 Jun 2008 17:30:48 +0200 [thread overview]
Message-ID: <200806251730.49201.rjw@sisk.pl> (raw)
In-Reply-To: <1214362501.3001.134.camel@rzhang-dt.sh.intel.com>
On Wednesday, 25 of June 2008, Zhang Rui wrote:
>
> On Tue, 2008-06-24 at 18:18 +0800, Rafael J. Wysocki wrote:
> > On Tuesday, 24 of June 2008, Zhang Rui wrote:
> > > According to the ACPI spec, ACPI NVS memory region is required to be
> > > saved/restored by OS during hibernation.
> > >
> > > Section 15.3.2 ACPI Spec 3.0b,
> > > "OSPM will call the _PTS control method some time before entering a
> > sleeping state,
> > > to allow the platform’s AML code to update this memory image before
> > entering the
> > > sleeping state. After the system awakes from an S4 state, OSPM will
> > restore this memory
> > > area and call the _WAK control method to enable the BIOS to reclaim
> > its memory image."
> > >
> > > Add the mechanism to save/restore ACPI NVS memory during
> > hibernation.
> > >
> > > Note: now Linux save ACPI NVS memory in
> > acpi_hibernation_pre_snapshot, and restore it in
> > > acpi_hibernation_leave. Both of these functions will be
> > invoked only once during
> > > the hibernate and resume.
> > > Note: in Section 14.3 ACPI spec 3.0b, I only get
> > > "EfiACPIMemoryNVS: The OS and loader must preserve this memory
> > range in
> > > the working and ACPI S1–S3 states."
> > > whether we should save/restore this piece of memory is not
> > cleared.
> > >
> > > Signed-off-by: Zhang Rui <rui.zhang@intel.com>
> >
> > Well, I know what the specification says, but we tried that in the
> > past and it
> > caused regressions.
> Yes, Shaohua generated the prototype patches a couple of years ago.
> But this is slightly different from the original one, e.g. not touching
> ACPI DATA memory, saving ACPI NVS memory after _PTS and restore it
> before _WAK strictly, etc.
> We generate this patch set and hope it be helpful for some hibernate
> specific issues.
>
> > > +
> > > +static int
> > > +acpi_hibernation_notifier_cb(struct notifier_block *nb,
> > > + unsigned long val, void *data)
> > > +{
> > > + int result = 0;
> > > +
> > > + switch (val) {
> > > + case PM_HIBERNATION_PREPARE:
> > > + result = acpi_hibernation_allocate_nvs_pages();
> > > + break;
> > > + case PM_POST_RESTORE: /* Failed */
> > > + case PM_POST_HIBERNATION:
> > > + acpi_hibernation_free_nvs_pages();
> > > + }
> > > + return result;
> > > +}
> > > +
> > > +struct notifier_block acpi_hibernation_nb = {
> > > + .notifier_call = acpi_hibernation_notifier_cb,
> > > +};
> >
> > This is over the top, IMO. Please put the appropriate call into
> > acpi_hibernation_begin() and create acpi_hibernation_end() with the
> > call to
> > acpi_hibernation_free_nvs_pages() (it must do what acpi_pm_end() does
> > apart
> > from this).
> Pages for ACPI NVS must be allocated before swsusp_shrink_memory.
Saying "must" in this context is way too strong IMO. :-)
First, you can allocate memory after swsusp_shrink_memory(), although you
can't allocate too much memory, where how much is "too much" really depends on
the requested size of the image. It certanly cannot be more than the I/O and
spare pages reserve which is 5 MB at present. I don't think there's so much
NVS memory to save in any case.
Still, if you really want to avoid the memory problem, it's better to change
the ordering between swsusp_shrink_memory() and platform_begin() in
kernel/power/disk.c:hibernation_snapshot() than to add a new notifier.
Thanks,
Rafael
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2008-06-25 15:29 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-06-24 7:43 [RFC] [PATCH 1/3] ACPI: save/restore ACPI NVS memory during hibernation Zhang Rui
2008-06-24 10:18 ` Rafael J. Wysocki
2008-06-24 11:16 ` Rafael J. Wysocki
2008-06-25 2:55 ` Zhang Rui
2008-06-25 15:30 ` Rafael J. Wysocki [this message]
2008-06-27 15:52 ` Len Brown
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=200806251730.49201.rjw@sisk.pl \
--to=rjw@sisk.pl \
--cc=lenb@kernel.org \
--cc=linux-acpi@vger.kernel.org \
--cc=linux-power-mgmt@linux.intel.com \
--cc=rui.zhang@intel.com \
--cc=shaohua.li@intel.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox