From 785d16fe75a4ea0d465f2641f0a19033e0d9badc Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 17 Feb 2010 02:16:19 +0000 Subject: [PATCH] Prep work to handle input chains of matched patterns and checking for 'ischaincompatible' when a pattern has more than one input chain. Need to do some commenting and cleanup now that I understand how this works. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@96443 91177308-0d34-0410-b5e6-96231b3b80d8 --- utils/TableGen/DAGISelMatcherGen.cpp | 32 ++++++++++++++++++++++++---- 1 file changed, 28 insertions(+), 4 deletions(-) diff --git a/utils/TableGen/DAGISelMatcherGen.cpp b/utils/TableGen/DAGISelMatcherGen.cpp index 5936e750654..b104660cb00 100644 --- a/utils/TableGen/DAGISelMatcherGen.cpp +++ b/utils/TableGen/DAGISelMatcherGen.cpp @@ -10,6 +10,7 @@ #include "DAGISelMatcher.h" #include "CodeGenDAGPatterns.h" #include "Record.h" +#include "llvm/ADT/SmallVector.h" #include "llvm/ADT/StringMap.h" using namespace llvm; @@ -29,7 +30,15 @@ namespace { StringMap VariableMap; unsigned NextRecordedOperandNo; + /// InputChains - This maintains the position in the recorded nodes array of + /// all of the recorded input chains. + SmallVector InputChains; + + /// Matcher - This is the top level of the generated matcher, the result. MatcherNodeWithChild *Matcher; + + /// CurPredicate - As we emit matcher nodes, this points to the latest check + /// which should have future checks stuck into its child position. MatcherNodeWithChild *CurPredicate; public: MatcherGen(const PatternToMatch &pattern, const CodeGenDAGPatterns &cgp); @@ -194,13 +203,30 @@ void MatcherGen::EmitOperatorMatchCode(const TreePatternNode *N, // the child numbers of the node are all offset by one. unsigned OpNo = 0; if (N->NodeHasProperty(SDNPHasChain, CGP)) { + // FIXME: Not correct for complex patterns, they need to push their own + // *matched* input chain. + // Record the input chain, which is always input #0 of the SDNode. AddMatcherNode(new MoveChildMatcherNode(0)); - ++NextRecordedOperandNo; AddMatcherNode(new RecordMatcherNode("'" + N->getOperator()->getName() + "' input chain")); + + // Remember all of the input chains our pattern will match. + InputChains.push_back(NextRecordedOperandNo); + ++NextRecordedOperandNo; AddMatcherNode(new MoveParentMatcherNode()); - + + // If this is the second (e.g. indbr(load) or store(add(load))) or third + // input chain (e.g. (store (add (load, load))) from msp430) we need to make + // sure that folding the chain won't induce cycles in the DAG. This could + // happen if there were an intermediate node between the indbr and load, for + // example. + + // FIXME: Emit "lastchain.getNode() == CurrentNode || + // IsChainCompatible(lastchain.getNode(), CurrentNode)". + // Rename IsChainCompatible -> IsChainUnreachable, add comment about + // complexity. + // Don't look at the input chain when matching the tree pattern to the // SDNode. OpNo = 1; @@ -252,8 +278,6 @@ void MatcherGen::EmitOperatorMatchCode(const TreePatternNode *N, AddMatcherNode(new CheckFoldableChainNodeMatcherNode()); } } - - // FIXME: Need to generate IsChainCompatible checks. for (unsigned i = 0, e = N->getNumChildren(); i != e; ++i, ++OpNo) { // Get the code suitable for matching this child. Move to the child, check