From 170f06ebe2e80ce8bda87425081541493056fb10 Mon Sep 17 00:00:00 2001 From: Devang Patel Date: Tue, 22 Jun 2010 23:29:55 +0000 Subject: Revert 106592 for now. It causes clang-selfhost build failure. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@106598 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Utils/ValueMapper.cpp | 47 ++++++++++-------------------------- 1 file changed, 13 insertions(+), 34 deletions(-) (limited to 'lib/Transforms/Utils/ValueMapper.cpp') diff --git a/lib/Transforms/Utils/ValueMapper.cpp b/lib/Transforms/Utils/ValueMapper.cpp index 69e03f8af0..87ce631ca6 100644 --- a/lib/Transforms/Utils/ValueMapper.cpp +++ b/lib/Transforms/Utils/ValueMapper.cpp @@ -21,44 +21,23 @@ using namespace llvm; Value *llvm::MapValue(const Value *V, ValueToValueMapTy &VM) { - ValueToValueMapTy::iterator VMI = VM.find(V); - if (VMI != VM.end()) - return VMI->second; // Does it exist in the map yet? + Value *&VMSlot = VM[V]; + if (VMSlot) return VMSlot; // Does it exist in the map yet? - // Global values, metadata strings and inline asm do not need to be seeded into + // NOTE: VMSlot can be invalidated by any reference to VM, which can grow the + // DenseMap. This includes any recursive calls to MapValue. + + // Global values and non-function-local metadata do not need to be seeded into // the ValueMap if they are using the identity mapping. - if (isa(V) || isa(V) || isa(V)) { - VM.insert(std::make_pair(V, const_cast(V))); - return const_cast(V); - } + if (isa(V) || isa(V) || isa(V) || + (isa(V) && !cast(V)->isFunctionLocal())) + return VMSlot = const_cast(V); if (const MDNode *MD = dyn_cast(V)) { - // Insert a place holder in map to handle mdnode cycles. - Value *TmpV = MDString::get(V->getContext(), - std::string("llvm.md.clone.tmp." + VM.size())); - VM.insert(std::make_pair(V, MDNode::get(V->getContext(), &TmpV, 1))); - - bool ReuseMD = true; SmallVector Elts; - // If metadata element is mapped to a new value then seed metadata - // in the map. - for (unsigned i = 0, e = MD->getNumOperands(); i != e; ++i) { - if (!MD->getOperand(i)) - Elts.push_back(0); - else { - Value *MappedOp = MapValue(MD->getOperand(i), VM); - if (MappedOp != MD->getOperand(i)) - ReuseMD = false; - Elts.push_back(MappedOp); - } - } - if (ReuseMD) { - VM.insert(std::make_pair(V, const_cast(V))); - return const_cast(V); - } - MDNode *NewMD = MDNode::get(V->getContext(), Elts.data(), Elts.size()); - VM.insert(std::make_pair(V, NewMD)); - return NewMD; + for (unsigned i = 0, e = MD->getNumOperands(); i != e; ++i) + Elts.push_back(MD->getOperand(i) ? MapValue(MD->getOperand(i), VM) : 0); + return VM[V] = MDNode::get(V->getContext(), Elts.data(), Elts.size()); } Constant *C = const_cast(dyn_cast(V)); @@ -67,7 +46,7 @@ Value *llvm::MapValue(const Value *V, ValueToValueMapTy &VM) { if (isa(C) || isa(C) || isa(C) || isa(C) || isa(C) || isa(C)) - return VM[V] = C; // Primitive constants map directly + return VMSlot = C; // Primitive constants map directly if (ConstantArray *CA = dyn_cast(C)) { for (User::op_iterator b = CA->op_begin(), i = b, e = CA->op_end(); -- cgit v1.2.3