radv: fix dual source blending
authorFredrik Höglund <fredrik@kde.org>
Wed, 7 Dec 2016 18:20:08 +0000 (19:20 +0100)
committerFredrik Höglund <fredrik@kde.org>
Thu, 22 Dec 2016 01:07:17 +0000 (02:07 +0100)
Add the index to the location when assigning driver locations for
output variables.

Otherwise two fragment shader outputs declared as:

   layout (location = 0, index = 0) out vec4 output1;
   layout (location = 0, index = 1) out vec4 output2;

will end up aliasing one another.

Note that this patch will make the second output variable in the above
example alias a possible third output variable with location = 1 and
index = 0. But this shouldn't be a problem in practice since only one
color attachment is supported when dual-source blending is used.

Cc: "13.0" <mesa-stable@lists.freedesktop.org>
Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
src/amd/common/ac_nir_to_llvm.c

index d66fefbe954bebda267a68c03fe8f29845a95dea..90ee917d13b47a1a0a0484baef42c6acee3d6a4e 100644 (file)
@@ -4125,7 +4125,7 @@ static void
 handle_shader_output_decl(struct nir_to_llvm_context *ctx,
                          struct nir_variable *variable)
 {
-       int idx = variable->data.location;
+       int idx = variable->data.location + variable->data.index;
        unsigned attrib_count = glsl_count_attribute_slots(variable->type, false);
 
        variable->data.driver_location = idx * 4;
@@ -4155,7 +4155,7 @@ handle_shader_output_decl(struct nir_to_llvm_context *ctx,
                                       si_build_alloca_undef(ctx, ctx->f32, "");
                }
        }
-       ctx->output_mask |= ((1ull << attrib_count) - 1) << variable->data.location;
+       ctx->output_mask |= ((1ull << attrib_count) - 1) << idx;
 }
 
 static void