For now, restrict FastISel to instructions that only involve one
authorDan Gohman <gohman@apple.com>
Tue, 19 Aug 2008 20:58:14 +0000 (20:58 +0000)
committerDan Gohman <gohman@apple.com>
Tue, 19 Aug 2008 20:58:14 +0000 (20:58 +0000)
register class.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55008 91177308-0d34-0410-b5e6-96231b3b80d8

utils/TableGen/FastISelEmitter.cpp

index 31e0d1953cf908e1e105d6c55b4ce05fee8bd3f6..b434c15d8c2de39f2fe356b6b8fc6cb57520cb92 100644 (file)
@@ -62,7 +62,8 @@ struct OperandsSignature {
   ///
   bool initialize(TreePatternNode *InstPatNode,
                   const CodeGenTarget &Target,
-                  MVT::SimpleValueType VT) {
+                  MVT::SimpleValueType VT,
+                  const CodeGenRegisterClass *DstRC) {
     for (unsigned i = 0, e = InstPatNode->getNumChildren(); i != e; ++i) {
       TreePatternNode *Op = InstPatNode->getChild(i);
       if (!Op->isLeaf())
@@ -82,6 +83,9 @@ struct OperandsSignature {
       const CodeGenRegisterClass *RC = &Target.getRegisterClass(OpLeafRec);
       if (!RC)
         return false;
+      // For now, all the operands must have the same register class.
+      if (DstRC != RC)
+        return false;
       // For now, all the operands must have the same type.
       if (Op->getTypeNum(0) != VT)
         return false;
@@ -230,7 +234,7 @@ void FastISelEmitter::run(std::ostream &OS) {
 
     // Check all the operands.
     OperandsSignature Operands;
-    if (!Operands.initialize(InstPatNode, Target, VT))
+    if (!Operands.initialize(InstPatNode, Target, VT, DstRC))
       continue;
 
     // If it's not a known signature, ignore it.