[llvm] r267152 - Emit code16 in assembly in 16-bit mode

Nirav Dave via llvm-commits llvm-commits at lists.llvm.org
Fri Apr 22 06:36:13 PDT 2016


Author: niravd
Date: Fri Apr 22 08:36:11 2016
New Revision: 267152

URL: http://llvm.org/viewvc/llvm-project?rev=267152&view=rev
Log:
Emit code16 in assembly in 16-bit mode

Summary:
When generating assembly using -m16 we must explicitly mark it as
16-bit. Emit .code16 at beginning of file. Fixes wrong results when
using -fno-integrated-as.

Reviewers: dwmw2

Subscribers: llvm-commits

Differential Revision: http://reviews.llvm.org/D19392

Added:
    llvm/trunk/test/CodeGen/X86/x86-16.ll
Modified:
    llvm/trunk/lib/Target/X86/X86AsmPrinter.cpp

Modified: llvm/trunk/lib/Target/X86/X86AsmPrinter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86AsmPrinter.cpp?rev=267152&r1=267151&r2=267152&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/X86AsmPrinter.cpp (original)
+++ llvm/trunk/lib/Target/X86/X86AsmPrinter.cpp Fri Apr 22 08:36:11 2016
@@ -538,6 +538,12 @@ void X86AsmPrinter::EmitStartOfAsmFile(M
     }
   }
   OutStreamer->EmitSyntaxDirective();
+
+  // If this is not inline asm and we're in 16-bit
+  // mode prefix assembly with .code16.
+  bool is16 = TT.getEnvironment() == Triple::CODE16;
+  if (M.getModuleInlineAsm().empty() && is16)
+    OutStreamer->EmitAssemblerFlag(MCAF_Code16);
 }
 
 static void

Added: llvm/trunk/test/CodeGen/X86/x86-16.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/x86-16.ll?rev=267152&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/X86/x86-16.ll (added)
+++ llvm/trunk/test/CodeGen/X86/x86-16.ll Fri Apr 22 08:36:11 2016
@@ -0,0 +1,20 @@
+; RUN: llc < %s | FileCheck %s
+target datalayout = "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128"
+target triple = "i386-unknown-linux-code16"
+
+; Function Attrs: nounwind
+define i32 @main() #0 {
+  %retval = alloca i32, align 4
+  store i32 0, i32* %retval, align 4
+  ret i32 0
+}
+
+; CHECK: .code16
+; CHECK-LABEL: main
+
+
+attributes #0 = { nounwind }
+
+!llvm.ident = !{!0}
+
+!0 = !{!"clang version 3.9.0 (trunk 265439) (llvm/trunk 265567)"}
\ No newline at end of file




More information about the llvm-commits mailing list