]> granicus.if.org Git - llvm/commitdiff
Merging r263118: ARM: correct __builtin_longjmp on WoA
authorRenato Golin <renato.golin@linaro.org>
Sat, 2 Apr 2016 20:31:15 +0000 (20:31 +0000)
committerRenato Golin <renato.golin@linaro.org>
Sat, 2 Apr 2016 20:31:15 +0000 (20:31 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_38@265243 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/ARMAsmPrinter.cpp
test/CodeGen/ARM/Windows/builtin_longjmp.ll [new file with mode: 0644]

index 206db9619a2f1b34b3b19273ad736fb6172dfe6d..ad13063c624061bfede19686d9137f2ae375f7e4 100644 (file)
@@ -1843,8 +1843,10 @@ void ARMAsmPrinter::EmitInstruction(const MachineInstr *MI) {
     // ldr $scratch, [$src, #4]
     // ldr r7, [$src]
     // bx $scratch
+    const Triple &TT = TM.getTargetTriple();
     unsigned SrcReg = MI->getOperand(0).getReg();
     unsigned ScratchReg = MI->getOperand(1).getReg();
+
     EmitToStreamer(*OutStreamer, MCInstBuilder(ARM::tLDRi)
       .addReg(ScratchReg)
       .addReg(SrcReg)
@@ -1871,7 +1873,7 @@ void ARMAsmPrinter::EmitInstruction(const MachineInstr *MI) {
       .addReg(0));
 
     EmitToStreamer(*OutStreamer, MCInstBuilder(ARM::tLDRi)
-      .addReg(ARM::R7)
+      .addReg(TT.isOSWindows() ? ARM::R11 : ARM::R7)
       .addReg(SrcReg)
       .addImm(0)
       // Predicate.
diff --git a/test/CodeGen/ARM/Windows/builtin_longjmp.ll b/test/CodeGen/ARM/Windows/builtin_longjmp.ll
new file mode 100644 (file)
index 0000000..d16b44f
--- /dev/null
@@ -0,0 +1,16 @@
+; RUN: llc -mtriple thumbv7--windows-itanium -filetype asm -o - %s | FileCheck %s
+
+declare void @llvm.eh.sjlj.longjmp(i8*)
+
+define arm_aapcs_vfpcc void @test___builtin_longjump(i8* %b) {
+entry:
+  tail call void @llvm.eh.sjlj.longjmp(i8* %b)
+  unreachable
+}
+
+; CHECK: ldr     r[[SP:[0-9]+]], [r0, #8]
+; CHECK: mov     sp, r[[SP]]
+; CHECK: ldr     r[[PC:[0-9]+]], [r0, #4]
+; CHECK: ldr     r11, [r0]
+; CHECK: bx      r[[PC]]
+