Home | History | Annotate | Download | only in InstCombine
      1 ; RUN: opt < %s -instcombine -S | FileCheck %s
      2 
      3 define <4 x i32> @psignd_3(<4 x i32> %a, <4 x i32> %b) nounwind ssp {
      4 entry:
      5   %cmp = icmp slt <4 x i32> %b, zeroinitializer
      6   %sext = sext <4 x i1> %cmp to <4 x i32>
      7   %sub = sub nsw <4 x i32> zeroinitializer, %a
      8   %0 = icmp slt <4 x i32> %sext, zeroinitializer
      9   %sext3 = sext <4 x i1> %0 to <4 x i32>
     10   %1 = xor <4 x i32> %sext3, <i32 -1, i32 -1, i32 -1, i32 -1>
     11   %2 = and <4 x i32> %a, %1
     12   %3 = and <4 x i32> %sext3, %sub
     13   %cond = or <4 x i32> %2, %3
     14   ret <4 x i32> %cond
     15 
     16 ; CHECK-LABEL: @psignd_3
     17 ; CHECK:   ashr <4 x i32> %b, <i32 31, i32 31, i32 31, i32 31>
     18 ; CHECK:   sub nsw <4 x i32> zeroinitializer, %a
     19 ; CHECK:   xor <4 x i32> %b.lobit, <i32 -1, i32 -1, i32 -1, i32 -1>
     20 ; CHECK:   and <4 x i32> %a, %0
     21 ; CHECK:   and <4 x i32> %b.lobit, %sub
     22 ; CHECK:   or <4 x i32> %1, %2
     23 }
     24 
     25 define <4 x i32> @test1(<4 x i32> %a, <4 x i32> %b) nounwind ssp {
     26 entry:
     27   %cmp = icmp sgt <4 x i32> %b, <i32 -1, i32 -1, i32 -1, i32 -1>
     28   %sext = sext <4 x i1> %cmp to <4 x i32>
     29   %sub = sub nsw <4 x i32> zeroinitializer, %a
     30   %0 = icmp slt <4 x i32> %sext, zeroinitializer
     31   %sext3 = sext <4 x i1> %0 to <4 x i32>
     32   %1 = xor <4 x i32> %sext3, <i32 -1, i32 -1, i32 -1, i32 -1>
     33   %2 = and <4 x i32> %a, %1
     34   %3 = and <4 x i32> %sext3, %sub
     35   %cond = or <4 x i32> %2, %3
     36   ret <4 x i32> %cond
     37 
     38 ; CHECK-LABEL: @test1
     39 ; CHECK:   ashr <4 x i32> %b, <i32 31, i32 31, i32 31, i32 31>
     40 ; CHECK:   xor <4 x i32> %b.lobit, <i32 -1, i32 -1, i32 -1, i32 -1>
     41 ; CHECK:   sub nsw <4 x i32> zeroinitializer, %a
     42 ; CHECK:   and <4 x i32> %b.lobit, %a
     43 ; CHECK:   and <4 x i32> %b.lobit.not, %sub
     44 ; CHECK:   or <4 x i32> %0, %1
     45 }
     46