summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNicolai Hähnle <[email protected]>2016-04-22 15:28:47 -0500
committerNicolai Hähnle <[email protected]>2016-04-27 11:16:40 -0500
commit01a3bb5d8bcdbcf5b27fadc6299c2d768c5c888a (patch)
tree0d0bea6702623f073737e7c5ce3a4d0e7597a100
parent450ff0f0d5d603bb36ca3fbd9c871c9e8553baab (diff)
radeonsi: move blend choice out of loop in si_blit_decompress_color
It does not depend on the level or layer. Reviewed-by: Marek Olšák <[email protected]>
-rw-r--r--src/gallium/drivers/radeonsi/si_blit.c18
1 files changed, 9 insertions, 9 deletions
diff --git a/src/gallium/drivers/radeonsi/si_blit.c b/src/gallium/drivers/radeonsi/si_blit.c
index 32f953daef6..b87275d8646 100644
--- a/src/gallium/drivers/radeonsi/si_blit.c
+++ b/src/gallium/drivers/radeonsi/si_blit.c
@@ -309,6 +309,7 @@ static void si_blit_decompress_color(struct pipe_context *ctx,
bool need_dcc_decompress)
{
struct si_context *sctx = (struct si_context *)ctx;
+ void* custom_blend;
unsigned layer, checked_last_layer, max_layer;
unsigned level_mask =
u_bit_consecutive(first_level, last_level - first_level + 1);
@@ -318,17 +319,16 @@ static void si_blit_decompress_color(struct pipe_context *ctx,
if (!level_mask)
return;
+ if (rtex->dcc_offset && need_dcc_decompress) {
+ custom_blend = sctx->custom_blend_dcc_decompress;
+ } else if (rtex->fmask.size) {
+ custom_blend = sctx->custom_blend_decompress;
+ } else {
+ custom_blend = sctx->custom_blend_fastclear;
+ }
+
while (level_mask) {
unsigned level = u_bit_scan(&level_mask);
- void* custom_blend;
-
- if (rtex->dcc_offset && need_dcc_decompress) {
- custom_blend = sctx->custom_blend_dcc_decompress;
- } else if (rtex->fmask.size) {
- custom_blend = sctx->custom_blend_decompress;
- } else {
- custom_blend = sctx->custom_blend_fastclear;
- }
/* The smaller the mipmap level, the less layers there are
* as far as 3D textures are concerned. */