[MIPS GlobalISel] Select MSA vector generic and builtin add
[llvm-complete.git] / test / Other / pr32085.ll
blob3676ea8e117132f7f45b97b9c5fbeeeaec93925b
1 ; RUN: opt -S -O1 < %s -o %t1.ll
2 ; RUN: opt -S < %t1.ll -o %t2.ll
3 ; RUN: opt -S -simplifycfg < %t1.ll -o %t3.ll
4 ;; Show that there's no difference after running another simplify CFG
5 ; RUN: diff %t2.ll %t3.ll
7 ; Test from LoopSink pass, leaves some single-entry single-exit basic blocks.
8 ; After LoopSink, we get a basic block .exit.loopexit which has one entry and
9 ; one exit, the only instruction is a branch. Make sure it doesn't show up.
10 ; Make sure they disappear at -O1.
12 @g = global i32 0, align 4
14 define i32 @t1(i32, i32) {
15   %3 = icmp eq i32 %1, 0
16   br i1 %3, label %.exit, label %.preheader
18 .preheader:
19   %invariant = load i32, i32* @g
20   br label %.b1
22 .b1:
23   %iv = phi i32 [ %t7, %.b7 ], [ 0, %.preheader ]
24   %c1 = icmp sgt i32 %iv, %0
25   br i1 %c1, label %.b2, label %.b6
27 .b2:
28   %c2 = icmp sgt i32 %iv, 1
29   br i1 %c2, label %.b3, label %.b4
31 .b3:
32   %t3 = sub nsw i32 %invariant, %iv
33   br label %.b5
35 .b4:
36   %t4 = add nsw i32 %invariant, %iv
37   br label %.b5
39 .b5:
40   %p5 = phi i32 [ %t3, %.b3 ], [ %t4, %.b4 ]
41   %t5 = mul nsw i32 %p5, 5
42   br label %.b7
44 .b6:
45   %t6 = add nsw i32 %iv, 100
46   br label %.b7
48 .b7:
49   %p7 = phi i32 [ %t6, %.b6 ], [ %t5, %.b5 ]
50   %t7 = add nuw nsw i32 %iv, 1
51   %c7 = icmp eq i32 %t7, %p7
52   br i1 %c7, label %.b1, label %.exit
54 .exit:
55   ret i32 10