diff options
author | Marek Olšák <marek.olsak@amd.com> | 2017-07-27 02:45:00 +0200 |
---|---|---|
committer | Marek Olšák <marek.olsak@amd.com> | 2017-07-28 08:03:24 +0200 |
commit | 28c7fbbe0fbd5c06db523140929f572e9c6e9dbe (patch) | |
tree | e86f7125cfb6590e9c5fe49f944043e1a2077a4c /src/gallium/drivers/radeonsi/si_hw_context.c | |
parent | 7c721b28f6122a75bc4e57f6996569eb442a134e (diff) |
radeonsi: rely on CLEAR_STATE for clearing UCP and blend color registers
Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
Diffstat (limited to 'src/gallium/drivers/radeonsi/si_hw_context.c')
-rw-r--r-- | src/gallium/drivers/radeonsi/si_hw_context.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/src/gallium/drivers/radeonsi/si_hw_context.c b/src/gallium/drivers/radeonsi/si_hw_context.c index cceb827ab25..92d0cc51dd6 100644 --- a/src/gallium/drivers/radeonsi/si_hw_context.c +++ b/src/gallium/drivers/radeonsi/si_hw_context.c @@ -227,7 +227,9 @@ void si_begin_new_cs(struct si_context *ctx) si_mark_atom_dirty(ctx, &ctx->framebuffer.atom); si_mark_atom_dirty(ctx, &ctx->clip_regs); - si_mark_atom_dirty(ctx, &ctx->clip_state.atom); + /* CLEAR_STATE sets zeros. */ + if (ctx->clip_state.any_nonzeros) + si_mark_atom_dirty(ctx, &ctx->clip_state.atom); ctx->msaa_sample_locs.nr_samples = 0; si_mark_atom_dirty(ctx, &ctx->msaa_sample_locs.atom); si_mark_atom_dirty(ctx, &ctx->msaa_config); @@ -235,7 +237,9 @@ void si_begin_new_cs(struct si_context *ctx) if (ctx->sample_mask.sample_mask != 0xffff) si_mark_atom_dirty(ctx, &ctx->sample_mask.atom); si_mark_atom_dirty(ctx, &ctx->cb_render_state); - si_mark_atom_dirty(ctx, &ctx->blend_color.atom); + /* CLEAR_STATE sets zeros. */ + if (ctx->blend_color.any_nonzeros) + si_mark_atom_dirty(ctx, &ctx->blend_color.atom); si_mark_atom_dirty(ctx, &ctx->db_render_state); si_mark_atom_dirty(ctx, &ctx->stencil_ref.atom); si_mark_atom_dirty(ctx, &ctx->spi_map); |