diff --git a/0001-profiledefaults-don-t-automatically-suspend-by-defau.patch b/0001-profiledefaults-don-t-automatically-suspend-by-defau.patch deleted file mode 100644 index 61450f9..0000000 --- a/0001-profiledefaults-don-t-automatically-suspend-by-defau.patch +++ /dev/null @@ -1,192 +0,0 @@ -From 5a523543de6bffc0f6d78eab1a6bf27c1454d752 Mon Sep 17 00:00:00 2001 -From: Adam Williamson -Date: Fri, 1 Sep 2023 17:09:16 -0700 -Subject: [PATCH] profiledefaults: don't automatically suspend by default if - running in a virtual machine - -To avoid hangs in virtual environments which don't suppport suspension. -https://invent.kde.org/plasma/powerdevil/-/merge_requests/230 -from Natalie Clarius, rebased on 5.27.7. - -Signed-off-by: Adam Williamson ---- - daemon/powerdevilcore.cpp | 4 +++- - daemon/powerdevilpowermanagement.cpp | 21 +++++++++++++++++++++ - daemon/powerdevilpowermanagement.h | 1 + - daemon/powerdevilprofilegenerator.cpp | 17 ++++++++++------- - daemon/powerdevilprofilegenerator.h | 2 +- - kcmodule/profiles/EditPage.cpp | 2 ++ - 6 files changed, 38 insertions(+), 9 deletions(-) - -diff --git a/daemon/powerdevilcore.cpp b/daemon/powerdevilcore.cpp -index 0791552c..5c4f8a7d 100644 ---- a/daemon/powerdevilcore.cpp -+++ b/daemon/powerdevilcore.cpp -@@ -24,6 +24,7 @@ - #include "powerdevilaction.h" - #include "powerdevilactionpool.h" - #include "powerdevilpolicyagent.h" -+#include "powerdevilpowermanagement.h" - #include "powerdevilprofilegenerator.h" - #include "powerdevil_debug.h" - -@@ -126,8 +127,9 @@ void Core::onBackendReady() - - // These are generated profiles, - const bool mobile = Kirigami::TabletModeWatcher::self()->isTabletMode(); -+ const bool vm = PowerDevil::PowerManagement::instance()->isVirtualMachine(); - -- ProfileGenerator::generateProfiles(mobile, toRam, toDisk); -+ ProfileGenerator::generateProfiles(mobile, vm, toRam, toDisk); - m_profilesConfig->reparseConfiguration(); - } - -diff --git a/daemon/powerdevilpowermanagement.cpp b/daemon/powerdevilpowermanagement.cpp -index 7b8e8d5d..573a6a7d 100644 ---- a/daemon/powerdevilpowermanagement.cpp -+++ b/daemon/powerdevilpowermanagement.cpp -@@ -19,6 +19,7 @@ License along with this library. If not, see . - *********************************************************************/ - - #include "powerdevilpowermanagement.h" -+#include "powerdevil_debug.h" - - #include - #include -@@ -217,6 +218,26 @@ void PowerManagement::suspendThenHibernate() - QDBusConnection::sessionBus().asyncCall(message); - } - -+bool PowerManagement::isVirtualMachine() -+{ -+ if (!QDBusConnection::systemBus().interface()->isServiceRegistered(QStringLiteral("org.freedesktop.systemd1"))) { -+ // can't check, fall back to assuming false -+ return false; -+ } -+ QDBusMessage message = QDBusMessage::createMethodCall(QStringLiteral("org.freedesktop.systemd1"), -+ QStringLiteral("/org/freedesktop/systemd1"), -+ QStringLiteral("org.freedesktop.DBus.Properties"), -+ QStringLiteral("Get")); -+ message.setArguments({QStringLiteral("org.freedesktop.systemd1.Manager"), QStringLiteral("Virtualization")}); -+ QDBusReply reply = QDBusConnection::systemBus().call(message); -+ if (!reply.isValid() || reply.value().variant().isNull() || reply.value().variant().toString().isNull()) { -+ qCWarning(POWERDEVIL) << "Failed to get property Virtualization from systemd1 DBus service:" << reply.error().message(); -+ return false; -+ } -+ /* on bare-metal hardware this is the empty string, otherwise an identifier such as "kvm", "vmware", etc. */ -+ return !reply.value().variant().toString().isEmpty(); -+} -+ - bool PowerManagement::canSuspend() const - { - return d->canSuspend; -diff --git a/daemon/powerdevilpowermanagement.h b/daemon/powerdevilpowermanagement.h -index 84c99f19..14069708 100644 ---- a/daemon/powerdevilpowermanagement.h -+++ b/daemon/powerdevilpowermanagement.h -@@ -35,6 +35,7 @@ class Q_DECL_EXPORT PowerManagement : public QObject - public: - ~PowerManagement() override; - -+ bool isVirtualMachine(); - bool canSuspend() const; - bool canHibernate() const; - bool canHybridSuspend() const; -diff --git a/daemon/powerdevilprofilegenerator.cpp b/daemon/powerdevilprofilegenerator.cpp -index b3029e02..475b9ed6 100644 ---- a/daemon/powerdevilprofilegenerator.cpp -+++ b/daemon/powerdevilprofilegenerator.cpp -@@ -29,7 +29,7 @@ - - namespace PowerDevil { - --void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) -+void ProfileGenerator::generateProfiles(bool mobile, bool vm, bool toRam, bool toDisk) - { - // Change critical action if default (hibernate) is unavailable - if (!toDisk) { -@@ -64,14 +64,17 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - dimDisplay.writeEntry< int >("idleTime", 300000); - } - -- auto initLid = [toRam, mobile](KConfigGroup &profile) -+ auto initLid = [vm, toRam, mobile](KConfigGroup &profile) - { - const Modes defaultPowerButtonAction = mobile ? ToggleScreenOnOffMode : LogoutDialogMode; - - KConfigGroup handleButtonEvents(&profile, "HandleButtonEvents"); - handleButtonEvents.writeEntry< uint >("powerButtonAction", defaultPowerButtonAction); - handleButtonEvents.writeEntry< uint >("powerDownAction", LogoutDialogMode); -- if (toRam) { -+ if (vm) { -+ handleButtonEvents.writeEntry< uint >("lidAction", NoneMode); -+ } -+ else if (toRam) { - handleButtonEvents.writeEntry< uint >("lidAction", ToRamMode); - } else { - handleButtonEvents.writeEntry< uint >("lidAction", TurnOffScreenMode); -@@ -91,8 +94,8 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - } - - // Even on AC power, suspend after a rather long period of inactivity. Energy -- // is precious! -- if (toRam) { -+ // is precious! But not on VMs. -+ if (toRam && !vm) { - // on mobile, 7 minutes, on laptop 15 minutes - auto timeout = mobile ? 420000 : 900000; - KConfigGroup suspendSession(&acProfile, "SuspendSession"); -@@ -124,7 +127,7 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - } - - // Last but not least, we want to suspend after some inactivity -- if (toRam) { -+ if (toRam && !vm) { - // on mobile, 5 minute, on laptop 10 minutes - auto timeout = mobile ? 300000 : 600000; - KConfigGroup suspendSession(&batteryProfile, "SuspendSession"); -@@ -164,7 +167,7 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - // Last but not least, we want to suspend after a rather long period of inactivity - // on mobile by default never suspend, if device wants to suspend, it will enable - // using configuration overlay -- if (toRam) { -+ if (toRam && !vm) { - // config is in the miliseconds - KConfigGroup suspendSession(&lowBatteryProfile, "SuspendSession"); - suspendSession.writeEntry< uint >("idleTime", 300000); -diff --git a/daemon/powerdevilprofilegenerator.h b/daemon/powerdevilprofilegenerator.h -index 481caa73..6f5ffb48 100644 ---- a/daemon/powerdevilprofilegenerator.h -+++ b/daemon/powerdevilprofilegenerator.h -@@ -36,7 +36,7 @@ namespace ProfileGenerator - ToggleScreenOnOffMode = 128 - }; - -- void generateProfiles(bool isMobile, bool toRam, bool toDisk); -+ void generateProfiles(bool isMobile, bool isVM, bool toRam, bool toDisk); - } - - } -diff --git a/kcmodule/profiles/EditPage.cpp b/kcmodule/profiles/EditPage.cpp -index 22ed5d0e..119d818e 100644 ---- a/kcmodule/profiles/EditPage.cpp -+++ b/kcmodule/profiles/EditPage.cpp -@@ -79,6 +79,7 @@ EditPage::EditPage(QWidget *parent, const QVariantList &args) - - PowerDevil::ProfileGenerator::generateProfiles( - interface->isTabletMode(), -+ PowerDevil::PowerManagement::instance()->isVirtualMachine(), - PowerDevil::PowerManagement::instance()->canSuspend(), - PowerDevil::PowerManagement::instance()->canHibernate() - ); -@@ -198,6 +199,7 @@ void EditPage::restoreDefaultProfiles() - - PowerDevil::ProfileGenerator::generateProfiles( - interface->isTabletMode(), -+ PowerDevil::PowerManagement::instance()->isVirtualMachine(), - PowerDevil::PowerManagement::instance()->canSuspend(), - PowerDevil::PowerManagement::instance()->canHibernate() - ); --- -2.41.0 - diff --git a/230.patch b/230.patch deleted file mode 100644 index 03ada2a..0000000 --- a/230.patch +++ /dev/null @@ -1,251 +0,0 @@ -From 1dcab6586cd1922376031243b354a6a86b7013a5 Mon Sep 17 00:00:00 2001 -From: Natalie Clarius -Date: Thu, 31 Aug 2023 17:04:52 +0200 -Subject: [PATCH] profiledefaults: don't automatically suspend by default if - running in a virtual machine - -To avoid hangs in virtual environments which don't suppport suspension. - -BUG: 473835 -FIXED-IN: 6.0 ---- - .../profilegenerator/generate_profiles.cpp | 4 +++- - daemon/powerdevilcore.cpp | 4 +++- - daemon/powerdevilpowermanagement.cpp | 17 +++++++++++++++++ - daemon/powerdevilpowermanagement.h | 1 + - daemon/powerdevilprofiledefaults.cpp | 14 ++++++++++++-- - daemon/powerdevilprofiledefaults.h | 4 ++-- - daemon/powerdevilprofilegenerator.cpp | 8 ++++---- - daemon/powerdevilprofilegenerator.h | 3 +-- - kcmodule/profiles/EditPage.cpp | 2 ++ - 9 files changed, 45 insertions(+), 12 deletions(-) - -diff --git a/autotests/profilegenerator/generate_profiles.cpp b/autotests/profilegenerator/generate_profiles.cpp -index ef6a6c309..f06309502 100644 ---- a/autotests/profilegenerator/generate_profiles.cpp -+++ b/autotests/profilegenerator/generate_profiles.cpp -@@ -31,6 +31,7 @@ int main(int argc, char **argv) - "powermanagementprofilesrc in your XDG_CONFIG_HOME, but this tool can produce a brand-new one under any name.")); - QCommandLineOption optionMobile("mobile", - "Generate profiles for a mobile device (i.e. phones, tablets running Plasma Mobile) instead of regular desktop/laptop."); -+ QCommandLineOption optionVM("vm", "Generate profiles for a virtual machine environment instead of bare metal."); - QCommandLineOption optionCannotSuspendToRam("cannot-suspend-to-ram", "Assume that the device does not support suspending to RAM a.k.a. Sleep."); - QCommandLineOption optionCannotSuspendToDisk("cannot-suspend-to-disk", "Assume that the device does not support suspending to disk a.k.a. Hibernate."); - parser.addOptions({optionMobile, optionCannotSuspendToRam, optionCannotSuspendToDisk}); -@@ -42,6 +43,7 @@ int main(int argc, char **argv) - } - - bool isMobile = parser.isSet(optionMobile); -+ bool isVM = parser.isSet(optionVM); - bool canSuspendToRam = !parser.isSet(optionCannotSuspendToRam); - bool canSuspendToDisk = !parser.isSet(optionCannotSuspendToDisk); - -@@ -55,7 +57,7 @@ int main(int argc, char **argv) - QFile::remove(temp_globalrc_path); - QFile::remove(parser.positionalArguments()[0]); - -- PowerDevil::ProfileGenerator::generateProfiles(isMobile, canSuspendToRam, canSuspendToDisk); -+ PowerDevil::ProfileGenerator::generateProfiles(isMobile, isVM, canSuspendToRam, canSuspendToDisk); - - if (!QFile::rename(temp_profilesrc_path, parser.positionalArguments()[0])) { - qDebug() << "Unable to move config file to destination."; -diff --git a/daemon/powerdevilcore.cpp b/daemon/powerdevilcore.cpp -index fc0087188..1392bb7ea 100644 ---- a/daemon/powerdevilcore.cpp -+++ b/daemon/powerdevilcore.cpp -@@ -13,6 +13,7 @@ - #include "powerdevilactionpool.h" - #include "powerdevilenums.h" - #include "powerdevilpolicyagent.h" -+#include "powerdevilpowermanagement.h" - #include "powerdevilprofilegenerator.h" - - #include -@@ -108,8 +109,9 @@ void Core::onBackendReady() - - // These are generated profiles, - const bool mobile = Kirigami::TabletModeWatcher::self()->isTabletMode(); -+ const bool vm = PowerDevil::PowerManagement::instance()->isVirtualMachine(); - -- ProfileGenerator::generateProfiles(mobile, toRam, toDisk); -+ ProfileGenerator::generateProfiles(mobile, vm, toRam, toDisk); - m_profilesConfig->reparseConfiguration(); - } - -diff --git a/daemon/powerdevilpowermanagement.cpp b/daemon/powerdevilpowermanagement.cpp -index 2e3d85ce9..1f42c82ab 100644 ---- a/daemon/powerdevilpowermanagement.cpp -+++ b/daemon/powerdevilpowermanagement.cpp -@@ -5,6 +5,7 @@ - */ - - #include "powerdevilpowermanagement.h" -+#include "powerdevil_debug.h" - - #include - #include -@@ -196,6 +197,22 @@ void PowerManagement::suspendThenHibernate() - QDBusConnection::sessionBus().asyncCall(message); - } - -+bool PowerManagement::isVirtualMachine() -+{ -+ QDBusMessage message = QDBusMessage::createMethodCall(QStringLiteral("org.freedesktop.systemd1"), -+ QStringLiteral("/org/freedesktop/systemd1"), -+ QStringLiteral("org.freedesktop.DBus.Properties"), -+ QStringLiteral("Get")); -+ message.setArguments({QStringLiteral("org.freedesktop.systemd1.Manager"), QStringLiteral("Virtualization")}); -+ QDBusReply reply = QDBusConnection::systemBus().call(message); -+ if (!reply.isValid() || reply.value().variant().isNull() || reply.value().variant().toString().isNull()) { -+ qCWarning(POWERDEVIL) << "Failed to get property Virtualization from systemd1 DBus service:" << reply.error().message(); -+ return false; -+ } -+ /* on bare-metal hardware this is the empty string, otherwise an identifier such as "kvm", "vmware", etc. */ -+ return !reply.value().variant().toString().isEmpty(); -+} -+ - bool PowerManagement::canSuspend() const - { - return d->canSuspend; -diff --git a/daemon/powerdevilpowermanagement.h b/daemon/powerdevilpowermanagement.h -index 6f4abce65..1e2a4dc8d 100644 ---- a/daemon/powerdevilpowermanagement.h -+++ b/daemon/powerdevilpowermanagement.h -@@ -22,6 +22,7 @@ class POWERDEVILCORE_EXPORT PowerManagement : public QObject - public: - ~PowerManagement() override; - -+ bool isVirtualMachine(); - bool canSuspend() const; - bool canHibernate() const; - bool canHybridSuspend() const; -diff --git a/daemon/powerdevilprofiledefaults.cpp b/daemon/powerdevilprofiledefaults.cpp -index eb4f79045..e3b5bc8c8 100644 ---- a/daemon/powerdevilprofiledefaults.cpp -+++ b/daemon/powerdevilprofiledefaults.cpp -@@ -75,8 +75,13 @@ bool ProfileDefaults::defaultLockBeforeTurnOffDisplay(bool isMobile) - return isMobile; - } - --bool ProfileDefaults::defaultAutoSuspendWhenIdle(bool canSuspendToRam) -+bool ProfileDefaults::defaultAutoSuspendWhenIdle(bool isVM, bool canSuspendToRam) - { -+ // Don't auto suspend by default when running in a virtual machine as it can cause hangs, -+ // see bug 473835 -+ if (isVM) { -+ return false; -+ } - // Even on AC power, suspend after a rather long period of inactivity. Energy is precious! - return canSuspendToRam; - } -@@ -111,8 +116,13 @@ unsigned int ProfileDefaults::defaultPowerDownAction() - return qToUnderlying(PowerButtonAction::PromptLogoutDialog); - } - --unsigned int ProfileDefaults::defaultLidAction(bool canSuspendToRam) -+unsigned int ProfileDefaults::defaultLidAction(bool isVM, bool canSuspendToRam) - { -+ // Don't auto suspend by default when running in a virtual machine as it can cause hangs, -+ // see bug 473835 -+ if (isVM) { -+ return qToUnderlying(PowerButtonAction::NoAction); -+ } - return qToUnderlying(canSuspendToRam ? PowerButtonAction::SuspendToRam : PowerButtonAction::TurnOffScreen); - } - -diff --git a/daemon/powerdevilprofiledefaults.h b/daemon/powerdevilprofiledefaults.h -index b874ed3b3..e9c8f570a 100644 ---- a/daemon/powerdevilprofiledefaults.h -+++ b/daemon/powerdevilprofiledefaults.h -@@ -27,13 +27,13 @@ public: - static int defaultTurnOffDisplayIdleTimeoutSec(const QString &profileGroup, bool isMobile); - static bool defaultLockBeforeTurnOffDisplay(bool isMobile); - -- static bool defaultAutoSuspendWhenIdle(bool canSuspendToRam); -+ static bool defaultAutoSuspendWhenIdle(bool isVM, bool canSuspendToRam); - static int defaultAutoSuspendIdleTimeoutSec(const QString &profileGroup, bool isMobile); - static unsigned int defaultAutoSuspendType(); - - static unsigned int defaultPowerButtonAction(bool isMobile); - static unsigned int defaultPowerDownAction(); -- static unsigned int defaultLidAction(bool canSuspendToRam); -+ static unsigned int defaultLidAction(bool isVM, bool canSuspendToRam); - }; - - } -diff --git a/daemon/powerdevilprofilegenerator.cpp b/daemon/powerdevilprofilegenerator.cpp -index 1c0202c2c..30b0c2185 100644 ---- a/daemon/powerdevilprofilegenerator.cpp -+++ b/daemon/powerdevilprofilegenerator.cpp -@@ -19,7 +19,7 @@ - - namespace PowerDevil - { --void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) -+void ProfileGenerator::generateProfiles(bool mobile, bool vm, bool toRam, bool toDisk) - { - // Change critical action if default (hibernate) is unavailable - if (!toDisk) { -@@ -44,7 +44,7 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - } - } - -- auto initProfile = [toRam, mobile](KConfigGroup &profile) { -+ auto initProfile = [toRam, mobile, vm](KConfigGroup &profile) { - if (ProfileDefaults::defaultUseProfileSpecificDisplayBrightness(profile.name())) { - KConfigGroup brightnessControl(&profile, "BrightnessControl"); - brightnessControl.writeEntry("value", ProfileDefaults::defaultDisplayBrightness(profile.name())); -@@ -53,7 +53,7 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - KConfigGroup handleButtonEvents(&profile, "HandleButtonEvents"); - handleButtonEvents.writeEntry("powerButtonAction", ProfileDefaults::defaultPowerButtonAction(mobile)); - handleButtonEvents.writeEntry("powerDownAction", ProfileDefaults::defaultPowerDownAction()); -- handleButtonEvents.writeEntry("lidAction", ProfileDefaults::defaultLidAction(toRam)); -+ handleButtonEvents.writeEntry("lidAction", ProfileDefaults::defaultLidAction(vm, toRam)); - - if (ProfileDefaults::defaultDimDisplayWhenIdle()) { - KConfigGroup dimDisplay(&profile, "DimDisplay"); -@@ -66,7 +66,7 @@ void ProfileGenerator::generateProfiles(bool mobile, bool toRam, bool toDisk) - dpmsControl.writeEntry("lockBeforeTurnOff", ProfileDefaults::defaultLockBeforeTurnOffDisplay(mobile)); - } - -- if (ProfileDefaults::defaultAutoSuspendWhenIdle(toRam)) { -+ if (ProfileDefaults::defaultAutoSuspendWhenIdle(vm, toRam)) { - KConfigGroup suspendSession(&profile, "SuspendSession"); - suspendSession.writeEntry("idleTime", ProfileDefaults::defaultAutoSuspendIdleTimeoutSec(profile.name(), mobile) * 1000); // milliseconds - suspendSession.writeEntry("suspendType", ProfileDefaults::defaultAutoSuspendType()); -diff --git a/daemon/powerdevilprofilegenerator.h b/daemon/powerdevilprofilegenerator.h -index bd92f3dc3..b29f5d06d 100644 ---- a/daemon/powerdevilprofilegenerator.h -+++ b/daemon/powerdevilprofilegenerator.h -@@ -13,7 +13,6 @@ namespace PowerDevil - namespace ProfileGenerator - { - --void POWERDEVILCORE_EXPORT generateProfiles(bool isMobile, bool toRam, bool toDisk); -- -+void POWERDEVILCORE_EXPORT generateProfiles(bool isMobile, bool isVM, bool toRam, bool toDisk); - } - } -diff --git a/kcmodule/profiles/EditPage.cpp b/kcmodule/profiles/EditPage.cpp -index 15210f342..0aa3d65ba 100644 ---- a/kcmodule/profiles/EditPage.cpp -+++ b/kcmodule/profiles/EditPage.cpp -@@ -53,6 +53,7 @@ EditPage::EditPage(QObject *parent, const KPluginMetaData &data) - auto interface = Kirigami::TabletModeWatcher::self(); - - PowerDevil::ProfileGenerator::generateProfiles(interface->isTabletMode(), -+ PowerDevil::PowerManagement::instance()->isVirtualMachine(), - PowerDevil::PowerManagement::instance()->canSuspend(), - PowerDevil::PowerManagement::instance()->canHibernate()); - m_profilesConfig->reparseConfiguration(); -@@ -166,6 +167,7 @@ void EditPage::restoreDefaultProfiles() - auto interface = Kirigami::TabletModeWatcher::self(); - - PowerDevil::ProfileGenerator::generateProfiles(interface->isTabletMode(), -+ PowerDevil::PowerManagement::instance()->isVirtualMachine(), - PowerDevil::PowerManagement::instance()->canSuspend(), - PowerDevil::PowerManagement::instance()->canHibernate()); - --- -GitLab - diff --git a/powerdevil.spec b/powerdevil.spec index bba2b6c..7efbf55 100644 --- a/powerdevil.spec +++ b/powerdevil.spec @@ -1,7 +1,7 @@ %global kf5_version 5.82.0 Name: powerdevil -Version: 5.27.10 +Version: 5.27.11 Release: 1%{?dist} Summary: Manages the power consumption settings of a Plasma Shell @@ -19,6 +19,8 @@ URL: https://invent.kde.org/plasma/%{name} %endif Source0: http://download.kde.org/%{stable}/plasma/%{plasma_version}/%{name}-%{version}.tar.xz +# Upstream patches + # filter plugin provides %global __provides_exclude_from ^(%{_kf5_qtplugindir}/.*\\.so)$ @@ -61,6 +63,8 @@ BuildRequires: xcb-util-wm-devel %ifnarch s390 s390x BuildRequires: libddcutil-devel +# udev rules +Requires: ddcutil %global DDCUTIL ON %else %global DDCUTIL OFF @@ -130,6 +134,15 @@ rm -fv %{buildroot}/%{_libdir}/libpowerdevil{configcommonprivate,core,ui}.so %{_kf5_qtplugindir}/powerdevil/action/powerdevil_*.so %changelog +* Sat Mar 09 2024 Alessandro Astone - 5.27.11-1 +- 5.27.11 + +* Fri Feb 23 2024 Alessandro Astone - 5.27.10-3 +- Require ddcutil for udev rules + +* Mon Feb 19 2024 Marc Deop i Argemí - 5.27.10-2 +- Backport keyboard backlit patch from upstream + * Sat Dec 16 2023 Marc Deop i Argemí - 5.27.10-1 - 5.27.10 diff --git a/sources b/sources index d671b15..2138a30 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (powerdevil-5.27.10.tar.xz) = 7bee5e98e5e1cedfc94c7e5d5296c88a88269f2838bb937073bd27cd0bc0ee696ae7134386ea84ea60b8ed18c5bdb6d2a715fd599c0836d62a3191183a47d47e +SHA512 (powerdevil-5.27.11.tar.xz) = 7ea5640d42c3aa4bc21091a56452202f798ed3df3cfab6b0f38895cdd558fe877e463bf2c801914ded2511777b353d6e252f9dcee2856b1995b6f08c84cc3b84