diff options
author | Emanoil Kotsev <deloptes@gmail.com> | 2021-04-27 21:37:05 +0200 |
---|---|---|
committer | Emanoil Kotsev <deloptes@gmail.com> | 2024-06-08 22:14:06 +0000 |
commit | b0364451f7a839e31e7dcd9a8d00025d76e8ef9e (patch) | |
tree | 7aba895b715976f8fbf844f07a249c5415ae64e3 /tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp | |
parent | b02c573742908ea6a2d17e3d301b7e9988c61bd3 (diff) | |
download | tdelibs-b0364451f7a839e31e7dcd9a8d00025d76e8ef9e.tar.gz tdelibs-b0364451f7a839e31e7dcd9a8d00025d76e8ef9e.zip |
A daemon based on dbus-1-tqt to replace the old tde_dbus_hardwarecontrol daemon
Signed-off-by: Emanoil Kotsev <deloptes@gmail.com>
Diffstat (limited to 'tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp')
-rw-r--r-- | tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp b/tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp new file mode 100644 index 000000000..1e689b7e1 --- /dev/null +++ b/tdecore/tdehw/hwlibdaemons/tdedbus/CPUGovernorService.cpp @@ -0,0 +1,73 @@ +/* + * CPUGovernorService.cpp + * + * Created on: Feb 1, 2021 + * Author: emanoil + * + * hardwarecontrol Copyright (C) 2021 trinity desktop development team + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 + * as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ +#include "CPUGovernorService.h" + +CPUGovernorService::CPUGovernorService(TQT_DBusConnection &conn) +: DeviceServiceBase(conn) +{ + // TODO Auto-generated constructor stub + +} + +CPUGovernorService::~CPUGovernorService() +{ + // TODO Auto-generated destructor stub +} + +/*! + * Implement virtual methods + * + */ +bool CPUGovernorService::CanSetCPUGovernor(TQ_INT32 cpu, bool& value, TQT_DBusError& error) { + // do something + TQString dev = TQString("/sys/devices/system/cpu/cpu%1/cpufreq/scaling_governor").arg(cpu); + if ((cpu>-1)) { + value = canSetDeviceValue(dev, error); + } else { + error = TQT_DBusError::stdInvalidArgs(TQString ("Invalid argument cpu: %1, governor: %2").arg(cpu).arg(dev)); + } + if (error.isValid()) { + tqDebug(error.message().local8Bit()); + return false; + } + return true; +} + +bool CPUGovernorService::SetCPUGovernor(TQ_INT32 cpu, const TQString& governor, bool& value, TQT_DBusError& error) { + + TQString dev = TQString("/sys/devices/system/cpu/cpu%1/cpufreq/scaling_governor").arg(cpu); + if ((cpu>-1) && !governor.isEmpty()) { + value = setDeviceValue(dev, governor, error); + } else { + error = TQT_DBusError::stdInvalidArgs(TQString ("Invalid argument cpu: %1, governor: %2").arg(cpu).arg(governor)); + } + if (error.isValid()) { + tqDebug(error.message().local8Bit()); + return false; + } + return true; +} + +void CPUGovernorService::handleMethodReply(const TQT_DBusMessage& reply) { + m_connection->send(reply); +} + |