From 23213bff2494778cf42aa5ff3624ce03783a43e0 Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Wed, 5 Aug 2015 23:22:34 +0000 Subject: [PATCH] ValueMapper: Simplify remap() helper function, NFC Rename `remap()` to `remapOperands()`, and restrict its contract to remapping operands. Previously, it also called `mapToMetadata()`, but this logic is hard to reason about externally. In particular, this refactors `mapUniquedNode()` to avoid redundant mapping calls, taking advantage of the RAUWs that are already in place. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@244168 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Utils/ValueMapper.cpp | 55 +++++++++++----------------- 1 file changed, 22 insertions(+), 33 deletions(-) diff --git a/lib/Transforms/Utils/ValueMapper.cpp b/lib/Transforms/Utils/ValueMapper.cpp index cec8648591c..3446462599b 100644 --- a/lib/Transforms/Utils/ValueMapper.cpp +++ b/lib/Transforms/Utils/ValueMapper.cpp @@ -183,35 +183,22 @@ static Metadata *mapMetadataOp(Metadata *Op, return nullptr; } -/// \brief Remap nodes. -/// -/// Insert \c NewNode in the value map, and then remap \c OldNode's operands. -/// Assumes that \c NewNode is already a clone of \c OldNode. -/// -/// \pre \c NewNode is a clone of \c OldNode. -static bool remap(const MDNode *OldNode, MDNode *NewNode, - SmallVectorImpl &Cycles, - ValueToValueMapTy &VM, RemapFlags Flags, - ValueMapTypeRemapper *TypeMapper, - ValueMaterializer *Materializer) { - assert(OldNode->getNumOperands() == NewNode->getNumOperands() && - "Expected nodes to match"); - assert(OldNode->isResolved() && "Expected resolved node"); - assert(!NewNode->isUniqued() && "Expected non-uniqued node"); - - // Map the node upfront so it's available for cyclic references. - mapToMetadata(VM, OldNode, NewNode); - bool AnyChanged = false; - for (unsigned I = 0, E = OldNode->getNumOperands(); I != E; ++I) { - Metadata *Old = OldNode->getOperand(I); - assert(NewNode->getOperand(I) == Old && - "Expected old operands to already be in place"); +/// Remap the operands of an MDNode. +static bool remapOperands(MDNode &Node, + SmallVectorImpl &Cycles, + ValueToValueMapTy &VM, RemapFlags Flags, + ValueMapTypeRemapper *TypeMapper, + ValueMaterializer *Materializer) { + assert(!Node.isUniqued() && "Expected temporary or distinct node"); + bool AnyChanged = false; + for (unsigned I = 0, E = Node.getNumOperands(); I != E; ++I) { + Metadata *Old = Node.getOperand(I); Metadata *New = mapMetadataOp(Old, Cycles, VM, Flags, TypeMapper, Materializer); if (Old != New) { AnyChanged = true; - NewNode->replaceOperandWith(I, New); + Node.replaceOperandWith(I, New); } } @@ -239,7 +226,8 @@ static Metadata *mapDistinctNode(const MDNode *Node, // Remap the operands. If any change, track those that could be involved in // uniquing cycles. - if (remap(Node, NewMD, Cycles, VM, Flags, TypeMapper, Materializer)) + mapToMetadata(VM, Node, NewMD); + if (remapOperands(*NewMD, Cycles, VM, Flags, TypeMapper, Materializer)) for (Metadata *Op : NewMD->operands()) if (auto *Node = dyn_cast_or_null(Op)) if (!Node->isResolved()) @@ -258,18 +246,19 @@ static Metadata *mapUniquedNode(const MDNode *Node, ValueMaterializer *Materializer) { assert(Node->isUniqued() && "Expected uniqued node"); - // Create a temporary node upfront in case we have a metadata cycle. + // Create a temporary node and map it upfront in case we have a uniquing + // cycle. If necessary, this mapping will get updated by RAUW logic before + // returning. auto ClonedMD = Node->clone(); - if (!remap(Node, ClonedMD.get(), Cycles, VM, Flags, TypeMapper, - Materializer)) { - // No operands changed, so use the identity mapping. + mapToMetadata(VM, Node, ClonedMD.get()); + if (!remapOperands(*ClonedMD, Cycles, VM, Flags, TypeMapper, Materializer)) { + // No operands changed, so use the original. ClonedMD->replaceAllUsesWith(const_cast(Node)); - return mapToSelf(VM, Node); + return const_cast(Node); } - // At least one operand has changed, so uniquify the cloned node. - return mapToMetadata(VM, Node, - MDNode::replaceWithUniqued(std::move(ClonedMD))); + // Uniquify the cloned node. + return MDNode::replaceWithUniqued(std::move(ClonedMD)); } static Metadata *MapMetadataImpl(const Metadata *MD, -- 2.34.1