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