DebugInfo: Fix bad debug info for compile units and types
[oota-llvm.git] / test / Transforms / InstCombine / vec_sext.ll
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 }