Commit 3497a562 authored by Deepak S's avatar Deepak S Committed by Daniel Vetter

drm/i915/chv: Add basic PM interrupt support for CHV

Enabled PM interrupt programming for CHV. Re-using gen8 code and extending same for CHV.
Signed-off-by: default avatarDeepak S <deepak.s@linux.intel.com>
Reviewed-by: default avatarMika Kuoppala <mika.kuoppala@intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent 22b1b2f8
...@@ -1407,7 +1407,7 @@ static void gen6_pm_rps_work(struct work_struct *work) ...@@ -1407,7 +1407,7 @@ static void gen6_pm_rps_work(struct work_struct *work)
spin_lock_irq(&dev_priv->irq_lock); spin_lock_irq(&dev_priv->irq_lock);
pm_iir = dev_priv->rps.pm_iir; pm_iir = dev_priv->rps.pm_iir;
dev_priv->rps.pm_iir = 0; dev_priv->rps.pm_iir = 0;
if (IS_BROADWELL(dev_priv->dev)) if (IS_BROADWELL(dev_priv->dev) || IS_CHERRYVIEW(dev_priv->dev))
bdw_enable_pm_irq(dev_priv, dev_priv->pm_rps_events); bdw_enable_pm_irq(dev_priv, dev_priv->pm_rps_events);
else { else {
/* Make sure not to corrupt PMIMR state used by ringbuffer */ /* Make sure not to corrupt PMIMR state used by ringbuffer */
......
...@@ -3392,6 +3392,8 @@ static void cherryview_disable_rps(struct drm_device *dev) ...@@ -3392,6 +3392,8 @@ static void cherryview_disable_rps(struct drm_device *dev)
struct drm_i915_private *dev_priv = dev->dev_private; struct drm_i915_private *dev_priv = dev->dev_private;
I915_WRITE(GEN6_RC_CONTROL, 0); I915_WRITE(GEN6_RC_CONTROL, 0);
gen8_disable_rps_interrupts(dev);
} }
static void valleyview_disable_rps(struct drm_device *dev) static void valleyview_disable_rps(struct drm_device *dev)
...@@ -4109,6 +4111,8 @@ static void cherryview_enable_rps(struct drm_device *dev) ...@@ -4109,6 +4111,8 @@ static void cherryview_enable_rps(struct drm_device *dev)
valleyview_set_rps(dev_priv->dev, dev_priv->rps.efficient_freq); valleyview_set_rps(dev_priv->dev, dev_priv->rps.efficient_freq);
gen8_enable_rps_interrupts(dev);
gen6_gt_force_wake_put(dev_priv, FORCEWAKE_ALL); gen6_gt_force_wake_put(dev_priv, FORCEWAKE_ALL);
} }
......
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