ac/nir_to_llvm: fix b2f for f64
authorTimothy Arceri <tarceri@itsqueeze.com>
Fri, 2 Nov 2018 02:33:52 +0000 (13:33 +1100)
committerTimothy Arceri <tarceri@itsqueeze.com>
Wed, 7 Nov 2018 05:35:07 +0000 (16:35 +1100)
Fixes: d7e0d47b9de3 ("nir: Add a bunch of b2[if] optimizations")
Reviewed-by: Dave Airlie <airlied@redhat.com>
src/amd/common/ac_nir_to_llvm.c

index e5fbe003f53c3d7800573125a8f3a07d9792a2c1..c950b81dca2b3c44ecef90975f1c74ef93fac21c 100644 (file)
@@ -311,9 +311,18 @@ static LLVMValueRef emit_uint_carry(struct ac_llvm_context *ctx,
 }
 
 static LLVMValueRef emit_b2f(struct ac_llvm_context *ctx,
-                            LLVMValueRef src0)
+                            LLVMValueRef src0,
+                            unsigned bitsize)
 {
-       return LLVMBuildAnd(ctx->builder, src0, LLVMBuildBitCast(ctx->builder, LLVMConstReal(ctx->f32, 1.0), ctx->i32, ""), "");
+       LLVMValueRef result = LLVMBuildAnd(ctx->builder, src0,
+                                          LLVMBuildBitCast(ctx->builder, LLVMConstReal(ctx->f32, 1.0), ctx->i32, ""),
+                                          "");
+       result = LLVMBuildBitCast(ctx->builder, result, ctx->f32, "");
+
+       if (bitsize == 32)
+               return result;
+
+       return LLVMBuildFPExt(ctx->builder, result, ctx->f64, "");
 }
 
 static LLVMValueRef emit_f2b(struct ac_llvm_context *ctx,
@@ -932,7 +941,7 @@ static void visit_alu(struct ac_nir_context *ctx, const nir_alu_instr *instr)
                result = emit_uint_carry(&ctx->ac, "llvm.usub.with.overflow.i32", src[0], src[1]);
                break;
        case nir_op_b2f:
-               result = emit_b2f(&ctx->ac, src[0]);
+               result = emit_b2f(&ctx->ac, src[0], instr->dest.dest.ssa.bit_size);
                break;
        case nir_op_f2b:
                result = emit_f2b(&ctx->ac, src[0]);