external_use.ll
1.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
; RUN: opt < %s -loop-reroll -S | FileCheck %s
; Check whether rerolling is rejected if values of the base and root
; instruction are used outside the loop block.
; Only the base/root instructions except a loop increment instruction
define void @test1() {
entry:
br label %loop1
loop1:
;CHECK-LABEL: loop1:
;CHECK-NEXT: %indvar = phi i64 [ 0, %entry ], [ %indvar.next, %loop1 ]
;CHECK-NEXT: %indvar.1 = add nsw i64 %indvar, 1
%indvar = phi i64 [ 0, %entry ], [ %indvar.next, %loop1 ]
%indvar.1 = add nsw i64 %indvar, 1
%indvar.next = add nsw i64 %indvar, 2
%cmp = icmp slt i64 %indvar.next, 200
br i1 %cmp, label %loop1, label %exit
exit:
%var1 = phi i64 [ %indvar.1, %loop1 ]
%var2 = phi i64 [ %indvar, %loop1 ]
ret void
}
; Both the base/root instructions and reduction instructions
define void @test2() {
entry:
br label %loop2
loop2:
;CHECK-LABEL: loop2:
;CHECK-NEXT: %indvar = phi i32 [ 0, %entry ], [ %indvar.next, %loop2 ]
;CHECK-NEXT: %redvar = phi i32 [ 0, %entry ], [ %add.2, %loop2 ]
;CHECK-NEXT: %indvar.1 = add nuw nsw i32 %indvar, 1
;CHECK-NEXT: %indvar.2 = add nuw nsw i32 %indvar, 2
%indvar = phi i32 [ 0, %entry ], [ %indvar.next, %loop2 ]
%redvar = phi i32 [ 0, %entry ], [ %add.2, %loop2 ]
%indvar.1 = add nuw nsw i32 %indvar, 1
%indvar.2 = add nuw nsw i32 %indvar, 2
%mul.0 = mul nsw i32 %indvar, %indvar
%mul.1 = mul nsw i32 %indvar.1, %indvar.1
%mul.2 = mul nsw i32 %indvar.2, %indvar.2
%add.0 = add nsw i32 %redvar, %mul.0
%add.1 = add nsw i32 %add.0, %mul.1
%add.2 = add nsw i32 %add.1, %mul.2
%indvar.next = add nuw nsw i32 %indvar, 3
%cmp = icmp slt i32 %indvar.next, 300
br i1 %cmp, label %loop2, label %exit
exit:
%a = phi i32 [ %indvar, %loop2 ]
%b = phi i32 [ %indvar.1, %loop2 ]
%c = phi i32 [ %indvar.2, %loop2 ]
%x = phi i32 [ %add.2, %loop2 ]
ret void
}