ARM: Fix an old refacto.
authorBenjamin Kramer <benny.kra@googlemail.com>
Fri, 15 Mar 2013 17:27:39 +0000 (17:27 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Fri, 15 Mar 2013 17:27:39 +0000 (17:27 +0000)
Fixes PR15520.

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

lib/Target/ARM/ARMAsmPrinter.cpp
test/CodeGen/ARM/call_nolink.ll

index 58c779830e1168fb4326865e5b9e3346a7f2804c..13ec2087938af89003d1b7fd074dfeeb20d8e41d 100644 (file)
@@ -1357,7 +1357,7 @@ void ARMAsmPrinter::EmitInstruction(const MachineInstr *MI) {
 
     OutStreamer.EmitInstruction(MCInstBuilder(ARM::MOVr)
       .addReg(ARM::PC)
-      .addImm(MI->getOperand(0).getReg())
+      .addReg(MI->getOperand(0).getReg())
       // Add predicate operands.
       .addImm(ARMCC::AL)
       .addReg(0)
index 00b16888f38946104948e2d088d806d006658439..5ec7f74a605f869660bc5338e060bff787a0693f 100644 (file)
@@ -1,5 +1,4 @@
-; RUN: llc < %s -march=arm -mtriple=arm-linux-gnueabi | \
-; RUN:   not grep "bx lr"
+; RUN: llc < %s -march=arm -mtriple=arm-linux-gnueabi | FileCheck %s
 
        %struct.anon = type { i32 (i32, i32, i32)*, i32, i32, [3 x i32], i8*, i8*, i8* }
 @r = external global [14 x i32]                ; <[14 x i32]*> [#uses=4]
@@ -8,6 +7,8 @@
 @numi = external global i32            ; <i32*> [#uses=1]
 @counter = external global [2 x i32]           ; <[2 x i32]*> [#uses=1]
 
+; CHECK: main_bb_2E_i_bb205_2E_i_2E_i_bb115_2E_i_2E_i:
+; CHECK-NOT: bx lr
 
 define void @main_bb_2E_i_bb205_2E_i_2E_i_bb115_2E_i_2E_i() {
 newFuncRoot:
@@ -50,3 +51,12 @@ bb115.i.i:           ; preds = %bb115.i.i.bb115.i.i_crit_edge, %newFuncRoot
        icmp slt i32 %tmp166.i.i, %tmp168.i.i           ; <i1>:0 [#uses=1]
        br i1 %0, label %bb115.i.i.bb115.i.i_crit_edge, label %bb115.i.i.bb170.i.i_crit_edge.exitStub
 }
+
+define void @PR15520(void ()* %fn) {
+  call void %fn()
+  ret void
+
+; CHECK: PR15520:
+; CHECK: mov lr, pc
+; CHECK: mov pc, r0
+}