diff options
| author | Gabor Greif <ggreif@gmail.com> | 2010-06-23 21:51:12 +0000 |
|---|---|---|
| committer | Gabor Greif <ggreif@gmail.com> | 2010-06-23 21:51:12 +0000 |
| commit | 5f5a86453963c93369cb999ebebc4952a19eeed8 (patch) | |
| tree | 310d6feae971ac6b4f7b4218f79f3849db487dc9 /llvm/lib/Analysis/MemoryBuiltins.cpp | |
| parent | ad7884ad9812b93dab07da6db4a2757719618234 (diff) | |
| download | llvm-5f5a86453963c93369cb999ebebc4952a19eeed8.zip llvm-5f5a86453963c93369cb999ebebc4952a19eeed8.tar.gz llvm-5f5a86453963c93369cb999ebebc4952a19eeed8.tar.bz2 | |
minor enhancement to llvm::isFreeCall API: return CallInst; no functional change
llvm-svn: 106686
Diffstat (limited to 'llvm/lib/Analysis/MemoryBuiltins.cpp')
| -rw-r--r-- | llvm/lib/Analysis/MemoryBuiltins.cpp | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/llvm/lib/Analysis/MemoryBuiltins.cpp b/llvm/lib/Analysis/MemoryBuiltins.cpp index 8150baf..1ab18ca 100644 --- a/llvm/lib/Analysis/MemoryBuiltins.cpp +++ b/llvm/lib/Analysis/MemoryBuiltins.cpp @@ -183,25 +183,25 @@ Value *llvm::getMallocArraySize(CallInst *CI, const TargetData *TD, // free Call Utility Functions. // -/// isFreeCall - Returns true if the value is a call to the builtin free() -bool llvm::isFreeCall(const Value *I) { +/// isFreeCall - Returns non-null if the value is a call to the builtin free() +const CallInst *llvm::isFreeCall(const Value *I) { const CallInst *CI = dyn_cast<CallInst>(I); if (!CI) - return false; + return 0; Function *Callee = CI->getCalledFunction(); if (Callee == 0 || !Callee->isDeclaration() || Callee->getName() != "free") - return false; + return 0; // Check free prototype. // FIXME: workaround for PR5130, this will be obsolete when a nobuiltin // attribute will exist. const FunctionType *FTy = Callee->getFunctionType(); if (!FTy->getReturnType()->isVoidTy()) - return false; + return 0; if (FTy->getNumParams() != 1) - return false; + return 0; if (FTy->param_begin()->get() != Type::getInt8PtrTy(Callee->getContext())) - return false; + return 0; - return true; + return CI; } |
