radeonsi: fix a deadlock due to partially-initialized context on CI
authorMarek Olšák <marek.olsak@amd.com>
Wed, 17 Oct 2018 16:41:38 +0000 (12:41 -0400)
committerMarek Olšák <marek.olsak@amd.com>
Thu, 18 Oct 2018 20:08:56 +0000 (16:08 -0400)
src/gallium/drivers/radeonsi/si_pipe.c

index 9d25748df4071d71251403a08fb4a6a51b0ef6a9..46cf37567f9d3b70debae27d1e1fc3199f53fd46 100644 (file)
@@ -572,12 +572,6 @@ static struct pipe_context *si_create_context(struct pipe_screen *screen,
                                 &sctx->null_const_buf);
                si_set_rw_buffer(sctx, SI_PS_CONST_SAMPLE_POSITIONS,
                                 &sctx->null_const_buf);
-
-               /* Clear the NULL constant buffer, because loads should return zeros. */
-               uint32_t clear_value = 0;
-               si_clear_buffer(sctx, sctx->null_const_buf.buffer, 0,
-                               sctx->null_const_buf.buffer->width0,
-                               &clear_value, 4, SI_COHERENCY_SHADER);
        }
 
        uint64_t max_threads_per_block;
@@ -622,6 +616,14 @@ static struct pipe_context *si_create_context(struct pipe_screen *screen,
 
        /* this must be last */
        si_begin_new_gfx_cs(sctx);
+
+       if (sctx->chip_class == CIK) {
+               /* Clear the NULL constant buffer, because loads should return zeros. */
+               uint32_t clear_value = 0;
+               si_clear_buffer(sctx, sctx->null_const_buf.buffer, 0,
+                               sctx->null_const_buf.buffer->width0,
+                               &clear_value, 4, SI_COHERENCY_SHADER);
+       }
        return &sctx->b;
 fail:
        fprintf(stderr, "radeonsi: Failed to create a context.\n");