summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2011-01-09 23:42:22 +0000
committerChris Lattner <sabre@nondot.org>2011-01-09 23:42:22 +0000
commit320370e3ca5654d5fe2bfed90acb6ec961aba2b7 (patch)
tree3a855bb31ae0b98192c0966eebe7b74f4d99b195 /llvm/lib
parent8786bda222aefa3150e54b6cdafa42f751d85d60 (diff)
downloadbcm5719-llvm-320370e3ca5654d5fe2bfed90acb6ec961aba2b7.tar.gz
bcm5719-llvm-320370e3ca5654d5fe2bfed90acb6ec961aba2b7.zip
xref a PR #
llvm-svn: 123141
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/README.txt24
1 files changed, 2 insertions, 22 deletions
diff --git a/llvm/lib/Target/README.txt b/llvm/lib/Target/README.txt
index bea240c0921..e04af6f8919 100644
--- a/llvm/lib/Target/README.txt
+++ b/llvm/lib/Target/README.txt
@@ -2109,33 +2109,13 @@ aggressively as malloc though.
//===---------------------------------------------------------------------===//
-clang -03 currently compiles this code
+clang -03 doesn't optimize this:
void f1(int* begin, int* end) {
std::fill(begin, end, 0);
}
-into
-
-define void @_Z2f1PiS_(i32* %begin, i32* %end) nounwind {
-entry:
- %cmp7.i.i = icmp eq i32* %begin, %end
- br i1 %cmp7.i.i, label %_ZSt4fillIPiiEvT_S1_RKT0_.exit, label %for.body.i.i
-
-for.body.i.i: ; preds = %entry, %for.body.i.i
- %indvar.i.i = phi i64 [ %tmp, %for.body.i.i ], [ 0, %entry ]
- %tmp = add i64 %indvar.i.i, 1
- %ptrincdec.i.i = getelementptr i32* %begin, i64 %tmp
- %__first.addr.08.i.i = getelementptr i32* %begin, i64 %indvar.i.i
- store i32 0, i32* %__first.addr.08.i.i, align 4, !tbaa !0
- %cmp.i.i = icmp eq i32* %ptrincdec.i.i, %end
- br i1 %cmp.i.i, label %_ZSt4fillIPiiEvT_S1_RKT0_.exit, label %for.body.i.i
-
-_ZSt4fillIPiiEvT_S1_RKT0_.exit: ; preds = %for.body.i.i, %entry
- ret void
-}
-
-It should compile it to a memset.
+int a memset. This is PR8942.
//===---------------------------------------------------------------------===//
OpenPOWER on IntegriCloud