diff options
author | Chris Lattner <sabre@nondot.org> | 2010-02-28 21:36:14 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-02-28 21:36:14 +0000 |
commit | 21221e357c6aa9ade3966ee86dab7d44c25220d0 (patch) | |
tree | 78dd6f9ed9f45dc89909c78f3dd7ad38173b88a2 /include | |
parent | 9a21500edc485a2c383a03fba429943f031c1398 (diff) | |
download | external_llvm-21221e357c6aa9ade3966ee86dab7d44c25220d0.zip external_llvm-21221e357c6aa9ade3966ee86dab7d44c25220d0.tar.gz external_llvm-21221e357c6aa9ade3966ee86dab7d44c25220d0.tar.bz2 |
enhance the new isel to handle the 'node already exists'
case of MorphNodeTo directly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97417 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include')
-rw-r--r-- | include/llvm/CodeGen/DAGISelHeader.h | 44 |
1 files changed, 29 insertions, 15 deletions
diff --git a/include/llvm/CodeGen/DAGISelHeader.h b/include/llvm/CodeGen/DAGISelHeader.h index cb10fb7..3ffc6e9 100644 --- a/include/llvm/CodeGen/DAGISelHeader.h +++ b/include/llvm/CodeGen/DAGISelHeader.h @@ -842,7 +842,19 @@ SDNode *SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable, // Create the node. SDNode *Res = 0; - if (Opcode == OPC_MorphNodeTo) { + if (Opcode != OPC_MorphNodeTo) { + // If this is a normal EmitNode command, just create the new node and + // add the results to the RecordedNodes list. + Res = CurDAG->getMachineNode(TargetOpc, NodeToMatch->getDebugLoc(), + VTList, Ops.data(), Ops.size()); + + // Add all the non-flag/non-chain results to the RecordedNodes list. + for (unsigned i = 0, e = VTs.size(); i != e; ++i) { + if (VTs[i] == MVT::Other || VTs[i] == MVT::Flag) break; + RecordedNodes.push_back(SDValue(Res, i)); + } + + } else { // It is possible we're using MorphNodeTo to replace a node with no // normal results with one that has a normal result (or we could be // adding a chain) and the input could have flags and chains as well. @@ -862,9 +874,15 @@ SDNode *SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable, Res = CurDAG->MorphNodeTo(NodeToMatch, ~TargetOpc, VTList, Ops.data(), Ops.size()); - // Reset the node ID, to the isel, this should be just like a newly - // allocated machine node. - Res->setNodeId(-1); + + // MorphNodeTo can operate in two ways: if an existing node with the + // specified operands exists, it can just return it. Otherwise, it + // updates the node in place to have the requested operands. + if (Res == NodeToMatch) { + // If we updated the node in place, reset the node ID. To the isel, + // this should be just like a newly allocated machine node. + Res->setNodeId(-1); + } // FIXME: Whether the selected node has a flag result should come from // flags on the node. @@ -873,7 +891,7 @@ SDNode *SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable, // Move the flag if needed. if (OldFlagResultNo != -1 && (unsigned)OldFlagResultNo != ResNumResults-1) - ReplaceUses(SDValue(Res, OldFlagResultNo), + ReplaceUses(SDValue(NodeToMatch, OldFlagResultNo), SDValue(Res, ResNumResults-1)); --ResNumResults; } @@ -881,16 +899,12 @@ SDNode *SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable, // Move the chain reference if needed. if ((EmitNodeInfo & OPFL_Chain) && OldChainResultNo != -1 && (unsigned)OldChainResultNo != ResNumResults-1) - ReplaceUses(SDValue(Res, OldChainResultNo), + ReplaceUses(SDValue(NodeToMatch, OldChainResultNo), SDValue(Res, ResNumResults-1)); - } else { - Res = CurDAG->getMachineNode(TargetOpc, NodeToMatch->getDebugLoc(), - VTList, Ops.data(), Ops.size()); - - // Add all the non-flag/non-chain results to the RecordedNodes list. - for (unsigned i = 0, e = VTs.size(); i != e; ++i) { - if (VTs[i] == MVT::Other || VTs[i] == MVT::Flag) break; - RecordedNodes.push_back(SDValue(Res, i)); + + if (Res != NodeToMatch) { + // Otherwise, no replacement happened because the node already exists. + ReplaceUses(NodeToMatch, Res); } } @@ -926,7 +940,7 @@ SDNode *SelectCodeCommon(SDNode *NodeToMatch, const unsigned char *MatcherTable, // Update chain and flag uses. UpdateChainsAndFlags(NodeToMatch, InputChain, ChainNodesMatched, InputFlag, FlagResultNodesMatched, true); - return Res; + return 0; } continue; |