summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2011-01-09 01:32:55 +0000
committerChandler Carruth <chandlerc@gmail.com>2011-01-09 01:32:55 +0000
commit5d684c17a7bf7c81e955f651a1a8e0391d9499db (patch)
tree41f21175e8ef432a314ff6bbb918f590d58e26d0
parent4a7b48d5f42b51fe51d967c15b6eb1880ee865c2 (diff)
downloadbcm5719-llvm-5d684c17a7bf7c81e955f651a1a8e0391d9499db.tar.gz
bcm5719-llvm-5d684c17a7bf7c81e955f651a1a8e0391d9499db.zip
Add a note about a missed memset optimization from std::fill.
llvm-svn: 123103
-rw-r--r--llvm/lib/Target/README.txt30
1 files changed, 30 insertions, 0 deletions
diff --git a/llvm/lib/Target/README.txt b/llvm/lib/Target/README.txt
index 5cc4fe027a8..799b6eae60b 100644
--- a/llvm/lib/Target/README.txt
+++ b/llvm/lib/Target/README.txt
@@ -2108,3 +2108,33 @@ into a call to calloc. We should make sure that we analyze calloc as
aggressively as malloc though.
//===---------------------------------------------------------------------===//
+
+clang -03 currently compiles this code
+
+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.
+
+//===---------------------------------------------------------------------===//
OpenPOWER on IntegriCloud