ARM "l" constraint for inline asm means R0-R7, also for Thumb2.
authorJakob Stoklund Olesen <stoklund@2pi.dk>
Thu, 14 Jan 2010 18:19:56 +0000 (18:19 +0000)
committerJakob Stoklund Olesen <stoklund@2pi.dk>
Thu, 14 Jan 2010 18:19:56 +0000 (18:19 +0000)
This is consistent with llvm-gcc's arm/constraints.md.

Certain instructions (e.g. CBZ, CBNZ) require a low register, even in Thumb2
mode.

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

lib/Target/ARM/ARMISelLowering.cpp

index 6643b74dd0283af7fa076d4d5e1be3764dfce69c..275b30c9ae9e91677769eecbdebbe186806f1d8f 100644 (file)
@@ -4258,10 +4258,10 @@ std::pair<unsigned, const TargetRegisterClass*>
 ARMTargetLowering::getRegForInlineAsmConstraint(const std::string &Constraint,
                                                 EVT VT) const {
   if (Constraint.size() == 1) {
-    // GCC RS6000 Constraint Letters
+    // GCC ARM Constraint Letters
     switch (Constraint[0]) {
     case 'l':
-      if (Subtarget->isThumb1Only())
+      if (Subtarget->isThumb())
         return std::make_pair(0U, ARM::tGPRRegisterClass);
       else
         return std::make_pair(0U, ARM::GPRRegisterClass);