blob: 7bf5a6084847f913ba7731de60bb330bf789753f [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"
12target triple = "x86_64-unknown-linux-gnu"
13
14define void @vectorized(float* nocapture %a, i64 %size) {
15entry:
Michael Zolotukhin540580c2014-12-02 22:59:02 +000016 %cmp1 = icmp sle i64 %size, 0
17 %cmp21 = icmp sgt i64 0, %size
18 %or.cond = or i1 %cmp1, %cmp21
19 br i1 %or.cond, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000020
Michael Zolotukhin540580c2014-12-02 22:59:02 +000021for.body: ; preds = %entry, %for.body
22 %indvars.iv2 = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
David Blaikie79e6c742015-02-27 19:29:02 +000023 %arrayidx = getelementptr inbounds float, float* %a, i64 %indvars.iv2
David Blaikiea79ac142015-02-27 21:17:42 +000024 %0 = load float, float* %arrayidx, align 4
Alexander Musmanf0785f42014-04-23 08:40:37 +000025 %mul = fmul float %0, %0
26 store float %mul, float* %arrayidx, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000027 %indvars.iv.next = add nuw nsw i64 %indvars.iv2, 1
28 %cmp2 = icmp sgt i64 %indvars.iv.next, %size
29 br i1 %cmp2, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000030
Michael Zolotukhin540580c2014-12-02 22:59:02 +000031for.end: ; preds = %entry, %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000032 ret void
33}
34
35define void @not_vectorized(float* nocapture %a, i64 %size) {
36entry:
Michael Zolotukhin540580c2014-12-02 22:59:02 +000037 %cmp1 = icmp sle i64 %size, 0
38 %cmp21 = icmp sgt i64 0, %size
39 %or.cond = or i1 %cmp1, %cmp21
40 br i1 %or.cond, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000041
Michael Zolotukhin540580c2014-12-02 22:59:02 +000042for.body: ; preds = %entry, %for.body
43 %indvars.iv2 = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
44 %0 = add nsw i64 %indvars.iv2, -5
David Blaikie79e6c742015-02-27 19:29:02 +000045 %arrayidx = getelementptr inbounds float, float* %a, i64 %0
David Blaikiea79ac142015-02-27 21:17:42 +000046 %1 = load float, float* %arrayidx, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000047 %2 = add nsw i64 %indvars.iv2, 2
David Blaikie79e6c742015-02-27 19:29:02 +000048 %arrayidx2 = getelementptr inbounds float, float* %a, i64 %2
David Blaikiea79ac142015-02-27 21:17:42 +000049 %3 = load float, float* %arrayidx2, align 4
Alexander Musmanf0785f42014-04-23 08:40:37 +000050 %mul = fmul float %1, %3
David Blaikie79e6c742015-02-27 19:29:02 +000051 %arrayidx4 = getelementptr inbounds float, float* %a, i64 %indvars.iv2
Alexander Musmanf0785f42014-04-23 08:40:37 +000052 store float %mul, float* %arrayidx4, align 4
Michael Zolotukhin540580c2014-12-02 22:59:02 +000053 %indvars.iv.next = add nuw nsw i64 %indvars.iv2, 1
54 %cmp2 = icmp sgt i64 %indvars.iv.next, %size
55 br i1 %cmp2, label %for.end, label %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000056
Michael Zolotukhin540580c2014-12-02 22:59:02 +000057for.end: ; preds = %entry, %for.body
Alexander Musmanf0785f42014-04-23 08:40:37 +000058 ret void
Sanjay Patelb653de12014-09-10 17:58:16 +000059}