Revert "r600g: rework rasterizer discard for evergreen"
authorMarek Olšák <maraeo@gmail.com>
Thu, 8 Mar 2012 10:14:53 +0000 (11:14 +0100)
committerMarek Olšák <maraeo@gmail.com>
Thu, 8 Mar 2012 10:23:24 +0000 (11:23 +0100)
I will use SX_MISC instead.

This reverts commit 734792e83fdc526623d8fe0a60479648c936bd53.

Conflicts:

src/gallium/drivers/r600/evergreen_hw_context.c
src/gallium/drivers/r600/evergreen_state.c
src/gallium/drivers/r600/r600_hw_context.c
src/gallium/drivers/r600/r600_pipe.h

src/gallium/drivers/r600/evergreen_hw_context.c
src/gallium/drivers/r600/evergreen_state.c
src/gallium/drivers/r600/r600_hw_context.c
src/gallium/drivers/r600/r600_pipe.h
src/gallium/drivers/r600/r600_state_common.c

index aba265ba0b40a18c000a806c89f38d51af54e9db..a05f3f3b1e727952400aa5128b3e606986f56b8f 100644 (file)
@@ -828,16 +828,18 @@ void evergreen_flush_vgt_streamout(struct r600_context *ctx)
 void evergreen_set_streamout_enable(struct r600_context *ctx, unsigned buffer_enable_bit)
 {
        struct radeon_winsys_cs *cs = ctx->cs;
-       bool enable = buffer_enable_bit != 0;
-
-       if (enable != ctx->eg_streamout_state.stream0_enable) {
-               ctx->eg_streamout_state.stream0_enable = enable;
-               r600_emit_atom(ctx, &ctx->eg_streamout_state.atom);
-       }
 
        if (buffer_enable_bit) {
+               cs->buf[cs->cdw++] = PKT3(PKT3_SET_CONTEXT_REG, 1, 0);
+               cs->buf[cs->cdw++] = (R_028B94_VGT_STRMOUT_CONFIG - EVERGREEN_CONTEXT_REG_OFFSET) >> 2;
+               cs->buf[cs->cdw++] = S_028B94_STREAMOUT_0_EN(1);
+
                cs->buf[cs->cdw++] = PKT3(PKT3_SET_CONTEXT_REG, 1, 0);
                cs->buf[cs->cdw++] = (R_028B98_VGT_STRMOUT_BUFFER_CONFIG - EVERGREEN_CONTEXT_REG_OFFSET) >> 2;
                cs->buf[cs->cdw++] = S_028B98_STREAM_0_BUFFER_EN(buffer_enable_bit);
+       } else {
+               cs->buf[cs->cdw++] = PKT3(PKT3_SET_CONTEXT_REG, 1, 0);
+               cs->buf[cs->cdw++] = (R_028B94_VGT_STRMOUT_CONFIG - EVERGREEN_CONTEXT_REG_OFFSET) >> 2;
+               cs->buf[cs->cdw++] = S_028B94_STREAMOUT_0_EN(0);
        }
 }
