summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2009-06-24 23:47:58 +0000
committerEvan Cheng <evan.cheng@apple.com>2009-06-24 23:47:58 +0000
commit83f979a48bf1d1fd168ddd5f17be359a22275a94 (patch)
treedaeb4d72e90e476874dfc2704cb9473f1c37be00 /llvm/test
parent816e2833c49928a071e9aa0f45fa5e15a6474dd3 (diff)
downloadbcm5719-llvm-83f979a48bf1d1fd168ddd5f17be359a22275a94.tar.gz
bcm5719-llvm-83f979a48bf1d1fd168ddd5f17be359a22275a94.zip
Add Thumb2 pc relative add.
llvm-svn: 74141
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/CodeGen/Thumb2/load-global.ll9
-rw-r--r--llvm/test/CodeGen/Thumb2/pic-jtbl.ll55
2 files changed, 64 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/Thumb2/load-global.ll b/llvm/test/CodeGen/Thumb2/load-global.ll
new file mode 100644
index 00000000000..0ffcb9575d5
--- /dev/null
+++ b/llvm/test/CodeGen/Thumb2/load-global.ll
@@ -0,0 +1,9 @@
+; RUN: llvm-as < %s | llc -mtriple=thumbv7-apple-darwin
+; RUN: llvm-as < %s | llc -mtriple=thumbv7-apple-darwin -relocation-model=pic | grep add | grep pc
+
+@G = external global i32
+
+define i32 @test1() {
+ %tmp = load i32* @G
+ ret i32 %tmp
+}
diff --git a/llvm/test/CodeGen/Thumb2/pic-jtbl.ll b/llvm/test/CodeGen/Thumb2/pic-jtbl.ll
new file mode 100644
index 00000000000..701d3083264
--- /dev/null
+++ b/llvm/test/CodeGen/Thumb2/pic-jtbl.ll
@@ -0,0 +1,55 @@
+; RUN: llvm-as < %s | llc -mtriple=thumbv7-apple-darwin -relocation-model=pic \
+; RUN: -o %t -f
+; RUN: grep add %t | grep pc
+;; NOT YET: grep "add pc"
+
+define void @bar(i32 %n.u) {
+entry:
+ switch i32 %n.u, label %bb12 [i32 1, label %bb i32 2, label %bb6 i32 4, label %bb7 i32 5, label %bb8 i32 6, label %bb10 i32 7, label %bb1 i32 8, label %bb3 i32 9, label %bb4 i32 10, label %bb9 i32 11, label %bb2 i32 12, label %bb5 i32 13, label %bb11 ]
+bb:
+ tail call void(...)* @foo1()
+ ret void
+bb1:
+ tail call void(...)* @foo2()
+ ret void
+bb2:
+ tail call void(...)* @foo6()
+ ret void
+bb3:
+ tail call void(...)* @foo3()
+ ret void
+bb4:
+ tail call void(...)* @foo4()
+ ret void
+bb5:
+ tail call void(...)* @foo5()
+ ret void
+bb6:
+ tail call void(...)* @foo1()
+ ret void
+bb7:
+ tail call void(...)* @foo2()
+ ret void
+bb8:
+ tail call void(...)* @foo6()
+ ret void
+bb9:
+ tail call void(...)* @foo3()
+ ret void
+bb10:
+ tail call void(...)* @foo4()
+ ret void
+bb11:
+ tail call void(...)* @foo5()
+ ret void
+bb12:
+ tail call void(...)* @foo6()
+ ret void
+}
+
+declare void @foo1(...)
+declare void @foo2(...)
+declare void @foo6(...)
+declare void @foo3(...)
+declare void @foo4(...)
+declare void @foo5(...)
OpenPOWER on IntegriCloud