From: jfannin@gmail.com (Joseph Fannin)
To: david@lang.hm
Cc: linux-kernel@vger.kernel.org, Pavel Machek <pavel@ucw.cz>,
"Huang, Ying" <ying.huang@intel.com>,
Andrew Morton <akpm@linux-foundation.org>,
linux-pm@lists.linux-foundation.org,
Jeremy Maitin-Shepard <jbms@cmu.edu>
Subject: Hibernating To Swap Considered Harmful
Date: Fri, 13 Jul 2007 01:42:48 -0400 [thread overview]
Message-ID: <20070713054244.GA20082@nineveh.local> (raw)
In-Reply-To: <Pine.LNX.4.64.0707121953440.25614@asgard.lang.hm>
On Thu, Jul 12, 2007 at 08:06:43PM -0700, david@lang.hm wrote:
> On Thu, 12 Jul 2007, Rafael J. Wysocki wrote:
> > Plus we need to figure out how to avoid corrupting filesystems and
> > swap in use by the "old" kernel and its processes (hint: a separate
> > "hibernation partition" is a no-go).
>
> I thought the existing hibernation wrote to the swap partition as it's
> dedicated space?
>
> I didn't know that anyone was suggesting writing the hibernation image to
> a filesystem that the kernel was activly accessing.
I'm suggesting a dedicated, preallocated hibernation *file*, right
now. There's no way around it, if hibernation is to be reliable --
otherwise hibernation can fail if the system has used enough of its
swap space, so that there isn't enough room to write the hibernate
image.
Even if it's desirable to allow hibernation to fail if the system is
too deep into swap, it's a moot point.
Consider how the need to ensure that there is enough space to write
the hibernate image is dealt with now: by making a big honking swap
space, so big that enough of it is all but guaranteed to be free,
except under the heaviest of memory usage. So the space is already
reserved -- and now that it's commingled with actual swap, you have the
need to pass the swap data structures between the two kernels.
Consider instead, you set up two swap spaces, one regular, and one
for hibernation. You don't touch the "hibernation swap" unless the
other is full -- I think just setting a lower priority on the swap
space is enough for this. Before you jump to the hibernate kernel,
you swapoff that hibernate swap.
If you can't swapoff the hibernate swap, hibernate fails right there.
If you can, you have your space for writing the image, free and clear
of any of the original kernel's internal state. There isn't any need
to treat that space as swap any more at all -- the only reason to do
so would be to reuse the existing code.
Setting aside two partitions for swap is obviously undesireable, but
thankfully, Linux supports swap *files*.
There hasn't been a performance penalty to using a swap file (vs. a
partition) since sometime in the 2.5 series. Well, swap files can be
fragmented, but that needs to be considered against the *guaranteed*
seeks you'll see with a swap partition on the same disk as a busy
filesystem, as is the usual case.
The only reasons I can see that Linux usually uses a single swap
partition are that that's how it's always been done, and because
swsusp doesn't support anything other than a single swap device. So,
despite Linux supporting those things, you can't actually use a swap
file or (or more than one swap device) if you want hibernation
support.
(Suspend2 has supported swap files for a long time, and I think I
heard that uswsusp supports them now too.)
Once you accept that swap files need to be supported, you're
already going to be supporting everything you need to support a
dedicated hibernation file -- if you don't consider the trouble to
share the swap and hibernate space to be worth the gain.
--
Joseph Fannin
jfannin@gmail.com
next prev parent reply other threads:[~2007-07-13 5:42 UTC|newest]
Thread overview: 113+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-07-11 15:30 [PATCH 0/2] Kexec jump: The first step to kexec base hibernation Huang, Ying
2007-07-11 11:13 ` Pavel Machek
2007-07-12 0:22 ` Andrew Morton
2007-07-12 5:48 ` Jeremy Fitzhardinge
[not found] ` <4695C096.5080400@goop.org>
2007-07-12 6:43 ` david
2007-07-12 12:46 ` Rafael J. Wysocki
[not found] ` <200707121446.14170.rjw@sisk.pl>
2007-07-12 13:51 ` Mark Lord
2007-07-12 18:42 ` david
[not found] ` <469631FA.2070405@rtr.ca>
2007-07-12 14:49 ` Pavel Machek
2007-07-12 15:35 ` Rafael J. Wysocki
[not found] ` <200707121735.40077.rjw@sisk.pl>
2007-07-12 16:03 ` Mark Lord
[not found] ` <469650DE.4000901@rtr.ca>
2007-07-12 16:35 ` Mark Lord
[not found] ` <46965837.8030907@rtr.ca>
2007-07-12 20:05 ` Jeremy Maitin-Shepard
[not found] ` <87y7hl2xro.fsf@jbms.ath.cx>
2007-07-13 2:38 ` Mark Lord
2007-07-12 16:09 ` Alan Stern
2007-07-12 18:49 ` david
[not found] ` <Pine.LNX.4.64.0707121138140.25614@asgard.lang.hm>
[not found] ` <200707122120.19662.rjw@sisk.pl>
2007-07-12 19:14 ` david
[not found] ` <Pine.LNX.4.64.0707121210210.25614@asgard.lang.hm>
2007-07-12 19:45 ` Rafael J. Wysocki
2007-07-12 19:20 ` Rafael J. Wysocki
[not found] ` <1184260174.9346.85.camel@caritas-dev.intel.com>
2007-07-12 12:47 ` Rafael J. Wysocki
2007-07-12 17:09 ` Huang, Ying
2007-07-12 12:38 ` Rafael J. Wysocki
[not found] ` <1184251423.9346.55.camel@caritas-dev.intel.com>
2007-07-12 7:03 ` david
2007-07-12 12:53 ` Rafael J. Wysocki
2007-07-12 16:32 ` Eric W. Biederman
[not found] ` <Pine.LNX.4.64.0707112345250.28090@asgard.lang.hm>
[not found] ` <1184260683.9346.91.camel@caritas-dev.intel.com>
2007-07-12 10:10 ` david
2007-07-12 13:01 ` Rafael J. Wysocki
[not found] ` <200707121501.03016.rjw@sisk.pl>
2007-07-12 13:22 ` jimmy bahuleyan
2007-07-12 19:03 ` david
2007-07-12 13:55 ` Mark Lord
2007-07-12 19:05 ` david
2007-07-12 14:06 ` Pavel Machek
2007-07-12 17:18 ` Huang, Ying
[not found] ` <200707121453.49616.rjw@sisk.pl>
2007-07-12 18:57 ` david
[not found] ` <Pine.LNX.4.64.0707121150460.25614@asgard.lang.hm>
2007-07-12 19:34 ` Rafael J. Wysocki
[not found] ` <200707122134.29991.rjw@sisk.pl>
2007-07-12 19:55 ` Jeremy Maitin-Shepard
[not found] ` <877ip54cti.fsf@jbms.ath.cx>
2007-07-12 20:45 ` Rafael J. Wysocki
2007-07-13 3:12 ` david
[not found] ` <Pine.LNX.4.64.0707122008550.25614@asgard.lang.hm>
2007-07-13 9:17 ` Rafael J. Wysocki
2007-07-13 9:25 ` david
2007-07-13 11:41 ` Rafael J. Wysocki
[not found] ` <200707131341.35801.rjw@sisk.pl>
2007-07-14 7:51 ` david
[not found] ` <Pine.LNX.4.64.0707140017560.25614@asgard.lang.hm>
2007-07-14 8:33 ` david
[not found] ` <Pine.LNX.4.64.0707140128210.25614@asgard.lang.hm>
2007-07-14 9:24 ` Rafael J. Wysocki
2007-07-14 20:00 ` Rafael J. Wysocki
2007-07-14 20:34 ` david
[not found] ` <Pine.LNX.4.64.0707141257290.14672@asgard.lang.hm>
2007-07-14 21:06 ` Rafael J. Wysocki
[not found] ` <200707142306.33783.rjw@sisk.pl>
2007-07-14 21:13 ` david
2007-07-15 10:31 ` Rafael J. Wysocki
[not found] ` <200707151231.27410.rjw@sisk.pl>
2007-07-15 19:23 ` david
2007-07-15 22:59 ` Rafael J. Wysocki
[not found] ` <200707160059.08277.rjw@sisk.pl>
2007-07-15 23:22 ` david
[not found] ` <Pine.LNX.4.64.0707151549200.25614@asgard.lang.hm>
2007-07-16 12:17 ` Rafael J. Wysocki
[not found] ` <200707161417.50166.rjw@sisk.pl>
2007-07-16 14:42 ` Huang, Ying
[not found] ` <1184596950.24143.28.camel@caritas-dev.intel.com>
2007-07-16 15:40 ` Rafael J. Wysocki
[not found] ` <200707161740.26703.rjw@sisk.pl>
2007-07-17 4:18 ` david
2007-07-17 11:46 ` Rafael J. Wysocki
2007-07-14 21:34 ` david
2007-07-15 10:39 ` Rafael J. Wysocki
[not found] ` <200707151239.28400.rjw@sisk.pl>
2007-07-15 19:33 ` david
[not found] ` <Pine.LNX.4.64.0707151224160.25614@asgard.lang.hm>
2007-07-15 23:11 ` Rafael J. Wysocki
[not found] ` <200707160111.16805.rjw@sisk.pl>
2007-07-15 23:33 ` david
2007-07-13 3:06 ` david
2007-07-13 5:42 ` Joseph Fannin [this message]
2007-07-13 5:57 ` Hibernating To Swap Considered Harmful david
2007-07-13 6:20 ` Joseph Fannin
[not found] ` <20070713062039.GA29055@nineveh.local>
2007-07-13 6:27 ` david
[not found] ` <Pine.LNX.4.64.0707122319270.25614@asgard.lang.hm>
2007-07-13 7:15 ` Joseph Fannin
[not found] ` <20070713071512.GB29055@nineveh.local>
2007-07-13 14:35 ` Jeremy Maitin-Shepard
[not found] ` <87odig1idx.fsf@jbms.ath.cx>
2007-07-17 0:12 ` Joseph Fannin
[not found] ` <20070717001239.GB20082@nineveh.local>
2007-07-17 5:44 ` Oliver Neukum
[not found] ` <200707170744.08191.oliver@neukum.org>
2007-07-17 6:28 ` Joseph Fannin
[not found] ` <20070717062803.GA9069@nineveh.local>
2007-07-17 6:42 ` david
2007-07-17 7:26 ` Joseph Fannin
2007-07-17 7:34 ` david
2007-07-17 11:52 ` Rafael J. Wysocki
[not found] ` <Pine.LNX.4.64.0707170030460.19248@asgard.lang.hm>
2007-07-17 11:54 ` Rafael J. Wysocki
2007-07-17 7:10 ` Oliver Neukum
2007-07-13 9:30 ` Rafael J. Wysocki
[not found] ` <200707131130.51279.rjw@sisk.pl>
2007-07-14 0:45 ` Joseph Fannin
[not found] ` <20070714004517.GA18336@nineveh.local>
2007-07-14 9:48 ` Rafael J. Wysocki
[not found] ` <200707141148.18279.rjw@sisk.pl>
2007-07-16 5:37 ` Joseph Fannin
2007-07-13 9:29 ` [PATCH 0/2] Kexec jump: The first step to kexec base hibernation Rafael J. Wysocki
[not found] ` <200707131129.34974.rjw@sisk.pl>
2007-07-13 9:38 ` david
2007-07-13 11:59 ` Rafael J. Wysocki
2007-07-13 14:37 ` Alan Stern
2007-07-13 15:12 ` Jeremy Maitin-Shepard
[not found] ` <87abu01gnv.fsf@jbms.ath.cx>
2007-07-13 15:45 ` Rafael J. Wysocki
[not found] ` <200707131745.43055.rjw@sisk.pl>
2007-07-13 15:50 ` Alan Stern
2007-07-13 16:48 ` Jeremy Maitin-Shepard
2007-07-13 21:23 ` Rafael J. Wysocki
2007-07-14 7:12 ` david
[not found] ` <1184347974.4523.30.camel@caritas-dev.intel.com>
2007-07-13 12:01 ` Rafael J. Wysocki
2007-07-13 17:32 ` Huang, Ying
[not found] ` <m14pk9fuqa.fsf@ebiederm.dsl.xmission.com>
2007-07-12 19:09 ` david
2007-07-12 19:49 ` Eric W. Biederman
[not found] ` <1184368525.1069.68.camel@caritas-dev.intel.com>
2007-07-13 16:43 ` Eric W. Biederman
[not found] ` <m1k5t4dzl4.fsf@ebiederm.dsl.xmission.com>
2007-07-14 5:48 ` Huang, Ying
[not found] ` <1184392129.1898.69.camel@caritas-dev.intel.com>
2007-07-14 9:59 ` Rafael J. Wysocki
2007-07-14 10:55 ` Huang, Ying
[not found] ` <1184410554.1898.84.camel@caritas-dev.intel.com>
2007-07-14 19:16 ` Rafael J. Wysocki
[not found] ` <200707142116.10237.rjw@sisk.pl>
2007-07-15 9:30 ` Huang, Ying
[not found] ` <1184491804.1898.121.camel@caritas-dev.intel.com>
2007-07-15 10:49 ` Rafael J. Wysocki
2007-07-17 8:13 ` david
[not found] ` <Pine.LNX.4.64.0707170101010.19248@asgard.lang.hm>
2007-07-17 11:59 ` Rafael J. Wysocki
2007-07-17 12:48 ` Huang, Ying
[not found] ` <1184676518.10998.34.camel@caritas-dev.intel.com>
2007-07-17 14:22 ` Rafael J. Wysocki
2007-07-18 0:25 ` david
2007-07-13 23:15 ` Huang, Ying
2007-07-12 14:43 ` Huang, Ying
[not found] ` <20070711111350.GI7091@elf.ucw.cz>
[not found] ` <1184257734.9346.76.camel@caritas-dev.intel.com>
2007-07-12 8:54 ` Pavel Machek
[not found] ` <20070712085428.GA1866@elf.ucw.cz>
2007-07-13 23:18 ` Huang, Ying
2007-07-12 16:28 ` Huang, Ying
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=20070713054244.GA20082@nineveh.local \
--to=jfannin@gmail.com \
--cc=akpm@linux-foundation.org \
--cc=david@lang.hm \
--cc=jbms@cmu.edu \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@lists.linux-foundation.org \
--cc=pavel@ucw.cz \
--cc=ying.huang@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