Mesa (master): radeonsi: simplify DCC handling in si_initialize_color_surface

Marek Olšák mareko at kemper.freedesktop.org
Tue Oct 27 09:49:46 UTC 2015


Module: Mesa
Branch: master
Commit: 5bc5dca0cbcb1a13fbe9b3a33489e88531d1eb33
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=5bc5dca0cbcb1a13fbe9b3a33489e88531d1eb33

Author: Marek Olšák <marek.olsak at amd.com>
Date:   Thu Oct 22 11:10:14 2015 +0200

radeonsi: simplify DCC handling in si_initialize_color_surface

Reviewed-by: Nicolai Hähnle <nicolai.haehnle at amd.com>

---

 src/gallium/drivers/radeonsi/si_state.c |   10 +++-------
 1 file changed, 3 insertions(+), 7 deletions(-)

diff --git a/src/gallium/drivers/radeonsi/si_state.c b/src/gallium/drivers/radeonsi/si_state.c
index 384c8e2..c87f661 100644
--- a/src/gallium/drivers/radeonsi/si_state.c
+++ b/src/gallium/drivers/radeonsi/si_state.c
@@ -1926,8 +1926,9 @@ static void si_initialize_color_surface(struct si_context *sctx,
 	surf->cb_color_info = color_info;
 	surf->cb_color_attrib = color_attrib;
 
-	if (sctx->b.chip_class >= VI) {
+	if (sctx->b.chip_class >= VI && rtex->surface.dcc_enabled) {
 		unsigned max_uncompressed_block_size = 2;
+		uint64_t dcc_offset = rtex->surface.level[level].dcc_offset;
 
 		if (rtex->surface.nsamples > 1) {
 			if (rtex->surface.bpe == 1)
@@ -1938,12 +1939,7 @@ static void si_initialize_color_surface(struct si_context *sctx,
 
 		surf->cb_dcc_control = S_028C78_MAX_UNCOMPRESSED_BLOCK_SIZE(max_uncompressed_block_size) |
 		                       S_028C78_INDEPENDENT_64B_BLOCKS(1);
-
-		if (rtex->surface.dcc_enabled) {
-			uint64_t dcc_offset = rtex->surface.level[level].dcc_offset;
-
-			surf->cb_dcc_base = (rtex->dcc_buffer->gpu_address + dcc_offset) >> 8;
-		}
+		surf->cb_dcc_base = (rtex->dcc_buffer->gpu_address + dcc_offset) >> 8;
 	}
 
 	if (rtex->fmask.size) {




More information about the mesa-commit mailing list