[TwoAddressInstructionPass] When looking for a 3 addr conversion after commuting...
[oota-llvm.git] / test / Transforms / LoopStrengthReduce / quadradic-exit-value.ll
1 ; RUN: opt < %s -analyze -iv-users | FileCheck %s
2
3 ; Provide legal integer types.
4 target datalayout = "n8:16:32:64"
5
6 ; The value of %r is dependent on a polynomial iteration expression.
7 ;
8 ; CHECK-LABEL: IV Users for loop %foo.loop
9 ; CHECK: {1,+,3,+,2}<%foo.loop>
10 define i64 @foo(i64 %n) {
11 entry:
12   br label %foo.loop
13
14 foo.loop:
15   %indvar = phi i64 [ 0, %entry ], [ %indvar.next, %foo.loop ]
16   %indvar.next = add i64 %indvar, 1
17   %c = icmp eq i64 %indvar.next, %n
18   br i1 %c, label %exit, label %foo.loop
19
20 exit:
21   %r = mul i64 %indvar.next, %indvar.next
22   ret i64 %r
23 }
24
25 ; PR15470: LSR miscompile. The test2 function should return '1'.
26 ;
27 ; SCEV does not know how to denormalize chained recurrences, so make
28 ; sure they aren't marked as post-inc users.
29 ;
30 ; CHECK-LABEL: IV Users for loop %test2.loop
31 ; CHECK: %sext.us = {0,+,(16777216 + (-16777216 * %sub.us)),+,33554432}<%test2.loop> in %f = ashr i32 %sext.us, 24
32 define i32 @test2() {
33 entry:
34   br label %test2.loop
35
36 test2.loop:
37   %inc1115.us = phi i32 [ 0, %entry ], [ %inc11.us, %test2.loop ]
38   %inc11.us = add nsw i32 %inc1115.us, 1
39   %cmp.us = icmp slt i32 %inc11.us, 2
40   br i1 %cmp.us, label %test2.loop, label %for.end
41
42 for.end:
43   %tobool.us = icmp eq i32 %inc1115.us, 0
44   %sub.us = select i1 %tobool.us, i32 0, i32 0
45   %mul.us = shl i32 %inc1115.us, 24
46   %sub.cond.us = sub nsw i32 %inc1115.us, %sub.us
47   %sext.us = mul i32 %mul.us, %sub.cond.us
48   %f = ashr i32 %sext.us, 24
49   br label %exit
50
51 exit:
52   ret i32 %f
53 }