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.

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

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

index d62df4dcc33cefdfa208bcb9134e861d286e99ff..dfeae9a416238a33d2d37c5c06714e776d3d5a39 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 a5e2c06576d421e2ece323ffec84d75a987fd947..f34f6a4b8cba9daa5872be62aca32686e5fc60ab 100644 (file)
@@ -5,6 +5,9 @@ define i32 @main() nounwind {
 entry:
   ret i32 0
 
+; 16:  .set    mips16                  # @main
+; 16:  .set    nomicromips
+
 ; 16:  jr      $ra
 
 }