gallium/radeon: move GFX/DMA flushing from add_to_buffer_list to need_cs_space
authorMarek Olšák <marek.olsak@amd.com>
Sat, 7 Nov 2015 12:31:03 +0000 (13:31 +0100)
committerMarek Olšák <marek.olsak@amd.com>
Fri, 13 Nov 2015 18:54:41 +0000 (19:54 +0100)
need_cs_space isn't invoked so often and is called before all commands too.
This is a lot cleaner. The code in radeon_add_to_buffer_list always seemed
dodgy to me.

Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
src/gallium/drivers/r600/r600_hw_context.c
src/gallium/drivers/radeon/r600_cs.h
src/gallium/drivers/radeon/r600_pipe_common.c
src/gallium/drivers/radeonsi/si_hw_context.c

index 6f11366e6069e84793d9501ca64f1b2f894d5f08..cf8a07f5a1a7837b6a1609dcff438898a169de75 100644 (file)
 void r600_need_cs_space(struct r600_context *ctx, unsigned num_dw,
                        boolean count_draw_in)
 {
+       struct radeon_winsys_cs *dma = ctx->b.rings.dma.cs;
+
+       /* Flush the DMA IB if it's not empty. */
+       if (dma && dma->cdw)
+               ctx->b.rings.dma.flush(ctx, RADEON_FLUSH_ASYNC, NULL);
 
        if (!ctx->b.ws->cs_memory_below_limit(ctx->b.rings.gfx.cs, ctx->b.vram, ctx->b.gtt)) {
                ctx->b.gtt = 0;
index b5a1dafb2730a9fbd9c69dd10c667f3341c404ce..ad067ce4e76dff5b6841fa03b6a36b7a5aefda60 100644 (file)
@@ -50,21 +50,6 @@ static inline unsigned radeon_add_to_buffer_list(struct r600_common_context *rct
                                                 enum radeon_bo_priority priority)
 {
        assert(usage);
-
-       /* Make sure that all previous rings are flushed so that everything
-        * looks serialized from the driver point of view.
-        */
-       if (!ring->flushing) {
-               if (ring == &rctx->rings.gfx) {
-                       if (rctx->rings.dma.cs) {
-                               /* flush dma ring */
-                               rctx->rings.dma.flush(rctx, RADEON_FLUSH_ASYNC, NULL);
-                       }
-               } else {
-                       /* flush gfx ring */
-                       rctx->rings.gfx.flush(rctx, RADEON_FLUSH_ASYNC, NULL);
-               }
-       }
        return rctx->ws->cs_add_buffer(ring->cs, rbo->cs_buf, usage,
                                      rbo->domains, priority) * 4;
 }
index 79e624ea12b34f693c2cb230660718f30c58f0d9..e7179dc0a463b20f0e865fdea27a4d319795c0e2 100644 (file)
@@ -117,6 +117,10 @@ void r600_draw_rectangle(struct blitter_context *blitter,
 
 void r600_need_dma_space(struct r600_common_context *ctx, unsigned num_dw)
 {
+       /* Flush the GFX IB if it's not empty. */
+       if (ctx->rings.gfx.cs->cdw > ctx->initial_gfx_cs_size)
+               ctx->rings.gfx.flush(ctx, RADEON_FLUSH_ASYNC, NULL);
+
        /* Flush if there's not enough space. */
        if ((num_dw + ctx->rings.dma.cs->cdw) > ctx->rings.dma.cs->max_dw) {
                ctx->rings.dma.flush(ctx, RADEON_FLUSH_ASYNC, NULL);
index 9b8bdf5d901260fce103272de6f7b1ac93f361fb..7d0e6d4dd45eb93e29e1640e9889197de8a909c5 100644 (file)
 void si_need_cs_space(struct si_context *ctx)
 {
        struct radeon_winsys_cs *cs = ctx->b.rings.gfx.cs;
+       struct radeon_winsys_cs *dma = ctx->b.rings.dma.cs;
+
+       /* Flush the DMA IB if it's not empty. */
+       if (dma && dma->cdw)
+               ctx->b.rings.dma.flush(ctx, RADEON_FLUSH_ASYNC, NULL);
 
        /* There are two memory usage counters in the winsys for all buffers
         * that have been added (cs_add_buffer) and two counters in the pipe