radeonsi: remove si_context::{scissor_enabled,clip_halfz}
authorNicolai Hähnle <nicolai.haehnle@amd.com>
Tue, 26 Sep 2017 16:10:58 +0000 (18:10 +0200)
committerNicolai Hähnle <nicolai.haehnle@amd.com>
Mon, 2 Oct 2017 13:07:45 +0000 (15:07 +0200)
They are just copies of the rasterizer state.

Reviewed-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/drivers/radeonsi/si_pipe.h
src/gallium/drivers/radeonsi/si_state.c
src/gallium/drivers/radeonsi/si_state_viewport.c

index 4fe158fb9af280ad8a4989875608e9cb312a23fc..ed88aa0521beec1160823d57d0a87f739bf9b304 100644 (file)
@@ -462,8 +462,6 @@ struct si_context {
        bool need_check_render_feedback;
        bool                    decompression_enabled;
 
-       bool                    scissor_enabled;
-       bool                    clip_halfz;
        bool                    vs_writes_viewport_index;
        bool                    vs_disables_clipping_viewport;
 
@@ -567,8 +565,6 @@ struct pipe_video_buffer *si_video_buffer_create(struct pipe_context *pipe,
                                                 const struct pipe_video_buffer *tmpl);
 
 /* si_viewport.c */
-void si_viewport_set_rast_deps(struct si_context *rctx,
-                              bool scissor_enable, bool clip_halfz);
 void si_update_vs_writes_viewport_index(struct si_context *ctx);
 void si_init_viewport_functions(struct si_context *ctx);
 
index 2dbe7c6e274f5772b617b9028546a6dfd5950e95..78a3fbd086ef562fcdebfe08eb8819d109b61e15 100644 (file)
@@ -1003,11 +1003,21 @@ static void si_bind_rs_state(struct pipe_context *ctx, void *state)
        sctx->current_vs_state &= C_VS_STATE_CLAMP_VERTEX_COLOR;
        sctx->current_vs_state |= S_VS_STATE_CLAMP_VERTEX_COLOR(rs->clamp_vertex_color);
 
-       si_viewport_set_rast_deps(sctx, rs->scissor_enable, rs->clip_halfz);
-
        si_pm4_bind_state(sctx, rasterizer, rs);
        si_update_poly_offset_state(sctx);
 
+       if (!old_rs ||
+           old_rs->scissor_enable != rs->scissor_enable) {
+               sctx->scissors.dirty_mask = (1 << SI_MAX_VIEWPORTS) - 1;
+               si_mark_atom_dirty(sctx, &sctx->scissors.atom);
+       }
+
+       if (!old_rs ||
+           old_rs->clip_halfz != rs->clip_halfz) {
+               sctx->viewports.depth_range_dirty_mask = (1 << SI_MAX_VIEWPORTS) - 1;
+               si_mark_atom_dirty(sctx, &sctx->viewports.atom);
+       }
+
        if (!old_rs ||
            old_rs->clip_plane_enable != rs->clip_plane_enable ||
            old_rs->pa_cl_clip_cntl != rs->pa_cl_clip_cntl)
index 8e08a61f2f61b2fb1ce1f642b4598fb55a084407..1201be8779e4cf9054085de6435cc6a521ffbb2b 100644 (file)
@@ -40,7 +40,8 @@ static void si_set_scissor_states(struct pipe_context *pctx,
        for (i = 0; i < num_scissors; i++)
                ctx->scissors.states[start_slot + i] = state[i];
 
-       if (!ctx->scissor_enabled)
+       if (!ctx->queued.named.rasterizer ||
+           !ctx->queued.named.rasterizer->scissor_enable)
                return;
 
        ctx->scissors.dirty_mask |= ((1 << num_scissors) - 1) << start_slot;
@@ -214,10 +215,13 @@ static void si_emit_scissors(struct r600_common_context *rctx, struct r600_atom
        struct radeon_winsys_cs *cs = ctx->b.gfx.cs;
        struct pipe_scissor_state *states = ctx->scissors.states;
        unsigned mask = ctx->scissors.dirty_mask;
-       bool scissor_enabled = ctx->scissor_enabled;
+       bool scissor_enabled = false;
        struct si_signed_scissor max_vp_scissor;
        int i;
 
+       if (ctx->queued.named.rasterizer)
+               scissor_enabled = ctx->queued.named.rasterizer->scissor_enable;
+
        /* The simple case: Only 1 viewport is active. */
        if (!ctx->vs_writes_viewport_index) {
                struct si_signed_scissor *vp = &ctx->viewports.as_scissor[0];
@@ -327,14 +331,18 @@ static void si_emit_depth_ranges(struct si_context *ctx)
        struct radeon_winsys_cs *cs = ctx->b.gfx.cs;
        struct pipe_viewport_state *states = ctx->viewports.states;
        unsigned mask = ctx->viewports.depth_range_dirty_mask;
+       bool clip_halfz = false;
        float zmin, zmax;
 
+       if (ctx->queued.named.rasterizer)
+               clip_halfz = ctx->queued.named.rasterizer->clip_halfz;
+
        /* The simple case: Only 1 viewport is active. */
        if (!ctx->vs_writes_viewport_index) {
                if (!(mask & 1))
                        return;
 
-               util_viewport_zmin_zmax(&states[0], ctx->clip_halfz, &zmin, &zmax);
+               util_viewport_zmin_zmax(&states[0], clip_halfz, &zmin, &zmax);
 
                radeon_set_context_reg_seq(cs, R_0282D0_PA_SC_VPORT_ZMIN_0, 2);
                radeon_emit(cs, fui(zmin));
@@ -351,7 +359,7 @@ static void si_emit_depth_ranges(struct si_context *ctx)
                radeon_set_context_reg_seq(cs, R_0282D0_PA_SC_VPORT_ZMIN_0 +
                                           start * 4 * 2, count * 2);
                for (i = start; i < start+count; i++) {
-                       util_viewport_zmin_zmax(&states[i], ctx->clip_halfz, &zmin, &zmax);
+                       util_viewport_zmin_zmax(&states[i], clip_halfz, &zmin, &zmax);
                        radeon_emit(cs, fui(zmin));
                        radeon_emit(cs, fui(zmax));
                }
@@ -367,22 +375,6 @@ static void si_emit_viewport_states(struct r600_common_context *rctx,
        si_emit_depth_ranges(ctx);
 }
 
-/* Set viewport dependencies on pipe_rasterizer_state. */
-void si_viewport_set_rast_deps(struct si_context *ctx,
-                              bool scissor_enable, bool clip_halfz)
-{
-       if (ctx->scissor_enabled != scissor_enable) {
-               ctx->scissor_enabled = scissor_enable;
-               ctx->scissors.dirty_mask = (1 << SI_MAX_VIEWPORTS) - 1;
-               si_mark_atom_dirty(ctx, &ctx->scissors.atom);
-       }
-       if (ctx->clip_halfz != clip_halfz) {
-               ctx->clip_halfz = clip_halfz;
-               ctx->viewports.depth_range_dirty_mask = (1 << SI_MAX_VIEWPORTS) - 1;
-               si_mark_atom_dirty(ctx, &ctx->viewports.atom);
-       }
-}
-
 /**
  * Normally, we only emit 1 viewport and 1 scissor if no shader is using
  * the VIEWPORT_INDEX output, and emitting the other viewports and scissors