From d21102cc6c7a4db204a29f376ce5eb316ef57a6e Mon Sep 17 00:00:00 2001 From: Kai Uwe Broulik <kde@privat.broulik.de> Date: Fri, 19 Jun 2020 19:51:06 +0200 Subject: [PATCH] Watch DBus service right away to discard pending inhibitions reliably PowerDevil delays applying a power management inhibition by 5 seconds to avoid brief inhibitions to e.g. wake up the screen and similar. However, when an inhibition was posted and the process then quit, we would then still enforce the inhibition as it wasn't explicitly revoked. Fix this by always watching the inhibition sender and remove it from pending when the service goes away. BUG: 423131 FIXED-IN: 5.18.6 --- daemon/powerdevilpolicyagent.cpp | 26 ++++++++++++-------------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/daemon/powerdevilpolicyagent.cpp b/daemon/powerdevilpolicyagent.cpp index a7d92dfd..2c2b1152 100644 --- a/daemon/powerdevilpolicyagent.cpp +++ b/daemon/powerdevilpolicyagent.cpp @@ -513,6 +513,11 @@ uint PolicyAgent::addInhibitionWithExplicitDBusService(uint types, const QString const int cookie = m_lastCookie; // when the Timer below fires, m_lastCookie might be different already + if (!m_busWatcher.isNull() && !service.isEmpty()) { + m_cookieToBusService.insert(cookie, service); + m_busWatcher.data()->addWatchedService(service); + } + m_pendingInhibitions.append(cookie); qCDebug(POWERDEVIL) << "Scheduling inhibition from" << service << appName << "with cookie" @@ -532,11 +537,6 @@ uint PolicyAgent::addInhibitionWithExplicitDBusService(uint types, const QString m_cookieToAppName.insert(cookie, qMakePair<QString, QString>(appName, reason)); - if (!m_busWatcher.isNull() && !service.isEmpty()) { - m_cookieToBusService.insert(cookie, service); - m_busWatcher.data()->addWatchedService(service); - } - addInhibitionTypeHelper(cookie, static_cast< PolicyAgent::RequiredPolicies >(types)); Q_EMIT InhibitionsChanged({ {qMakePair(appName, reason)} }, {}); @@ -596,22 +596,20 @@ void PolicyAgent::ReleaseInhibition(uint cookie) { qCDebug(POWERDEVIL) << "Releasing inhibition with cookie " << cookie; - if (m_pendingInhibitions.contains(cookie)) { + QString service = m_cookieToBusService.take(cookie); + if (!m_busWatcher.isNull() && !service.isEmpty() && !m_cookieToBusService.key(service)) { + // no cookies from service left + m_busWatcher.data()->removeWatchedService(service); + } + + if (m_pendingInhibitions.removeOne(cookie)) { qCDebug(POWERDEVIL) << "It was only scheduled for inhibition but not enforced yet, just discarding it"; - m_pendingInhibitions.removeOne(cookie); return; } Q_EMIT InhibitionsChanged(QList<InhibitionInfo>(), { {m_cookieToAppName.value(cookie).first} }); m_cookieToAppName.remove(cookie); - - QString service = m_cookieToBusService.take(cookie); - if (!m_busWatcher.isNull() && !service.isEmpty() && !m_cookieToBusService.key(service)) { - // no cookies from service left - m_busWatcher.data()->removeWatchedService(service); - } - // Look through all of the inhibition types bool notify = false; if (m_typesToCookie[ChangeProfile].contains(cookie)) { -- GitLab