On Fri, Jan 12, 2018 at 4:42 PM, Bas Nieuwenhuizen
<b...@basnieuwenhuizen.nl> wrote:
> Maybe just zero-extend the 32-bit value? (or truncate for 16-bit?) I
> don't know what generates better machinecode.

It depends on what result type you want. ZExt and Trunc are
essentially typecasts that change the bit size. LLVM passes might
convert icmp+select into zext automatically, not sure.

Marek

>
> On Fri, Jan 12, 2018 at 2:34 AM, Timothy Arceri <tarc...@itsqueeze.com> wrote:
>> ---
>>
>>  Open to suggestions for better ways to do this.
>>
>>  src/amd/common/ac_nir_to_llvm.c | 13 ++++++++++---
>>  1 file changed, 10 insertions(+), 3 deletions(-)
>>
>> diff --git a/src/amd/common/ac_nir_to_llvm.c 
>> b/src/amd/common/ac_nir_to_llvm.c
>> index b0a8a94a2d..f013b4b387 100644
>> --- a/src/amd/common/ac_nir_to_llvm.c
>> +++ b/src/amd/common/ac_nir_to_llvm.c
>> @@ -1422,9 +1422,16 @@ static LLVMValueRef emit_f2b(struct ac_llvm_context 
>> *ctx,
>>  }
>>
>>  static LLVMValueRef emit_b2i(struct ac_llvm_context *ctx,
>> -                            LLVMValueRef src0)
>> +                            LLVMValueRef src0,
>> +                            unsigned bitsize)
>>  {
>> -       return LLVMBuildAnd(ctx->builder, src0, ctx->i32_1, "");
>> +       LLVMValueRef result = LLVMBuildAnd(ctx->builder, src0, ctx->i32_1, 
>> "");
>> +
>> +       if (bitsize == 32)
>> +               return result;
>> +
>> +       LLVMValueRef icond = LLVMBuildICmp(ctx->builder, LLVMIntEQ, result, 
>> ctx->i32_1, "");
>> +       return LLVMBuildSelect(ctx->builder, icond, ctx->i64_1, ctx->i64_0, 
>> "");
>>  }
>>
>>  static LLVMValueRef emit_i2b(struct ac_llvm_context *ctx,
>> @@ -1979,7 +1986,7 @@ static void visit_alu(struct ac_nir_context *ctx, 
>> const nir_alu_instr *instr)
>>                 result = emit_f2b(&ctx->ac, src[0]);
>>                 break;
>>         case nir_op_b2i:
>> -               result = emit_b2i(&ctx->ac, src[0]);
>> +               result = emit_b2i(&ctx->ac, src[0], 
>> instr->dest.dest.ssa.bit_size);
>>                 break;
>>         case nir_op_i2b:
>>                 src[0] = ac_to_integer(&ctx->ac, src[0]);
>> --
>> 2.14.3
>>
>> _______________________________________________
>> mesa-dev mailing list
>> mesa-dev@lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
> _______________________________________________
> mesa-dev mailing list
> mesa-dev@lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to