r600g,radeonsi: share some of gfx flush code
authorMarek Olšák <marek.olsak@amd.com>
Sat, 12 Apr 2014 16:12:11 +0000 (18:12 +0200)
committerMarek Olšák <marek.olsak@amd.com>
Wed, 16 Apr 2014 12:02:52 +0000 (14:02 +0200)
Reviewed-by: Christian König <christian.koenig@amd.com>
src/gallium/drivers/r600/r600_hw_context.c
src/gallium/drivers/radeon/r600_pipe_common.c
src/gallium/drivers/radeon/r600_pipe_common.h
src/gallium/drivers/radeonsi/si_hw_context.c

index 6d3f799270885cafe1f9263bcd420474b5832a7c..a860519d911b390156c88ce8ee97ad7f5945e274 100644 (file)
@@ -236,35 +236,12 @@ void r600_context_gfx_flush(void *context, unsigned flags,
        struct r600_context *ctx = context;
        struct radeon_winsys_cs *cs = ctx->b.rings.gfx.cs;
 
-       if (ctx->b.rings.gfx.cs->cdw == ctx->b.initial_gfx_cs_size)
+       if (cs->cdw == ctx->b.initial_gfx_cs_size)
                return;
 
        ctx->b.rings.gfx.flushing = true;
 
-       /* Disable render condition. */
-       ctx->b.saved_render_cond = NULL;
-       ctx->b.saved_render_cond_cond = FALSE;
-       ctx->b.saved_render_cond_mode = 0;
-       if (ctx->b.current_render_cond) {
-               ctx->b.saved_render_cond = ctx->b.current_render_cond;
-               ctx->b.saved_render_cond_cond = ctx->b.current_render_cond_cond;
-               ctx->b.saved_render_cond_mode = ctx->b.current_render_cond_mode;
-               ctx->b.b.render_condition(&ctx->b.b, NULL, FALSE, 0);
-       }
-
-       ctx->b.nontimer_queries_suspended = false;
-       ctx->b.streamout.suspended = false;
-
-       /* suspend queries */
-       if (ctx->b.num_cs_dw_nontimer_queries_suspend) {
-               r600_suspend_nontimer_queries(&ctx->b);
-               ctx->b.nontimer_queries_suspended = true;
-       }
-
-       if (ctx->b.streamout.begin_emitted) {
-               r600_emit_streamout_end(&ctx->b);
-               ctx->b.streamout.suspended = true;
-       }
+       r600_preflush_suspend_features(&ctx->b);
 
        /* flush the framebuffer cache */
        ctx->b.flags |= R600_CONTEXT_FLUSH_AND_INV |
@@ -362,22 +339,7 @@ void r600_begin_new_cs(struct r600_context *ctx)
                r600_sampler_states_dirty(ctx, &samplers->states);
        }
 
-       if (ctx->b.streamout.suspended) {
-               ctx->b.streamout.append_bitmask = ctx->b.streamout.enabled_mask;
-               r600_streamout_buffers_dirty(&ctx->b);
-       }
-
-       /* resume queries */
-       if (ctx->b.nontimer_queries_suspended) {
-               r600_resume_nontimer_queries(&ctx->b);
-       }
-
-       /* Re-enable render condition. */
-       if (ctx->b.saved_render_cond) {
-               ctx->b.b.render_condition(&ctx->b.b, ctx->b.saved_render_cond,
-                                         ctx->b.saved_render_cond_cond,
-                                         ctx->b.saved_render_cond_mode);
-       }
+       r600_postflush_resume_features(&ctx->b);
 
        /* Re-emit the draw state. */
        ctx->last_primitive_type = -1;
index 3a0d9811ce66eb0b293a4aa2a106714ad6718697..750886532f219ff403fbd9fd690d9b8f3c18c32b 100644 (file)
@@ -53,6 +53,53 @@ static void r600_memory_barrier(struct pipe_context *ctx, unsigned flags)
 {
 }
 
