diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2011-01-09 01:32:55 +0000 |
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2011-01-09 01:32:55 +0000 |
| commit | 5d684c17a7bf7c81e955f651a1a8e0391d9499db (patch) | |
| tree | 41f21175e8ef432a314ff6bbb918f590d58e26d0 | |
| parent | 4a7b48d5f42b51fe51d967c15b6eb1880ee865c2 (diff) | |
| download | bcm5719-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.txt | 30 |
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. + +//===---------------------------------------------------------------------===// |

