Re-land [openmp] Fix warnings when building on Windows with latest MSVC or Clang...
[llvm-project.git] / llvm / test / Analysis / ScalarEvolution / sext-iv-1.ll
bloba1dccb74751c82458de819945042f94b985bcb4e
1 ; RUN: opt < %s "-passes=print<scalar-evolution>" -disable-output 2>&1 | FileCheck %s
3 ; CHECK: -->  (sext i{{.}} {{{.*}},+,{{.*}}}<%bb1> to i64)
4 ; CHECK: -->  (sext i{{.}} {{{.*}},+,{{.*}}}<%bb1> to i64)
5 ; CHECK: -->  (sext i{{.}} {{{.*}},+,{{.*}}}<%bb1> to i64)
6 ; CHECK: -->  (sext i{{.}} {{{.*}},+,{{.*}}}<%bb1> to i64)
7 ; CHECK: -->  (sext i{{.}} {{{.*}},+,{{.*}}}<%bb1> to i64)
8 ; CHECK-NOT: -->  (sext
10 ; Don't convert (sext {...,+,...}) to {sext(...),+,sext(...)} in cases
11 ; where the trip count is not within range.
13 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128"
14 target triple = "x86_64-unknown-linux-gnu"
16 define void @foo0(ptr nocapture %x) nounwind {
17 bb1.thread:
18         br label %bb1
20 bb1:            ; preds = %bb1, %bb1.thread
21         %i.0.reg2mem.0 = phi i64 [ -128, %bb1.thread ], [ %8, %bb1 ]            ; <i64> [#uses=3]
22         %0 = trunc i64 %i.0.reg2mem.0 to i7             ; <i8> [#uses=1]
23         %1 = trunc i64 %i.0.reg2mem.0 to i9             ; <i8> [#uses=1]
24         %2 = sext i9 %1 to i64          ; <i64> [#uses=1]
25         %3 = getelementptr double, ptr %x, i64 %2               ; <ptr> [#uses=1]
26         %4 = load double, ptr %3, align 8               ; <double> [#uses=1]
27         %5 = fmul double %4, 3.900000e+00               ; <double> [#uses=1]
28         %6 = sext i7 %0 to i64          ; <i64> [#uses=1]
29         %7 = getelementptr double, ptr %x, i64 %6               ; <ptr> [#uses=1]
30         store double %5, ptr %7, align 8
31         %8 = add i64 %i.0.reg2mem.0, 1          ; <i64> [#uses=2]
32         %9 = icmp sgt i64 %8, 127               ; <i1> [#uses=1]
33         br i1 %9, label %return, label %bb1
35 return:         ; preds = %bb1
36         ret void
39 define void @foo1(ptr nocapture %x) nounwind {
40 bb1.thread:
41         br label %bb1
43 bb1:            ; preds = %bb1, %bb1.thread
44         %i.0.reg2mem.0 = phi i64 [ -128, %bb1.thread ], [ %8, %bb1 ]            ; <i64> [#uses=3]
45         %0 = trunc i64 %i.0.reg2mem.0 to i8             ; <i8> [#uses=1]
46         %1 = trunc i64 %i.0.reg2mem.0 to i9             ; <i8> [#uses=1]
47         %2 = sext i9 %1 to i64          ; <i64> [#uses=1]
48         %3 = getelementptr double, ptr %x, i64 %2               ; <ptr> [#uses=1]
49         %4 = load double, ptr %3, align 8               ; <double> [#uses=1]
50         %5 = fmul double %4, 3.900000e+00               ; <double> [#uses=1]
51         %6 = sext i8 %0 to i64          ; <i64> [#uses=1]
52         %7 = getelementptr double, ptr %x, i64 %6               ; <ptr> [#uses=1]
53         store double %5, ptr %7, align 8
54         %8 = add i64 %i.0.reg2mem.0, 1          ; <i64> [#uses=2]
55         %9 = icmp sgt i64 %8, 128               ; <i1> [#uses=1]
56         br i1 %9, label %return, label %bb1
58 return:         ; preds = %bb1
59         ret void
62 define void @foo2(ptr nocapture %x) nounwind {
63 bb1.thread:
64         br label %bb1
66 bb1:            ; preds = %bb1, %bb1.thread
67         %i.0.reg2mem.0 = phi i64 [ -129, %bb1.thread ], [ %8, %bb1 ]            ; <i64> [#uses=3]
68         %0 = trunc i64 %i.0.reg2mem.0 to i8             ; <i8> [#uses=1]
69         %1 = trunc i64 %i.0.reg2mem.0 to i9             ; <i8> [#uses=1]
70         %2 = sext i9 %1 to i64          ; <i64> [#uses=1]
71         %3 = getelementptr double, ptr %x, i64 %2               ; <ptr> [#uses=1]
72         %4 = load double, ptr %3, align 8               ; <double> [#uses=1]
73         %5 = fmul double %4, 3.900000e+00               ; <double> [#uses=1]
74         %6 = sext i8 %0 to i64          ; <i64> [#uses=1]
75         %7 = getelementptr double, ptr %x, i64 %6               ; <ptr> [#uses=1]
76         store double %5, ptr %7, align 8
77         %8 = add i64 %i.0.reg2mem.0, 1          ; <i64> [#uses=2]
78         %9 = icmp sgt i64 %8, 127               ; <i1> [#uses=1]
79         br i1 %9, label %return, label %bb1
81 return:         ; preds = %bb1
82         ret void
85 define void @foo3(ptr nocapture %x) nounwind {
86 bb1.thread:
87         br label %bb1
89 bb1:            ; preds = %bb1, %bb1.thread
90         %i.0.reg2mem.0 = phi i64 [ -128, %bb1.thread ], [ %8, %bb1 ]            ; <i64> [#uses=3]
91         %0 = trunc i64 %i.0.reg2mem.0 to i8             ; <i8> [#uses=1]
92         %1 = trunc i64 %i.0.reg2mem.0 to i9             ; <i8> [#uses=1]
93         %2 = sext i9 %1 to i64          ; <i64> [#uses=1]
94         %3 = getelementptr double, ptr %x, i64 %2               ; <ptr> [#uses=1]
95         %4 = load double, ptr %3, align 8               ; <double> [#uses=1]
96         %5 = fmul double %4, 3.900000e+00               ; <double> [#uses=1]
97         %6 = sext i8 %0 to i64          ; <i64> [#uses=1]
98         %7 = getelementptr double, ptr %x, i64 %6               ; <ptr> [#uses=1]
99         store double %5, ptr %7, align 8
100         %8 = add i64 %i.0.reg2mem.0, -1         ; <i64> [#uses=2]
101         %9 = icmp sgt i64 %8, 127               ; <i1> [#uses=1]
102         br i1 %9, label %return, label %bb1
104 return:         ; preds = %bb1
105         ret void