index c8c45365ad7a1ecfebded7f1962a5707e7ee55b2..d4f908e307117125bd90fbb9b1c69178d5946321 100644 (file)
@@ -825,7 +825,6 @@ static void *evergreen_create_rs_state(struct pipe_context *ctx,
                prov_vtx = 0;
 
        rstate = &rs->rstate;
-       rs->rasterizer_discard = state->rasterizer_discard;
        rs->flatshade = state->flatshade;
        rs->sprite_coord_enable = state->sprite_coord_enable;
        rs->two_side = state->light_twoside;
@@ -894,8 +893,8 @@ static void *evergreen_create_rs_state(struct pipe_context *ctx,
        r600_pipe_state_add_reg(rstate, R_028B7C_PA_SU_POLY_OFFSET_CLAMP, fui(state->offset_clamp), NULL, 0);
        r600_pipe_state_add_reg(rstate, R_028814_PA_SU_SC_MODE_CNTL,
                                S_028814_PROVOKING_VTX_LAST(prov_vtx) |
-                               S_028814_CULL_FRONT(state->cull_face & PIPE_FACE_FRONT ? 1 : 0) |
-                               S_028814_CULL_BACK(state->cull_face & PIPE_FACE_BACK ? 1 : 0) |
+                               S_028814_CULL_FRONT(state->rasterizer_discard || (state->cull_face & PIPE_FACE_FRONT) ? 1 : 0) |
+                               S_028814_CULL_BACK(state->rasterizer_discard || (state->cull_face & PIPE_FACE_BACK) ? 1 : 0) |
                                S_028814_FACE(!state->front_ccw) |
                                S_028814_POLY_OFFSET_FRONT_ENABLE(state->offset_tri) |
                                S_028814_POLY_OFFSET_BACK_ENABLE(state->offset_tri) |
@@ -907,16 +906,6 @@ static void *evergreen_create_rs_state(struct pipe_context *ctx,
        return rstate;
 }
 
-void evergreen_set_rasterizer_discard(struct pipe_context *ctx, boolean discard)
-{
-       struct r600_context *rctx = (struct r600_context*)ctx;
-
-       if (discard != rctx->eg_streamout_state.rasterizer_discard) {
-               rctx->eg_streamout_state.rasterizer_discard = discard;
-               r600_atom_dirty(rctx, &rctx->eg_streamout_state.atom);
-       }
-}
-
 static void *evergreen_create_sampler_state(struct pipe_context *ctx,
                                        const struct pipe_sampler_state *state)
 {
@@ -1731,22 +1720,10 @@ static void evergreen_emit_db_misc_state(struct r600_context *rctx, struct r600_
        r600_write_context_reg(cs, R_02800C_DB_RENDER_OVERRIDE, db_render_override);
 }
 
-static void evergreen_emit_streamout_config(struct r600_context *rctx, struct r600_atom *atom)
-{
-       struct radeon_winsys_cs *cs = rctx->cs;
-       struct r600_eg_streamout_state *a = (struct r600_eg_streamout_state*)atom;
-
-       r600_write_context_reg(cs, R_028B94_VGT_STRMOUT_CONFIG,
-                              S_028B94_STREAMOUT_0_EN(a->stream0_enable) |
-                              S_028B94_RAST_STREAM(a->rasterizer_discard ? 4 : 0));
-}
-
 void evergreen_init_state_functions(struct r600_context *rctx)
 {
        r600_init_atom(&rctx->db_misc_state.atom, evergreen_emit_db_misc_state, 6, 0);
        r600_atom_dirty(rctx, &rctx->db_misc_state.atom);
-       r600_init_atom(&rctx->eg_streamout_state.atom, evergreen_emit_streamout_config, 6, 0);
-       r600_atom_dirty(rctx, &rctx->eg_streamout_state.atom);
 
        rctx->context.create_blend_state = evergreen_create_blend_state;
        rctx->context.create_depth_stencil_alpha_state = evergreen_create_dsa_state;
@@ -1831,7 +1808,9 @@ static void cayman_init_atom_start_cs(struct r600_context *rctx)
        r600_store_value(cb, 0); /* R_028A3C_VGT_GROUP_VECT_1_FMT_CNTL */
        r600_store_value(cb, 0); /* R_028A40_VGT_GS_MODE */
 
-       r600_store_context_reg(cb, R_028B98_VGT_STRMOUT_BUFFER_CONFIG, 0);
+       r600_store_context_reg_seq(cb, R_028B94_VGT_STRMOUT_CONFIG, 2);
+       r600_store_value(cb, 0); /* R_028B94_VGT_STRMOUT_CONFIG */
+       r600_store_value(cb, 0); /* R_028B98_VGT_STRMOUT_BUFFER_CONFIG */
 
        r600_store_context_reg_seq(cb, R_028AB4_VGT_REUSE_OFF, 2);
        r600_store_value(cb, 0); /* R_028AB4_VGT_REUSE_OFF */
@@ -2327,7 +2306,9 @@ void evergreen_init_atom_start_cs(struct r600_context *rctx)
        r600_store_value(cb, 0); /* R_028A3C_VGT_GROUP_VECT_1_FMT_CNTL */
        r600_store_value(cb, 0); /* R_028A40_VGT_GS_MODE */
 
-       r600_store_context_reg(cb, R_028B98_VGT_STRMOUT_BUFFER_CONFIG, 0);
+       r600_store_context_reg_seq(cb, R_028B94_VGT_STRMOUT_CONFIG, 2);
+       r600_store_value(cb, 0); /* R_028B94_VGT_STRMOUT_CONFIG */
+       r600_store_value(cb, 0); /* R_028B98_VGT_STRMOUT_BUFFER_CONFIG */
 
        r600_store_context_reg_seq(cb, R_028AB4_VGT_REUSE_OFF, 2);
        r600_store_value(cb, 0); /* R_028AB4_VGT_REUSE_OFF */
index 927a5ba9454e04c9d760cf7b4310a6c6cf4eadb1..41cf1b421319f870b29c5452d9d6e2eb4a36398d 100644 (file)
@@ -1249,8 +1249,6 @@ void r600_context_flush(struct r600_context *ctx, unsigned flags)
 
        r600_emit_atom(ctx, &ctx->start_cs_cmd.atom);
        r600_atom_dirty(ctx, &ctx->db_misc_state.atom);
-       if (ctx->chip_class >= EVERGREEN)
-               r600_atom_dirty(ctx, &ctx->eg_streamout_state.atom);
 
        if (streamout_suspended) {
                ctx->streamout_start = TRUE;
index 9965e2811d0f771776327a0759c0d74d1ec3cc8b..c5ea55eba32d253d4875d2fceb577f31643ac95d 100644 (file)
@@ -78,12 +78,6 @@ struct r600_db_misc_state {
        bool flush_depthstencil_enabled;
 };
 
-struct r600_eg_streamout_state {
-       struct r600_atom atom;
-       bool rasterizer_discard;
-       bool stream0_enable;
-};
-
 enum r600_pipe_state_id {
        R600_PIPE_STATE_BLEND = 0,
        R600_PIPE_STATE_BLEND_COLOR,
@@ -151,7 +145,6 @@ struct r600_pipe_rasterizer {
        float                           offset_units;
        float                           offset_scale;
        bool                            scissor_enable;
-       bool                            rasterizer_discard;
 };
 
 struct r600_pipe_blend {
@@ -293,7 +286,6 @@ struct r600_context {
        struct r600_surface_sync_cmd    surface_sync_cmd;
        struct r600_atom                r6xx_flush_and_inv_cmd;
        struct r600_db_misc_state       db_misc_state;
-       struct r600_eg_streamout_state  eg_streamout_state;
 
        /* Below are variables from the old r600_context.
         */
@@ -388,7 +380,6 @@ boolean evergreen_is_format_supported(struct pipe_screen *screen,
                                      enum pipe_texture_target target,
                                      unsigned sample_count,
                                      unsigned usage);
-void evergreen_set_rasterizer_discard(struct pipe_context *ctx, boolean discard);
 
 /* r600_blit.c */
 void r600_init_blit_functions(struct r600_context *rctx);
index 0a159113d391cfad2575e152fba669b8becfc04a..f3b63cfe92cd989af2d76178bf17560feec59a39 100644 (file)
@@ -296,7 +296,6 @@ void r600_bind_rs_state(struct pipe_context *ctx, void *state)
 
        if (rctx->chip_class >= EVERGREEN) {
                evergreen_polygon_offset_update(rctx);
-               evergreen_set_rasterizer_discard(ctx, rs->rasterizer_discard);
        } else {
                r600_polygon_offset_update(rctx);
        }