diff options
author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2013-11-06 16:02:20 -0500 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-11-21 03:06:31 -0500 |
commit | 37c1d94fa83482c308f14ec671910278e8647934 (patch) | |
tree | 3e987bbc44b51a1c3dcaa1d85466465cc9837448 /drivers/gpu/drm/i915/intel_ringbuffer.c | |
parent | 9688ecadd268770834cca72ac81c9aec8fb8cf2f (diff) |
drm/i915: Emit SRM after the MSG_FBC_REND_STATE LRI
The spec tells us that we need to emit an SRM after the LRI
to MSG_FBC_REND_STATE.
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@gmail.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_ringbuffer.c')
-rw-r--r-- | drivers/gpu/drm/i915/intel_ringbuffer.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c index e26e18a1d916..b65f4d77e3ed 100644 --- a/drivers/gpu/drm/i915/intel_ringbuffer.c +++ b/drivers/gpu/drm/i915/intel_ringbuffer.c | |||
@@ -285,14 +285,16 @@ static int gen7_ring_fbc_flush(struct intel_ring_buffer *ring, u32 value) | |||
285 | if (!ring->fbc_dirty) | 285 | if (!ring->fbc_dirty) |
286 | return 0; | 286 | return 0; |
287 | 287 | ||
288 | ret = intel_ring_begin(ring, 4); | 288 | ret = intel_ring_begin(ring, 6); |
289 | if (ret) | 289 | if (ret) |
290 | return ret; | 290 | return ret; |
291 | intel_ring_emit(ring, MI_NOOP); | ||
292 | /* WaFbcNukeOn3DBlt:ivb/hsw */ | 291 | /* WaFbcNukeOn3DBlt:ivb/hsw */ |
293 | intel_ring_emit(ring, MI_LOAD_REGISTER_IMM(1)); | 292 | intel_ring_emit(ring, MI_LOAD_REGISTER_IMM(1)); |
294 | intel_ring_emit(ring, MSG_FBC_REND_STATE); | 293 | intel_ring_emit(ring, MSG_FBC_REND_STATE); |
295 | intel_ring_emit(ring, value); | 294 | intel_ring_emit(ring, value); |
295 | intel_ring_emit(ring, MI_STORE_REGISTER_MEM(1) | MI_SRM_LRM_GLOBAL_GTT); | ||
296 | intel_ring_emit(ring, MSG_FBC_REND_STATE); | ||
297 | intel_ring_emit(ring, ring->scratch.gtt_offset + 256); | ||
296 | intel_ring_advance(ring); | 298 | intel_ring_advance(ring); |
297 | 299 | ||
298 | ring->fbc_dirty = false; | 300 | ring->fbc_dirty = false; |