i965: Move brw_emit_query_begin() to the render ring prelude.
authorKenneth Graunke <kenneth@whitecape.org>
Wed, 16 Oct 2013 02:32:53 +0000 (19:32 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Thu, 21 Nov 2013 23:01:13 +0000 (15:01 -0800)
Without hardware contexts, the pipeline statistics registers are
free-running and include data from every 3D application running.

In order to find out the contributions of one particular context, we
need to take a snapshot at the start and end of each batch.

Previously, we emitted the PIPE_CONTROL necessary to capture
PS_DEPTH_COUNT when drawing primitives.  Special tracking ensured it
happened only on the first draw of the batch, rather than on every draw.

Moving this to brw_new_batch increases symmetry, since the final
snapshot has always been in brw_finish_batch, which is just a few lines
below.  It should be basically equivalent.

Signed-off-by: Kenneth Graunke <kenneth@whitecape.org>
Reviewed-by: Eric Anholt <eric@anholt.net>
src/mesa/drivers/dri/i965/brw_draw_upload.c
src/mesa/drivers/dri/i965/intel_batchbuffer.c

index 57b81df81108dc1e592430026f12c22b2504f3ba..89404b09e6132a41ee3509663231285a8f4e310b 100644 (file)
@@ -614,8 +614,6 @@ static void brw_emit_vertices(struct brw_context *brw)
 
    brw_prepare_vertices(brw);
 
-   brw_emit_query_begin(brw);
-
    nr_elements = brw->vb.nr_enabled + brw->vs.prog_data->uses_vertexid;
 
    /* If the VS doesn't read any inputs (calculating vertex position from
index d054e444d9fb4cfc9f426cef9571498c4a6342b2..20c924ee3b831e31dd4a20e4353c82f6b5ad42d8 100644 (file)
@@ -182,6 +182,11 @@ do_batch_dump(struct brw_context *brw)
 void
 intel_batchbuffer_emit_render_ring_prelude(struct brw_context *brw)
 {
+   /* Without hardware contexts, we need to capture the pipeline statistics
+    * registers at the start and end of each render ring batch, so we can see
+    * what that batch contributed.  Emit state packets to write them to a BO.
+    */
+   brw_emit_query_begin(brw);
 }
 
 /**
@@ -234,6 +239,9 @@ brw_new_batch(struct brw_context *brw)
 static void
 brw_finish_batch(struct brw_context *brw)
 {
+   /* Capture the closing pipeline statistics register values necessary to
+    * support query objects (in the non-hardware context world).
+    */
    brw_emit_query_end(brw);
 
    if (brw->curbe.curbe_bo) {