|
@@ -8148,6 +8148,15 @@ static void gen6_init_clock_gating(struct drm_device *dev)
|
|
|
I915_WRITE(WM2_LP_ILK, 0);
|
|
|
I915_WRITE(WM1_LP_ILK, 0);
|
|
|
|
|
|
+ /* According to the BSpec vol1g, bit 12 (RCPBUNIT) clock
|
|
|
+ * gating disable must be set. Failure to set it results in
|
|
|
+ * flickering pixels due to Z write ordering failures after
|
|
|
+ * some amount of runtime in the Mesa "fire" demo, and Unigine
|
|
|
+ * Sanctuary and Tropics, and apparently anything else with
|
|
|
+ * alpha test or pixel discard.
|
|
|
+ */
|
|
|
+ I915_WRITE(GEN6_UCGCTL2, GEN6_RCPBUNIT_CLOCK_GATE_DISABLE);
|
|
|
+
|
|
|
/*
|
|
|
* According to the spec the following bits should be
|
|
|
* set in order to enable memory self-refresh and fbc:
|