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