Hibernation (computing)

From HandWiki
Short description: Powering down a computer while retaining its state

Hibernation (also known as suspend to disk, or Safe Sleep on Macintosh computers[1]) in computing is powering down a computer while retaining its state. When hibernation begins, the computer saves the contents of its random access memory (RAM) to a hard disk or other non-volatile storage. When the computer is turned on the RAM is restored and the computer is exactly as it was before entering hibernation. Hibernation was first implemented in 1992 and patented[2] by Compaq Computer Corporation in Houston, Texas. Microsoft's Windows 10 employs a type of hibernation (fast startup) by default when shutting down.[3]

Uses

After hibernating, the hardware is powered down like a regular shutdown.[4] The system can have a total loss of power for an indefinite length of time and then resume to the original state. Hibernation is mostly used in laptops, which have limited battery power available.[4] It can be set to happen automatically on a low battery alarm. Most desktops also support hibernation, mainly as a general energy saving measure and allows for replacement of a removable battery quickly. Google and Apple mobile hardware (Android, Chromebooks, iOS) do not support hibernation. Apple hardware using macOS calls hibernation Safe Sleep.[1]

Comparison to sleep mode

Many systems support a low-power sleep mode in which the processing functions of the machine are lowered, using a trickle of power to preserve the contents of RAM and support waking up. Instantaneous resumption is one of the advantages of sleep mode over hibernation. A hibernated system must start up and read data from permanent storage and then transfer that back to RAM, which takes longer and depends on the speed of the permanent storage device, often much slower than RAM memory. A system in sleep mode only needs to power up the CPU and display, which is almost instantaneous. On the other hand, a system in sleep mode still consumes power to keep the data in the RAM. Detaching power from a system in sleep mode results in data loss, while cutting the power of a system in hibernation has no risk; the hibernated system can resume when and if the power is restored. Both shut down and hibernated systems may consume standby power unless they are unplugged.[5]

Hibernation is a means of avoiding the burden of saving unsaved data before shutting down and restoring all running programs and re-opening documents and browser tabs. Both hibernation and sleep preserve memory fragmentation and atrophy that lead to mobile devices working more poorly the longer you avoid a power off. This is why many experts recommend a frequent shut down or reboot of electronic devices.

First implementation

The first working retail hibernation was in 1992 on the Compaq LTE Lite 386 as noted in its sales material.[6] It is made possible in part due to the sleep and protected mode opcodes in the Intel 386 CPU. It was implemented in ROM and worked independently of the operating system with no drivers needed. The LTE would sense low battery and prevented data loss by making use of a hidden partition. It preserved and restored the system in the midst of disk writes and operations with a math co-processor. It could also be controlled using an optional software GUI or a customized keyboard shortcut. It was tested on DOS, Windows 3.1, Banyan Vines, and Novell Netware. Compaq's hibernation is also noted in an IBM patent[7] from 1993.

Operating system support

Early implementations of hibernation used the BIOS as noted above, but modern operating systems usually handle hibernation themselves. Hibernation is defined as sleeping mode S4 in the ACPI specification.[8]

Microsoft Windows

On Windows computers, hibernation is available only if all hardware and device drivers are ACPI and plug-and-play–compliant. This allows some desktop computers to hibernate quickly to SSD in the event of a power failure and power supplied to even a lightweight or aging UPS. Hibernation can be invoked from the Start menu or the command line.[9]

Windows 95 supports hibernation through hardware manufacturer-supplied drivers and only if compatible hardware and BIOS are present. Since Windows 95 supports only Advanced Power Management (APM), hibernation is called Suspend-to-Disk. Windows 98 and later support ACPI. However, hibernation often caused problems since most hardware was not fully ACPI 1.0 compliant or did not have WDM drivers. There were also issues with the FAT32 file system.[10]

Windows 2000 is the first Windows to support hibernation at the operating system level (OS-controlled ACPI S4 sleep state) without special drivers from the hardware manufacturer. A hidden system file named "hiberfil.sys" in the root of the boot partition is used to store the contents of RAM when the computer hibernates. In Windows 2000, this file is as big as the total RAM installed.

Windows Me, the last release in the Windows 9x family, also supports OS controlled hibernation and requires disk space equal to that of the computer's RAM.[11][12]

