mirror of https://gitee.com/openkylin/linux.git
drm/i915: vlv: fix RPS interrupt mask setting
This typo may lead to missed RPS interrupts and as a result a too low or too high frequency for the current workload. The interrupt mask will be set properly at a subsequent GPU idle event, but can get corrupted again at the next RPS up/down event. Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
This commit is contained in:
parent
f6d519481b
commit
09c87db8b4
|
@ -3159,7 +3159,7 @@ void valleyview_set_rps(struct drm_device *dev, u8 val)
|
||||||
if (val != dev_priv->rps.cur_freq)
|
if (val != dev_priv->rps.cur_freq)
|
||||||
vlv_punit_write(dev_priv, PUNIT_REG_GPU_FREQ_REQ, val);
|
vlv_punit_write(dev_priv, PUNIT_REG_GPU_FREQ_REQ, val);
|
||||||
|
|
||||||
I915_WRITE(GEN6_PMINTRMSK, val);
|
I915_WRITE(GEN6_PMINTRMSK, gen6_rps_pm_mask(dev_priv, val));
|
||||||
|
|
||||||
dev_priv->rps.cur_freq = val;
|
dev_priv->rps.cur_freq = val;
|
||||||
trace_intel_gpu_freq_change(vlv_gpu_freq(dev_priv, val));
|
trace_intel_gpu_freq_change(vlv_gpu_freq(dev_priv, val));
|
||||||
|
|
Loading…
Reference in New Issue