aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_ringbuffer.c
diff options
context:
space:
mode:
authorJesse Barnes <jbarnes@virtuousgeek.org>2012-10-26 12:42:42 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2012-11-11 17:51:36 -0500
commit9a28977181724ebbd9bdc45291cf29da55a729ee (patch)
treed83f779436fcaab0b445c64ee50252269ba6b211 /drivers/gpu/drm/i915/intel_ringbuffer.c
parent12f3382bc0262e981a2e58aca900cbbdbbe66825 (diff)
drm/i915: TLB invalidation with MI_FLUSH_DW requires a post-sync op v3
So store into the scratch space of the HWS to make sure the invalidate occurs. v2: use GTT address space for store, clean up #defines (Chris) v3: use correct #define in blt ring flush (Chris) Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org> Reviewed-by: Antti Koskipää <antti.koskipaa@intel.com> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> References: https://bugs.launchpad.net/ubuntu/+source/xserver-xorg-video-intel/+bug/1063252 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.c22
1 files changed, 18 insertions, 4 deletions
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c
index b13393b593b8..1591955044c8 100644
--- a/drivers/gpu/drm/i915/intel_ringbuffer.c
+++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
@@ -1395,10 +1395,17 @@ static int gen6_ring_flush(struct intel_ring_buffer *ring,
1395 return ret; 1395 return ret;
1396 1396
1397 cmd = MI_FLUSH_DW; 1397 cmd = MI_FLUSH_DW;
1398 /*
1399 * Bspec vol 1c.5 - video engine command streamer:
1400 * "If ENABLED, all TLBs will be invalidated once the flush
1401 * operation is complete. This bit is only valid when the
1402 * Post-Sync Operation field is a value of 1h or 3h."
1403 */
1398 if (invalidate & I915_GEM_GPU_DOMAINS) 1404 if (invalidate & I915_GEM_GPU_DOMAINS)
1399 cmd |= MI_INVALIDATE_TLB | MI_INVALIDATE_BSD; 1405 cmd |= MI_INVALIDATE_TLB | MI_INVALIDATE_BSD |
1406 MI_FLUSH_DW_STORE_INDEX | MI_FLUSH_DW_OP_STOREDW;
1400 intel_ring_emit(ring, cmd); 1407 intel_ring_emit(ring, cmd);
1401 intel_ring_emit(ring, 0); 1408 intel_ring_emit(ring, I915_GEM_HWS_SCRATCH_ADDR | MI_FLUSH_DW_USE_GTT);
1402 intel_ring_emit(ring, 0); 1409 intel_ring_emit(ring, 0);
1403 intel_ring_emit(ring, MI_NOOP); 1410 intel_ring_emit(ring, MI_NOOP);
1404 intel_ring_advance(ring); 1411 intel_ring_advance(ring);
@@ -1460,10 +1467,17 @@ static int blt_ring_flush(struct intel_ring_buffer *ring,
1460 return ret; 1467 return ret;
1461 1468
1462 cmd = MI_FLUSH_DW; 1469 cmd = MI_FLUSH_DW;
1470 /*
1471 * Bspec vol 1c.3 - blitter engine command streamer:
1472 * "If ENABLED, all TLBs will be invalidated once the flush
1473 * operation is complete. This bit is only valid when the
1474 * Post-Sync Operation field is a value of 1h or 3h."
1475 */
1463 if (invalidate & I915_GEM_DOMAIN_RENDER) 1476 if (invalidate & I915_GEM_DOMAIN_RENDER)
1464 cmd |= MI_INVALIDATE_TLB; 1477 cmd |= MI_INVALIDATE_TLB | MI_FLUSH_DW_STORE_INDEX |
1478 MI_FLUSH_DW_OP_STOREDW | MI_FLUSH_DW_OP_STOREDW;
1465 intel_ring_emit(ring, cmd); 1479 intel_ring_emit(ring, cmd);
1466 intel_ring_emit(ring, 0); 1480 intel_ring_emit(ring, I915_GEM_HWS_SCRATCH_ADDR | MI_FLUSH_DW_USE_GTT);
1467 intel_ring_emit(ring, 0); 1481 intel_ring_emit(ring, 0);
1468 intel_ring_emit(ring, MI_NOOP); 1482 intel_ring_emit(ring, MI_NOOP);
1469 intel_ring_advance(ring); 1483 intel_ring_advance(ring);