Don't return registers from register classes that aren't legal.
authorChris Lattner <sabre@nondot.org>
Wed, 22 Feb 2006 23:00:51 +0000 (23:00 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 22 Feb 2006 23:00:51 +0000 (23:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26317 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/TargetLowering.cpp

index e82e7f768eac657a2805bc6b940f1e75eb9e93af..c875a85c805ad68628a5b2fd5cc8e86d013930ad 100644 (file)
@@ -766,11 +766,24 @@ getRegForInlineAsmConstraint(const std::string &Constraint,
   for (MRegisterInfo::regclass_iterator RCI = RI->regclass_begin(),
        E = RI->regclass_end(); RCI != E; ++RCI) {
     const TargetRegisterClass *RC = *RCI;
+    
+    // If none of the the value types for this register class are valid, we 
+    // can't use it.  For example, 64-bit reg classes on 32-bit targets.
+    bool isLegal = false;
+    for (TargetRegisterClass::vt_iterator I = RC->vt_begin(), E = RC->vt_end();
+         I != E; ++I) {
+      if (isTypeLegal(*I)) {
+        isLegal = true;
+        break;
+      }
+    }
+    
+    if (!isLegal) continue;
+    
     for (TargetRegisterClass::iterator I = RC->begin(), E = RC->end(); 
          I != E; ++I) {
-      if (StringsEqualNoCase(RegName, RI->get(*I).Name)) {
+      if (StringsEqualNoCase(RegName, RI->get(*I).Name))
         return std::make_pair(*I, RC);
-      }
     }
   }