From eaff66a8950bb9ed76e830c4ded7e0b695ab6904 Mon Sep 17 00:00:00 2001 From: Benjamin Kramer Date: Fri, 7 Jan 2011 20:42:20 +0000 Subject: [PATCH] Revert 122959, it needs more thought. Add it back to README.txt with additional notes. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123030 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/README.txt | 22 +++++++++++++++ .../InstCombine/InstCombineCalls.cpp | 4 --- test/Transforms/InstCombine/objsize.ll | 27 ------------------- 3 files changed, 22 insertions(+), 31 deletions(-) diff --git a/lib/Target/README.txt b/lib/Target/README.txt index d13ea736a10..5cc4fe027a8 100644 --- a/lib/Target/README.txt +++ b/lib/Target/README.txt @@ -2009,6 +2009,28 @@ entry: //===---------------------------------------------------------------------===// +This code can be seen in viterbi: + + %64 = call noalias i8* @malloc(i64 %62) nounwind +... + %67 = call i64 @llvm.objectsize.i64(i8* %64, i1 false) nounwind + %68 = call i8* @__memset_chk(i8* %64, i32 0, i64 %62, i64 %67) nounwind + +llvm.objectsize.i64 should be taught about malloc/calloc, allowing it to +fold to %62. This is a security win (overflows of malloc will get caught) +and also a performance win by exposing more memsets to the optimizer. + +This occurs several times in viterbi. + +Note that this would change the semantics of @llvm.objectsize which by its +current definition always folds to a constant. We also should make sure that +we remove checking in code like + + char *p = malloc(strlen(s)+1); + __strcpy_chk(p, s, __builtin_objectsize(p, 0)); + +//===---------------------------------------------------------------------===// + This code (from Benchmarks/Dhrystone/dry.c): define i32 @Func1(i32, i32) nounwind readnone optsize ssp { diff --git a/lib/Transforms/InstCombine/InstCombineCalls.cpp b/lib/Transforms/InstCombine/InstCombineCalls.cpp index ecd2243c35d..bd451ebcac9 100644 --- a/lib/Transforms/InstCombine/InstCombineCalls.cpp +++ b/lib/Transforms/InstCombine/InstCombineCalls.cpp @@ -304,10 +304,6 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) { if (Value *NElems = getMallocArraySize(MI, TD, true)) if (ConstantInt *NElements = dyn_cast(NElems)) Size = NElements->getZExtValue() * TD->getTypeAllocSize(MallocType); - - // If there is no offset we can just return the size passed to malloc. - if (Offset == 0) - return ReplaceInstUsesWith(CI, MI->getArgOperand(0)); } // Do not return "I don't know" here. Later optimization passes could diff --git a/test/Transforms/InstCombine/objsize.ll b/test/Transforms/InstCombine/objsize.ll index 4154ea0afbb..043525b7555 100644 --- a/test/Transforms/InstCombine/objsize.ll +++ b/test/Transforms/InstCombine/objsize.ll @@ -160,30 +160,3 @@ define i32 @test7() { ret i32 %objsize } -define i32 @test8(i32 %x) { -; CHECK: @test8 - %alloc = call noalias i8* @malloc(i32 %x) nounwind - %objsize = call i32 @llvm.objectsize.i32(i8* %alloc, i1 false) nounwind readonly -; CHECK-NEXT: ret i32 %x - ret i32 %objsize -} - -define i32 @test9(i32 %x) { -; CHECK: @test9 - %alloc = call noalias i8* @malloc(i32 %x) nounwind - %gep = getelementptr inbounds i8* %alloc, i32 16 - %objsize = call i32 @llvm.objectsize.i32(i8* %gep, i1 false) nounwind readonly -; CHECK-NOT: ret i32 %x - ret i32 %objsize -} - -define i8* @test10(i32 %x) { -; CHECK: @test10 - %alloc = call noalias i8* @malloc(i32 %x) nounwind - %objsize = call i32 @llvm.objectsize.i32(i8* %alloc, i1 false) nounwind readonly - tail call i8* @__memset_chk(i8* %alloc, i32 0, i32 %x, i32 %objsize) nounwind -; CHECK-NOT: @llvm.objectsize -; CHECK: @llvm.memset - ret i8* %alloc -; CHECK: ret i8* -}