diff options
author | Marek Olšák <marek.olsak@amd.com> | 2021-01-09 07:59:11 -0500 |
---|---|---|
committer | Marge Bot <eric+marge@anholt.net> | 2021-01-22 16:45:30 +0000 |
commit | 488cd3b93fc894689544b0c9b6436b88adc3559a (patch) | |
tree | b24f9dc242508905b0c3258020785ae816b42a53 | |
parent | a0978fffb849264ccb20e6b4905b9cf05ed17593 (diff) |
radeonsi: clear dirty_states if si_pm4_bind_state is unbinding or no-op
Reviewed-by: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8653>
-rw-r--r-- | src/gallium/drivers/radeonsi/si_state.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/gallium/drivers/radeonsi/si_state.h b/src/gallium/drivers/radeonsi/si_state.h index a293787487a..a4ce4e77337 100644 --- a/src/gallium/drivers/radeonsi/si_state.h +++ b/src/gallium/drivers/radeonsi/si_state.h @@ -478,7 +478,10 @@ struct si_buffer_resources { #define si_pm4_bind_state(sctx, member, value) \ do { \ (sctx)->queued.named.member = (value); \ - (sctx)->dirty_states |= SI_STATE_BIT(member); \ + if (value && value != (sctx)->emitted.named.member) \ + (sctx)->dirty_states |= SI_STATE_BIT(member); \ + else \ + (sctx)->dirty_states &= ~SI_STATE_BIT(member); \ } while (0) #define si_pm4_delete_state(sctx, member, value) \ |