collect commutativity information
authorChris Lattner <sabre@nondot.org>
Wed, 28 Sep 2005 18:28:29 +0000 (18:28 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 28 Sep 2005 18:28:29 +0000 (18:28 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23499 91177308-0d34-0410-b5e6-96231b3b80d8

utils/TableGen/DAGISelEmitter.cpp
utils/TableGen/DAGISelEmitter.h

index 9f5e387b169ea62d61e5d0053cec30e863064e6c..dde7f6770dfdda3a931e9edf09c1b580dc5a0b79 100644 (file)
@@ -137,6 +137,22 @@ SDNodeInfo::SDNodeInfo(Record *R) : Def(R) {
   NumResults = TypeProfile->getValueAsInt("NumResults");
   NumOperands = TypeProfile->getValueAsInt("NumOperands");
   
+  // Parse the properties.
+  Properties = 0;
+  ListInit *LI = R->getValueAsListInit("Properties");
+  for (unsigned i = 0, e = LI->getSize(); i != e; ++i) {
+    DefInit *DI = dynamic_cast<DefInit*>(LI->getElement(i));
+    assert(DI && "Properties list must be list of defs!");
+    if (DI->getDef()->getName() == "SDNPCommutative") {
+      Properties |= 1 << SDNPCommutative;
+    } else {
+      std::cerr << "Unknown SD Node property '" << DI->getDef()->getName()
+                << "' on node '" << R->getName() << "'!\n";
+      exit(1);
+    }
+  }
+  
+  
   // Parse the type constraints.
   ListInit *Constraints = TypeProfile->getValueAsListInit("Constraints");
   for (unsigned i = 0, e = Constraints->getSize(); i != e; ++i) {
index 8ec729926b9949ac13d0c353be6a134c4e11d325..48f941d859346700c481aa16e1c287b17b057c5b 100644 (file)
@@ -69,6 +69,7 @@ namespace llvm {
     Record *Def;
     std::string EnumName;
     std::string SDClassName;
+    unsigned Properties;
     unsigned NumResults;
     int NumOperands;
     std::vector<SDTypeConstraint> TypeConstraints;
@@ -84,6 +85,13 @@ namespace llvm {
     const std::vector<SDTypeConstraint> &getTypeConstraints() const {
       return TypeConstraints;
     }
+    
+    // SelectionDAG node properties.
+    enum SDNP { SDNPCommutative };
+
+    /// hasProperty - Return true if this node has the specified property.
+    ///
+    bool hasProperty(enum SDNP Prop) const { return Properties & (1 << Prop); }
 
     /// ApplyTypeConstraints - Given a node in a pattern, apply the type
     /// constraints for this node to the operands of the node.  This returns