| Rafael J. Wysocki | 296699d | 2007-07-29 23:27:18 +0200 | [diff] [blame] | 1 | config SUSPEND | 
|  | 2 | bool "Suspend to RAM and standby" | 
| Rafael J. Wysocki | 1eb208a | 2011-02-11 00:06:30 +0100 | [diff] [blame] | 3 | depends on ARCH_SUSPEND_POSSIBLE | 
| Rafael J. Wysocki | 296699d | 2007-07-29 23:27:18 +0200 | [diff] [blame] | 4 | default y | 
|  | 5 | ---help--- | 
|  | 6 | Allow the system to enter sleep states in which main memory is | 
|  | 7 | powered and thus its contents are preserved, such as the | 
| Johannes Berg | f4cb570 | 2007-12-08 02:14:00 +0100 | [diff] [blame] | 8 | suspend-to-RAM state (e.g. the ACPI S3 state). | 
| Rafael J. Wysocki | 296699d | 2007-07-29 23:27:18 +0200 | [diff] [blame] | 9 |  | 
| Johannes Berg | b28f508 | 2008-01-15 23:17:00 -0500 | [diff] [blame] | 10 | config SUSPEND_FREEZER | 
|  | 11 | bool "Enable freezer for suspend to RAM/standby" \ | 
|  | 12 | if ARCH_WANTS_FREEZER_CONTROL || BROKEN | 
|  | 13 | depends on SUSPEND | 
|  | 14 | default y | 
|  | 15 | help | 
|  | 16 | This allows you to turn off the freezer for suspend. If this is | 
|  | 17 | done, no tasks are frozen for suspend to RAM/standby. | 
|  | 18 |  | 
|  | 19 | Turning OFF this setting is NOT recommended! If in doubt, say Y. | 
|  | 20 |  | 
| Arve Hjønnevåg | fe6cd63 | 2008-09-09 22:14:34 -0700 | [diff] [blame] | 21 | config HAS_WAKELOCK | 
|  | 22 | bool | 
|  | 23 |  | 
| Arve Hjønnevåg | c1783f5 | 2008-10-07 20:48:01 -0700 | [diff] [blame] | 24 | config HAS_EARLYSUSPEND | 
|  | 25 | bool | 
|  | 26 |  | 
| Arve Hjønnevåg | fe6cd63 | 2008-09-09 22:14:34 -0700 | [diff] [blame] | 27 | config WAKELOCK | 
|  | 28 | bool "Wake lock" | 
|  | 29 | depends on PM && RTC_CLASS | 
|  | 30 | default n | 
|  | 31 | select HAS_WAKELOCK | 
|  | 32 | ---help--- | 
|  | 33 | Enable wakelocks. When user space request a sleep state the | 
|  | 34 | sleep request will be delayed until no wake locks are held. | 
|  | 35 |  | 
|  | 36 | config WAKELOCK_STAT | 
|  | 37 | bool "Wake lock stats" | 
|  | 38 | depends on WAKELOCK | 
|  | 39 | default y | 
|  | 40 | ---help--- | 
|  | 41 | Report wake lock stats in /proc/wakelocks | 
|  | 42 |  | 
| Arve Hjønnevåg | 47dfb46 | 2008-10-09 21:01:46 -0700 | [diff] [blame] | 43 | config USER_WAKELOCK | 
|  | 44 | bool "Userspace wake locks" | 
|  | 45 | depends on WAKELOCK | 
|  | 46 | default y | 
|  | 47 | ---help--- | 
|  | 48 | User-space wake lock api. Write "lockname" or "lockname timeout" | 
|  | 49 | to /sys/power/wake_lock lock and if needed create a wake lock. | 
|  | 50 | Write "lockname" to /sys/power/wake_unlock to unlock a user wake | 
|  | 51 | lock. | 
|  | 52 |  | 
| Arve Hjønnevåg | c1783f5 | 2008-10-07 20:48:01 -0700 | [diff] [blame] | 53 | config EARLYSUSPEND | 
|  | 54 | bool "Early suspend" | 
|  | 55 | depends on WAKELOCK | 
|  | 56 | default y | 
|  | 57 | select HAS_EARLYSUSPEND | 
|  | 58 | ---help--- | 
|  | 59 | Call early suspend handlers when the user requested sleep state | 
|  | 60 | changes. | 
|  | 61 |  | 
| Arve Hjønnevåg | c8bb315 | 2008-10-15 17:52:20 -0700 | [diff] [blame^] | 62 | choice | 
|  | 63 | prompt "User-space screen access" | 
|  | 64 | default CONSOLE_EARLYSUSPEND | 
|  | 65 | depends on HAS_EARLYSUSPEND | 
|  | 66 |  | 
|  | 67 | config NO_USER_SPACE_SCREEN_ACCESS_CONTROL | 
|  | 68 | bool "None" | 
|  | 69 |  | 
|  | 70 | config CONSOLE_EARLYSUSPEND | 
|  | 71 | bool "Console switch on early-suspend" | 
|  | 72 | depends on HAS_EARLYSUSPEND && VT | 
|  | 73 | ---help--- | 
|  | 74 | Register early suspend handler to perform a console switch to | 
|  | 75 | when user-space should stop drawing to the screen and a switch | 
|  | 76 | back when it should resume. | 
|  | 77 | endchoice | 
|  | 78 |  | 
| Rafael J. Wysocki | 1f112ce | 2011-04-11 22:54:42 +0200 | [diff] [blame] | 79 | config HIBERNATE_CALLBACKS | 
|  | 80 | bool | 
|  | 81 |  | 
| Rafael J. Wysocki | b0cb1a1 | 2007-07-29 23:24:36 +0200 | [diff] [blame] | 82 | config HIBERNATION | 
| Rafael J. Wysocki | 296699d | 2007-07-29 23:27:18 +0200 | [diff] [blame] | 83 | bool "Hibernation (aka 'suspend to disk')" | 
| Rafael J. Wysocki | 1eb208a | 2011-02-11 00:06:30 +0100 | [diff] [blame] | 84 | depends on SWAP && ARCH_HIBERNATION_POSSIBLE | 
| Rafael J. Wysocki | 1f112ce | 2011-04-11 22:54:42 +0200 | [diff] [blame] | 85 | select HIBERNATE_CALLBACKS | 
| Bojan Smojver | f996fc9 | 2010-09-09 23:06:23 +0200 | [diff] [blame] | 86 | select LZO_COMPRESS | 
|  | 87 | select LZO_DECOMPRESS | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | ---help--- | 
| David Brownell | a7ee2e5 | 2007-05-06 14:50:50 -0700 | [diff] [blame] | 89 | Enable the suspend to disk (STD) functionality, which is usually | 
|  | 90 | called "hibernation" in user interfaces.  STD checkpoints the | 
|  | 91 | system and powers it off; and restores that checkpoint on reboot. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 |  | 
| Pavel Machek | 23b168d | 2008-02-05 19:27:12 +0100 | [diff] [blame] | 93 | You can suspend your machine with 'echo disk > /sys/power/state' | 
|  | 94 | after placing resume=/dev/swappartition on the kernel command line | 
|  | 95 | in your bootloader's configuration file. | 
|  | 96 |  | 
| Rafael J. Wysocki | c7276fd | 2007-03-06 01:42:24 -0800 | [diff] [blame] | 97 | Alternatively, you can use the additional userland tools available | 
|  | 98 | from <http://suspend.sf.net>. | 
|  | 99 |  | 
|  | 100 | In principle it does not require ACPI or APM, although for example | 
| David Brownell | a7ee2e5 | 2007-05-06 14:50:50 -0700 | [diff] [blame] | 101 | ACPI will be used for the final steps when it is available.  One | 
|  | 102 | of the reasons to use software suspend is that the firmware hooks | 
|  | 103 | for suspend states like suspend-to-RAM (STR) often don't work very | 
|  | 104 | well with Linux. | 
| Rafael J. Wysocki | c7276fd | 2007-03-06 01:42:24 -0800 | [diff] [blame] | 105 |  | 
|  | 106 | It creates an image which is saved in your active swap. Upon the next | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 107 | boot, pass the 'resume=/dev/swappartition' argument to the kernel to | 
|  | 108 | have it detect the saved image, restore memory state from it, and | 
|  | 109 | continue to run as before. If you do not want the previous state to | 
| Rafael J. Wysocki | c7276fd | 2007-03-06 01:42:24 -0800 | [diff] [blame] | 110 | be reloaded, then use the 'noresume' kernel command line argument. | 
|  | 111 | Note, however, that fsck will be run on your filesystems and you will | 
|  | 112 | need to run mkswap against the swap partition used for the suspend. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 113 |  | 
| Rafael J. Wysocki | c7276fd | 2007-03-06 01:42:24 -0800 | [diff] [blame] | 114 | It also works with swap files to a limited extent (for details see | 
|  | 115 | <file:Documentation/power/swsusp-and-swap-files.txt>). | 
|  | 116 |  | 
|  | 117 | Right now you may boot without resuming and resume later but in the | 
|  | 118 | meantime you cannot use the swap partition(s)/file(s) involved in | 
|  | 119 | suspending.  Also in this case you must not use the filesystems | 
|  | 120 | that were mounted before the suspend.  In particular, you MUST NOT | 
|  | 121 | MOUNT any journaled filesystems mounted before the suspend or they | 
|  | 122 | will get corrupted in a nasty way. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 123 |  | 
|  | 124 | For more information take a look at <file:Documentation/power/swsusp.txt>. | 
|  | 125 |  | 
|  | 126 | config PM_STD_PARTITION | 
|  | 127 | string "Default resume partition" | 
| Rafael J. Wysocki | b0cb1a1 | 2007-07-29 23:24:36 +0200 | [diff] [blame] | 128 | depends on HIBERNATION | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 | default "" | 
|  | 130 | ---help--- | 
|  | 131 | The default resume partition is the partition that the suspend- | 
|  | 132 | to-disk implementation will look for a suspended disk image. | 
|  | 133 |  | 
|  | 134 | The partition specified here will be different for almost every user. | 
|  | 135 | It should be a valid swap partition (at least for now) that is turned | 
|  | 136 | on before suspending. | 
|  | 137 |  | 
|  | 138 | The partition specified can be overridden by specifying: | 
|  | 139 |  | 
|  | 140 | resume=/dev/<other device> | 
|  | 141 |  | 
|  | 142 | which will set the resume partition to the device specified. | 
|  | 143 |  | 
|  | 144 | Note there is currently not a way to specify which device to save the | 
|  | 145 | suspended image to. It will simply pick the first available swap | 
|  | 146 | device. | 
|  | 147 |  | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 148 | config PM_SLEEP | 
| Jan Beulich | cf4fb80 | 2011-02-18 01:05:36 +0100 | [diff] [blame] | 149 | def_bool y | 
| Shriram Rajagopalan | d419e4c | 2011-04-11 22:54:48 +0200 | [diff] [blame] | 150 | depends on SUSPEND || HIBERNATE_CALLBACKS | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 151 |  | 
|  | 152 | config PM_SLEEP_SMP | 
| Jan Beulich | cf4fb80 | 2011-02-18 01:05:36 +0100 | [diff] [blame] | 153 | def_bool y | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 154 | depends on SMP | 
|  | 155 | depends on ARCH_SUSPEND_POSSIBLE || ARCH_HIBERNATION_POSSIBLE | 
|  | 156 | depends on PM_SLEEP | 
|  | 157 | select HOTPLUG | 
|  | 158 | select HOTPLUG_CPU | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 159 |  | 
|  | 160 | config PM_RUNTIME | 
|  | 161 | bool "Run-time PM core functionality" | 
|  | 162 | depends on !IA64_HP_SIM | 
|  | 163 | ---help--- | 
|  | 164 | Enable functionality allowing I/O devices to be put into energy-saving | 
|  | 165 | (low power) states at run time (or autosuspended) after a specified | 
|  | 166 | period of inactivity and woken up in response to a hardware-generated | 
|  | 167 | wake-up event or a driver's request. | 
|  | 168 |  | 
|  | 169 | Hardware support is generally required for this functionality to work | 
|  | 170 | and the bus type drivers of the buses the devices are on are | 
|  | 171 | responsible for the actual handling of the autosuspend requests and | 
|  | 172 | wake-up events. | 
|  | 173 |  | 
|  | 174 | config PM | 
| Jan Beulich | cf4fb80 | 2011-02-18 01:05:36 +0100 | [diff] [blame] | 175 | def_bool y | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 176 | depends on PM_SLEEP || PM_RUNTIME | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 177 |  | 
|  | 178 | config PM_DEBUG | 
|  | 179 | bool "Power Management Debug Support" | 
|  | 180 | depends on PM | 
|  | 181 | ---help--- | 
|  | 182 | This option enables various debugging support in the Power Management | 
|  | 183 | code. This is helpful when debugging and reporting PM bugs, like | 
|  | 184 | suspend support. | 
|  | 185 |  | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 186 | config PM_ADVANCED_DEBUG | 
|  | 187 | bool "Extra PM attributes in sysfs for low-level debugging/testing" | 
|  | 188 | depends on PM_DEBUG | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 189 | ---help--- | 
|  | 190 | Add extra sysfs attributes allowing one to access some Power Management | 
|  | 191 | fields of device objects from user space.  If you are not a kernel | 
|  | 192 | developer interested in debugging/testing Power Management, say "no". | 
|  | 193 |  | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 194 | config PM_TEST_SUSPEND | 
|  | 195 | bool "Test suspend/resume and wakealarm during bootup" | 
|  | 196 | depends on SUSPEND && PM_DEBUG && RTC_CLASS=y | 
|  | 197 | ---help--- | 
|  | 198 | This option will let you suspend your machine during bootup, and | 
|  | 199 | make it wake up a few seconds later using an RTC wakeup alarm. | 
|  | 200 | Enable this with a kernel parameter like "test_suspend=mem". | 
|  | 201 |  | 
|  | 202 | You probably want to have your system's RTC driver statically | 
|  | 203 | linked, ensuring that it's available when this test runs. | 
|  | 204 |  | 
|  | 205 | config CAN_PM_TRACE | 
|  | 206 | def_bool y | 
| Rafael J. Wysocki | 88a6f33 | 2011-02-11 20:31:11 +0100 | [diff] [blame] | 207 | depends on PM_DEBUG && PM_SLEEP | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 208 |  | 
|  | 209 | config PM_TRACE | 
|  | 210 | bool | 
|  | 211 | help | 
|  | 212 | This enables code to save the last PM event point across | 
|  | 213 | reboot. The architecture needs to support this, x86 for | 
|  | 214 | example does by saving things in the RTC, see below. | 
|  | 215 |  | 
|  | 216 | The architecture specific code must provide the extern | 
|  | 217 | functions from <linux/resume-trace.h> as well as the | 
|  | 218 | <asm/resume-trace.h> header with a TRACE_RESUME() macro. | 
|  | 219 |  | 
|  | 220 | The way the information is presented is architecture- | 
|  | 221 | dependent, x86 will print the information during a | 
|  | 222 | late_initcall. | 
|  | 223 |  | 
|  | 224 | config PM_TRACE_RTC | 
|  | 225 | bool "Suspend/resume event tracing" | 
|  | 226 | depends on CAN_PM_TRACE | 
|  | 227 | depends on X86 | 
|  | 228 | select PM_TRACE | 
| Rafael J. Wysocki | 196ec24 | 2011-02-11 00:06:42 +0100 | [diff] [blame] | 229 | ---help--- | 
|  | 230 | This enables some cheesy code to save the last PM event point in the | 
|  | 231 | RTC across reboots, so that you can debug a machine that just hangs | 
|  | 232 | during suspend (or more commonly, during resume). | 
|  | 233 |  | 
|  | 234 | To use this debugging feature you should attempt to suspend the | 
|  | 235 | machine, reboot it and then run | 
|  | 236 |  | 
|  | 237 | dmesg -s 1000000 | grep 'hash matches' | 
|  | 238 |  | 
|  | 239 | CAUTION: this option will cause your machine's real-time clock to be | 
|  | 240 | set to an invalid time after a resume. | 
|  | 241 |  | 
| Ralf Baechle | 7726942 | 2007-02-09 17:08:57 +0000 | [diff] [blame] | 242 | config APM_EMULATION | 
|  | 243 | tristate "Advanced Power Management Emulation" | 
|  | 244 | depends on PM && SYS_SUPPORTS_APM_EMULATION | 
|  | 245 | help | 
|  | 246 | APM is a BIOS specification for saving power using several different | 
|  | 247 | techniques. This is mostly useful for battery powered laptops with | 
|  | 248 | APM compliant BIOSes. If you say Y here, the system time will be | 
|  | 249 | reset after a RESUME operation, the /proc/apm device will provide | 
|  | 250 | battery status information, and user-space programs will receive | 
|  | 251 | notification of APM "events" (e.g. battery status change). | 
|  | 252 |  | 
|  | 253 | In order to use APM, you will need supporting software. For location | 
| Randy Dunlap | 5347112 | 2008-03-12 18:10:51 -0400 | [diff] [blame] | 254 | and more information, read <file:Documentation/power/pm.txt> and the | 
| Ralf Baechle | 7726942 | 2007-02-09 17:08:57 +0000 | [diff] [blame] | 255 | Battery Powered Linux mini-HOWTO, available from | 
|  | 256 | <http://www.tldp.org/docs.html#howto>. | 
|  | 257 |  | 
|  | 258 | This driver does not spin down disk drives (see the hdparm(8) | 
|  | 259 | manpage ("man 8 hdparm") for that), and it doesn't turn off | 
|  | 260 | VESA-compliant "green" monitors. | 
|  | 261 |  | 
|  | 262 | Generally, if you don't have a battery in your machine, there isn't | 
|  | 263 | much point in using this driver and you should say N. If you get | 
|  | 264 | random kernel OOPSes or reboots that don't seem to be related to | 
|  | 265 | anything, try disabling/enabling this option (or disabling/enabling | 
|  | 266 | APM in your BIOS). | 
| Rafael J. Wysocki | 5e928f7 | 2009-08-18 23:38:32 +0200 | [diff] [blame] | 267 |  | 
| Mark Brown | 43e6086 | 2010-11-11 01:51:26 +0100 | [diff] [blame] | 268 | config ARCH_HAS_OPP | 
|  | 269 | bool | 
|  | 270 |  | 
| Nishanth Menon | e1f60b2 | 2010-10-13 00:13:10 +0200 | [diff] [blame] | 271 | config PM_OPP | 
|  | 272 | bool "Operating Performance Point (OPP) Layer library" | 
| Mark Brown | 43e6086 | 2010-11-11 01:51:26 +0100 | [diff] [blame] | 273 | depends on ARCH_HAS_OPP | 
| Nishanth Menon | e1f60b2 | 2010-10-13 00:13:10 +0200 | [diff] [blame] | 274 | ---help--- | 
|  | 275 | SOCs have a standard set of tuples consisting of frequency and | 
|  | 276 | voltage pairs that the device will support per voltage domain. This | 
|  | 277 | is called Operating Performance Point or OPP. The actual definitions | 
|  | 278 | of OPP varies over silicon within the same family of devices. | 
|  | 279 |  | 
|  | 280 | OPP layer organizes the data internally using device pointers | 
|  | 281 | representing individual voltage domains and provides SOC | 
|  | 282 | implementations a ready to use framework to manage OPPs. | 
|  | 283 | For more information, read <file:Documentation/power/opp.txt> | 
| Rafael J. Wysocki | 85eb8c8 | 2011-04-30 00:25:44 +0200 | [diff] [blame] | 284 |  | 
|  | 285 | config PM_RUNTIME_CLK | 
|  | 286 | def_bool y | 
|  | 287 | depends on PM_RUNTIME && HAVE_CLK |