[Mesa-dev] [PATCH 2/2] radv: always clear the FCE predicate after DCC/FMASK/CMASK decompressions

Samuel Pitoiset samuel.pitoiset at gmail.com
Fri Nov 16 12:40:10 UTC 2018


DCC and FMASK also imply a fast-clear eliminate, so it should be
safe to reset the predicate unconditionally. We still only skip
FMASK or CMASK decompressions for now.

Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
---
 src/amd/vulkan/radv_meta_fast_clear.c | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)

diff --git a/src/amd/vulkan/radv_meta_fast_clear.c b/src/amd/vulkan/radv_meta_fast_clear.c
index 27b82339e4..99f67f74d6 100644
--- a/src/amd/vulkan/radv_meta_fast_clear.c
+++ b/src/amd/vulkan/radv_meta_fast_clear.c
@@ -702,11 +702,6 @@ radv_emit_color_decompress(struct radv_cmd_buffer *cmd_buffer,
 
 		radv_emit_set_predication_state_from_image(cmd_buffer, image, false);
 
-		/* Clear the image's fast-clear eliminate predicate because
-		 * FMASK and DCC also imply a fast-clear eliminate.
-		 */
-		radv_update_fce_metadata(cmd_buffer, image, false);
-
 		if (cmd_buffer->state.predication_type != -1) {
 			/* Restore previous conditional rendering user state. */
 			si_emit_set_predication_state(cmd_buffer,
@@ -714,6 +709,14 @@ radv_emit_color_decompress(struct radv_cmd_buffer *cmd_buffer,
 						      cmd_buffer->state.predication_va);
 		}
 	}
+
+	if (radv_image_has_dcc(image)) {
+		/* Clear the image's fast-clear eliminate predicate because
+		 * FMASK and DCC also imply a fast-clear eliminate.
+		 */
+		radv_update_fce_metadata(cmd_buffer, image, false);
+	}
+
 	radv_meta_restore(&saved_state, cmd_buffer);
 }
 
-- 
2.19.1



More information about the mesa-dev mailing list