From 508b4786e8592e82eb4832549f74aaa54335d14c Mon Sep 17 00:00:00 2001 From: Michal Sekletar Date: Tue, 12 Dec 2023 19:03:39 +0100 Subject: [PATCH] logind: don't setup idle session watch for lock-screen and greeter Reason to skip the idle session logic for these session classes is that they are idle by default. --- man/logind.conf.xml | 9 +++++---- src/login/logind-session.c | 2 +- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/man/logind.conf.xml b/man/logind.conf.xml index ff19ba91fa0..d74c9b410fd 100644 --- a/man/logind.conf.xml +++ b/man/logind.conf.xml @@ -379,10 +379,11 @@ StopIdleSessionSec= Specifies a timeout in seconds, or a time span value after which - systemd-logind checks the idle state of all sessions. Every session that is idle for - longer then the timeout will be stopped. Defaults to infinity - (systemd-logind is not checking the idle state of sessions). For details about the syntax - of time spans, see + systemd-logind checks the idle state of all sessions. Every session that is idle + for longer than the timeout will be stopped. Note that this option doesn't apply to + greeter or lock-screen sessions. Defaults to + infinity (systemd-logind is not checking the idle state + of sessions). For details about the syntax of time spans, see systemd.time7. diff --git a/src/login/logind-session.c b/src/login/logind-session.c index 03e5d68bdfc..b4277c33f14 100644 --- a/src/login/logind-session.c +++ b/src/login/logind-session.c @@ -738,7 +738,7 @@ static int session_setup_stop_on_idle_timer(Session *s) { assert(s); - if (s->manager->stop_idle_session_usec == USEC_INFINITY) + if (s->manager->stop_idle_session_usec == USEC_INFINITY || IN_SET(s->class, SESSION_GREETER, SESSION_LOCK_SCREEN)) return 0; r = sd_event_add_time_relative(