blob: 5c4a87c969ce705e90ad9994200923cd47bcdf4a [file] [log] [blame]
Sriraman Tallamf29fa582016-10-13 20:54:39 +00001; RUN: llc < %s -march=x86-64 -mcpu=generic -mtriple=x86_64-linux-gnu -relocation-model=pic -pie-copy-relocations \
2; RUN: | FileCheck -check-prefix=X64 %s
3; RUN: llc < %s -emulated-tls -march=x86 -mcpu=generic -mtriple=i386-linux-gnu -relocation-model=pic -pie-copy-relocations \
4; RUN: | FileCheck -check-prefix=X32 %s
5
6; External Linkage
7@a = global i32 0, align 4
8
9define i32 @my_access_global_a() #0 {
10; X32-LABEL: my_access_global_a:
11; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
12; X32-NEXT: movl a@GOTOFF(%eax), %eax
13; X64-LABEL: my_access_global_a:
14; X64: movl a(%rip), %eax
15
16entry:
17 %0 = load i32, i32* @a, align 4
18 ret i32 %0
19}
20
21; WeakAny Linkage
22@b = weak global i32 0, align 4
23
24define i32 @my_access_global_b() #0 {
25; X32-LABEL: my_access_global_b:
26; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
27; X32-NEXT: movl b@GOTOFF(%eax), %eax
28; X64-LABEL: my_access_global_b:
29; X64: movl b(%rip), %eax
30
31entry:
32 %0 = load i32, i32* @b, align 4
33 ret i32 %0
34}
35
36; Internal Linkage
37@c = internal global i32 0, align 4
38
39define i32 @my_access_global_c() #0 {
40; X32-LABEL: my_access_global_c:
41; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
42; X32-NEXT: movl c@GOTOFF(%eax), %eax
43; X64-LABEL: my_access_global_c:
44; X64: movl c(%rip), %eax
45
46entry:
47 %0 = load i32, i32* @c, align 4
48 ret i32 %0
49}
50
51; External Linkage, only declaration.
52@d = external global i32, align 4
53
54define i32 @my_access_global_load_d() #0 {
55; X32-LABEL: my_access_global_load_d:
56; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
57; X32-NEXT: movl d@GOTOFF(%eax), %eax
58; X64-LABEL: my_access_global_load_d:
59; X64: movl d(%rip), %eax
60
61entry:
62 %0 = load i32, i32* @d, align 4
63 ret i32 %0
64}
65
66; External Linkage, only declaration, store a value.
67
68define i32 @my_access_global_store_d() #0 {
69; X32-LABEL: my_access_global_store_d:
70; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
71; X32-NEXT: movl $2, d@GOTOFF(%eax)
72; X64-LABEL: my_access_global_store_d:
73; X64: movl $2, d(%rip)
74
75entry:
76 store i32 2, i32* @d, align 4
77 ret i32 0
78}
79
80; External Linkage, function pointer access.
81declare i32 @access_fp(i32 ()*)
82declare i32 @foo()
83
84define i32 @my_access_fp_foo() #0 {
85; X32-LABEL: my_access_fp_foo:
86; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %ebx
87; X32-NEXT: movl foo@GOT(%ebx), %eax
88; X64-LABEL: my_access_fp_foo:
89; X64: movq foo@GOTPCREL(%rip), %rdi
90
91entry:
92 %call = call i32 @access_fp(i32 ()* @foo)
93 ret i32 %call
94}
95
96; LinkOnceODR Linkage, function pointer access.
97
98$bar = comdat any
99
100define linkonce_odr i32 @bar() comdat {
101entry:
102 ret i32 0
103}
104
105define i32 @my_access_fp_bar() #0 {
106; X32-LABEL: my_access_fp_bar:
107; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %ebx
108; X32-NEXT: leal bar@GOTOFF(%ebx), %eax
109; X64-LABEL: my_access_fp_bar:
110; X64: leaq bar(%rip), %rdi
111
112entry:
113 %call = call i32 @access_fp(i32 ()* @bar)
114 ret i32 %call
115}
116
117!llvm.module.flags = !{!0, !1}
118!0 = !{i32 1, !"PIC Level", i32 1}
119!1 = !{i32 1, !"PIE Level", i32 1}