Mesa (master): radeonsi: remove TC L2 cache flush for index buffers on VI

Marek Olšák mareko at kemper.freedesktop.org
Wed Oct 7 17:20:39 UTC 2015


Module: Mesa
Branch: master
Commit: 5749676d03d1a4964888a2d9a7624d3b96cc4886
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=5749676d03d1a4964888a2d9a7624d3b96cc4886

Author: Marek Olšák <marek.olsak at amd.com>
Date:   Sun Sep  6 15:43:23 2015 +0200

radeonsi: remove TC L2 cache flush for index buffers on VI

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

---

 src/gallium/drivers/radeonsi/si_state_draw.c |    6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/src/gallium/drivers/radeonsi/si_state_draw.c b/src/gallium/drivers/radeonsi/si_state_draw.c
index 43170ec..5face42 100644
--- a/src/gallium/drivers/radeonsi/si_state_draw.c
+++ b/src/gallium/drivers/radeonsi/si_state_draw.c
@@ -813,9 +813,9 @@ void si_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *info)
 		}
 	}
 
-	/* TODO: VI should read index buffers through TC, so this shouldn't be
-	 * needed on VI. */
-	if (info->indexed && r600_resource(ib.buffer)->TC_L2_dirty) {
+	/* VI reads index buffers through TC L2. */
+	if (info->indexed && sctx->b.chip_class <= CIK &&
+	    r600_resource(ib.buffer)->TC_L2_dirty) {
 		sctx->b.flags |= SI_CONTEXT_INV_TC_L2;
 		r600_resource(ib.buffer)->TC_L2_dirty = false;
 	}




More information about the mesa-commit mailing list