aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/ARM
diff options
context:
space:
mode:
authorLogan Chien <tzuhsiang.chien@gmail.com>2013-08-22 12:08:04 +0000
committerLogan Chien <tzuhsiang.chien@gmail.com>2013-08-22 12:08:04 +0000
commit7ddda4704cdb24163591857e8d08614463cec335 (patch)
tree4f900dd865b4e1b2dd07d0639427890a5bf1fd65 /test/CodeGen/ARM
parenta5bd3937ab34d88fe87f25f9c7d1f059445234b8 (diff)
downloadexternal_llvm-7ddda4704cdb24163591857e8d08614463cec335.zip
external_llvm-7ddda4704cdb24163591857e8d08614463cec335.tar.gz
external_llvm-7ddda4704cdb24163591857e8d08614463cec335.tar.bz2
Fix ARM FastISel PIC function call.
The function call to external function should come with PLT relocation type if the PIC relocation model is used. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189002 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/ARM')
-rw-r--r--test/CodeGen/ARM/pic.ll23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/CodeGen/ARM/pic.ll b/test/CodeGen/ARM/pic.ll
new file mode 100644
index 0000000..32cea50
--- /dev/null
+++ b/test/CodeGen/ARM/pic.ll
@@ -0,0 +1,23 @@
+; Check the function call in PIC relocation model.
+
+; If the relocation model is PIC, then the "bl" instruction for the function
+; call to the external function should come with PLT fixup type.
+
+; RUN: llc < %s -mtriple=armv7-unknown-linux-gnueabi \
+; RUN: -relocation-model=pic -fast-isel \
+; RUN: | FileCheck %s
+
+define void @test() {
+entry:
+
+ %0 = call i32 @get()
+; CHECK: bl get(PLT)
+
+ call void @put(i32 %0)
+; CHECK: bl put(PLT)
+
+ ret void
+}
+
+declare i32 @get()
+declare void @put(i32)