blob: 0e29d605476db87ff4895d4f594b8f4aa47853d1 [file] [log] [blame]
Sriraman Tallam7da9b442016-04-29 21:19:16 +00001; RUN: llc < %s -march=x86-64 -mcpu=generic -mtriple=x86_64-linux-gnu -relocation-model=pic \
Sriraman Tallam3cb77342016-04-22 21:41:58 +00002; RUN: | FileCheck -check-prefix=X64 %s
Sriraman Tallam7da9b442016-04-29 21:19:16 +00003; RUN: llc < %s -emulated-tls -march=x86 -mcpu=generic -mtriple=i386-linux-gnu -relocation-model=pic \
Sriraman Tallam3cb77342016-04-22 21:41:58 +00004; 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@GOT(%eax), %eax
58; X32-NEXT: movl (%eax), %eax
59; X64-LABEL: my_access_global_load_d:
60; X64: movq d@GOTPCREL(%rip), %rax
61; X64-NEXT: movl (%rax), %eax
62
63entry:
64 %0 = load i32, i32* @d, align 4
65 ret i32 %0
66}
67
68; External Linkage, only declaration, store a value.
69
70define i32 @my_access_global_store_d() #0 {
71; X32-LABEL: my_access_global_store_d:
72; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %eax
73; X32-NEXT: movl d@GOT(%eax), %eax
74; X32-NEXT: movl $2, (%eax)
75; X64-LABEL: my_access_global_store_d:
76; X64: movq d@GOTPCREL(%rip), %rax
77; X64-NEXT: movl $2, (%rax)
78
79entry:
80 store i32 2, i32* @d, align 4
81 ret i32 0
82}
83
84; External Linkage, function pointer access.
85declare i32 @access_fp(i32 ()*)
86declare i32 @foo()
87
88define i32 @my_access_fp_foo() #0 {
89; X32-LABEL: my_access_fp_foo:
90; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %ebx
91; X32-NEXT: movl foo@GOT(%ebx), %eax
92; X64-LABEL: my_access_fp_foo:
93; X64: movq foo@GOTPCREL(%rip), %rdi
94
95entry:
96 %call = call i32 @access_fp(i32 ()* @foo)
97 ret i32 %call
98}
99
100; LinkOnceODR Linkage, function pointer access.
101
102$bar = comdat any
103
104define linkonce_odr i32 @bar() comdat {
105entry:
106 ret i32 0
107}
108
109define i32 @my_access_fp_bar() #0 {
110; X32-LABEL: my_access_fp_bar:
111; X32: addl $_GLOBAL_OFFSET_TABLE_{{.*}}, %ebx
112; X32-NEXT: leal bar@GOTOFF(%ebx), %eax
113; X64-LABEL: my_access_fp_bar:
114; X64: leaq bar(%rip), %rdi
115
116entry:
117 %call = call i32 @access_fp(i32 ()* @bar)
118 ret i32 %call
119}
Sriraman Tallam7da9b442016-04-29 21:19:16 +0000120
121!llvm.module.flags = !{!0, !1}
122!0 = !{i32 1, !"PIC Level", i32 1}
123!1 = !{i32 1, !"PIE Level", i32 1}