Commit 19c9fb89 authored by Thomas Renninger's avatar Thomas Renninger Committed by Rafael J. Wysocki

cpupower: Enable disabled Cstates if they are below max latency

cpupower idle-set -D <latency>
currently only disables all C-states that have a higher latency than the
specified <latency>. But if deep sleep states were already disabled and
have a lower latency, they should get enabled again.

For example:
This call:
cpupower idle-set -D 30
disables all C-states with a higher or equal latency than 30.
If one then calls:
cpupower idle-set -D 100
C-states with a latency between 30-99 will get enabled again with this patch
now. It is ensured that only C-states with a latency of 100 and higher are
disabled.
Signed-off-by: default avatarThomas Renninger <trenn@suse.de>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 64520947
...@@ -20,7 +20,9 @@ Disable a specific processor sleep state. ...@@ -20,7 +20,9 @@ Disable a specific processor sleep state.
Enable a specific processor sleep state. Enable a specific processor sleep state.
.TP .TP
\fB\-D\fR \fB\-\-disable-by-latency\fR <LATENCY> \fB\-D\fR \fB\-\-disable-by-latency\fR <LATENCY>
Disable all idle states with a equal or higher latency than <LATENCY> Disable all idle states with a equal or higher latency than <LATENCY>.
Enable all idle states with a latency lower than <LATENCY>.
.TP .TP
\fB\-E\fR \fB\-\-enable-all\fR \fB\-E\fR \fB\-\-enable-all\fR
Enable all idle states if not enabled already. Enable all idle states if not enabled already.
......
...@@ -148,12 +148,21 @@ int cmd_idle_set(int argc, char **argv) ...@@ -148,12 +148,21 @@ int cmd_idle_set(int argc, char **argv)
(cpu, idlestate); (cpu, idlestate);
state_latency = sysfs_get_idlestate_latency state_latency = sysfs_get_idlestate_latency
(cpu, idlestate); (cpu, idlestate);
if (disabled == 1 || latency > state_latency) if (disabled == 1) {
if (latency > state_latency){
ret = sysfs_idlestate_disable
(cpu, idlestate, 0);
if (ret == 0)
printf(_("Idlestate %u enabled on CPU %u\n"), idlestate, cpu);
}
continue; continue;
ret = sysfs_idlestate_disable }
(cpu, idlestate, 1); if (latency <= state_latency){
if (ret == 0) ret = sysfs_idlestate_disable
(cpu, idlestate, 1);
if (ret == 0)
printf(_("Idlestate %u disabled on CPU %u\n"), idlestate, cpu); printf(_("Idlestate %u disabled on CPU %u\n"), idlestate, cpu);
}
} }
break; break;
case 'E': case 'E':
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment