summaryrefslogtreecommitdiffstats
path: root/kernel/sched
diff options
context:
space:
mode:
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>2020-07-28 19:09:32 +0200
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2020-07-30 18:20:23 +0200
commitde002c55cadfc2f6cdf0ed427526f6085d240238 (patch)
tree3f9bca4261e41622950446bbd46e7649a394b686 /kernel/sched
parentcpufreq: intel_pstate: Rearrange the storing of new EPP values (diff)
downloadlinux-de002c55cadfc2f6cdf0ed427526f6085d240238.tar.xz
linux-de002c55cadfc2f6cdf0ed427526f6085d240238.zip
cpufreq: intel_pstate: Fix EPP setting via sysfs in active mode
Because intel_pstate_set_energy_pref_index() reads and writes the MSR_HWP_REQUEST register without using the cached value of it used by intel_pstate_hwp_boost_up() and intel_pstate_hwp_boost_down(), those functions may overwrite the value written by it and so the EPP value set via sysfs may be lost. To avoid that, make intel_pstate_set_energy_pref_index() take the cached value of MSR_HWP_REQUEST just like the other two routines mentioned above and update it with the new EPP value coming from user space in addition to updating the MSR. Note that the MSR itself still needs to be updated too in case hwp_boost is unset or the boosting mechanism is not active at the EPP change time. Fixes: e0efd5be63e8 ("cpufreq: intel_pstate: Add HWP boost utility and sched util hooks") Reported-by: Francisco Jerez <currojerez@riseup.net> Cc: 4.18+ <stable@vger.kernel.org> # 4.18+: 3da97d4db8ee cpufreq: intel_pstate: Rearrange ... Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Reviewed-by: Francisco Jerez <currojerez@riseup.net>
Diffstat (limited to 'kernel/sched')
0 files changed, 0 insertions, 0 deletions