summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarek Olšák <marek.olsak@amd.com>2021-01-09 07:59:11 -0500
committerMarge Bot <eric+marge@anholt.net>2021-01-22 16:45:30 +0000
commit488cd3b93fc894689544b0c9b6436b88adc3559a (patch)
treeb24f9dc242508905b0c3258020785ae816b42a53
parenta0978fffb849264ccb20e6b4905b9cf05ed17593 (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.h5
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) \