|
@@ -8796,6 +8796,54 @@ static void ivybridge_init_clock_gating(struct drm_device *dev)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+static void valleyview_init_clock_gating(struct drm_device *dev)
|
|
|
+{
|
|
|
+ struct drm_i915_private *dev_priv = dev->dev_private;
|
|
|
+ int pipe;
|
|
|
+ uint32_t dspclk_gate = VRHUNIT_CLOCK_GATE_DISABLE;
|
|
|
+
|
|
|
+ I915_WRITE(PCH_DSPCLK_GATE_D, dspclk_gate);
|
|
|
+
|
|
|
+ I915_WRITE(WM3_LP_ILK, 0);
|
|
|
+ I915_WRITE(WM2_LP_ILK, 0);
|
|
|
+ I915_WRITE(WM1_LP_ILK, 0);
|
|
|
+
|
|
|
+ /* According to the spec, bit 13 (RCZUNIT) must be set on IVB.
|
|
|
+ * This implements the WaDisableRCZUnitClockGating workaround.
|
|
|
+ */
|
|
|
+ I915_WRITE(GEN6_UCGCTL2, GEN6_RCZUNIT_CLOCK_GATE_DISABLE);
|
|
|
+
|
|
|
+ I915_WRITE(ILK_DSPCLK_GATE, IVB_VRHUNIT_CLK_GATE);
|
|
|
+
|
|
|
+ I915_WRITE(IVB_CHICKEN3,
|
|
|
+ CHICKEN3_DGMG_REQ_OUT_FIX_DISABLE |
|
|
|
+ CHICKEN3_DGMG_DONE_FIX_DISABLE);
|
|
|
+
|
|
|
+ /* Apply the WaDisableRHWOOptimizationForRenderHang workaround. */
|
|
|
+ I915_WRITE(GEN7_COMMON_SLICE_CHICKEN1,
|
|
|
+ GEN7_CSC1_RHWO_OPT_DISABLE_IN_RCC);
|
|
|
+
|
|
|
+ /* WaApplyL3ControlAndL3ChickenMode requires those two on Ivy Bridge */
|
|
|
+ I915_WRITE(GEN7_L3CNTLREG1, GEN7_WA_FOR_GEN7_L3_CONTROL);
|
|
|
+ I915_WRITE(GEN7_L3_CHICKEN_MODE_REGISTER, GEN7_WA_L3_CHICKEN_MODE);
|
|
|
+
|
|
|
+ /* This is required by WaCatErrorRejectionIssue */
|
|
|
+ I915_WRITE(GEN7_SQ_CHICKEN_MBCUNIT_CONFIG,
|
|
|
+ I915_READ(GEN7_SQ_CHICKEN_MBCUNIT_CONFIG) |
|
|
|
+ GEN7_SQ_CHICKEN_MBCUNIT_SQINTMOB);
|
|
|
+
|
|
|
+ for_each_pipe(pipe) {
|
|
|
+ I915_WRITE(DSPCNTR(pipe),
|
|
|
+ I915_READ(DSPCNTR(pipe)) |
|
|
|
+ DISPPLANE_TRICKLE_FEED_DISABLE);
|
|
|
+ intel_flush_display_plane(dev_priv, pipe);
|
|
|
+ }
|
|
|
+
|
|
|
+ I915_WRITE(CACHE_MODE_1, I915_READ(CACHE_MODE_1) |
|
|
|
+ (PIXEL_SUBSPAN_COLLECT_OPT_DISABLE << 16) |
|
|
|
+ PIXEL_SUBSPAN_COLLECT_OPT_DISABLE);
|
|
|
+}
|
|
|
+
|
|
|
static void g4x_init_clock_gating(struct drm_device *dev)
|
|
|
{
|
|
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
@@ -9150,6 +9198,8 @@ static void intel_init_display(struct drm_device *dev)
|
|
|
dev_priv->display.update_wm = NULL;
|
|
|
} else if (IS_VALLEYVIEW(dev)) {
|
|
|
dev_priv->display.update_wm = valleyview_update_wm;
|
|
|
+ dev_priv->display.init_clock_gating =
|
|
|
+ valleyview_init_clock_gating;
|
|
|
} else if (IS_PINEVIEW(dev)) {
|
|
|
if (!intel_get_cxsr_latency(IS_PINEVIEW_G(dev),
|
|
|
dev_priv->is_ddr3,
|