diff options
author | Nuno Lopes <nunoplopes@sapo.pt> | 2012-05-03 22:08:19 +0000 |
---|---|---|
committer | Nuno Lopes <nunoplopes@sapo.pt> | 2012-05-03 22:08:19 +0000 |
commit | d4cf35d77576c8de1e958937aed5445a81f6989b (patch) | |
tree | db2c08363ca8a03d03b8df5c4e4acffd0080b233 | |
parent | f8e5e3c072ac81a8987bc8dea86facd4b7fda9d8 (diff) | |
download | bcm5719-llvm-d4cf35d77576c8de1e958937aed5445a81f6989b.tar.gz bcm5719-llvm-d4cf35d77576c8de1e958937aed5445a81f6989b.zip |
remove calls to calloc if the allocated memory is not used (it was already being done for malloc)
fix a few typos found by Chad in my previous commit
llvm-svn: 156110
-rw-r--r-- | llvm/lib/Analysis/MemoryBuiltins.cpp | 4 | ||||
-rw-r--r-- | llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp | 2 | ||||
-rw-r--r-- | llvm/test/Transforms/InstCombine/objsize.ll | 4 |
3 files changed, 5 insertions, 5 deletions
diff --git a/llvm/lib/Analysis/MemoryBuiltins.cpp b/llvm/lib/Analysis/MemoryBuiltins.cpp index 347a7ea7a8b..9695ae1dec2 100644 --- a/llvm/lib/Analysis/MemoryBuiltins.cpp +++ b/llvm/lib/Analysis/MemoryBuiltins.cpp @@ -182,7 +182,7 @@ Value *llvm::getMallocArraySize(CallInst *CI, const TargetData *TD, //===----------------------------------------------------------------------===// -// clloc Call Utility Functions. +// calloc Call Utility Functions. // static bool isCallocCall(const CallInst *CI) { @@ -197,7 +197,7 @@ static bool isCallocCall(const CallInst *CI) { // Check malloc prototype. // FIXME: workaround for PR5130, this will be obsolete when a nobuiltin - // attribute will exist. + // attribute exists. FunctionType *FTy = Callee->getFunctionType(); return FTy->getReturnType() == Type::getInt8PtrTy(FTy->getContext()) && FTy->getNumParams() == 2 && diff --git a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp index 4196ca6cf79..5fdb57bc7aa 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineCalls.cpp @@ -172,7 +172,7 @@ Instruction *InstCombiner::SimplifyMemSet(MemSetInst *MI) { Instruction *InstCombiner::visitCallInst(CallInst &CI) { if (isFreeCall(&CI)) return visitFree(CI); - if (isMalloc(&CI)) + if (extractMallocCall(&CI) || extractCallocCall(&CI)) return visitMalloc(CI); // If the caller function is nounwind, mark the call as nounwind, even if the diff --git a/llvm/test/Transforms/InstCombine/objsize.ll b/llvm/test/Transforms/InstCombine/objsize.ll index 6b5c0f56eb1..39ad3db5bac 100644 --- a/llvm/test/Transforms/InstCombine/objsize.ll +++ b/llvm/test/Transforms/InstCombine/objsize.ll @@ -165,7 +165,7 @@ define i32 @test8() { %alloc = call noalias i8* @calloc(i32 5, i32 7) nounwind %gep = getelementptr inbounds i8* %alloc, i32 5 %objsize = call i32 @llvm.objectsize.i32(i8* %gep, i1 false) nounwind readonly -; CHECK: ret i32 30 +; CHECK-NEXT: ret i32 30 ret i32 %objsize } @@ -175,6 +175,6 @@ define i32 @test9() { %alloc = call noalias i8* @calloc(i32 100000000, i32 100000000) nounwind %gep = getelementptr inbounds i8* %alloc, i32 2 %objsize = call i32 @llvm.objectsize.i32(i8* %gep, i1 true) nounwind readonly -; CHECK: ret i32 0 +; CHECK-NEXT: ret i32 0 ret i32 %objsize } |