mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-02 08:26:39 +00:00
Refactor TLS code and add some tests. The tests and expected results are:
pic | declaration | linkage | visibility | !pic | declaration | external | default | tls1.ll tls2.ll | local exec pic | declaration | external | default | tls1-pic.ll tls2-pic.ll | general dynamic !pic | !declaration | external | default | tls3.ll tls4.ll | initial exec pic | !declaration | external | default | tls3-pic.ll tls4-pic.ll | general dynamic !pic | declaration | external | hidden | tls7.ll tls8.ll | local exec pic | declaration | external | hidden | X | local dynamic !pic | !declaration | external | hidden | tls9.ll tls10.ll | local exec pic | !declaration | external | hidden | X | local dynamic !pic | declaration | internal | default | tls5.ll tls6.ll | local exec pic | declaration | internal | default | X | local dynamic The ones marked with an X have not been implemented since local dynamic is not implemented. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65632 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
11
test/CodeGen/X86/tls1-pic.ll
Normal file
11
test/CodeGen/X86/tls1-pic.ll
Normal file
@@ -0,0 +1,11 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic > %t
|
||||
; RUN: grep {leal i@TLSGD(,%ebx,1), %eax} %t
|
||||
; RUN: grep {call ___tls_get_addr@PLT} %t
|
||||
|
||||
@i = thread_local global i32 15
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i
|
||||
ret i32 %tmp1
|
||||
}
|
@@ -1,19 +1,10 @@
|
||||
; 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}
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:i@NTPOFF, %eax} %t
|
||||
|
||||
@i = thread_local global i32 15 ; <i32*> [#uses=2]
|
||||
@i = thread_local global i32 15
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i ; <i32> [#uses=1]
|
||||
%tmp1 = load i32* @i
|
||||
ret i32 %tmp1
|
||||
}
|
||||
|
||||
define i32* @g() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
||||
|
10
test/CodeGen/X86/tls10.ll
Normal file
10
test/CodeGen/X86/tls10.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:0, %eax} %t
|
||||
; RUN: grep {leal i@NTPOFF(%eax), %eax} %t
|
||||
|
||||
@i = external hidden thread_local global i32
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
10
test/CodeGen/X86/tls2-pic.ll
Normal file
10
test/CodeGen/X86/tls2-pic.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic > %t
|
||||
; RUN: grep {leal i@TLSGD(,%ebx,1), %eax} %t
|
||||
; RUN: grep {call ___tls_get_addr@PLT} %t
|
||||
|
||||
@i = thread_local global i32 15
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
@@ -1,19 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu | \
|
||||
; RUN: grep {movl %gs:(%eax), %eax}
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu | \
|
||||
; RUN: grep {addl i@INDNTPOFF, %eax}
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic | \
|
||||
; RUN: grep {leal i@TLSGD(,%ebx,1), %eax}
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:0, %eax} %t
|
||||
; RUN: grep {leal i@NTPOFF(%eax), %eax} %t
|
||||
|
||||
@i = external thread_local global i32 ; <i32*> [#uses=2]
|
||||
@i = thread_local global i32 15
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i ; <i32> [#uses=1]
|
||||
ret i32 %tmp1
|
||||
}
|
||||
|
||||
define i32* @g() {
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
||||
|
11
test/CodeGen/X86/tls3-pic.ll
Normal file
11
test/CodeGen/X86/tls3-pic.ll
Normal file
@@ -0,0 +1,11 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic > %t
|
||||
; RUN: grep {leal i@TLSGD(,%ebx,1), %eax} %t
|
||||
; RUN: grep {call ___tls_get_addr@PLT} %t
|
||||
|
||||
@i = external thread_local global i32 ; <i32*> [#uses=2]
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i ; <i32> [#uses=1]
|
||||
ret i32 %tmp1
|
||||
}
|
11
test/CodeGen/X86/tls3.ll
Normal file
11
test/CodeGen/X86/tls3.ll
Normal file
@@ -0,0 +1,11 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl i@INDNTPOFF, %eax} %t
|
||||
; RUN: grep {movl %gs:(%eax), %eax} %t
|
||||
|
||||
@i = external thread_local global i32 ; <i32*> [#uses=2]
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i ; <i32> [#uses=1]
|
||||
ret i32 %tmp1
|
||||
}
|
10
test/CodeGen/X86/tls4-pic.ll
Normal file
10
test/CodeGen/X86/tls4-pic.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu -relocation-model=pic > %t
|
||||
; RUN: grep {leal i@TLSGD(,%ebx,1), %eax} %t
|
||||
; RUN: grep {call ___tls_get_addr@PLT} %t
|
||||
|
||||
@i = external thread_local global i32 ; <i32*> [#uses=2]
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
10
test/CodeGen/X86/tls4.ll
Normal file
10
test/CodeGen/X86/tls4.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:0, %eax} %t
|
||||
; RUN: grep {addl i@INDNTPOFF, %eax} %t
|
||||
|
||||
@i = external thread_local global i32 ; <i32*> [#uses=2]
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
10
test/CodeGen/X86/tls5.ll
Normal file
10
test/CodeGen/X86/tls5.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:i@NTPOFF, %eax} %t
|
||||
|
||||
@i = internal thread_local global i32 15
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i
|
||||
ret i32 %tmp1
|
||||
}
|
10
test/CodeGen/X86/tls6.ll
Normal file
10
test/CodeGen/X86/tls6.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:0, %eax} %t
|
||||
; RUN: grep {leal i@NTPOFF(%eax), %eax} %t
|
||||
|
||||
@i = internal thread_local global i32 15
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
10
test/CodeGen/X86/tls7.ll
Normal file
10
test/CodeGen/X86/tls7.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:i@NTPOFF, %eax} %t
|
||||
|
||||
@i = hidden thread_local global i32 15
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i
|
||||
ret i32 %tmp1
|
||||
}
|
10
test/CodeGen/X86/tls8.ll
Normal file
10
test/CodeGen/X86/tls8.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:0, %eax} %t
|
||||
; RUN: grep {leal i@NTPOFF(%eax), %eax} %t
|
||||
|
||||
@i = hidden thread_local global i32 15
|
||||
|
||||
define i32* @f() {
|
||||
entry:
|
||||
ret i32* @i
|
||||
}
|
10
test/CodeGen/X86/tls9.ll
Normal file
10
test/CodeGen/X86/tls9.ll
Normal file
@@ -0,0 +1,10 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86 -mtriple=i386-linux-gnu > %t
|
||||
; RUN: grep {movl %gs:i@NTPOFF, %eax} %t
|
||||
|
||||
@i = external hidden thread_local global i32
|
||||
|
||||
define i32 @f() {
|
||||
entry:
|
||||
%tmp1 = load i32* @i
|
||||
ret i32 %tmp1
|
||||
}
|
Reference in New Issue
Block a user