Turn on mips16 pseudo op when compiling for mips16.
authorAkira Hatanaka <ahatanaka@mips.com>
Thu, 24 May 2012 18:37:43 +0000 (18:37 +0000)
committerAkira Hatanaka <ahatanaka@mips.com>
Thu, 24 May 2012 18:37:43 +0000 (18:37 +0000)
Expand test case for this.

Patch by Reed Kotler.

llvm-svn: 157410

llvm/lib/Target/Mips/MipsAsmPrinter.cpp
llvm/test/CodeGen/Mips/null.ll

index d62df4d..dfeae9a 100644 (file)
@@ -274,8 +274,14 @@ const char *MipsAsmPrinter::getCurrentABIString() const {
 }
 
 void MipsAsmPrinter::EmitFunctionEntryLabel() {
-  if (OutStreamer.hasRawTextSupport())
+  if (OutStreamer.hasRawTextSupport()) {
+    if (Subtarget->inMips16Mode())
+      OutStreamer.EmitRawText(StringRef("\t.set\tmips16"));
+    else
+      OutStreamer.EmitRawText(StringRef("\t.set\tnomips16"));
+    OutStreamer.EmitRawText(StringRef("\t.set\tnomicromips"));
     OutStreamer.EmitRawText("\t.ent\t" + Twine(CurrentFnSym->getName()));
+  }
   OutStreamer.EmitLabel(CurrentFnSym);
 }
 
index a5e2c06..f34f6a4 100644 (file)
@@ -5,6 +5,9 @@ define i32 @main() nounwind {
 entry:
   ret i32 0
 
+; 16:  .set    mips16                  # @main
+; 16:  .set    nomicromips
+
 ; 16:  jr      $ra
 
 }