diff options
author | Victor Hernandez <vhernandez@apple.com> | 2010-01-14 20:12:34 +0000 |
---|---|---|
committer | Victor Hernandez <vhernandez@apple.com> | 2010-01-14 20:12:34 +0000 |
commit | e05f66ef2e37bcbd88acaeef2bf14ddb1f04488f (patch) | |
tree | 612dd3c9befa918214344d1a06ac99d11cdca93e /lib/VMCore | |
parent | 2d59ae6a35ef54df7e8254e2ce2692e76ee34d7e (diff) |
In debug builds, assert that function-local metadata has only 1 parent function
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93449 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore')
-rw-r--r-- | lib/VMCore/Metadata.cpp | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/lib/VMCore/Metadata.cpp b/lib/VMCore/Metadata.cpp index 1e767ffba6..7988b446fb 100644 --- a/lib/VMCore/Metadata.cpp +++ b/lib/VMCore/Metadata.cpp @@ -121,9 +121,39 @@ MDNode::~MDNode() { Op->~MDNodeOperand(); } +#ifndef NDEBUG +static Function *assertLocalFunction(const MDNode *N, + SmallPtrSet<const MDNode *, 32> &Visited) { + Function *F = NULL; + // Only visit each MDNode once. + if (!Visited.insert(N)) return F; + + for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i) { + Value *V = N->getOperand(i); + Function *NewF = NULL; + if (!V) continue; + if (Instruction *I = dyn_cast<Instruction>(V)) + NewF = I->getParent()->getParent(); + else if (BasicBlock *BB = dyn_cast<BasicBlock>(V)) + NewF = BB->getParent(); + else if (Argument *A = dyn_cast<Argument>(V)) + NewF = A->getParent(); + else if (MDNode *MD = dyn_cast<MDNode>(V)) + if (MD->isFunctionLocal()) + NewF = assertLocalFunction(MD, Visited); + if (F && NewF) assert(F == NewF && "inconsistent function-local metadata"); + if (!F) F = NewF; + } + return F; +} +#endif + static Function *getFunctionHelper(const MDNode *N, SmallPtrSet<const MDNode *, 32> &Visited) { assert(N->isFunctionLocal() && "Should only be called on function-local MD"); +#ifndef NDEBUG + return assertLocalFunction(N, Visited); +#endif Function *F = NULL; // Only visit each MDNode once. if (!Visited.insert(N)) return F; @@ -142,7 +172,6 @@ static Function *getFunctionHelper(const MDNode *N, F = getFunctionHelper(MD, Visited); if (F) break; } - return F; } |