Fix part 1 of pr4682. PICADD is a 16-bit instruction even in thumb2 mode.
[llvm/avr.git] / test / CodeGen / Thumb2 / thumb2-call.ll
blobb70c2a945324a8c8a157b09544818bead5a3ba7e
1 ; RUN: llvm-as < %s | llc -mtriple=thumbv7-apple-darwin -mattr=+thumb2 | FileCheck %s -check-prefix=DARWIN
2 ; RUN: llvm-as < %s | llc -mtriple=thumbv7-linux -mattr=+thumb2 | FileCheck %s -check-prefix=LINUX
4 @t = weak global i32 ()* null           ; <i32 ()**> [#uses=1]
6 declare void @g(i32, i32, i32, i32)
8 define void @f() {
9 ; DARWIN: f:
10 ; DARWIN: blx L_g$stub
12 ; LINUX: f:
13 ; LINUX: bl g
14         call void @g( i32 1, i32 2, i32 3, i32 4 )
15         ret void
18 define void @h() {
19 ; DARWIN: h:
20 ; DARWIN: blx r0
22 ; LINUX: h:
23 ; LINUX: blx r0
24         %tmp = load i32 ()** @t         ; <i32 ()*> [#uses=1]
25         %tmp.upgrd.2 = tail call i32 %tmp( )            ; <i32> [#uses=0]
26         ret void