radeonsi: fix a regression in si_eliminate_const_output
authorNicolai Hähnle <nicolai.haehnle@amd.com>
Thu, 20 Oct 2016 11:05:40 +0000 (13:05 +0200)
committerNicolai Hähnle <nicolai.haehnle@amd.com>
Fri, 21 Oct 2016 07:59:26 +0000 (09:59 +0200)
A constant value of float type is not necessarily a ConstantFP: it could also
be a constant expression that for some reason hasn't been folded.

This fixes a regression in GL45-CTS.arrays_of_arrays_gl.InteractionFunctionCalls2
that was introduced by commit 3ec9975555d1cc5365413ad9062f412904f944a3.

Reviewed-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/drivers/radeonsi/si_shader.c

index 25449ecaf9446e1b104cde6326ff3e6717089edd..8edd5934234f9786dd3d637dfd9a752fdf6a5f6a 100644 (file)
@@ -6535,14 +6535,12 @@ static bool si_eliminate_const_output(struct si_shader_context *ctx,
        for (i = 0; i < 4; i++) {
                LLVMBool loses_info;
                LLVMValueRef p = LLVMGetOperand(inst, 5 + i);
-               if (!LLVMIsConstant(p))
-                       return false;
 
                /* It's a constant expression. Undef outputs are eliminated too. */
                if (LLVMIsUndef(p)) {
                        is_zero[i] = true;
                        is_one[i] = true;
-               } else {
+               } else if (LLVMIsAConstantFP(p)) {
                        double a = LLVMConstRealGetDouble(p, &loses_info);
 
                        if (a == 0)
@@ -6551,7 +6549,8 @@ static bool si_eliminate_const_output(struct si_shader_context *ctx,
                                is_one[i] = true;
                        else
                                return false; /* other constant */
-               }
+               } else
+                       return false;
        }
 
        /* Only certain combinations of 0 and 1 can be eliminated. */