aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorEric Anholt <eric@anholt.net>2011-11-07 19:07:04 -0500
committerKeith Packard <keithp@keithp.com>2011-11-07 22:25:15 -0500
commit406478dc911e16677fbd9c84d1d50cdffbc031ab (patch)
treedccb7db94e10333a3526d54c182d8d80df2ff582 /drivers
parent680da876f44a644aee891e1d0df5a560cfa4720e (diff)
drm/i915: Turn on a required 3D clock gating bit on Sandybridge.
Fixes rendering failures in Unigine Tropics and Sanctuary and the mesa "fire" demo. Signed-off-by: Eric Anholt <eric@anholt.net> Cc: stable@kernel.org Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/i915/i915_reg.h3
-rw-r--r--drivers/gpu/drm/i915/intel_display.c9
2 files changed, 12 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
index 5a09416e611..b807275ea73 100644
--- a/drivers/gpu/drm/i915/i915_reg.h
+++ b/drivers/gpu/drm/i915/i915_reg.h
@@ -3444,6 +3444,9 @@
3444#define GT_FIFO_FREE_ENTRIES 0x120008 3444#define GT_FIFO_FREE_ENTRIES 0x120008
3445#define GT_FIFO_NUM_RESERVED_ENTRIES 20 3445#define GT_FIFO_NUM_RESERVED_ENTRIES 20
3446 3446
3447#define GEN6_UCGCTL2 0x9404
3448# define GEN6_RCPBUNIT_CLOCK_GATE_DISABLE (1 << 12)
3449
3447#define GEN6_RPNSWREQ 0xA008 3450#define GEN6_RPNSWREQ 0xA008
3448#define GEN6_TURBO_DISABLE (1<<31) 3451#define GEN6_TURBO_DISABLE (1<<31)
3449#define GEN6_FREQUENCY(x) ((x)<<25) 3452#define GEN6_FREQUENCY(x) ((x)<<25)
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index 9fa342e8945..2b2a7645cd0 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -8148,6 +8148,15 @@ static void gen6_init_clock_gating(struct drm_device *dev)
8148 I915_WRITE(WM2_LP_ILK, 0); 8148 I915_WRITE(WM2_LP_ILK, 0);
8149 I915_WRITE(WM1_LP_ILK, 0); 8149 I915_WRITE(WM1_LP_ILK, 0);
8150 8150
8151 /* According to the BSpec vol1g, bit 12 (RCPBUNIT) clock
8152 * gating disable must be set. Failure to set it results in
8153 * flickering pixels due to Z write ordering failures after
8154 * some amount of runtime in the Mesa "fire" demo, and Unigine
8155 * Sanctuary and Tropics, and apparently anything else with
8156 * alpha test or pixel discard.
8157 */
8158 I915_WRITE(GEN6_UCGCTL2, GEN6_RCPBUNIT_CLOCK_GATE_DISABLE);
8159
8151 /* 8160 /*
8152 * According to the spec the following bits should be 8161 * According to the spec the following bits should be
8153 * set in order to enable memory self-refresh and fbc: 8162 * set in order to enable memory self-refresh and fbc: