diff options
author | Victor Hernandez <vhernandez@apple.com> | 2009-11-03 20:39:35 +0000 |
---|---|---|
committer | Victor Hernandez <vhernandez@apple.com> | 2009-11-03 20:39:35 +0000 |
commit | 3ad70d5d61f3f86fb5bc167e157680fc107a1173 (patch) | |
tree | c0abf43548aaf93987feaa96e76695ffff7aa121 /lib/Analysis/MemoryBuiltins.cpp | |
parent | a9e610768bad77f400bc763a0011e77aee19053e (diff) |
Changes requested (avoid getFunction(), avoid Type creation via isVoidTy(), and avoid redundant isFreeCall cases) in feedback to r85176
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85936 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/MemoryBuiltins.cpp')
-rw-r--r-- | lib/Analysis/MemoryBuiltins.cpp | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/lib/Analysis/MemoryBuiltins.cpp b/lib/Analysis/MemoryBuiltins.cpp index 47a70d1297..e710350fa0 100644 --- a/lib/Analysis/MemoryBuiltins.cpp +++ b/lib/Analysis/MemoryBuiltins.cpp @@ -33,16 +33,14 @@ static bool isMallocCall(const CallInst *CI) { if (!CI) return false; - const Module *M = CI->getParent()->getParent()->getParent(); - Function *MallocFunc = M->getFunction("malloc"); - - if (CI->getOperand(0) != MallocFunc) + Function *Callee = CI->getCalledFunction(); + if (Callee == 0 || !Callee->isDeclaration() || Callee->getName() != "malloc") return false; // Check malloc prototype. // FIXME: workaround for PR5130, this will be obsolete when a nobuiltin // attribute will exist. - const FunctionType *FTy = MallocFunc->getFunctionType(); + const FunctionType *FTy = Callee->getFunctionType(); if (FTy->getNumParams() != 1) return false; if (IntegerType *ITy = dyn_cast<IntegerType>(FTy->param_begin()->get())) { @@ -260,22 +258,19 @@ bool llvm::isFreeCall(const Value *I) { const CallInst *CI = dyn_cast<CallInst>(I); if (!CI) return false; - - const Module *M = CI->getParent()->getParent()->getParent(); - Function *FreeFunc = M->getFunction("free"); - - if (CI->getOperand(0) != FreeFunc) + Function *Callee = CI->getCalledFunction(); + if (Callee == 0 || !Callee->isDeclaration() || Callee->getName() != "free") return false; // Check free prototype. // FIXME: workaround for PR5130, this will be obsolete when a nobuiltin // attribute will exist. - const FunctionType *FTy = FreeFunc->getFunctionType(); - if (FTy->getReturnType() != Type::getVoidTy(M->getContext())) + const FunctionType *FTy = Callee->getFunctionType(); + if (!FTy->getReturnType()->isVoidTy()) return false; if (FTy->getNumParams() != 1) return false; - if (FTy->param_begin()->get() != Type::getInt8PtrTy(M->getContext())) + if (FTy->param_begin()->get() != Type::getInt8PtrTy(Callee->getContext())) return false; return true; |