From db8f57a5cb4ab8e1ad789793678797c04e95de21 Mon Sep 17 00:00:00 2001 From: Kenneth Graunke Date: Thu, 20 Jun 2019 00:47:33 -0500 Subject: [PATCH] iris: Don't check VF address high bits when there is no buffer. If there is no buffer, then it doesn't matter. Leave the old stale high bits in place (for next time) and don't bother invalidating. Cuts 5.6% of the flushes in the Civilization VI demo on Kabylake GT2. --- src/gallium/drivers/iris/iris_blorp.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gallium/drivers/iris/iris_blorp.c b/src/gallium/drivers/iris/iris_blorp.c index 209940e9bc7..ede679e731a 100644 --- a/src/gallium/drivers/iris/iris_blorp.c +++ b/src/gallium/drivers/iris/iris_blorp.c @@ -212,7 +212,7 @@ blorp_vf_invalidate_for_vb_48b_transitions(struct blorp_batch *blorp_batch, struct iris_bo *bo = addrs[i].buffer; uint16_t high_bits = bo ? bo->gtt_offset >> 32u : 0; - if (high_bits != ice->state.last_vbo_high_bits[i]) { + if (bo && high_bits != ice->state.last_vbo_high_bits[i]) { need_invalidate = true; ice->state.last_vbo_high_bits[i] = high_bits; } -- 2.30.2