add TLS tests.
authorLauro Ramos Venancio <lauro.venancio@gmail.com>
Fri, 27 Apr 2007 21:08:48 +0000 (21:08 +0000)
committerLauro Ramos Venancio <lauro.venancio@gmail.com>
Fri, 27 Apr 2007 21:08:48 +0000 (21:08 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36516 91177308-0d34-0410-b5e6-96231b3b80d8

test/CodeGen/ARM/tls1.ll [new file with mode: 0644]
test/CodeGen/ARM/tls2.ll [new file with mode: 0644]

diff --git a/test/CodeGen/ARM/tls1.ll b/test/CodeGen/ARM/tls1.ll
new file mode 100644 (file)
index 0000000..ae90c94
--- /dev/null
@@ -0,0 +1,19 @@
+; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu | \
+; RUN:     grep {movl %gs:i@NTPOFF, %eax}
+; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu | \
+; RUN:     grep {leal i@NTPOFF(%eax), %eax}
+; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic | \
+; RUN:     grep {leal i@TLSGD(,%ebx,1), %eax}
+
+@i = thread_local global i32 15                ; <i32*> [#uses=2]
+
+define i32 @f() {
+entry:
+       %tmp1 = load i32* @i            ; <i32> [#uses=1]
+       ret i32 %tmp1
+}
+
+define i32* @g() {
+entry:
+       ret i32* @i
+}
diff --git a/test/CodeGen/ARM/tls2.ll b/test/CodeGen/ARM/tls2.ll
new file mode 100644 (file)
index 0000000..90e3bcf
--- /dev/null
@@ -0,0 +1,19 @@
+; RUN: llvm-as < %s | llc -march=arm -mtriple=arm-linux-gnueabi | \
+; RUN:     grep {i(gottpoff)}
+; RUN: llvm-as < %s | llc -march=arm -mtriple=arm-linux-gnueabi | \
+; RUN:     grep {ldr r., \[pc, r.\]}
+; RUN: llvm-as < %s | llc -march=arm -mtriple=arm-linux-gnueabi \
+; RUN:     -relocation-model=pic | grep {__tls_get_addr}
+
+@i = external thread_local global i32          ; <i32*> [#uses=2]
+
+define i32 @f() {
+entry:
+       %tmp1 = load i32* @i            ; <i32> [#uses=1]
+       ret i32 %tmp1
+}
+
+define i32* @g() {
+entry:
+       ret i32* @i
+}