[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / HardwareLoops / ARM / counter.ll
blobfd216d9f356ad581318b31ec1f7731cea2f29cbe
1 ; RUN: opt -mtriple=thumbv8.1m.main-none-none-eabi -hardware-loops %s -o - | FileCheck %s
3 @g = common local_unnamed_addr global i32* null, align 4
5 ; CHECK-LABEL: counter_too_large
6 ; CHECK-NOT: call void @llvm.set.loop.iterations
7 ; CHECK-NOT: call i32 @llvm.loop.decrement
9 define i32 @counter_too_large(i64 %n) {
10 entry:
11   %cmp7 = icmp eq i64 %n, 0
12   br i1 %cmp7, label %while.end, label %while.body.lr.ph
14 while.body.lr.ph:
15   %0 = load i32*, i32** @g, align 4
16   br label %while.body
18 while.body:
19   %i.09 = phi i64 [ 0, %while.body.lr.ph ], [ %inc1, %while.body ]
20   %res.08 = phi i32 [ 0, %while.body.lr.ph ], [ %add, %while.body ]
21   %idxprom = trunc i64 %i.09 to i32
22   %arrayidx = getelementptr inbounds i32, i32* %0, i32 %idxprom
23   %1 = load i32, i32* %arrayidx, align 4
24   %add = add nsw i32 %1, %res.08
25   %inc1 = add nuw i64 %i.09, 1
26   %cmp = icmp ult i64 %inc1, %n
27   br i1 %cmp, label %while.body, label %while.end.loopexit
29 while.end.loopexit:
30   br label %while.end
32 while.end:
33   %res.0.lcssa = phi i32 [ 0, %entry ], [ %add, %while.end.loopexit ]
34   ret i32 %res.0.lcssa