From 92394e2850e50efa0f3334ef3526421befe33072 Mon Sep 17 00:00:00 2001 From: Michele Calgaro Date: Mon, 2 May 2016 23:34:35 +1000 Subject: tdecore: Improved code for hybrid suspend (aka suspend to RAM + suspend to disk). Now code is more consistent. This relates to bug 2601. Signed-off-by: Michele Calgaro --- tdecore/tdehw/tdehardwaredevices.cpp | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) (limited to 'tdecore/tdehw/tdehardwaredevices.cpp') diff --git a/tdecore/tdehw/tdehardwaredevices.cpp b/tdecore/tdehw/tdehardwaredevices.cpp index e2a935e61..e9c7daff1 100644 --- a/tdecore/tdehw/tdehardwaredevices.cpp +++ b/tdecore/tdehw/tdehardwaredevices.cpp @@ -3325,6 +3325,10 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist if (dirlist) { TQFileInfoListIterator valuesdirit(*dirlist); TQFileInfo *dirfi; + TDESystemPowerStateList powerstates; + TDESystemHibernationMethodList hibernationmethods; + TDESystemHibernationMethod::TDESystemHibernationMethod hibernationmethod = + TDESystemHibernationMethod::Unsupported; while ( (dirfi = valuesdirit.current()) != 0 ) { nodename = dirfi->fileName(); TQFile file( valuesnodename + nodename ); @@ -3333,7 +3337,6 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist TQString line; line = stream.readLine(); if (nodename == "state") { - TDESystemPowerStateList powerstates; // Always assume that these two fully on/fully off states are available powerstates.append(TDESystemPowerState::Active); powerstates.append(TDESystemPowerState::PowerOff); @@ -3347,13 +3350,11 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist powerstates.append(TDESystemPowerState::Suspend); } if (line.contains("disk")) { - powerstates.append(TDESystemPowerState::Hibernate); + powerstates.append(TDESystemPowerState::Disk); } - rdevice->internalSetPowerStates(powerstates); } if (nodename == "disk") { // Get list of available hibernation methods - TDESystemHibernationMethodList hibernationmethods; if (line.contains("platform")) { hibernationmethods.append(TDESystemHibernationMethod::Platform); } @@ -3372,12 +3373,10 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist if (line.contains("test")) { hibernationmethods.append(TDESystemHibernationMethod::Test); } - rdevice->internalSetHibernationMethods(hibernationmethods); // Get current hibernation method line.truncate(line.findRev("]")); line.remove(0, line.findRev("[")+1); - TDESystemHibernationMethod::TDESystemHibernationMethod hibernationmethod = TDESystemHibernationMethod::Unsupported; if (line.contains("platform")) { hibernationmethod = TDESystemHibernationMethod::Platform; } @@ -3396,7 +3395,6 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist if (line.contains("test")) { hibernationmethod = TDESystemHibernationMethod::Test; } - rdevice->internalSetHibernationMethod(hibernationmethod); } if (nodename == "image_size") { rdevice->internalSetDiskSpaceNeededForHibernation(line.toULong()); @@ -3405,6 +3403,22 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist } ++valuesdirit; } + // Hibernation and Hybrid Suspend are not real power states, being just two different + // ways of suspending to disk. Since they are very common and it is very convenient to + // treat them as power states, we do so, as other power frameworks also do. + if (powerstates.contains(TDESystemPowerState::Disk) && + hibernationmethods.contains(TDESystemHibernationMethod::Platform)) { + powerstates.append(TDESystemPowerState::Hibernate); + } + if (powerstates.contains(TDESystemPowerState::Disk) && + hibernationmethods.contains(TDESystemHibernationMethod::Suspend)) { + powerstates.append(TDESystemPowerState::HybridSuspend); + } + powerstates.remove(TDESystemPowerState::Disk); + // Set power states and hibernation methods + rdevice->internalSetPowerStates(powerstates); + rdevice->internalSetHibernationMethods(hibernationmethods); + rdevice->internalSetHibernationMethod(hibernationmethod); } } -- cgit v1.2.1