radeonsi: move descriptor logs to after corresponding draw/compute packet
authorNicolai Hähnle <nicolai.haehnle@amd.com>
Sat, 23 Sep 2017 20:34:10 +0000 (22:34 +0200)
committerNicolai Hähnle <nicolai.haehnle@amd.com>
Fri, 29 Sep 2017 09:37:06 +0000 (11:37 +0200)
It has to happen after descriptor uploads since otherwise we'll print out
the wrong GPU list / incorrectly claim descriptor corruption.

Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/drivers/radeonsi/si_compute.c
src/gallium/drivers/radeonsi/si_state_draw.c

index 3987eecca8e9984f27198ace002745c94e476b33..0a9d4f787d4fd1758b7c5af7663ce4fff4c388f3 100644 (file)
@@ -806,9 +806,6 @@ static void si_launch_grid(
 
        si_need_cs_space(sctx);
 
-       if (sctx->b.log)
-               si_log_compute_state(sctx, sctx->b.log);
-
        if (!sctx->cs_shader_state.initialized)
                si_initialize_compute(sctx);
 
@@ -851,8 +848,10 @@ static void si_launch_grid(
 
        si_emit_dispatch_packets(sctx, info);
 
-       if (unlikely(sctx->current_saved_cs))
+       if (unlikely(sctx->current_saved_cs)) {
                si_trace_emit(sctx);
+               si_log_compute_state(sctx, sctx->b.log);
+       }
 
        sctx->compute_is_busy = true;
        sctx->b.num_compute_calls++;
index 897c86b05447a6a1208596318660f74ca2c1bc75..0a672c503fd2f7342ab4e33c42455bc08b7526f8 100644 (file)
@@ -1376,9 +1376,6 @@ void si_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *info)
 
        si_need_cs_space(sctx);
 
-       if (unlikely(sctx->b.log))
-               si_log_draw_state(sctx, sctx->b.log);
-
        /* Since we've called r600_context_add_resource_size for vertex buffers,
         * this must be called after si_need_cs_space, because we must let
         * need_cs_space flush before we add buffers to the buffer list.
@@ -1454,8 +1451,10 @@ void si_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *info)
                si_emit_draw_packets(sctx, info, indexbuf, index_size, index_offset);
        }
 
-       if (unlikely(sctx->current_saved_cs))
+       if (unlikely(sctx->current_saved_cs)) {
                si_trace_emit(sctx);
+               si_log_draw_state(sctx, sctx->b.log);
+       }
 
        /* Workaround for a VGT hang when streamout is enabled.
         * It must be done after drawing. */