|
@@ -5335,6 +5335,15 @@ static void valleyview_init_clock_gating(struct drm_device *dev)
|
|
|
I915_WRITE(VLV_GUNIT_CLOCK_GATE, GCFG_DIS);
|
|
|
}
|
|
|
|
|
|
+static void cherryview_init_clock_gating(struct drm_device *dev)
|
|
|
+{
|
|
|
+ struct drm_i915_private *dev_priv = dev->dev_private;
|
|
|
+
|
|
|
+ I915_WRITE(DSPCLK_GATE_D, VRHUNIT_CLOCK_GATE_DISABLE);
|
|
|
+
|
|
|
+ I915_WRITE(MI_ARB_VLV, MI_ARB_DISPLAY_TRICKLE_FEED_DISABLE);
|
|
|
+}
|
|
|
+
|
|
|
static void g4x_init_clock_gating(struct drm_device *dev)
|
|
|
{
|
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
@@ -6270,6 +6279,10 @@ void intel_init_pm(struct drm_device *dev)
|
|
|
dev_priv->display.init_clock_gating = haswell_init_clock_gating;
|
|
|
else if (INTEL_INFO(dev)->gen == 8)
|
|
|
dev_priv->display.init_clock_gating = gen8_init_clock_gating;
|
|
|
+ } else if (IS_CHERRYVIEW(dev)) {
|
|
|
+ dev_priv->display.update_wm = valleyview_update_wm;
|
|
|
+ dev_priv->display.init_clock_gating =
|
|
|
+ cherryview_init_clock_gating;
|
|
|
} else if (IS_VALLEYVIEW(dev)) {
|
|
|
dev_priv->display.update_wm = valleyview_update_wm;
|
|
|
dev_priv->display.init_clock_gating =
|