diff options
author | Gabor Greif <ggreif@gmail.com> | 2010-03-24 13:21:49 +0000 |
---|---|---|
committer | Gabor Greif <ggreif@gmail.com> | 2010-03-24 13:21:49 +0000 |
commit | a2fbc0ae1bacf971f8ddee8927e8750d1e3a273a (patch) | |
tree | 9fe1225ed0555ecb0011eada989bff71ecc6f6b9 /llvm/lib/VMCore/Function.cpp | |
parent | be18ae6781837a8d1c1bc305420435ececce4039 (diff) | |
download | bcm5719-llvm-a2fbc0ae1bacf971f8ddee8927e8750d1e3a273a.tar.gz bcm5719-llvm-a2fbc0ae1bacf971f8ddee8927e8750d1e3a273a.zip |
Finally land the InvokeInst operand reordering.
I have audited all getOperandNo calls now, fixing
hidden assumptions. CallSite related uglyness will
be eliminated successively.
Note this patch has a long and griveous history,
for all the back-and-forths have a look at
CallSite.h's log.
llvm-svn: 99399
Diffstat (limited to 'llvm/lib/VMCore/Function.cpp')
-rw-r--r-- | llvm/lib/VMCore/Function.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/Function.cpp b/llvm/lib/VMCore/Function.cpp index 4f55098da16..575381e0303 100644 --- a/llvm/lib/VMCore/Function.cpp +++ b/llvm/lib/VMCore/Function.cpp @@ -16,6 +16,7 @@ #include "llvm/IntrinsicInst.h" #include "llvm/LLVMContext.h" #include "llvm/CodeGen/ValueTypes.h" +#include "llvm/Support/CallSite.h" #include "llvm/Support/LeakDetector.h" #include "llvm/Support/ManagedStatic.h" #include "llvm/Support/StringPool.h" @@ -402,11 +403,14 @@ Function *Intrinsic::getDeclaration(Module *M, ID id, const Type **Tys, /// hasAddressTaken - returns true if there are any uses of this function /// other than direct calls or invokes to it. -bool Function::hasAddressTaken() const { +bool Function::hasAddressTaken(const User* *PutOffender) const { for (Value::use_const_iterator I = use_begin(), E = use_end(); I != E; ++I) { - if (I.getOperandNo() != 0 || - (!isa<CallInst>(*I) && !isa<InvokeInst>(*I))) - return true; + const User *U = *I; + if (!isa<CallInst>(U) && !isa<InvokeInst>(U)) + return PutOffender ? (*PutOffender = U, true) : true; + CallSite CS(const_cast<Instruction*>(static_cast<const Instruction*>(U))); + if (!CS.isCallee(I)) + return PutOffender ? (*PutOffender = U, true) : true; } return false; } |