2011-07-07 11:55:05 +08:00
; RUN: llc < %s -relocation-model=pic -mtriple=armv6-apple-darwin | FileCheck %s -check-prefix=ARM
; RUN: llc < %s -relocation-model=pic -mtriple=thumbv6-apple-darwin | FileCheck %s -check-prefix=THUMB
2009-11-05 08:30:35 +08:00
; RUN: llc < %s -relocation-model=static -mtriple=thumbv7-apple-darwin | FileCheck %s -check-prefix=THUMB2
2013-09-09 22:21:49 +08:00
; RUN: llc < %s -relocation-model=static -mtriple=thumbv8-apple-darwin | FileCheck %s -check-prefix=THUMB2
2009-11-05 03:25:34 +08:00
@nextaddr = global i8 * null ; <i8**> [#uses=2]
@C.0.2070 = private constant [ 5 x i8 * ] [ i8 * blockaddress ( @foo , %L1 ) , i8 * blockaddress ( @foo , %L2 ) , i8 * blockaddress ( @foo , %L3 ) , i8 * blockaddress ( @foo , %L4 ) , i8 * blockaddress ( @foo , %L5 ) ] ; <[5 x i8*]*> [#uses=1]
2010-06-17 23:18:27 +08:00
define internal i32 @foo ( i32 %i ) nounwind {
2013-07-14 14:24:09 +08:00
; ARM-LABEL: foo:
; THUMB-LABEL: foo:
; THUMB2-LABEL: foo:
2009-11-05 03:25:34 +08:00
entry:
2013-12-02 18:35:41 +08:00
; _nextaddr gets CSEed for use later on.
; THUMB: ldr r[[NEXTADDR_REG:[0-9]+]], [[NEXTADDR_CPI:LCPI0_[0-9]+]]
; THUMB: [[NEXTADDR_PCBASE:LPC0_[0-9]]]:
; THUMB: add r[[NEXTADDR_REG]], pc
2009-11-05 03:25:34 +08:00
%0 = load i8 * * @nextaddr , align 4 ; <i8*> [#uses=2]
%1 = icmp eq i8 * %0 , null ; <i1> [#uses=1]
2010-01-16 08:29:50 +08:00
; indirect branch gets duplicated here
; ARM: bx
2011-04-01 06:14:03 +08:00
; THUMB: mov pc,
; THUMB2: mov pc,
2009-11-05 03:25:34 +08:00
br i1 %1 , label %bb3 , label %bb2
bb2: ; preds = %entry, %bb3
%gotovar.4.0 = phi i8 * [ %gotovar.4.0.pre , %bb3 ] , [ %0 , %entry ] ; <i8*> [#uses=1]
; ARM: bx
2011-04-01 06:14:03 +08:00
; THUMB: mov pc,
2009-11-05 03:25:34 +08:00
indirectbr i8 * %gotovar.4.0 , [ label %L5 , label %L4 , label %L3 , label %L2 , label %L1 ]
bb3: ; preds = %entry
%2 = getelementptr inbounds [ 5 x i8 * ] * @C.0.2070 , i32 0 , i32 %i ; <i8**> [#uses=1]
%gotovar.4.0.pre = load i8 * * %2 , align 4 ; <i8*> [#uses=1]
br label %bb2
L5: ; preds = %bb2
br label %L4
L4: ; preds = %L5, %bb2
%res.0 = phi i32 [ 385 , %L5 ] , [ 35 , %bb2 ] ; <i32> [#uses=1]
br label %L3
L3: ; preds = %L4, %bb2
%res.1 = phi i32 [ %res.0 , %L4 ] , [ 5 , %bb2 ] ; <i32> [#uses=1]
br label %L2
L2: ; preds = %L3, %bb2
2011-04-30 09:37:52 +08:00
; THUMB: muls
2009-11-05 03:25:34 +08:00
%res.2 = phi i32 [ %res.1 , %L3 ] , [ 1 , %bb2 ] ; <i32> [#uses=1]
%phitmp = mul i32 %res.2 , 6 ; <i32> [#uses=1]
br label %L1
L1: ; preds = %L2, %bb2
%res.3 = phi i32 [ %phitmp , %L2 ] , [ 2 , %bb2 ] ; <i32> [#uses=1]
2013-09-09 22:21:49 +08:00
; ARM-LABEL: %L1
2011-04-30 09:37:52 +08:00
; ARM: ldr [[R1:r[0-9]+]], LCPI
; ARM: add [[R1b:r[0-9]+]], pc, [[R1]]
; ARM: str [[R1b]]
2013-12-02 18:35:41 +08:00
2013-09-09 22:21:49 +08:00
; THUMB-LABEL: %L1
2013-07-22 23:49:36 +08:00
; THUMB: ldr [[R2:r[0-9]+]], LCPI
2011-04-30 09:37:52 +08:00
; THUMB: add [[R2]], pc
2013-12-02 18:35:41 +08:00
; THUMB: str [[R2]], [r[[NEXTADDR_REG]]]
2013-09-09 22:21:49 +08:00
; THUMB2-LABEL: %L1
2013-07-22 23:49:36 +08:00
; THUMB2: ldr [[R2:r[0-9]+]], LCPI
2011-04-30 09:37:52 +08:00
; THUMB2-NEXT: str{{(.w)?}} [[R2]]
2009-11-05 03:25:34 +08:00
store i8 * blockaddress ( @foo , %L5 ) , i8 * * @nextaddr , align 4
ret i32 %res.3
}
2014-03-07 14:08:31 +08:00
; ARM: .long Ltmp0-(LPC{{.*}}+8)
; THUMB: .long Ltmp0-(LPC{{.*}}+4)
2013-12-02 18:35:41 +08:00
; THUMB: .long _nextaddr-([[NEXTADDR_PCBASE]]+4)
2014-03-07 14:08:31 +08:00
; THUMB2: .long Ltmp0