1// RUN: llvm-mc -filetype=obj -triple mipsel-unknown-linux %s -o - | llvm-readobj -r | FileCheck %s
2
3// Check that the appropriate relocations were created.
4
5// CHECK: Relocations [
6// CHECK:   Section {{.*}} .rel.text {
7// CHECK:     R_MIPS_TLS_LDM
8// CHECK:     R_MIPS_TLS_DTPREL_HI16
9// CHECK:     R_MIPS_TLS_DTPREL_LO16
10// CHECK:   }
11// CHECK: ]
12
13	.text
14	.abicalls
15	.section	.mdebug.abi32,"",@progbits
16	.file	"/home/espindola/llvm/llvm/test/MC/Mips/elf-tls.ll"
17	.text
18	.globl	f1
19	.align	2
20	.type	f1,@function
21	.set	nomips16
22	.ent	f1
23f1:                                     # @f1
24	.frame	$sp,24,$ra
25	.mask 	0x80000000,-4
26	.fmask	0x00000000,0
27	.set	noreorder
28	.set	nomacro
29	.set	noat
30# %bb.0:                                # %entry
31	lui	$2, %hi(_gp_disp)
32	addiu	$2, $2, %lo(_gp_disp)
33	addiu	$sp, $sp, -24
34	sw	$ra, 20($sp)            # 4-byte Folded Spill
35	addu	$gp, $2, $25
36	lw	$25, %call16(__tls_get_addr)($gp)
37	jalr	$25
38	addiu	$4, $gp, %tlsgd(t1)
39	lw	$2, 0($2)
40	lw	$ra, 20($sp)            # 4-byte Folded Reload
41	jr	$ra
42	addiu	$sp, $sp, 24
43	.set	at
44	.set	macro
45	.set	reorder
46	.end	f1
47$tmp0:
48	.size	f1, ($tmp0)-f1
49
50	.globl	f2
51	.align	2
52	.type	f2,@function
53	.set	nomips16
54	.ent	f2
55f2:                                     # @f2
56	.frame	$sp,24,$ra
57	.mask 	0x80000000,-4
58	.fmask	0x00000000,0
59	.set	noreorder
60	.set	nomacro
61	.set	noat
62# %bb.0:                                # %entry
63	lui	$2, %hi(_gp_disp)
64	addiu	$2, $2, %lo(_gp_disp)
65	addiu	$sp, $sp, -24
66	sw	$ra, 20($sp)            # 4-byte Folded Spill
67	addu	$gp, $2, $25
68	lw	$25, %call16(__tls_get_addr)($gp)
69	jalr	$25
70	addiu	$4, $gp, %tlsgd(t2)
71	lw	$2, 0($2)
72	lw	$ra, 20($sp)            # 4-byte Folded Reload
73	jr	$ra
74	addiu	$sp, $sp, 24
75	.set	at
76	.set	macro
77	.set	reorder
78	.end	f2
79$tmp1:
80	.size	f2, ($tmp1)-f2
81
82	.globl	f3
83	.align	2
84	.type	f3,@function
85	.set	nomips16
86	.ent	f3
87f3:                                     # @f3
88	.frame	$sp,24,$ra
89	.mask 	0x80000000,-4
90	.fmask	0x00000000,0
91	.set	noreorder
92	.set	nomacro
93	.set	noat
94# %bb.0:                                # %entry
95	lui	$2, %hi(_gp_disp)
96	addiu	$2, $2, %lo(_gp_disp)
97	addiu	$sp, $sp, -24
98	sw	$ra, 20($sp)            # 4-byte Folded Spill
99	addu	$gp, $2, $25
100	lw	$25, %call16(__tls_get_addr)($gp)
101	jalr	$25
102	addiu	$4, $gp, %tlsldm(f3.i)
103	lui	$1, %dtprel_hi(f3.i)
104	addu	$1, $1, $2
105	lw	$2, %dtprel_lo(f3.i)($1)
106	addiu	$2, $2, 1
107	sw	$2, %dtprel_lo(f3.i)($1)
108	lw	$ra, 20($sp)            # 4-byte Folded Reload
109	jr	$ra
110	addiu	$sp, $sp, 24
111	.set	at
112	.set	macro
113	.set	reorder
114	.end	f3
115$tmp2:
116	.size	f3, ($tmp2)-f3
117
118	.type	t1,@object              # @t1
119	.section	.tbss,"awT",@nobits
120	.globl	t1
121	.align	2
122t1:
123	.4byte	0                       # 0x0
124	.size	t1, 4
125
126	.type	f3.i,@object            # @f3.i
127	.section	.tdata,"awT",@progbits
128	.align	2
129f3.i:
130	.4byte	1                       # 0x1
131	.size	f3.i, 4
132
133
134	.text
135