[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Analysis / DependenceAnalysis / NonAffineExpr.ll
blob801b3f6dd6ff8fd7bbd2eabb2fe45fbd58c48bbd
1 ; RUN: opt < %s -disable-output "-passes=print<da>" -aa-pipeline=basic-aa 2>&1
2 ; RUN: opt < %s -analyze -basicaa -da
4 ; CHECK: da analyze - consistent input [S S]!
5 ; CHECK: da analyze - confused!
6 ; CHECK: da analyze - input [* *]!
8 target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n8:16:32-S64"
9 target triple = "thumbv7--linux-gnueabi"
11 define void @f(i32** %a, i32 %n) align 2 {
12 for.preheader:
13   %t.0 = ashr exact i32 %n, 3
14   br label %for.body.1
16 for.body.1:
17   %i.1 = phi i32 [ %t.5, %for.inc ], [ 0, %for.preheader ]
18   %i.2 = phi i32 [ %i.5, %for.inc ], [ %t.0, %for.preheader ]
19   br i1 undef, label %for.inc, label %for.body.2
21 for.body.2:
22   %i.3 = phi i32 [ %t.1, %for.body.2 ], [ %i.1, %for.body.1 ]
23   %t.1 = add i32 %i.3, 1
24   %t.2 = load i32*, i32** %a, align 4
25   %t.3 = getelementptr inbounds i32, i32* %t.2, i32 %i.3
26   %t.4 = load i32, i32* %t.3, align 4
27   br i1 undef, label %for.inc, label %for.body.2
29 for.inc:
30   %i.4 = phi i32 [ %i.2, %for.body.1 ], [ %i.2, %for.body.2 ]
31   %t.5 = add i32 %i.1, %i.4
32   %i.5 = add i32 %i.2, -1
33   br i1 undef, label %for.exit, label %for.body.1
35 for.exit:
36   ret void