blob: 909d9c28398d3315afa21736a419f0d83014e8b9 [file] [log] [blame]
Sanjay Patelb653de12014-09-10 17:58:16 +00001; RUN: opt < %s -loop-vectorize -force-vector-interleave=4 -force-vector-width=4 -debug-only=loop-vectorize -stats -S 2>&1 | FileCheck %s
Alexander Musmanf0785f42014-04-23 08:40:37 +00002; REQUIRES: asserts
3
4;
5; We have 2 loops, one of them is vectorizable and the second one is not.
6;
7
8; CHECK: 2 loop-vectorize - Number of loops analyzed for vectorization
9; CHECK: 1 loop-vectorize - Number of loops vectorized
10
11target 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-n8:16:32:64-S128"
Alexander Musmanf0785f42014-04-23 08:40:37 +000012
13define void @vectorized(float* nocapture %a, i64 %size) {
14entry:
Michael Zolotukhin540580c2014-12-02 22:59:02 +000015 %cmp1 = icmp sle i64 %size, 0
16 %cmp21 = icmp sgt i64 0, %size
17 %or.cond = or i1 %cmp1, %cmp21
18 br i1 %or.cond, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000019
Michael Zolotukhin540580c2014-12-02 22:59:02 +000020for.body: ; preds = %entry, %for.body
21 %indvars.iv2 = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
David Blaikie79e6c742015-02-27 19:29:02 +000022 %arrayidx = getelementptr inbounds float, float* %a, i64 %indvars.iv2
David Blaikiea79ac142015-02-27 21:17:42 +000023 %0 = load float, float* %arrayidx, align 4
Alexander Musmanf0785f42014-04-23 08:40:37 +000024 %mul = fmul float %0, %0
25 store float %mul, float* %arrayidx, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000026 %indvars.iv.next = add nuw nsw i64 %indvars.iv2, 1
27 %cmp2 = icmp sgt i64 %indvars.iv.next, %size
28 br i1 %cmp2, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000029
Michael Zolotukhin540580c2014-12-02 22:59:02 +000030for.end: ; preds = %entry, %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000031 ret void
32}
33
34define void @not_vectorized(float* nocapture %a, i64 %size) {
35entry:
Michael Zolotukhin540580c2014-12-02 22:59:02 +000036 %cmp1 = icmp sle i64 %size, 0
37 %cmp21 = icmp sgt i64 0, %size
38 %or.cond = or i1 %cmp1, %cmp21
39 br i1 %or.cond, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000040
Michael Zolotukhin540580c2014-12-02 22:59:02 +000041for.body: ; preds = %entry, %for.body
42 %indvars.iv2 = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
43 %0 = add nsw i64 %indvars.iv2, -5
David Blaikie79e6c742015-02-27 19:29:02 +000044 %arrayidx = getelementptr inbounds float, float* %a, i64 %0
David Blaikiea79ac142015-02-27 21:17:42 +000045 %1 = load float, float* %arrayidx, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000046 %2 = add nsw i64 %indvars.iv2, 2
David Blaikie79e6c742015-02-27 19:29:02 +000047 %arrayidx2 = getelementptr inbounds float, float* %a, i64 %2
David Blaikiea79ac142015-02-27 21:17:42 +000048 %3 = load float, float* %arrayidx2, align 4
Alexander Musmanf0785f42014-04-23 08:40:37 +000049 %mul = fmul float %1, %3
David Blaikie79e6c742015-02-27 19:29:02 +000050 %arrayidx4 = getelementptr inbounds float, float* %a, i64 %indvars.iv2
Alexander Musmanf0785f42014-04-23 08:40:37 +000051 store float %mul, float* %arrayidx4, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000052 %indvars.iv.next = add nuw nsw i64 %indvars.iv2, 1
53 %cmp2 = icmp sgt i64 %indvars.iv.next, %size
54 br i1 %cmp2, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000055
Michael Zolotukhin540580c2014-12-02 22:59:02 +000056for.end: ; preds = %entry, %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000057 ret void
Sanjay Patelb653de12014-09-10 17:58:16 +000058}