[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Analysis / ScalarEvolution / expander-replace-congruent-ivs.ll
blob0adb92d671b16207d3d8707a45a68a88c1f6346c
1 ; RUN: opt -S -indvars < %s | FileCheck %s
3 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
4 target triple = "x86_64-apple-macosx10.11.0"
6 ; SCEVExpander would try to RAUW %val_2 with %c.lcssa, breaking "def
7 ; dominates uses".
9 define void @pr27232(i32 %val) {
10 ; CHECK-LABEL: @pr27232(
11 entry:
12   br i1 undef, label %loop_0.cond, label %for.body.us
14 for.body.us:
15   br label %loop_0.cond
17 loop_0.cond:
18   %val_2 = phi i32 [ %val, %for.body.us ], [ undef, %entry ]
19   br i1 true, label %loop_0.ph, label %loop_1.ph
21 loop_0.ph:
22   br label %loop_0
24 loop_1.exit:
25   br label %loop_1.ph
27 loop_1.ph:
28   %c.lcssa = phi i32 [ 0, %loop_0.cond ], [ %val_2, %loop_1.exit ]
29   br label %loop_1
31 loop_0:
32   br i1 undef, label %loop_0, label %loop_1.exit
34 loop_1:
35   %d.1 = phi i32 [ %c.lcssa, %loop_1 ], [ %val_2, %loop_1.ph ]
36   %t.1 = phi i32 [ %val_2, %loop_1 ], [ %c.lcssa, %loop_1.ph ]
37   br i1 undef, label %leave, label %loop_1
39 leave:
40   ret void
44 ; @ReplaceArg_0 and @ReplaceArg_1 used to trigger a failed cast<>
45 ; assertion in SCEVExpander.
47 define void @ReplaceArg_0(i32 %val) {
48 ; CHECK-LABEL: @ReplaceArg_0(
49 entry:
50   br i1 undef, label %loop_0.cond, label %for.body.us
52 for.body.us:
53   br label %loop_0.cond
55 loop_0.cond:
56   br i1 true, label %loop_0.ph, label %loop_1.ph
58 loop_0.ph:
59   br label %loop_0
61 loop_1.exit:
62   br label %loop_1.ph
64 loop_1.ph:
65   %c.lcssa = phi i32 [ 0, %loop_0.cond ], [ %val, %loop_1.exit ]
66   br label %loop_1
68 loop_0:
69   br i1 undef, label %loop_0, label %loop_1.exit
71 loop_1:
72   %d.1 = phi i32 [ %c.lcssa, %loop_1 ], [ %val, %loop_1.ph ]
73   %t.1 = phi i32 [ %val, %loop_1 ], [ %c.lcssa, %loop_1.ph ]
74   br i1 undef, label %leave, label %loop_1
76 leave:
77   ret void
80 define void @ReplaceArg_1(i32 %val) {
81 ; CHECK-LABEL: @ReplaceArg_1(
82 entry:
83   br i1 undef, label %loop_0.cond, label %for.body.us
85 for.body.us:
86   br label %loop_0.cond
88 loop_0.cond:
89   br i1 true, label %loop_0.ph, label %loop_1.ph
91 loop_0.ph:
92   br label %loop_0
94 loop_1.exit:
95   br label %loop_1.ph
97 loop_1.ph:
98   %c.lcssa = phi i32 [ 0, %loop_0.cond ], [ %val, %loop_1.exit ]
99   br label %loop_1
101 loop_0:
102   br i1 undef, label %loop_0, label %loop_1.exit
104 loop_1:
105   %t.1 = phi i32 [ %val, %loop_1 ], [ %c.lcssa, %loop_1.ph ]
106   %d.1 = phi i32 [ %c.lcssa, %loop_1 ], [ %val, %loop_1.ph ]
107   br i1 undef, label %leave, label %loop_1
109 leave:
110   ret void