[Mesa-dev] [PATCH] i965: Fix occlusion queries for BLORP operations.

Kenneth Graunke kenneth at whitecape.org
Mon May 7 15:45:12 UTC 2018


Gen4-5 traditionally don't use GEM context support, which means that
the PS_DEPTH_COUNT register isn't saved/restored for us across batches.

This means that we have to bookend each batch with start/end snapshots,
and add deltas from a series of pairs, instead of simply having a single
<start, end> pair.  Much messier.

In the normal state upload code, we check on every draw call whether
we need to take the starting snapshot for the batch.  But in BLORP,
we forgot to do this, so we'd miss the BLORP operation if it were the
first thing in the batch.
---
 src/mesa/drivers/dri/i965/gen4_blorp_exec.h | 2 ++
 1 file changed, 2 insertions(+)

I haven't observed this to fix anything.  I was hoping it might help
with NV_conditional_render test flakiness...

diff --git a/src/mesa/drivers/dri/i965/gen4_blorp_exec.h b/src/mesa/drivers/dri/i965/gen4_blorp_exec.h
index e59bc9f2c2c..ccff1f98123 100644
--- a/src/mesa/drivers/dri/i965/gen4_blorp_exec.h
+++ b/src/mesa/drivers/dri/i965/gen4_blorp_exec.h
@@ -173,6 +173,8 @@ blorp_emit_pipeline(struct blorp_batch *batch,
    assert(batch->blorp->driver_ctx == batch->driver_batch);
    struct brw_context *brw = batch->driver_batch;
 
+   brw_emit_query_begin(brw);
+
    emit_urb_config(batch, params);
 
    blorp_emit(batch, GENX(3DSTATE_PIPELINED_POINTERS), pp) {
-- 
2.17.0



More information about the mesa-dev mailing list