blob: a33a2919dbe4bee89ccce1f387f598cc70e941a5 [file] [log] [blame]
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -03001===============================================
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -08002Using swap files with software suspend (swsusp)
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -03003===============================================
4
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -08005 (C) 2006 Rafael J. Wysocki <rjw@sisk.pl>
6
7The Linux kernel handles swap files almost in the same way as it handles swap
8partitions and there are only two differences between these two types of swap
9areas:
10(1) swap files need not be contiguous,
11(2) the header of a swap file is not in the first block of the partition that
12holds it. From the swsusp's point of view (1) is not a problem, because it is
13already taken care of by the swap-handling code, but (2) has to be taken into
14consideration.
15
16In principle the location of a swap file's header may be determined with the
17help of appropriate filesystem driver. Unfortunately, however, it requires the
18filesystem holding the swap file to be mounted, and if this filesystem is
19journaled, it cannot be mounted during resume from disk. For this reason to
20identify a swap file swsusp uses the name of the partition that holds the file
21and the offset from the beginning of the partition at which the swap file's
22header is located. For convenience, this offset is expressed in <PAGE_SIZE>
23units.
24
25In order to use a swap file with swsusp, you need to:
26
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -0300271) Create the swap file and make it active, eg.::
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080028
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -030029 # dd if=/dev/zero of=<swap_file_path> bs=1024 count=<swap_file_size_in_k>
30 # mkswap <swap_file_path>
31 # swapon <swap_file_path>
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080032
332) Use an application that will bmap the swap file with the help of the
34FIBMAP ioctl and determine the location of the file's swap header, as the
35offset, in <PAGE_SIZE> units, from the beginning of the partition which
36holds the swap file.
37
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -0300383) Add the following parameters to the kernel command line::
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080039
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -030040 resume=<swap_file_partition> resume_offset=<swap_file_offset>
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080041
42where <swap_file_partition> is the partition on which the swap file is located
43and <swap_file_offset> is the offset of the swap header determined by the
Rafael J. Wysockibf73bae2006-12-06 20:34:16 -080044application in 2) (of course, this step may be carried out automatically
Matt LaPlante01dd2fb2007-10-20 01:34:40 +020045by the same application that determines the swap file's header offset using the
Rafael J. Wysockibf73bae2006-12-06 20:34:16 -080046FIBMAP ioctl)
47
48OR
49
50Use a userland suspend application that will set the partition and offset
51with the help of the SNAPSHOT_SET_SWAP_AREA ioctl described in
Mauro Carvalho Chehab151f4e22019-06-13 07:10:36 -030052Documentation/power/userland-swsusp.rst (this is the only method to suspend
Rafael J. Wysockibf73bae2006-12-06 20:34:16 -080053to a swap file allowing the resume to be initiated from an initrd or initramfs
54image).
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080055
56Now, swsusp will use the swap file in the same way in which it would use a swap
Rafael J. Wysockibf73bae2006-12-06 20:34:16 -080057partition. In particular, the swap file has to be active (ie. be present in
58/proc/swaps) so that it can be used for suspending.
Rafael J. Wysockiecbd0da2006-12-06 20:34:13 -080059
60Note that if the swap file used for suspending is deleted and recreated,
61the location of its header need not be the same as before. Thus every time
62this happens the value of the "resume_offset=" kernel command line parameter
63has to be updated.