summaryrefslogtreecommitdiff
path: root/net/unix
diff options
context:
space:
mode:
authorJoel Fernandes <joelaf@google.com>2017-07-23 08:54:25 -0700
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-07-26 22:52:13 +0200
commita5a0809bc58e133d674e45175b052c9bdf002f1d (patch)
treefd192920b77bcc95f5aa4be534508b4cf2c339c6 /net/unix
parent520eccdfe187591a51ea9ab4c1a024ae4d0f68d9 (diff)
downloadlwn-a5a0809bc58e133d674e45175b052c9bdf002f1d.tar.gz
lwn-a5a0809bc58e133d674e45175b052c9bdf002f1d.zip
cpufreq: schedutil: Make iowait boost more energy efficient
Currently the iowait_boost feature in schedutil makes the frequency go to max on iowait wakeups. This feature was added to handle a case that Peter described where the throughput of operations involving continuous I/O requests [1] is reduced due to running at a lower frequency, however the lower throughput itself causes utilization to be low and hence causing frequency to be low hence its "stuck". Instead of going to max, its also possible to achieve the same effect by ramping up to max if there are repeated in_iowait wakeups happening. This patch is an attempt to do that. We start from a lower frequency (policy->min) and double the boost for every consecutive iowait update until we reach the maximum iowait boost frequency (iowait_boost_max). I ran a synthetic test (continuous O_DIRECT writes in a loop) on an x86 machine with intel_pstate in passive mode using schedutil. In this test the iowait_boost value ramped from 800MHz to 4GHz in 60ms. The patch achieves the desired improved throughput as the existing behavior. [1] https://patchwork.kernel.org/patch/9735885/ Suggested-by: Peter Zijlstra <peterz@infradead.org> Suggested-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Joel Fernandes <joelaf@google.com> Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'net/unix')
0 files changed, 0 insertions, 0 deletions