Emit register names in lowercase, as required by the assembler.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12182 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Target/Sparc/SparcAsmPrinter.cpp b/lib/Target/Sparc/SparcAsmPrinter.cpp
index e9752842..a500f24 100644
--- a/lib/Target/Sparc/SparcAsmPrinter.cpp
+++ b/lib/Target/Sparc/SparcAsmPrinter.cpp
@@ -26,6 +26,7 @@
 #include "Support/Statistic.h"
 #include "Support/StringExtras.h"
 #include "Support/CommandLine.h"
+#include <cctype>
 using namespace llvm;
 
 namespace {
@@ -365,6 +366,15 @@
   return false;
 }
 
+
+std::string LowercaseString (const std::string &S) {
+  std::string result (S);
+  for (unsigned i = 0; i < S.length(); ++i) 
+    if (isupper (result[i]))
+      result[i] = tolower(result[i]);
+  return result;
+}
+
 void V8Printer::printOperand(const MachineOperand &MO) {
   const MRegisterInfo &RI = *TM.getRegisterInfo();
   switch (MO.getType()) {
@@ -376,7 +386,7 @@
     // FALLTHROUGH
   case MachineOperand::MO_MachineRegister:
     if (MRegisterInfo::isPhysicalRegister(MO.getReg()))
-      O << "%" << RI.get(MO.getReg()).Name;
+      O << "%" << LowercaseString (RI.get(MO.getReg()).Name);
     else
       O << "%reg" << MO.getReg();
     return;