2018-07-03 05:15:39 +08:00
|
|
|
<?xml version='1.0'?>
|
2019-03-14 21:40:58 +08:00
|
|
|
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
|
2023-12-25 22:48:33 +08:00
|
|
|
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
|
2020-11-09 12:23:58 +08:00
|
|
|
<!-- SPDX-License-Identifier: LGPL-2.1-or-later -->
|
2013-05-05 00:31:28 +08:00
|
|
|
|
2014-11-29 17:06:28 +08:00
|
|
|
<refentry id="systemd-sleep.conf"
|
|
|
|
xmlns:xi="http://www.w3.org/2001/XInclude">
|
2013-05-05 00:31:28 +08:00
|
|
|
<refentryinfo>
|
|
|
|
<title>systemd-sleep.conf</title>
|
|
|
|
<productname>systemd</productname>
|
|
|
|
</refentryinfo>
|
|
|
|
|
|
|
|
<refmeta>
|
|
|
|
<refentrytitle>systemd-sleep.conf</refentrytitle>
|
|
|
|
<manvolnum>5</manvolnum>
|
|
|
|
</refmeta>
|
|
|
|
|
|
|
|
<refnamediv>
|
|
|
|
<refname>systemd-sleep.conf</refname>
|
2014-11-29 17:06:28 +08:00
|
|
|
<refname>sleep.conf.d</refname>
|
2013-05-05 00:31:28 +08:00
|
|
|
<refpurpose>Suspend and hibernation configuration file</refpurpose>
|
|
|
|
</refnamediv>
|
|
|
|
|
|
|
|
<refsynopsisdiv>
|
2023-12-14 19:52:03 +08:00
|
|
|
<para><simplelist>
|
|
|
|
<member><filename>/etc/systemd/sleep.conf</filename></member>
|
|
|
|
<member><filename>/etc/systemd/sleep.conf.d/*.conf</filename></member>
|
|
|
|
<member><filename>/run/systemd/sleep.conf.d/*.conf</filename></member>
|
|
|
|
<member><filename>/usr/lib/systemd/sleep.conf.d/*.conf</filename></member>
|
|
|
|
</simplelist></para>
|
2013-05-05 00:31:28 +08:00
|
|
|
</refsynopsisdiv>
|
|
|
|
|
|
|
|
<refsect1>
|
|
|
|
<title>Description</title>
|
|
|
|
|
2018-03-08 21:17:33 +08:00
|
|
|
<para><command>systemd</command> supports four general
|
2013-05-05 00:31:28 +08:00
|
|
|
power-saving modes:</para>
|
|
|
|
|
|
|
|
<variablelist>
|
|
|
|
<varlistentry>
|
|
|
|
<term>suspend</term>
|
|
|
|
|
|
|
|
<listitem><para>a low-power state
|
|
|
|
where execution of the OS is paused,
|
|
|
|
and complete power loss might result
|
|
|
|
in lost data, and which is fast to
|
|
|
|
enter and exit. This corresponds to
|
|
|
|
suspend, standby, or freeze states as
|
|
|
|
understood by the kernel.
|
2023-08-23 00:52:36 +08:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v203"/></listitem>
|
2013-05-05 00:31:28 +08:00
|
|
|
</varlistentry>
|
|
|
|
|
|
|
|
<varlistentry>
|
|
|
|
<term>hibernate</term>
|
|
|
|
|
|
|
|
<listitem><para>a low-power state
|
|
|
|
where execution of the OS is paused,
|
|
|
|
and complete power loss does not
|
|
|
|
result in lost data, and which might
|
|
|
|
be slow to enter and exit. This
|
|
|
|
corresponds to the hibernation as
|
|
|
|
understood by the kernel.
|
2023-08-23 00:52:36 +08:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v203"/></listitem>
|
2013-05-05 00:31:28 +08:00
|
|
|
</varlistentry>
|
|
|
|
|
|
|
|
<varlistentry>
|
|
|
|
<term>hybrid-sleep</term>
|
|
|
|
|
|
|
|
<listitem><para>a low-power state
|
|
|
|
where execution of the OS is paused,
|
|
|
|
which might be slow to enter, and on
|
|
|
|
complete power loss does not result in
|
|
|
|
lost data but might be slower to exit
|
|
|
|
in that case. This mode is called
|
|
|
|
suspend-to-both by the kernel.
|
2023-08-23 00:52:36 +08:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v203"/></listitem>
|
2013-05-05 00:31:28 +08:00
|
|
|
</varlistentry>
|
2018-03-08 21:17:33 +08:00
|
|
|
|
|
|
|
<varlistentry>
|
2018-03-29 00:00:06 +08:00
|
|
|
<term>suspend-then-hibernate</term>
|
2018-03-08 21:17:33 +08:00
|
|
|
|
2022-11-14 01:08:05 +08:00
|
|
|
<listitem>
|
|
|
|
<para>A low power state where the system is initially suspended (the state is stored in
|
|
|
|
RAM). If the system supports low-battery alarms (ACPI _BTP), then the system will be woken up by
|
|
|
|
the ACPI low-battery signal and hibernated (the state is then stored on disk). Also, if not
|
|
|
|
interrupted within the timespan specified by <varname>HibernateDelaySec=</varname> or the estimated
|
|
|
|
timespan until the system battery charge level goes down to 5%, then the system will be woken up by the
|
|
|
|
RTC alarm and hibernated. The estimated timespan is calculated from the change of the battery
|
|
|
|
capacity level after the time specified by <varname>SuspendEstimationSec=</varname> or when
|
|
|
|
the system is woken up from the suspend.</para>
|
2023-08-23 00:52:36 +08:00
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v239"/>
|
2022-11-14 01:08:05 +08:00
|
|
|
</listitem>
|
2018-03-08 21:17:33 +08:00
|
|
|
</varlistentry>
|
|
|
|
|
2013-05-05 00:31:28 +08:00
|
|
|
</variablelist>
|
|
|
|
|
2014-11-29 17:06:28 +08:00
|
|
|
<para>Settings in these files determine what strings
|
2013-05-05 00:31:28 +08:00
|
|
|
will be written to
|
|
|
|
<filename>/sys/power/disk</filename> and
|
|
|
|
<filename>/sys/power/state</filename> by
|
|
|
|
<citerefentry><refentrytitle>systemd-sleep</refentrytitle><manvolnum>8</manvolnum></citerefentry>
|
|
|
|
when
|
|
|
|
<citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>
|
2018-04-16 23:09:58 +08:00
|
|
|
attempts to suspend or hibernate the machine.
|
|
|
|
See
|
2020-07-11 06:05:23 +08:00
|
|
|
<citerefentry><refentrytitle>systemd.syntax</refentrytitle><manvolnum>7</manvolnum></citerefentry>
|
2018-04-16 23:09:58 +08:00
|
|
|
for a general description of the syntax.</para>
|
2013-05-05 00:31:28 +08:00
|
|
|
</refsect1>
|
|
|
|
|
2015-03-04 08:10:21 +08:00
|
|
|
<xi:include href="standard-conf.xml" xpointer="main-conf" />
|
2014-11-29 17:06:28 +08:00
|
|
|
|
2013-05-05 00:31:28 +08:00
|
|
|
<refsect1>
|
|
|
|
<title>Options</title>
|
|
|
|
|
|
|
|
<para>The following options can be configured in the
|
2020-07-06 17:00:06 +08:00
|
|
|
[Sleep] section of
|
2015-06-19 01:47:44 +08:00
|
|
|
<filename>/etc/systemd/sleep.conf</filename> or a
|
2014-11-29 17:06:28 +08:00
|
|
|
<filename>sleep.conf.d</filename> file:</para>
|
2013-05-05 00:31:28 +08:00
|
|
|
|
2019-02-13 17:49:47 +08:00
|
|
|
<variablelist class='config-directives'>
|
2018-09-26 17:17:36 +08:00
|
|
|
<varlistentry>
|
|
|
|
<term><varname>AllowSuspend=</varname></term>
|
|
|
|
<term><varname>AllowHibernation=</varname></term>
|
|
|
|
<term><varname>AllowHybridSleep=</varname></term>
|
2023-10-21 00:21:20 +08:00
|
|
|
<term><varname>AllowSuspendThenHibernate=</varname></term>
|
2018-09-26 17:17:36 +08:00
|
|
|
|
|
|
|
<listitem><para>By default any power-saving mode is advertised if possible (i.e.
|
|
|
|
the kernel supports that mode, the necessary resources are available). Those
|
|
|
|
switches can be used to disable specific modes.</para>
|
|
|
|
|
|
|
|
<para>If <varname>AllowHibernation=no</varname> or <varname>AllowSuspend=no</varname> is
|
|
|
|
used, this implies <varname>AllowSuspendThenHibernate=no</varname> and
|
|
|
|
<varname>AllowHybridSleep=no</varname>, since those methods use both suspend and hibernation
|
|
|
|
internally. <varname>AllowSuspendThenHibernate=yes</varname> and
|
|
|
|
<varname>AllowHybridSleep=yes</varname> can be used to override and enable those specific
|
2023-08-23 00:52:36 +08:00
|
|
|
modes.</para>
|
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v240"/></listitem>
|
2018-09-26 17:17:36 +08:00
|
|
|
</varlistentry>
|
|
|
|
|
2013-05-05 00:31:28 +08:00
|
|
|
<varlistentry>
|
|
|
|
<term><varname>HibernateMode=</varname></term>
|
|
|
|
|
2023-10-24 18:10:21 +08:00
|
|
|
<listitem><para>The string to be written to <filename>/sys/power/disk</filename> by <citerefentry>
|
|
|
|
<refentrytitle>systemd-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
|
2023-05-17 17:12:32 +08:00
|
|
|
More than one value can be specified by separating multiple values with whitespace. They will be
|
|
|
|
tried in turn, until one is written without error. If none of the writes succeed, the operation will
|
|
|
|
be aborted.</para>
|
|
|
|
|
|
|
|
<para>The allowed set of values is determined by the kernel and is shown in the file itself (use
|
2023-11-06 19:43:40 +08:00
|
|
|
<command>cat /sys/power/disk</command> to display). See the kernel documentation page
|
|
|
|
<ulink url="https://www.kernel.org/doc/html/latest/admin-guide/pm/sleep-states.html#basic-sysfs-interfaces-for-system-suspend-and-hibernation">
|
|
|
|
Basic sysfs Interfaces for System Suspend and Hibernation</ulink> for more details.</para>
|
2023-05-17 17:12:32 +08:00
|
|
|
|
|
|
|
<para>
|
|
|
|
<citerefentry><refentrytitle>systemd-suspend-then-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>
|
2023-11-04 05:33:52 +08:00
|
|
|
uses the value of <varname>HibernateMode=</varname> when hibernating.</para>
|
2023-08-23 00:52:36 +08:00
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v203"/></listitem>
|
2013-05-05 00:31:28 +08:00
|
|
|
</varlistentry>
|
|
|
|
|
|
|
|
<varlistentry>
|
|
|
|
<term><varname>SuspendState=</varname></term>
|
|
|
|
|
2023-10-21 00:21:20 +08:00
|
|
|
<listitem><para>The string to be written to <filename>/sys/power/state</filename> by <citerefentry>
|
|
|
|
<refentrytitle>systemd-suspend.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
|
2023-05-17 17:12:32 +08:00
|
|
|
More than one value can be specified by separating multiple values with whitespace. They will be
|
|
|
|
tried in turn, until one is written without error. If none of the writes succeed, the operation will
|
2023-10-21 00:21:20 +08:00
|
|
|
be aborted.</para>
|
2021-07-07 17:32:35 +08:00
|
|
|
|
2023-05-17 17:12:32 +08:00
|
|
|
<para>The allowed set of values is determined by the kernel and is shown in the file itself (use
|
|
|
|
<command>cat /sys/power/state</command> to display). See <ulink
|
2023-11-06 19:43:40 +08:00
|
|
|
url="https://www.kernel.org/doc/html/latest/admin-guide/pm/sleep-states.html#basic-sysfs-interfaces-for-system-suspend-and-hibernation">
|
|
|
|
Basic sysfs Interfaces for System Suspend and Hibernation</ulink> for more details.</para>
|
2023-05-17 17:12:32 +08:00
|
|
|
|
|
|
|
<para>
|
|
|
|
<citerefentry><refentrytitle>systemd-suspend-then-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>
|
2023-10-21 00:21:20 +08:00
|
|
|
uses this value when suspending.</para>
|
2023-08-23 00:52:36 +08:00
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v203"/></listitem>
|
2013-05-05 00:31:28 +08:00
|
|
|
</varlistentry>
|
2022-11-14 01:08:05 +08:00
|
|
|
|
2018-03-08 21:17:33 +08:00
|
|
|
<varlistentry>
|
|
|
|
<term><varname>HibernateDelaySec=</varname></term>
|
2022-11-14 01:08:05 +08:00
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>The amount of time the system spends in suspend mode before the system is
|
|
|
|
automatically put into hibernate mode. Only used by
|
|
|
|
<citerefentry><refentrytitle>systemd-suspend-then-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
|
|
|
|
If the system has a battery, then defaults to the estimated timespan until the system battery charge level goes down to 5%.
|
|
|
|
If the system has no battery, then defaults to 2h.</para>
|
2023-08-23 00:52:36 +08:00
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v239"/>
|
2022-11-14 01:08:05 +08:00
|
|
|
</listitem>
|
|
|
|
</varlistentry>
|
|
|
|
|
|
|
|
<varlistentry>
|
|
|
|
<term><varname>SuspendEstimationSec=</varname></term>
|
|
|
|
|
|
|
|
<listitem>
|
|
|
|
<para>The RTC alarm will wake the system after the specified timespan to measure the system battery
|
|
|
|
capacity level and estimate battery discharging rate, which is used for estimating timespan until the system battery charge
|
|
|
|
level goes down to 5%. Only used by
|
|
|
|
<citerefentry><refentrytitle>systemd-suspend-then-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
|
2023-08-23 00:52:36 +08:00
|
|
|
Defaults to 1h.</para>
|
|
|
|
|
|
|
|
<xi:include href="version-info.xml" xpointer="v253"/></listitem>
|
2018-03-08 21:17:33 +08:00
|
|
|
</varlistentry>
|
2013-05-05 00:31:28 +08:00
|
|
|
</variablelist>
|
|
|
|
</refsect1>
|
|
|
|
|
|
|
|
<refsect1>
|
|
|
|
<title>Example: freeze</title>
|
|
|
|
|
|
|
|
<para>Example: to exploit the <quote>freeze</quote> mode added
|
|
|
|
in Linux 3.9, one can use <command>systemctl suspend</command>
|
|
|
|
with
|
2014-02-14 22:56:19 +08:00
|
|
|
<programlisting>[Sleep]
|
|
|
|
SuspendState=freeze</programlisting></para>
|
2013-05-05 00:31:28 +08:00
|
|
|
</refsect1>
|
|
|
|
|
|
|
|
<refsect1>
|
|
|
|
<title>See Also</title>
|
2023-12-23 02:09:32 +08:00
|
|
|
<para><simplelist type="inline">
|
|
|
|
<member><citerefentry><refentrytitle>systemd-sleep</refentrytitle><manvolnum>8</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd-suspend.service</refentrytitle><manvolnum>8</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd-hybrid-sleep.service</refentrytitle><manvolnum>8</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd-suspend-then-hibernate.service</refentrytitle><manvolnum>8</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry></member>
|
|
|
|
<member><citerefentry><refentrytitle>systemd.directives</refentrytitle><manvolnum>7</manvolnum></citerefentry></member>
|
|
|
|
</simplelist></para>
|
2013-05-05 00:31:28 +08:00
|
|
|
</refsect1>
|
|
|
|
|
|
|
|
</refentry>
|