Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932121AbWITVUw (ORCPT ); Wed, 20 Sep 2006 17:20:52 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S932122AbWITVUv (ORCPT ); Wed, 20 Sep 2006 17:20:51 -0400 Received: from ogre.sisk.pl ([217.79.144.158]:20645 "EHLO ogre.sisk.pl") by vger.kernel.org with ESMTP id S932121AbWITVUo (ORCPT ); Wed, 20 Sep 2006 17:20:44 -0400 From: "Rafael J. Wysocki" To: Pavel Machek Subject: [PATCH -mm 6/6] swsusp: Document support for swap files Date: Wed, 20 Sep 2006 22:01:08 +0200 User-Agent: KMail/1.9.1 Cc: Andrew Morton , LKML References: <200609202120.58082.rjw@sisk.pl> In-Reply-To: <200609202120.58082.rjw@sisk.pl> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200609202201.08918.rjw@sisk.pl> Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 5069 Lines: 113 Document the "resume_offset=" command line parameter as well as the way in which swap files are supported by swsusp. Signed-off-by: Rafael J. Wysocki --- Documentation/kernel-parameters.txt | 6 +++ Documentation/power/swsusp-and-swap-files.txt | 46 ++++++++++++++++++++++++++ Documentation/power/swsusp.txt | 20 +++-------- 3 files changed, 58 insertions(+), 14 deletions(-) Index: linux-2.6.18-rc7-mm1/Documentation/kernel-parameters.txt =================================================================== --- linux-2.6.18-rc7-mm1.orig/Documentation/kernel-parameters.txt +++ linux-2.6.18-rc7-mm1/Documentation/kernel-parameters.txt @@ -1370,6 +1370,12 @@ and is between 256 and 4096 characters. resume= [SWSUSP] Specify the partition device for software suspend + resume_offset= [SWSUSP] + Specify the offset from the beginning of the partition + given by "resume=" at which the swap header is located, + in units (needed only for swap files). + See Documentation/power/swsusp-and-swap-files.txt + rhash_entries= [KNL,NET] Set number of hash buckets for route cache Index: linux-2.6.18-rc7-mm1/Documentation/power/swsusp-and-swap-files.txt =================================================================== --- /dev/null +++ linux-2.6.18-rc7-mm1/Documentation/power/swsusp-and-swap-files.txt @@ -0,0 +1,46 @@ +Using swap files with software suspend (swsusp) + (C) 2006 Rafael J. Wysocki + +The Linux kernel handles swap files almost in the same way as it handles swap +partitions and there are only two differences between these two types of swap +areas: +(1) swap files need not be contiguous, +(2) the header of a swap file is not in the first block of the partition that +holds it. From the swsusp's point of view (1) is not a problem, because it is +already taken care of by the swap-handling code, but (2) has to be taken into +consideration. + +In principle the location of a swap file's header may be determined with the +help of appropriate filesystem driver. Unfortunately, however, it requires the +filesystem holding the swap file to be mounted, and if this filesystem is +journaled, it cannot be mounted during resume from disk. For this reason to +identify a swap file swsusp uses the name of the partition that holds the file +and the offset from the beginning of the partition at which the swap file's +header is located. For convenience, this offset is expressed in +units. + +In order to use a swap file with swsusp, you need to: + +1) Create the swap file and make it active, eg. + +# dd if=/dev/zero of= bs=1024 count= +# mkswap +# swapon + +Then, the kernel will place the following line in the dmesg: + +Adding k swap on . Priority:-2 extents: across:k offset: + +where , , are numbers that describe +the swap file configuration. The last one, , is needed by +swsusp. + +2) Add the following parameters to the kernel command line: + +resume= resume_offset= + +where is the partition on which the swap file is located. + +Now, swsusp will use the swap file in the same way in which it would use a swap +partition. [Of course this means that the resume from a swap file cannot be +initiated from whithin an initrd of initramfs image.] Index: linux-2.6.18-rc7-mm1/Documentation/power/swsusp.txt =================================================================== --- linux-2.6.18-rc7-mm1.orig/Documentation/power/swsusp.txt +++ linux-2.6.18-rc7-mm1/Documentation/power/swsusp.txt @@ -297,20 +297,12 @@ system is shut down or suspended. Additi suspend image to prevent sensitive data from being stolen after resume. -Q: Why can't we suspend to a swap file? +Q: Can I suspend to a swap file? -A: Because accessing swap file needs the filesystem mounted, and -filesystem might do something wrong (like replaying the journal) -during mount. - -There are few ways to get that fixed: - -1) Probably could be solved by modifying every filesystem to support -some kind of "really read-only!" option. Patches welcome. - -2) suspend2 gets around that by storing absolute positions in on-disk -image (and blocksize), with resume parameter pointing directly to -suspend header. +A: Generally, yes, you can. However, it requires you to use the "resume=" and +"resume_offset=" kernel command line parameters, so the resume from a swap file +cannot be initiated from an initrd or initramfs image. See +swsusp-and-swap-files.txt for details. Q: Is there a maximum system RAM size that is supported by swsusp? - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/