+void r600_preflush_suspend_features(struct r600_common_context *ctx)
+{
+       /* Disable render condition. */
+       ctx->saved_render_cond = NULL;
+       ctx->saved_render_cond_cond = FALSE;
+       ctx->saved_render_cond_mode = 0;
+       if (ctx->current_render_cond) {
+               ctx->saved_render_cond = ctx->current_render_cond;
+               ctx->saved_render_cond_cond = ctx->current_render_cond_cond;
+               ctx->saved_render_cond_mode = ctx->current_render_cond_mode;
+               ctx->b.render_condition(&ctx->b, NULL, FALSE, 0);
+       }
+
+       /* suspend queries */
+       ctx->nontimer_queries_suspended = false;
+       if (ctx->num_cs_dw_nontimer_queries_suspend) {
+               r600_suspend_nontimer_queries(ctx);
+               ctx->nontimer_queries_suspended = true;
+       }
+
+       ctx->streamout.suspended = false;
+       if (ctx->streamout.begin_emitted) {
+               r600_emit_streamout_end(ctx);
+               ctx->streamout.suspended = true;
+       }
+}
+
+void r600_postflush_resume_features(struct r600_common_context *ctx)
+{
+       if (ctx->streamout.suspended) {
+               ctx->streamout.append_bitmask = ctx->streamout.enabled_mask;
+               r600_streamout_buffers_dirty(ctx);
+       }
+
+       /* resume queries */
+       if (ctx->nontimer_queries_suspended) {
+               r600_resume_nontimer_queries(ctx);
+       }
+
+       /* Re-enable render condition. */
+       if (ctx->saved_render_cond) {
+               ctx->b.render_condition(&ctx->b, ctx->saved_render_cond,
+                                         ctx->saved_render_cond_cond,
+                                         ctx->saved_render_cond_mode);
+       }
+}
+
 static void r600_flush_from_st(struct pipe_context *ctx,
                               struct pipe_fence_handle **fence,
                               unsigned flags)
index a87efdcbdae98dc6a66d1cede80f04b580d4fa18..ada124f93edada0b15318feae537c37cd5656e65 100644 (file)
@@ -407,6 +407,8 @@ struct pipe_resource *r600_buffer_create(struct pipe_screen *screen,
 bool r600_common_screen_init(struct r600_common_screen *rscreen,
                             struct radeon_winsys *ws);
 void r600_destroy_common_screen(struct r600_common_screen *rscreen);
+void r600_preflush_suspend_features(struct r600_common_context *ctx);
+void r600_postflush_resume_features(struct r600_common_context *ctx);
 bool r600_common_context_init(struct r600_common_context *rctx,
                              struct r600_common_screen *rscreen);
 void r600_common_context_cleanup(struct r600_common_context *rctx);
index 37ca290291f490313a2ed965b4424fb7f1ad642d..185041e959848414ce6b3e37e105fa6c528d302f 100644 (file)
@@ -88,30 +88,7 @@ void si_context_gfx_flush(void *context, unsigned flags,
 
        ctx->b.rings.gfx.flushing = true;
 
-       /* Disable render condition. */
-       ctx->b.saved_render_cond = NULL;
-       ctx->b.saved_render_cond_cond = FALSE;
-       ctx->b.saved_render_cond_mode = 0;
-       if (ctx->b.current_render_cond) {
-               ctx->b.saved_render_cond = ctx->b.current_render_cond;
-               ctx->b.saved_render_cond_cond = ctx->b.current_render_cond_cond;
-               ctx->b.saved_render_cond_mode = ctx->b.current_render_cond_mode;
-               ctx->b.b.render_condition(&ctx->b.b, NULL, FALSE, 0);
-       }
-
-       /* suspend queries */
-       ctx->b.nontimer_queries_suspended = false;
-       if (ctx->b.num_cs_dw_nontimer_queries_suspend) {
-               r600_suspend_nontimer_queries(&ctx->b);
-               ctx->b.nontimer_queries_suspended = true;
-       }
-
-       ctx->b.streamout.suspended = false;
-
-       if (ctx->b.streamout.begin_emitted) {
-               r600_emit_streamout_end(&ctx->b);
-               ctx->b.streamout.suspended = true;
-       }
+       r600_preflush_suspend_features(&ctx->b);
 
        ctx->b.flags |= R600_CONTEXT_FLUSH_AND_INV_CB |
                        R600_CONTEXT_FLUSH_AND_INV_CB_META |
@@ -182,27 +159,12 @@ void si_begin_new_cs(struct si_context *ctx)
        si_pm4_emit(ctx, ctx->queued.named.init);
        ctx->emitted.named.init = ctx->queued.named.init;
 
-       if (ctx->b.streamout.suspended) {
-               ctx->b.streamout.append_bitmask = ctx->b.streamout.enabled_mask;
-               r600_streamout_buffers_dirty(&ctx->b);
-       }
-
-       /* resume queries */
-       if (ctx->b.nontimer_queries_suspended) {
-               r600_resume_nontimer_queries(&ctx->b);
-       }
-
-       /* Re-enable render condition. */
-       if (ctx->b.saved_render_cond) {
-               ctx->b.b.render_condition(&ctx->b.b, ctx->b.saved_render_cond,
-                                         ctx->b.saved_render_cond_cond,
-                                         ctx->b.saved_render_cond_mode);
-       }
-
        ctx->framebuffer.atom.dirty = true;
        ctx->b.streamout.enable_atom.dirty = true;
        si_all_descriptors_begin_new_cs(ctx);
 
+       r600_postflush_resume_features(&ctx->b);
+
        ctx->b.initial_gfx_cs_size = ctx->b.rings.gfx.cs->cdw;
 }