2012-06-26 19:33:11 +04:00
<?xml version='1.0'?> <!-- * - nxml - * -->
2019-03-14 16:40:58 +03:00
< !DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
2015-06-18 20:47:44 +03:00
"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
2019-03-14 16:29:37 +03:00
<!-- SPDX - License - Identifier: LGPL - 2.1+ -->
2012-06-26 19:33:11 +04:00
2014-02-13 23:33:51 +04:00
<refentry id= "systemd-suspend.service"
2015-02-04 05:14:13 +03:00
xmlns:xi="http://www.w3.org/2001/XInclude">
<refentryinfo >
<title > systemd-suspend.service</title>
<productname > systemd</productname>
</refentryinfo>
<refmeta >
<refentrytitle > systemd-suspend.service</refentrytitle>
<manvolnum > 8</manvolnum>
</refmeta>
<refnamediv >
<refname > systemd-suspend.service</refname>
<refname > systemd-hibernate.service</refname>
<refname > systemd-hybrid-sleep.service</refname>
2018-03-28 19:00:06 +03:00
<refname > systemd-suspend-then-hibernate.service</refname>
2015-02-04 05:14:13 +03:00
<refname > systemd-sleep</refname>
<refpurpose > System sleep state logic</refpurpose>
</refnamediv>
<refsynopsisdiv >
<para > <filename > systemd-suspend.service</filename> </para>
<para > <filename > systemd-hibernate.service</filename> </para>
<para > <filename > systemd-hybrid-sleep.service</filename> </para>
2018-03-28 19:00:06 +03:00
<para > <filename > systemd-suspend-then-hibernate.service</filename> </para>
2015-06-18 20:47:44 +03:00
<para > <filename > /usr/lib/systemd/system-sleep</filename> </para>
2015-02-04 05:14:13 +03:00
</refsynopsisdiv>
<refsect1 >
<title > Description</title>
<para > <filename > systemd-suspend.service</filename> is a system
service that is pulled in by <filename > suspend.target</filename>
and is responsible for the actual system suspend. Similarly,
<filename > systemd-hibernate.service</filename> is pulled in by
<filename > hibernate.target</filename> to execute the actual
hibernation. Finally,
<filename > systemd-hybrid-sleep.service</filename> is pulled in by
<filename > hybrid-sleep.target</filename> to execute hybrid
2018-03-08 16:17:33 +03:00
hibernation with system suspend and pulled in by
2018-03-28 19:00:06 +03:00
<filename > suspend-then-hibernate.target</filename> to execute system suspend
2018-03-08 16:17:33 +03:00
with a timeout that will activate hibernate later.</para>
2015-02-04 05:14:13 +03:00
<para > Immediately before entering system suspend and/or
hibernation <filename > systemd-suspend.service</filename> (and the
other mentioned units, respectively) will run all executables in
2015-06-18 20:47:44 +03:00
<filename > /usr/lib/systemd/system-sleep/</filename> and pass two
2015-02-04 05:14:13 +03:00
arguments to them. The first argument will be
<literal > pre</literal> , the second either
2018-03-08 16:17:33 +03:00
<literal > suspend</literal> , <literal > hibernate</literal> ,
2018-03-28 19:00:06 +03:00
<literal > hybrid-sleep</literal> , or <literal > suspend-then-hibernate</literal>
2018-03-08 16:17:33 +03:00
depending on the chosen action.
2015-02-04 05:14:13 +03:00
Immediately after leaving system suspend and/or hibernation the
same executables are run, but the first argument is now
<literal > post</literal> . All executables in this directory are
executed in parallel, and execution of the action is not continued
until all executables have finished.</para>
<para > Note that scripts or binaries dropped in
2015-06-18 20:47:44 +03:00
<filename > /usr/lib/systemd/system-sleep/</filename> are intended
2015-02-04 05:14:13 +03:00
for local use only and should be considered hacks. If applications
2017-02-03 20:11:37 +03:00
want to react to system suspend/hibernation and resume,
they should rather use the <ulink
2017-02-21 18:28:04 +03:00
url="https://www.freedesktop.org/wiki/Software/systemd/inhibit">Inhibitor
2017-02-03 20:11:37 +03:00
interface</ulink> .</para>
2015-02-04 05:14:13 +03:00
<para > Note that
<filename > systemd-suspend.service</filename> ,
<filename > systemd-hibernate.service</filename> , and
<filename > systemd-hybrid-sleep.service</filename>
2018-03-28 19:00:06 +03:00
<filename > systemd-suspend-then-hibernate.service</filename>
2015-02-04 05:14:13 +03:00
should never be executed directly. Instead, trigger system sleep
states with a command such as <literal > systemctl suspend</literal>
or similar.</para>
<para > Internally, this service will echo a string like
<literal > mem</literal> into <filename > /sys/power/state</filename> ,
to trigger the actual system suspend. What exactly is written
where can be configured in the <literal > [Sleep]</literal> section
2015-06-18 20:47:44 +03:00
of <filename > /etc/systemd/sleep.conf</filename> or a
2015-02-04 05:14:13 +03:00
<filename > sleep.conf.d</filename> file. See
<citerefentry > <refentrytitle > systemd-sleep.conf</refentrytitle> <manvolnum > 5</manvolnum> </citerefentry> .
</para>
</refsect1>
<refsect1 >
<title > Options</title>
<para > <command > systemd-sleep</command> understands the
following commands:</para>
<variablelist >
<xi:include href= "standard-options.xml" xpointer= "help" />
<xi:include href= "standard-options.xml" xpointer= "version" />
<varlistentry >
<term > <option > suspend</option> </term>
<term > <option > hibernate</option> </term>
<term > <option > hybrid-sleep</option> </term>
2018-03-28 19:00:06 +03:00
<term > <option > suspend-then-hibernate</option> </term>
2015-02-04 05:14:13 +03:00
2018-03-28 19:00:06 +03:00
<listitem > <para > Suspend, hibernate, suspend then hibernate, or put the
2018-03-08 16:17:33 +03:00
system to hybrid sleep.</para>
2015-02-04 05:14:13 +03:00
</listitem>
</varlistentry>
</variablelist>
</refsect1>
<refsect1 >
<title > See Also</title>
<para >
<citerefentry > <refentrytitle > systemd-sleep.conf</refentrytitle> <manvolnum > 5</manvolnum> </citerefentry> ,
<citerefentry > <refentrytitle > systemd</refentrytitle> <manvolnum > 1</manvolnum> </citerefentry> ,
<citerefentry > <refentrytitle > systemctl</refentrytitle> <manvolnum > 1</manvolnum> </citerefentry> ,
<citerefentry > <refentrytitle > systemd.special</refentrytitle> <manvolnum > 7</manvolnum> </citerefentry> ,
<citerefentry > <refentrytitle > systemd-halt.service</refentrytitle> <manvolnum > 8</manvolnum> </citerefentry>
</para>
</refsect1>
2012-06-26 19:33:11 +04:00
</refentry>