summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/LoopIdiom
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2012-10-27 14:25:51 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2012-10-27 14:25:51 +0000
commit1c9e5186c0233f78d2e4978aa9c6b30e5fdcb235 (patch)
tree1b8bcd05dc4bdf8510782b4e5746daec5f30bf14 /llvm/test/Transforms/LoopIdiom
parentd5c9be82471b002295b3d5684eafc4167ba81279 (diff)
downloadbcm5719-llvm-1c9e5186c0233f78d2e4978aa9c6b30e5fdcb235.tar.gz
bcm5719-llvm-1c9e5186c0233f78d2e4978aa9c6b30e5fdcb235.zip
LoopIdiom: Recognize memmove loops.
This turns loops like for (unsigned i = 0; i != n; ++i) p[i] = p[i+1]; into memmove, which has a highly optimized implementation in most libcs. This was really easy with the new DependenceAnalysis :) llvm-svn: 166875
Diffstat (limited to 'llvm/test/Transforms/LoopIdiom')
-rw-r--r--llvm/test/Transforms/LoopIdiom/basic.ll22
1 files changed, 22 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopIdiom/basic.ll b/llvm/test/Transforms/LoopIdiom/basic.ll
index 46ab7e5542b..5afc405fa6b 100644
--- a/llvm/test/Transforms/LoopIdiom/basic.ll
+++ b/llvm/test/Transforms/LoopIdiom/basic.ll
@@ -383,4 +383,26 @@ for.end: ; preds = %for.inc
}
+@p = common global [1024 x i8] zeroinitializer, align 16
+define void @test15(i32 %n) nounwind {
+entry:
+ %cmp6 = icmp eq i32 %n, 0
+ br i1 %cmp6, label %for.end, label %for.body
+
+for.body: ; preds = %entry, %for.body
+ %indvars.iv = phi i64 [ %indvars.iv.next, %for.body ], [ 0, %entry ]
+ %indvars.iv.next = add i64 %indvars.iv, 1
+ %arrayidx = getelementptr inbounds [1024 x i8]* @p, i64 0, i64 %indvars.iv.next
+ %0 = load i8* %arrayidx, align 1
+ %arrayidx2 = getelementptr inbounds [1024 x i8]* @p, i64 0, i64 %indvars.iv
+ store i8 %0, i8* %arrayidx2, align 1
+ %lftr.wideiv = trunc i64 %indvars.iv.next to i32
+ %exitcond = icmp eq i32 %lftr.wideiv, %n
+ br i1 %exitcond, label %for.end, label %for.body
+
+for.end: ; preds = %for.body, %entry
+ ret void
+; CHECK: @test15
+; CHECK: call void @llvm.memmove.p0i8.p0i8.i64(i8* getelementptr inbounds ([1024 x i8]* @p, i32 0, i32 0), i8* getelementptr inbounds ([1024 x i8]* @p, i64 0, i64 1),
+}
OpenPOWER on IntegriCloud