123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331 |
- Some warnings, first.
- * BIG FAT WARNING *********************************************************
- *
- * If you touch anything on disk between suspend and resume...
- * ...kiss your data goodbye.
- *
- * If you do resume from initrd after your filesystems are mounted...
- * ...bye bye root partition.
- * [this is actually same case as above]
- *
- * If you have unsupported (*) devices using DMA, you may have some
- * problems. If your disk driver does not support suspend... (IDE does),
- * it may cause some problems, too. If you change kernel command line
- * between suspend and resume, it may do something wrong. If you change
- * your hardware while system is suspended... well, it was not good idea;
- * but it will probably only crash.
- *
- * (*) suspend/resume support is needed to make it safe.
- You need to append resume=/dev/your_swap_partition to kernel command
- line. Then you suspend by
- echo shutdown > /sys/power/disk; echo disk > /sys/power/state
- . If you feel ACPI works pretty well on your system, you might try
- echo platform > /sys/power/disk; echo disk > /sys/power/state
- Encrypted suspend image:
- ------------------------
- If you want to store your suspend image encrypted with a temporary
- key to prevent data gathering after resume you must compile
- crypto and the aes algorithm into the kernel - modules won't work
- as they cannot be loaded at resume time.
- Article about goals and implementation of Software Suspend for Linux
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Author: G‚ábor Kuti
- Last revised: 2003-10-20 by Pavel Machek
- Idea and goals to achieve
- Nowadays it is common in several laptops that they have a suspend button. It
- saves the state of the machine to a filesystem or to a partition and switches
- to standby mode. Later resuming the machine the saved state is loaded back to
- ram and the machine can continue its work. It has two real benefits. First we
- save ourselves the time machine goes down and later boots up, energy costs
- are real high when running from batteries. The other gain is that we don't have to
- interrupt our programs so processes that are calculating something for a long
- time shouldn't need to be written interruptible.
- swsusp saves the state of the machine into active swaps and then reboots or
- powerdowns. You must explicitly specify the swap partition to resume from with
- ``resume='' kernel option. If signature is found it loads and restores saved
- state. If the option ``noresume'' is specified as a boot parameter, it skips
- the resuming.
- In the meantime while the system is suspended you should not add/remove any
- of the hardware, write to the filesystems, etc.
- Sleep states summary
- ====================
- There are three different interfaces you can use, /proc/acpi should
- work like this:
- In a really perfect world:
- echo 1 > /proc/acpi/sleep # for standby
- echo 2 > /proc/acpi/sleep # for suspend to ram
- echo 3 > /proc/acpi/sleep # for suspend to ram, but with more power conservative
- echo 4 > /proc/acpi/sleep # for suspend to disk
- echo 5 > /proc/acpi/sleep # for shutdown unfriendly the system
- and perhaps
- echo 4b > /proc/acpi/sleep # for suspend to disk via s4bios
- Frequently Asked Questions
- ==========================
- Q: well, suspending a server is IMHO a really stupid thing,
- but... (Diego Zuccato):
- A: You bought new UPS for your server. How do you install it without
- bringing machine down? Suspend to disk, rearrange power cables,
- resume.
- You have your server on UPS. Power died, and UPS is indicating 30
- seconds to failure. What do you do? Suspend to disk.
- Q: Maybe I'm missing something, but why don't the regular I/O paths work?
- A: We do use the regular I/O paths. However we cannot restore the data
- to its original location as we load it. That would create an
- inconsistent kernel state which would certainly result in an oops.
- Instead, we load the image into unused memory and then atomically copy
- it back to it original location. This implies, of course, a maximum
- image size of half the amount of memory.
- There are two solutions to this:
- * require half of memory to be free during suspend. That way you can
- read "new" data onto free spots, then cli and copy
- * assume we had special "polling" ide driver that only uses memory
- between 0-640KB. That way, I'd have to make sure that 0-640KB is free
- during suspending, but otherwise it would work...
- suspend2 shares this fundamental limitation, but does not include user
- data and disk caches into "used memory" by saving them in
- advance. That means that the limitation goes away in practice.
- Q: Does linux support ACPI S4?
- A: Yes. That's what echo platform > /sys/power/disk does.
- Q: What is 'suspend2'?
- A: suspend2 is 'Software Suspend 2', a forked implementation of
- suspend-to-disk which is available as separate patches for 2.4 and 2.6
- kernels from swsusp.sourceforge.net. It includes support for SMP, 4GB
- highmem and preemption. It also has a extensible architecture that
- allows for arbitrary transformations on the image (compression,
- encryption) and arbitrary backends for writing the image (eg to swap
- or an NFS share[Work In Progress]). Questions regarding suspend2
- should be sent to the mailing list available through the suspend2
- website, and not to the Linux Kernel Mailing List. We are working
- toward merging suspend2 into the mainline kernel.
- Q: A kernel thread must voluntarily freeze itself (call 'refrigerator').
- I found some kernel threads that don't do it, and they don't freeze
- so the system can't sleep. Is this a known behavior?
- A: All such kernel threads need to be fixed, one by one. Select the
- place where the thread is safe to be frozen (no kernel semaphores
- should be held at that point and it must be safe to sleep there), and
- add:
- try_to_freeze();
- If the thread is needed for writing the image to storage, you should
- instead set the PF_NOFREEZE process flag when creating the thread (and
- be very carefull).
- Q: What is the difference between between "platform", "shutdown" and
- "firmware" in /sys/power/disk?
- A:
- shutdown: save state in linux, then tell bios to powerdown
- platform: save state in linux, then tell bios to powerdown and blink
- "suspended led"
- firmware: tell bios to save state itself [needs BIOS-specific suspend
- partition, and has very little to do with swsusp]
- "platform" is actually right thing to do, but "shutdown" is most
- reliable.
- Q: I do not understand why you have such strong objections to idea of
- selective suspend.
- A: Do selective suspend during runtime power managment, that's okay. But
- its useless for suspend-to-disk. (And I do not see how you could use
- it for suspend-to-ram, I hope you do not want that).
- Lets see, so you suggest to
- * SUSPEND all but swap device and parents
- * Snapshot
- * Write image to disk
- * SUSPEND swap device and parents
- * Powerdown
- Oh no, that does not work, if swap device or its parents uses DMA,
- you've corrupted data. You'd have to do
- * SUSPEND all but swap device and parents
- * FREEZE swap device and parents
- * Snapshot
- * UNFREEZE swap device and parents
- * Write
- * SUSPEND swap device and parents
- Which means that you still need that FREEZE state, and you get more
- complicated code. (And I have not yet introduce details like system
- devices).
- Q: There don't seem to be any generally useful behavioral
- distinctions between SUSPEND and FREEZE.
- A: Doing SUSPEND when you are asked to do FREEZE is always correct,
- but it may be unneccessarily slow. If you want USB to stay simple,
- slowness may not matter to you. It can always be fixed later.
- For devices like disk it does matter, you do not want to spindown for
- FREEZE.
- Q: After resuming, system is paging heavilly, leading to very bad interactivity.
- A: Try running
- cat `cat /proc/[0-9]*/maps | grep / | sed 's:.* /:/:' | sort -u` > /dev/null
- after resume. swapoff -a; swapon -a may also be usefull.
- Q: What happens to devices during swsusp? They seem to be resumed
- during system suspend?
- A: That's correct. We need to resume them if we want to write image to
- disk. Whole sequence goes like
- Suspend part
- ~~~~~~~~~~~~
- running system, user asks for suspend-to-disk
- user processes are stopped
- suspend(PMSG_FREEZE): devices are frozen so that they don't interfere
- with state snapshot
- state snapshot: copy of whole used memory is taken with interrupts disabled
- resume(): devices are woken up so that we can write image to swap
- write image to swap
- suspend(PMSG_SUSPEND): suspend devices so that we can power off
- turn the power off
- Resume part
- ~~~~~~~~~~~
- (is actually pretty similar)
- running system, user asks for suspend-to-disk
- user processes are stopped (in common case there are none, but with resume-from-initrd, noone knows)
- read image from disk
- suspend(PMSG_FREEZE): devices are frozen so that they don't interfere
- with image restoration
- image restoration: rewrite memory with image
- resume(): devices are woken up so that system can continue
- thaw all user processes
- Q: What is this 'Encrypt suspend image' for?
- A: First of all: it is not a replacement for dm-crypt encrypted swap.
- It cannot protect your computer while it is suspended. Instead it does
- protect from leaking sensitive data after resume from suspend.
- Think of the following: you suspend while an application is running
- that keeps sensitive data in memory. The application itself prevents
- the data from being swapped out. Suspend, however, must write these
- data to swap to be able to resume later on. Without suspend encryption
- your sensitive data are then stored in plaintext on disk. This means
- that after resume your sensitive data are accessible to all
- applications having direct access to the swap device which was used
- for suspend. If you don't need swap after resume these data can remain
- on disk virtually forever. Thus it can happen that your system gets
- broken in weeks later and sensitive data which you thought were
- encrypted and protected are retrieved and stolen from the swap device.
- To prevent this situation you should use 'Encrypt suspend image'.
- During suspend a temporary key is created and this key is used to
- encrypt the data written to disk. When, during resume, the data was
- read back into memory the temporary key is destroyed which simply
- means that all data written to disk during suspend are then
- inaccessible so they can't be stolen later on. The only thing that
- you must then take care of is that you call 'mkswap' for the swap
- partition used for suspend as early as possible during regular
- boot. This asserts that any temporary key from an oopsed suspend or
- from a failed or aborted resume is erased from the swap device.
- As a rule of thumb use encrypted swap to protect your data while your
- system is shut down or suspended. Additionally use the encrypted
- suspend image to prevent sensitive data from being stolen after
- resume.
- Q: Why can't we 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.
- Q: Is there a maximum system RAM size that is supported by swsusp?
- A: It should work okay with highmem.
- Q: Does swsusp (to disk) use only one swap partition or can it use
- multiple swap partitions (aggregate them into one logical space)?
- A: Only one swap partition, sorry.
- Q: If my application(s) causes lots of memory & swap space to be used
- (over half of the total system RAM), is it correct that it is likely
- to be useless to try to suspend to disk while that app is running?
- A: No, it should work okay, as long as your app does not mlock()
- it. Just prepare big enough swap partition.
- Q: What information is usefull for debugging suspend-to-disk problems?
- A: Well, last messages on the screen are always useful. If something
- is broken, it is usually some kernel driver, therefore trying with as
- little as possible modules loaded helps a lot. I also prefer people to
- suspend from console, preferably without X running. Booting with
- init=/bin/bash, then swapon and starting suspend sequence manually
- usually does the trick. Then it is good idea to try with latest
- vanilla kernel.
|