diff options
author | Eric Anholt <eric@anholt.net> | 2011-11-07 19:07:04 -0500 |
---|---|---|
committer | Keith Packard <keithp@keithp.com> | 2011-11-07 22:25:15 -0500 |
commit | 406478dc911e16677fbd9c84d1d50cdffbc031ab (patch) | |
tree | dccb7db94e10333a3526d54c182d8d80df2ff582 /drivers | |
parent | 680da876f44a644aee891e1d0df5a560cfa4720e (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.h | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 9 |
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 5a09416e611f..b807275ea739 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 9fa342e89454..2b2a7645cd0c 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: |