Windows XP further improved support for hibernation.[13] Hibernation and resumption are much faster as memory pages are compressed using an improved algorithm; compression is overlapped with disk writes, unused memory pages are freed and DMA transfers are used during I/O.[14] hiberfil.sys contains further information including processor state. This file was documented by security researcher Matthieu Suiche[15] during Black Hat Briefings 2008 who also provided a computer forensics framework to manage and convert this file into a readable memory dump.[16] The compression feature was later documented by Microsoft as well.[17]

Although Windows XP added support for more than 4 gigabytes of memory (through Windows XP 64-bit Edition and Windows XP Professional x64 Edition), this operating system, as well as Windows Server 2003, Windows Vista and Windows Server 2008 do not support hibernation when this amount of memory is installed because of performance issues associated with saving such a large pool of data from RAM to disk.[18]

Windows Vista introduced a hybrid sleep feature, which saves the contents of memory to hard disk but instead of powering down, enters sleep mode. If the power is lost, the computer can resume as if hibernated.

Windows 7 introduced compression to the hibernation file and set the default size to 75% of the total physical memory.[17] Microsoft also recommends that the size be increased using the powercfg.exe tool in some rare workloads where the memory footprint exceeds that amount. It can be set from anywhere between 50% and 100%, although decreasing it is not recommended.

Windows 8 also introduces a Fast startup feature. When users select the Shut Down option, it hibernates the computer, but closes all programs and logs out the user session before hibernating.[19] According to Microsoft, a regular hibernation includes more data in memory pages which takes longer to be written to disk. In comparison, when the user session is closed, the hibernation data is much smaller and therefore takes less time to write to disk and resume. Users have the option of performing a traditional shutdown by holding down the Shift key while clicking Shut Down.[20]

Windows 10 mirrors Windows 8 as noted by Microsoft.[3] Windows 10's hibernation algorithm is solid-state drive optimized.

Hibernation is often underused in business environments as it is difficult to enable it on a large network of computers without resorting to third-party PC power management software.[21] This omission by Microsoft has been criticized as having led to a huge waste in energy.[22]

It is possible to disable hibernation and delete hiberfil.sys.[23]

Third-party PC power management software offers features beyond those present in Windows.[24][25][26] Most products offer Active Directory integration and per-user or per-machine settings with more advanced power plans, scheduled power plans, anti-insomnia features and enterprise power usage reporting.

macOS

On Macs, a feature known as Safe Sleep saves the contents of volatile memory to the system hard disk each time the Mac enters Sleep mode. The Mac can instantaneously wake from sleep mode if power to the RAM has not been lost. However, if the power supply was interrupted, such as when removing batteries without an AC power connection, the Mac would wake from Safe Sleep instead, restoring memory contents from the hard drive.[27] Because Safe Sleep's hibernation process occurs during regular Sleep, the Apple menu does not have a "hibernate" option.

Safe Sleep capability was added in Mac models starting with the October 2005 PowerBook G4 (Double-Layer SD). Safe Sleep requires Mac OS X v10.4 or higher.

Shortly after Apple started supporting Safe Sleep, Mac enthusiasts released a hack to enable this feature for much older Mac computers running Mac OS X v10.4.[28] The classic Mac OS once also supported hibernation, but this feature was dropped by Apple.[29]

Linux

In the Linux kernel, hibernation is implemented by swsusp which is built into the 2.6 series. An alternative implementation is TuxOnIce which is available as patches for the kernel version 3.4. TuxOnIce provides advantages such as support for symmetric multiprocessing and preemption. Another alternative implementation is uswsusp. All three refer to it as "suspend-to-disk". systemd, if deployed, manages hibernation itself.

Hybrid sleep

Sleep mode and hibernation can be combined: the contents of RAM are copied to the non-volatile storage and the computer enters sleep mode. This approach combines the benefits of sleep mode and hibernation: The machine can resume instantaneously, and its state, including open and unsaved files, survives a power outage. Hybrid sleep consumes as much power as sleep mode, whereas hibernation powers down the computer.[30][4]

See also

References

  1. 1.0 1.1 "What is safe sleep on Mac?" (in en). https://support.apple.com/guide/mac-help/what-is-safe-sleep-mh10328/mac. 
  2. "Hibernation Patent". 1998. https://patentimages.storage.googleapis.com/4d/66/ea/18621f850b2f81/US6243831.pdf. 
  3. 3.0 3.1 windows-driver-content. "Delivering a great startup and shutdown experience" (in en-us). https://docs.microsoft.com/en-us/windows-hardware/test/weg/delivering-a-great-startup-and-shutdown-experience. 
  4. 4.0 4.1 4.2 "Sleep and hibernation: frequently asked questions". Windows 7 Online Help. Microsoft Corporation. http://windows.microsoft.com/en-us/windows7/Sleep-and-hibernation-frequently-asked-questions. 
  5. "Shut down, sleep, or hibernate your PC". https://support.microsoft.com/en-us/windows/shut-down-sleep-or-hibernate-your-pc-2941d165-7d0a-a5e8-c5ad-8c972e8e6eff. 
  6. "Sales Material from Compaq Computer Corp". 1992. http://www.1000bit.it/ad/bro/compaq/Compaq-LTE-Family.pdf. 
  7. "Hibernation file creation device and method" patent, issued 1993-07-26
  8. "ACPI Specification Rev 3.0b". http://www.acpi.info/DOWNLOADS/ACPIspec30b.pdf. 
  9. "Microsoft Help and Support – How To Put the System into hibernation or Standby from Run menu". http://support.microsoft.com/kb/555569/. 
  10. BIOS and Hibernate Issues for FAT32 File System
  11. "Interview with Nicolas Coudière, Chief Product Manager: Microsoft Windows Millennium Edition (Me)". Activewin.com. http://www.activewin.com/interviews/microsoft/7.shtml. 
  12. "Windows Power Management". Microsoft.com. 2001-12-04. http://www.microsoft.com/whdc/archive/winpowmgmt.mspx#EUE. 
  13. Windows Power Management: Instant PC availability and energy savings
  14. Kernel Enhancements for Windows XP
  15. "BlackHat USA 2008 – Windows hibernation file for fun and profit". http://msuiche.net/con/bhusa2008/Windows_hibernation_file_for_fun_%27n%27_profit-0.6.pdf. 
  16. "SandMan Computer Forensics Framework". http://sandman.msuiche.net/. 
  17. 17.0 17.1 "Reducing the Disk Footprint for Windows 7 Hibernation". http://download.microsoft.com/download/7/E/7/7E7662CF-CBEA-470B-A97E-CE7CE0D98DC2/HiberFootprint.docx. 
  18. "You cannot put a computer that has more than 4 GB of memory into hibernation in Windows XP, in Windows Server 2003, in Windows Vista, or in Windows Server 2008". Microsoft. 23 September 2011. http://support.microsoft.com/kb/888575. 
  19. "Delivering fast boot times in Windows 8". http://blogs.msdn.com/b/b8/archive/2011/09/08/delivering-fast-boot-times-in-windows-8.aspx. 
  20. "Windows 8 / Windows Server 2012: Faster Boot Process | Ask the Performance Team Blog". https://blogs.technet.microsoft.com/askperf/2012/10/25/windows-8-windows-server-2012-faster-boot-process/. 
  21. Enable hibernate using group policy
  22. "EcoGeek – How Windows XP Wasted $25 Billion of Energy". http://www.treehugger.com/files/2006/11/how_windows_xp.php. 
  23. How to disable and re-enable hibernation on a computer that is running Windows; Microsoft; August 12, 2010.
  24. "Power Management Software for Windows Workstations". http://www.windowsitpro.com/article/buyers-guide/Power-Management-Software-for-Windows-Workstations-Buyers-Guide. 
  25. "Energy Star Commercial Packages List". http://www.energystar.gov/index.cfm?c=power_mgt.pr_power_mgt_comm_packages. 
  26. The Headmasters' and Headmistresses' Conference. "HMC: A Practical Guide to Sustainable Building for Schools". http://www.hmcsustainability.org.uk/energy.html. 
  27. "Apple Support: Progress bar appears after waking from sleep". February 20, 2006. http://docs.info.apple.com/article.html?artnum=302477. 
  28. "How to Safe Sleep (Hibernate) Your Mac". AndrewEscobar.com. http://andrewescobar.com/archive/2005/11/11/how-to-safe-sleep-your-mac/. 
  29. "Sleep Memory Extension 1.0 Document and Software". http://docs.info.apple.com/article.html?artnum=59016. 
  30. "Turn off a computer: frequently asked questions". Windows Vista Online Help. Microsoft Corporation. http://windows.microsoft.com/en-US/windows-vista/Turn-off-a-computer-frequently-asked-questions.