radeonsi: split sample locations into its own state atom
authorMarek Olšák <marek.olsak@amd.com>
Sun, 15 Mar 2015 16:54:29 +0000 (17:54 +0100)
committerMarek Olšák <marek.olsak@amd.com>
Mon, 16 Mar 2015 11:54:18 +0000 (12:54 +0100)
Sample locations are not updated as often as framebuffers.

Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
src/gallium/drivers/radeonsi/si_hw_context.c
src/gallium/drivers/radeonsi/si_pipe.c
src/gallium/drivers/radeonsi/si_pipe.h
src/gallium/drivers/radeonsi/si_state.c
src/gallium/drivers/radeonsi/si_state.h

index 1cacc2660c3194d657f32d6a736ca68096cb6783..30bf41f23160849ff4fa65404659cfb341567092 100644 (file)
@@ -145,6 +145,7 @@ void si_begin_new_cs(struct si_context *ctx)
 
        ctx->clip_regs.dirty = true;
        ctx->framebuffer.atom.dirty = true;
+       ctx->msaa_sample_locs.dirty = true;
        ctx->msaa_config.dirty = true;
        ctx->db_render_state.dirty = true;
        ctx->b.streamout.enable_atom.dirty = true;
index 993b153d1f48f55ffe18f2eee79a94ffb10a8cb5..8b4246cfeff096f2f081f0692e5437bf0d45f086 100644 (file)
@@ -112,6 +112,9 @@ static struct pipe_context *si_create_context(struct pipe_screen *screen, void *
        sctx->cache_flush = si_atom_cache_flush;
        sctx->atoms.s.cache_flush = &sctx->cache_flush;
 
+       sctx->msaa_sample_locs = si_atom_msaa_sample_locs;
+       sctx->atoms.s.msaa_sample_locs = &sctx->msaa_sample_locs;
+
        sctx->msaa_config = si_atom_msaa_config;
        sctx->atoms.s.msaa_config = &sctx->msaa_config;
 
index 059fe0dc99beb55539efa0ebc068af53c7c50713..1496d5fedd7f516e0e1cb251c2ce8af9fc1b95b0 100644 (file)
@@ -151,6 +151,7 @@ struct si_context {
                        struct r600_atom *streamout_begin;
                        struct r600_atom *streamout_enable; /* must be after streamout_begin */
                        struct r600_atom *framebuffer;
+                       struct r600_atom *msaa_sample_locs;
                        struct r600_atom *db_render_state;
                        struct r600_atom *msaa_config;
                        struct r600_atom *clip_regs;
@@ -181,6 +182,7 @@ struct si_context {
        unsigned                        border_color_offset;
 
        struct r600_atom                clip_regs;
+       struct r600_atom                msaa_sample_locs;
        struct r600_atom                msaa_config;
        int                             ps_iter_samples;
 
index b20042ce8318f6f5cd2ff78f20ae2ad92f83abd3..f844fc192013b70ac767f69b3a58e0acbe1f805f 100644 (file)
@@ -2093,6 +2093,8 @@ static void si_set_framebuffer_state(struct pipe_context *ctx,
                constbuf.buffer_size = sctx->framebuffer.nr_samples * 2 * 4;
                ctx->set_constant_buffer(ctx, PIPE_SHADER_FRAGMENT,
                                         SI_DRIVER_STATE_CONST_BUF, &constbuf);
+
+               sctx->msaa_sample_locs.dirty = true;
        }
 }
 
@@ -2196,10 +2198,19 @@ static void si_emit_framebuffer_state(struct si_context *sctx, struct r600_atom
         /* PA_SC_WINDOW_SCISSOR_TL is set in si_init_config() */
        r600_write_context_reg(cs, R_028208_PA_SC_WINDOW_SCISSOR_BR,
                               S_028208_BR_X(state->width) | S_028208_BR_Y(state->height));
+}
+
+static void si_emit_msaa_sample_locs(struct r600_common_context *rctx,
+                                    struct r600_atom *atom)
+{
+       struct si_context *sctx = (struct si_context *)rctx;
+       struct radeon_winsys_cs *cs = sctx->b.rings.gfx.cs;
 
        cayman_emit_msaa_sample_locs(cs, sctx->framebuffer.nr_samples);
 }
 
+const struct r600_atom si_atom_msaa_sample_locs = { si_emit_msaa_sample_locs, 18 }; /* number of CS dwords */
+
 static void si_emit_msaa_config(struct r600_common_context *rctx, struct r600_atom *atom)
 {
        struct si_context *sctx = (struct si_context *)rctx;
index d1ed53065ca13d27ee3be1fcac92c452e199cef8..4e6b1e27c46c06e06fb5fe713f7b6598a4eca6d3 100644 (file)
@@ -269,6 +269,7 @@ void si_init_shader_functions(struct si_context *sctx);
 
 /* si_state_draw.c */
 extern const struct r600_atom si_atom_cache_flush;
+extern const struct r600_atom si_atom_msaa_sample_locs;
 extern const struct r600_atom si_atom_msaa_config;
 void si_emit_cache_flush(struct r600_common_context *sctx, struct r600_atom *atom);
 void si_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *dinfo);