* elf-m10300.c (_bfd_mn10300_elf_adjust_dynamic_symbol): Don't error
[external/binutils.git] / bfd / elfxx-sparc.c
1 /* SPARC-specific support for ELF
2    Copyright 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012
3    Free Software Foundation, Inc.
4
5    This file is part of BFD, the Binary File Descriptor library.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20    MA 02110-1301, USA.  */
21
22
23 /* This file handles functionality common to the different SPARC ABI's.  */
24
25 #include "sysdep.h"
26 #include "bfd.h"
27 #include "bfdlink.h"
28 #include "libbfd.h"
29 #include "libiberty.h"
30 #include "elf-bfd.h"
31 #include "elf/sparc.h"
32 #include "opcode/sparc.h"
33 #include "elfxx-sparc.h"
34 #include "elf-vxworks.h"
35 #include "objalloc.h"
36 #include "hashtab.h"
37
38 /* In case we're on a 32-bit machine, construct a 64-bit "-1" value.  */
39 #define MINUS_ONE (~ (bfd_vma) 0)
40
41 #define ABI_64_P(abfd) \
42   (get_elf_backend_data (abfd)->s->elfclass == ELFCLASS64)
43
44 /* The relocation "howto" table.  */
45
46 /* Utility for performing the standard initial work of an instruction
47    relocation.
48    *PRELOCATION will contain the relocated item.
49    *PINSN will contain the instruction from the input stream.
50    If the result is `bfd_reloc_other' the caller can continue with
51    performing the relocation.  Otherwise it must stop and return the
52    value to its caller.  */
53
54 static bfd_reloc_status_type
55 init_insn_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
56                  PTR data, asection *input_section, bfd *output_bfd,
57                  bfd_vma *prelocation, bfd_vma *pinsn)
58 {
59   bfd_vma relocation;
60   reloc_howto_type *howto = reloc_entry->howto;
61
62   if (output_bfd != (bfd *) NULL
63       && (symbol->flags & BSF_SECTION_SYM) == 0
64       && (! howto->partial_inplace
65           || reloc_entry->addend == 0))
66     {
67       reloc_entry->address += input_section->output_offset;
68       return bfd_reloc_ok;
69     }
70
71   /* This works because partial_inplace is FALSE.  */
72   if (output_bfd != NULL)
73     return bfd_reloc_continue;
74
75   if (reloc_entry->address > bfd_get_section_limit (abfd, input_section))
76     return bfd_reloc_outofrange;
77
78   relocation = (symbol->value
79                 + symbol->section->output_section->vma
80                 + symbol->section->output_offset);
81   relocation += reloc_entry->addend;
82   if (howto->pc_relative)
83     {
84       relocation -= (input_section->output_section->vma
85                      + input_section->output_offset);
86       relocation -= reloc_entry->address;
87     }
88
89   *prelocation = relocation;
90   *pinsn = bfd_get_32 (abfd, (bfd_byte *) data + reloc_entry->address);
91   return bfd_reloc_other;
92 }
93
94 /* For unsupported relocs.  */
95
96 static bfd_reloc_status_type
97 sparc_elf_notsup_reloc (bfd *abfd ATTRIBUTE_UNUSED,
98                         arelent *reloc_entry ATTRIBUTE_UNUSED,
99                         asymbol *symbol ATTRIBUTE_UNUSED,
100                         PTR data ATTRIBUTE_UNUSED,
101                         asection *input_section ATTRIBUTE_UNUSED,
102                         bfd *output_bfd ATTRIBUTE_UNUSED,
103                         char **error_message ATTRIBUTE_UNUSED)
104 {
105   return bfd_reloc_notsupported;
106 }
107
108 /* Handle the WDISP16 reloc.  */
109
110 static bfd_reloc_status_type
111 sparc_elf_wdisp16_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
112                          PTR data, asection *input_section, bfd *output_bfd,
113                          char **error_message ATTRIBUTE_UNUSED)
114 {
115   bfd_vma relocation;
116   bfd_vma insn;
117   bfd_reloc_status_type status;
118
119   status = init_insn_reloc (abfd, reloc_entry, symbol, data,
120                             input_section, output_bfd, &relocation, &insn);
121   if (status != bfd_reloc_other)
122     return status;
123
124   insn &= ~ (bfd_vma) 0x303fff;
125   insn |= (((relocation >> 2) & 0xc000) << 6) | ((relocation >> 2) & 0x3fff);
126   bfd_put_32 (abfd, insn, (bfd_byte *) data + reloc_entry->address);
127
128   if ((bfd_signed_vma) relocation < - 0x40000
129       || (bfd_signed_vma) relocation > 0x3ffff)
130     return bfd_reloc_overflow;
131   else
132     return bfd_reloc_ok;
133 }
134
135 /* Handle the HIX22 reloc.  */
136
137 static bfd_reloc_status_type
138 sparc_elf_hix22_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
139                        PTR data, asection *input_section, bfd *output_bfd,
140                        char **error_message ATTRIBUTE_UNUSED)
141 {
142   bfd_vma relocation;
143   bfd_vma insn;
144   bfd_reloc_status_type status;
145
146   status = init_insn_reloc (abfd, reloc_entry, symbol, data,
147                             input_section, output_bfd, &relocation, &insn);
148   if (status != bfd_reloc_other)
149     return status;
150
151   relocation ^= MINUS_ONE;
152   insn = (insn &~ (bfd_vma) 0x3fffff) | ((relocation >> 10) & 0x3fffff);
153   bfd_put_32 (abfd, insn, (bfd_byte *) data + reloc_entry->address);
154
155   if ((relocation & ~ (bfd_vma) 0xffffffff) != 0)
156     return bfd_reloc_overflow;
157   else
158     return bfd_reloc_ok;
159 }
160
161 /* Handle the LOX10 reloc.  */
162
163 static bfd_reloc_status_type
164 sparc_elf_lox10_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
165                        PTR data, asection *input_section, bfd *output_bfd,
166                        char **error_message ATTRIBUTE_UNUSED)
167 {
168   bfd_vma relocation;
169   bfd_vma insn;
170   bfd_reloc_status_type status;
171
172   status = init_insn_reloc (abfd, reloc_entry, symbol, data,
173                             input_section, output_bfd, &relocation, &insn);
174   if (status != bfd_reloc_other)
175     return status;
176
177   insn = (insn &~ (bfd_vma) 0x1fff) | 0x1c00 | (relocation & 0x3ff);
178   bfd_put_32 (abfd, insn, (bfd_byte *) data + reloc_entry->address);
179
180   return bfd_reloc_ok;
181 }
182
183 static reloc_howto_type _bfd_sparc_elf_howto_table[] =
184 {
185   HOWTO(R_SPARC_NONE,      0,0, 0,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_NONE",    FALSE,0,0x00000000,TRUE),
186   HOWTO(R_SPARC_8,         0,0, 8,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_8",       FALSE,0,0x000000ff,TRUE),
187   HOWTO(R_SPARC_16,        0,1,16,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_16",      FALSE,0,0x0000ffff,TRUE),
188   HOWTO(R_SPARC_32,        0,2,32,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_32",      FALSE,0,0xffffffff,TRUE),
189   HOWTO(R_SPARC_DISP8,     0,0, 8,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_DISP8",   FALSE,0,0x000000ff,TRUE),
190   HOWTO(R_SPARC_DISP16,    0,1,16,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_DISP16",  FALSE,0,0x0000ffff,TRUE),
191   HOWTO(R_SPARC_DISP32,    0,2,32,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_DISP32",  FALSE,0,0xffffffff,TRUE),
192   HOWTO(R_SPARC_WDISP30,   2,2,30,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_WDISP30", FALSE,0,0x3fffffff,TRUE),
193   HOWTO(R_SPARC_WDISP22,   2,2,22,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_WDISP22", FALSE,0,0x003fffff,TRUE),
194   HOWTO(R_SPARC_HI22,     10,2,22,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_HI22",    FALSE,0,0x003fffff,TRUE),
195   HOWTO(R_SPARC_22,        0,2,22,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_22",      FALSE,0,0x003fffff,TRUE),
196   HOWTO(R_SPARC_13,        0,2,13,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_13",      FALSE,0,0x00001fff,TRUE),
197   HOWTO(R_SPARC_LO10,      0,2,10,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_LO10",    FALSE,0,0x000003ff,TRUE),
198   HOWTO(R_SPARC_GOT10,     0,2,10,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_GOT10",   FALSE,0,0x000003ff,TRUE),
199   HOWTO(R_SPARC_GOT13,     0,2,13,FALSE,0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_GOT13",   FALSE,0,0x00001fff,TRUE),
200   HOWTO(R_SPARC_GOT22,    10,2,22,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_GOT22",   FALSE,0,0x003fffff,TRUE),
201   HOWTO(R_SPARC_PC10,      0,2,10,TRUE, 0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_PC10",    FALSE,0,0x000003ff,TRUE),
202   HOWTO(R_SPARC_PC22,     10,2,22,TRUE, 0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_PC22",    FALSE,0,0x003fffff,TRUE),
203   HOWTO(R_SPARC_WPLT30,    2,2,30,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_WPLT30",  FALSE,0,0x3fffffff,TRUE),
204   HOWTO(R_SPARC_COPY,      0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_COPY",    FALSE,0,0x00000000,TRUE),
205   HOWTO(R_SPARC_GLOB_DAT,  0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_GLOB_DAT",FALSE,0,0x00000000,TRUE),
206   HOWTO(R_SPARC_JMP_SLOT,  0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_JMP_SLOT",FALSE,0,0x00000000,TRUE),
207   HOWTO(R_SPARC_RELATIVE,  0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_RELATIVE",FALSE,0,0x00000000,TRUE),
208   HOWTO(R_SPARC_UA32,      0,2,32,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_UA32",    FALSE,0,0xffffffff,TRUE),
209   HOWTO(R_SPARC_PLT32,     0,2,32,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_PLT32",   FALSE,0,0xffffffff,TRUE),
210   HOWTO(R_SPARC_HIPLT22,   0,0,00,FALSE,0,complain_overflow_dont,    sparc_elf_notsup_reloc, "R_SPARC_HIPLT22",  FALSE,0,0x00000000,TRUE),
211   HOWTO(R_SPARC_LOPLT10,   0,0,00,FALSE,0,complain_overflow_dont,    sparc_elf_notsup_reloc, "R_SPARC_LOPLT10",  FALSE,0,0x00000000,TRUE),
212   HOWTO(R_SPARC_PCPLT32,   0,0,00,FALSE,0,complain_overflow_dont,    sparc_elf_notsup_reloc, "R_SPARC_PCPLT32",  FALSE,0,0x00000000,TRUE),
213   HOWTO(R_SPARC_PCPLT22,   0,0,00,FALSE,0,complain_overflow_dont,    sparc_elf_notsup_reloc, "R_SPARC_PCPLT22",  FALSE,0,0x00000000,TRUE),
214   HOWTO(R_SPARC_PCPLT10,   0,0,00,FALSE,0,complain_overflow_dont,    sparc_elf_notsup_reloc, "R_SPARC_PCPLT10",  FALSE,0,0x00000000,TRUE),
215   HOWTO(R_SPARC_10,        0,2,10,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_10",      FALSE,0,0x000003ff,TRUE),
216   HOWTO(R_SPARC_11,        0,2,11,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_11",      FALSE,0,0x000007ff,TRUE),
217   HOWTO(R_SPARC_64,        0,4,64,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_64",      FALSE,0,MINUS_ONE, TRUE),
218   HOWTO(R_SPARC_OLO10,     0,2,13,FALSE,0,complain_overflow_signed,  sparc_elf_notsup_reloc, "R_SPARC_OLO10",   FALSE,0,0x00001fff,TRUE),
219   HOWTO(R_SPARC_HH22,     42,2,22,FALSE,0,complain_overflow_unsigned,bfd_elf_generic_reloc,  "R_SPARC_HH22",    FALSE,0,0x003fffff,TRUE),
220   HOWTO(R_SPARC_HM10,     32,2,10,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_HM10",    FALSE,0,0x000003ff,TRUE),
221   HOWTO(R_SPARC_LM22,     10,2,22,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_LM22",    FALSE,0,0x003fffff,TRUE),
222   HOWTO(R_SPARC_PC_HH22,  42,2,22,TRUE, 0,complain_overflow_unsigned,bfd_elf_generic_reloc,  "R_SPARC_PC_HH22",    FALSE,0,0x003fffff,TRUE),
223   HOWTO(R_SPARC_PC_HM10,  32,2,10,TRUE, 0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_PC_HM10",    FALSE,0,0x000003ff,TRUE),
224   HOWTO(R_SPARC_PC_LM22,  10,2,22,TRUE, 0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_PC_LM22",    FALSE,0,0x003fffff,TRUE),
225   HOWTO(R_SPARC_WDISP16,   2,2,16,TRUE, 0,complain_overflow_signed,  sparc_elf_wdisp16_reloc,"R_SPARC_WDISP16", FALSE,0,0x00000000,TRUE),
226   HOWTO(R_SPARC_WDISP19,   2,2,19,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_WDISP19", FALSE,0,0x0007ffff,TRUE),
227   HOWTO(R_SPARC_UNUSED_42, 0,0, 0,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_UNUSED_42",FALSE,0,0x00000000,TRUE),
228   HOWTO(R_SPARC_7,         0,2, 7,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_7",       FALSE,0,0x0000007f,TRUE),
229   HOWTO(R_SPARC_5,         0,2, 5,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_5",       FALSE,0,0x0000001f,TRUE),
230   HOWTO(R_SPARC_6,         0,2, 6,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_6",       FALSE,0,0x0000003f,TRUE),
231   HOWTO(R_SPARC_DISP64,    0,4,64,TRUE, 0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_DISP64",  FALSE,0,MINUS_ONE, TRUE),
232   HOWTO(R_SPARC_PLT64,     0,4,64,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_PLT64",   FALSE,0,MINUS_ONE, TRUE),
233   HOWTO(R_SPARC_HIX22,     0,4, 0,FALSE,0,complain_overflow_bitfield,sparc_elf_hix22_reloc,  "R_SPARC_HIX22",   FALSE,0,MINUS_ONE, FALSE),
234   HOWTO(R_SPARC_LOX10,     0,4, 0,FALSE,0,complain_overflow_dont,    sparc_elf_lox10_reloc,  "R_SPARC_LOX10",   FALSE,0,MINUS_ONE, FALSE),
235   HOWTO(R_SPARC_H44,      22,2,22,FALSE,0,complain_overflow_unsigned,bfd_elf_generic_reloc,  "R_SPARC_H44",     FALSE,0,0x003fffff,FALSE),
236   HOWTO(R_SPARC_M44,      12,2,10,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_M44",     FALSE,0,0x000003ff,FALSE),
237   HOWTO(R_SPARC_L44,       0,2,13,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_L44",     FALSE,0,0x00000fff,FALSE),
238   HOWTO(R_SPARC_REGISTER,  0,4, 0,FALSE,0,complain_overflow_bitfield,sparc_elf_notsup_reloc, "R_SPARC_REGISTER",FALSE,0,MINUS_ONE, FALSE),
239   HOWTO(R_SPARC_UA64,        0,4,64,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_UA64",      FALSE,0,MINUS_ONE, TRUE),
240   HOWTO(R_SPARC_UA16,        0,1,16,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,  "R_SPARC_UA16",      FALSE,0,0x0000ffff,TRUE),
241   HOWTO(R_SPARC_TLS_GD_HI22,10,2,22,FALSE,0,complain_overflow_dont,  bfd_elf_generic_reloc,  "R_SPARC_TLS_GD_HI22",FALSE,0,0x003fffff,TRUE),
242   HOWTO(R_SPARC_TLS_GD_LO10,0,2,10,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_GD_LO10",FALSE,0,0x000003ff,TRUE),
243   HOWTO(R_SPARC_TLS_GD_ADD,0,0, 0,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_TLS_GD_ADD",FALSE,0,0x00000000,TRUE),
244   HOWTO(R_SPARC_TLS_GD_CALL,2,2,30,TRUE,0,complain_overflow_signed,  bfd_elf_generic_reloc,  "R_SPARC_TLS_GD_CALL",FALSE,0,0x3fffffff,TRUE),
245   HOWTO(R_SPARC_TLS_LDM_HI22,10,2,22,FALSE,0,complain_overflow_dont, bfd_elf_generic_reloc,  "R_SPARC_TLS_LDM_HI22",FALSE,0,0x003fffff,TRUE),
246   HOWTO(R_SPARC_TLS_LDM_LO10,0,2,10,FALSE,0,complain_overflow_dont,  bfd_elf_generic_reloc,  "R_SPARC_TLS_LDM_LO10",FALSE,0,0x000003ff,TRUE),
247   HOWTO(R_SPARC_TLS_LDM_ADD,0,0, 0,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_LDM_ADD",FALSE,0,0x00000000,TRUE),
248   HOWTO(R_SPARC_TLS_LDM_CALL,2,2,30,TRUE,0,complain_overflow_signed, bfd_elf_generic_reloc,  "R_SPARC_TLS_LDM_CALL",FALSE,0,0x3fffffff,TRUE),
249   HOWTO(R_SPARC_TLS_LDO_HIX22,0,2,0,FALSE,0,complain_overflow_bitfield,sparc_elf_hix22_reloc,"R_SPARC_TLS_LDO_HIX22",FALSE,0,0x003fffff, FALSE),
250   HOWTO(R_SPARC_TLS_LDO_LOX10,0,2,0,FALSE,0,complain_overflow_dont,  sparc_elf_lox10_reloc,  "R_SPARC_TLS_LDO_LOX10",FALSE,0,0x000003ff, FALSE),
251   HOWTO(R_SPARC_TLS_LDO_ADD,0,0, 0,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_LDO_ADD",FALSE,0,0x00000000,TRUE),
252   HOWTO(R_SPARC_TLS_IE_HI22,10,2,22,FALSE,0,complain_overflow_dont,  bfd_elf_generic_reloc,  "R_SPARC_TLS_IE_HI22",FALSE,0,0x003fffff,TRUE),
253   HOWTO(R_SPARC_TLS_IE_LO10,0,2,10,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_IE_LO10",FALSE,0,0x000003ff,TRUE),
254   HOWTO(R_SPARC_TLS_IE_LD,0,0, 0,FALSE,0,complain_overflow_dont,     bfd_elf_generic_reloc,  "R_SPARC_TLS_IE_LD",FALSE,0,0x00000000,TRUE),
255   HOWTO(R_SPARC_TLS_IE_LDX,0,0, 0,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_TLS_IE_LDX",FALSE,0,0x00000000,TRUE),
256   HOWTO(R_SPARC_TLS_IE_ADD,0,0, 0,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_TLS_IE_ADD",FALSE,0,0x00000000,TRUE),
257   HOWTO(R_SPARC_TLS_LE_HIX22,0,2,0,FALSE,0,complain_overflow_bitfield,sparc_elf_hix22_reloc, "R_SPARC_TLS_LE_HIX22",FALSE,0,0x003fffff, FALSE),
258   HOWTO(R_SPARC_TLS_LE_LOX10,0,2,0,FALSE,0,complain_overflow_dont,   sparc_elf_lox10_reloc,  "R_SPARC_TLS_LE_LOX10",FALSE,0,0x000003ff, FALSE),
259   HOWTO(R_SPARC_TLS_DTPMOD32,0,0, 0,FALSE,0,complain_overflow_dont,  bfd_elf_generic_reloc,  "R_SPARC_TLS_DTPMOD32",FALSE,0,0x00000000,TRUE),
260   HOWTO(R_SPARC_TLS_DTPMOD64,0,0, 0,FALSE,0,complain_overflow_dont,  bfd_elf_generic_reloc,  "R_SPARC_TLS_DTPMOD64",FALSE,0,0x00000000,TRUE),
261   HOWTO(R_SPARC_TLS_DTPOFF32,0,2,32,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,"R_SPARC_TLS_DTPOFF32",FALSE,0,0xffffffff,TRUE),
262   HOWTO(R_SPARC_TLS_DTPOFF64,0,4,64,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc,"R_SPARC_TLS_DTPOFF64",FALSE,0,MINUS_ONE,TRUE),
263   HOWTO(R_SPARC_TLS_TPOFF32,0,0, 0,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_TPOFF32",FALSE,0,0x00000000,TRUE),
264   HOWTO(R_SPARC_TLS_TPOFF64,0,0, 0,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_TLS_TPOFF64",FALSE,0,0x00000000,TRUE),
265   HOWTO(R_SPARC_GOTDATA_HIX22,0,2,0,FALSE,0,complain_overflow_bitfield,sparc_elf_hix22_reloc,"R_SPARC_GOTDATA_HIX22",FALSE,0,0x003fffff, FALSE),
266   HOWTO(R_SPARC_GOTDATA_LOX10,0,2,0,FALSE,0,complain_overflow_dont,  sparc_elf_lox10_reloc,  "R_SPARC_GOTDATA_LOX10",FALSE,0,0x000003ff, FALSE),
267   HOWTO(R_SPARC_GOTDATA_OP_HIX22,0,2,0,FALSE,0,complain_overflow_bitfield,sparc_elf_hix22_reloc,"R_SPARC_GOTDATA_OP_HIX22",FALSE,0,0x003fffff, FALSE),
268   HOWTO(R_SPARC_GOTDATA_OP_LOX10,0,2,0,FALSE,0,complain_overflow_dont,  sparc_elf_lox10_reloc,  "R_SPARC_GOTDATA_OP_LOX10",FALSE,0,0x000003ff, FALSE),
269   HOWTO(R_SPARC_GOTDATA_OP,0,0, 0,FALSE,0,complain_overflow_dont,   bfd_elf_generic_reloc,  "R_SPARC_GOTDATA_OP",FALSE,0,0x00000000,TRUE),
270 };
271 static reloc_howto_type sparc_jmp_irel_howto =
272   HOWTO(R_SPARC_JMP_IREL,  0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_JMP_IREL",FALSE,0,0x00000000,TRUE);
273 static reloc_howto_type sparc_irelative_howto =
274   HOWTO(R_SPARC_IRELATIVE,  0,0,00,FALSE,0,complain_overflow_dont,    bfd_elf_generic_reloc,  "R_SPARC_IRELATIVE",FALSE,0,0x00000000,TRUE);
275 static reloc_howto_type sparc_vtinherit_howto =
276   HOWTO (R_SPARC_GNU_VTINHERIT, 0,2,0,FALSE,0,complain_overflow_dont, NULL, "R_SPARC_GNU_VTINHERIT", FALSE,0, 0, FALSE);
277 static reloc_howto_type sparc_vtentry_howto =
278   HOWTO (R_SPARC_GNU_VTENTRY, 0,2,0,FALSE,0,complain_overflow_dont, _bfd_elf_rel_vtable_reloc_fn,"R_SPARC_GNU_VTENTRY", FALSE,0,0, FALSE);
279 static reloc_howto_type sparc_rev32_howto =
280   HOWTO(R_SPARC_REV32, 0,2,32,FALSE,0,complain_overflow_bitfield,bfd_elf_generic_reloc, "R_SPARC_REV32", FALSE,0,0xffffffff,TRUE);
281
282 reloc_howto_type *
283 _bfd_sparc_elf_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED,
284                                   bfd_reloc_code_real_type code)
285 {
286   /* We explicitly handle each relocation type in the switch
287      instead of using a lookup table for efficiency.  */
288   switch (code)
289     {
290     case BFD_RELOC_NONE:
291       return &_bfd_sparc_elf_howto_table[R_SPARC_NONE];
292
293     case BFD_RELOC_8:
294       return &_bfd_sparc_elf_howto_table[R_SPARC_8];
295
296     case BFD_RELOC_16:
297       return &_bfd_sparc_elf_howto_table[R_SPARC_16];
298
299     case BFD_RELOC_32:
300       return &_bfd_sparc_elf_howto_table[R_SPARC_32];
301
302     case BFD_RELOC_8_PCREL:
303       return &_bfd_sparc_elf_howto_table[R_SPARC_DISP8];
304
305     case BFD_RELOC_16_PCREL:
306       return &_bfd_sparc_elf_howto_table[R_SPARC_DISP16];
307
308     case BFD_RELOC_32_PCREL:
309       return &_bfd_sparc_elf_howto_table[R_SPARC_DISP32];
310
311     case BFD_RELOC_32_PCREL_S2:
312       return &_bfd_sparc_elf_howto_table[R_SPARC_WDISP30];
313
314     case BFD_RELOC_SPARC_WDISP22:
315       return &_bfd_sparc_elf_howto_table[R_SPARC_WDISP22];
316
317     case BFD_RELOC_HI22:
318       return &_bfd_sparc_elf_howto_table[R_SPARC_HI22];
319
320     case BFD_RELOC_SPARC22:
321       return &_bfd_sparc_elf_howto_table[R_SPARC_22];
322
323     case BFD_RELOC_SPARC13:
324       return &_bfd_sparc_elf_howto_table[R_SPARC_13];
325
326     case BFD_RELOC_LO10:
327       return &_bfd_sparc_elf_howto_table[R_SPARC_LO10];
328
329     case BFD_RELOC_SPARC_GOT10:
330       return &_bfd_sparc_elf_howto_table[R_SPARC_GOT10];
331
332     case BFD_RELOC_SPARC_GOT13:
333       return &_bfd_sparc_elf_howto_table[R_SPARC_GOT13];
334
335     case BFD_RELOC_SPARC_GOT22:
336       return &_bfd_sparc_elf_howto_table[R_SPARC_GOT22];
337
338     case BFD_RELOC_SPARC_PC10:
339       return &_bfd_sparc_elf_howto_table[R_SPARC_PC10];
340
341     case BFD_RELOC_SPARC_PC22:
342       return &_bfd_sparc_elf_howto_table[R_SPARC_PC22];
343
344     case BFD_RELOC_SPARC_WPLT30:
345       return &_bfd_sparc_elf_howto_table[R_SPARC_WPLT30];
346
347     case BFD_RELOC_SPARC_COPY:
348       return &_bfd_sparc_elf_howto_table[R_SPARC_COPY];
349
350     case BFD_RELOC_SPARC_GLOB_DAT:
351       return &_bfd_sparc_elf_howto_table[R_SPARC_GLOB_DAT];
352
353     case BFD_RELOC_SPARC_JMP_SLOT:
354       return &_bfd_sparc_elf_howto_table[R_SPARC_JMP_SLOT];
355
356     case BFD_RELOC_SPARC_RELATIVE:
357       return &_bfd_sparc_elf_howto_table[R_SPARC_RELATIVE];
358
359     case BFD_RELOC_SPARC_UA32:
360       return &_bfd_sparc_elf_howto_table[R_SPARC_UA32];
361
362     case BFD_RELOC_SPARC_PLT32:
363       return &_bfd_sparc_elf_howto_table[R_SPARC_PLT32];
364
365     case BFD_RELOC_SPARC_10:
366       return &_bfd_sparc_elf_howto_table[R_SPARC_10];
367
368     case BFD_RELOC_SPARC_11:
369       return &_bfd_sparc_elf_howto_table[R_SPARC_11];
370
371     case BFD_RELOC_SPARC_64:
372       return &_bfd_sparc_elf_howto_table[R_SPARC_64];
373
374     case BFD_RELOC_SPARC_OLO10:
375       return &_bfd_sparc_elf_howto_table[R_SPARC_OLO10];
376
377     case BFD_RELOC_SPARC_HH22:
378       return &_bfd_sparc_elf_howto_table[R_SPARC_HH22];
379
380     case BFD_RELOC_SPARC_HM10:
381       return &_bfd_sparc_elf_howto_table[R_SPARC_HM10];
382
383     case BFD_RELOC_SPARC_LM22:
384       return &_bfd_sparc_elf_howto_table[R_SPARC_LM22];
385
386     case BFD_RELOC_SPARC_PC_HH22:
387       return &_bfd_sparc_elf_howto_table[R_SPARC_PC_HH22];
388
389     case BFD_RELOC_SPARC_PC_HM10:
390       return &_bfd_sparc_elf_howto_table[R_SPARC_PC_HM10];
391
392     case BFD_RELOC_SPARC_PC_LM22:
393       return &_bfd_sparc_elf_howto_table[R_SPARC_PC_LM22];
394
395     case BFD_RELOC_SPARC_WDISP16:
396       return &_bfd_sparc_elf_howto_table[R_SPARC_WDISP16];
397
398     case BFD_RELOC_SPARC_WDISP19:
399       return &_bfd_sparc_elf_howto_table[R_SPARC_WDISP19];
400
401     case BFD_RELOC_SPARC_7:
402       return &_bfd_sparc_elf_howto_table[R_SPARC_7];
403
404     case BFD_RELOC_SPARC_5:
405       return &_bfd_sparc_elf_howto_table[R_SPARC_5];
406
407     case BFD_RELOC_SPARC_6:
408       return &_bfd_sparc_elf_howto_table[R_SPARC_6];
409
410     case BFD_RELOC_SPARC_DISP64:
411       return &_bfd_sparc_elf_howto_table[R_SPARC_DISP64];
412
413     case BFD_RELOC_SPARC_PLT64:
414       return &_bfd_sparc_elf_howto_table[R_SPARC_PLT64];
415
416     case BFD_RELOC_SPARC_HIX22:
417       return &_bfd_sparc_elf_howto_table[R_SPARC_HIX22];
418
419     case BFD_RELOC_SPARC_LOX10:
420       return &_bfd_sparc_elf_howto_table[R_SPARC_LOX10];
421
422     case BFD_RELOC_SPARC_H44:
423       return &_bfd_sparc_elf_howto_table[R_SPARC_H44];
424
425     case BFD_RELOC_SPARC_M44:
426       return &_bfd_sparc_elf_howto_table[R_SPARC_M44];
427
428     case BFD_RELOC_SPARC_L44:
429       return &_bfd_sparc_elf_howto_table[R_SPARC_L44];
430
431     case BFD_RELOC_SPARC_REGISTER:
432       return &_bfd_sparc_elf_howto_table[R_SPARC_REGISTER];
433
434     case BFD_RELOC_SPARC_UA64:
435       return &_bfd_sparc_elf_howto_table[R_SPARC_UA64];
436
437     case BFD_RELOC_SPARC_UA16:
438       return &_bfd_sparc_elf_howto_table[R_SPARC_UA16];
439
440     case BFD_RELOC_SPARC_TLS_GD_HI22:
441       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_GD_HI22];
442
443     case BFD_RELOC_SPARC_TLS_GD_LO10:
444       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_GD_LO10];
445
446     case BFD_RELOC_SPARC_TLS_GD_ADD:
447       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_GD_ADD];
448
449     case BFD_RELOC_SPARC_TLS_GD_CALL:
450       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_GD_CALL];
451
452     case BFD_RELOC_SPARC_TLS_LDM_HI22:
453       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDM_HI22];
454
455     case BFD_RELOC_SPARC_TLS_LDM_LO10:
456       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDM_LO10];
457
458     case BFD_RELOC_SPARC_TLS_LDM_ADD:
459       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDM_ADD];
460
461     case BFD_RELOC_SPARC_TLS_LDM_CALL:
462       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDM_CALL];
463
464     case BFD_RELOC_SPARC_TLS_LDO_HIX22:
465       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDO_HIX22];
466
467     case BFD_RELOC_SPARC_TLS_LDO_LOX10:
468       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDO_LOX10];
469
470     case BFD_RELOC_SPARC_TLS_LDO_ADD:
471       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LDO_ADD];
472
473     case BFD_RELOC_SPARC_TLS_IE_HI22:
474       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_IE_HI22];
475
476     case BFD_RELOC_SPARC_TLS_IE_LO10:
477       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_IE_LO10];
478
479     case BFD_RELOC_SPARC_TLS_IE_LD:
480       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_IE_LD];
481
482     case BFD_RELOC_SPARC_TLS_IE_LDX:
483       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_IE_LDX];
484
485     case BFD_RELOC_SPARC_TLS_IE_ADD:
486       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_IE_ADD];
487
488     case BFD_RELOC_SPARC_TLS_LE_HIX22:
489       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LE_HIX22];
490
491     case BFD_RELOC_SPARC_TLS_LE_LOX10:
492       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_LE_LOX10];
493
494     case BFD_RELOC_SPARC_TLS_DTPMOD32:
495       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_DTPMOD32];
496
497     case BFD_RELOC_SPARC_TLS_DTPMOD64:
498       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_DTPMOD64];
499
500     case BFD_RELOC_SPARC_TLS_DTPOFF32:
501       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_DTPOFF32];
502
503     case BFD_RELOC_SPARC_TLS_DTPOFF64:
504       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_DTPOFF64];
505
506     case BFD_RELOC_SPARC_TLS_TPOFF32:
507       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_TPOFF32];
508
509     case BFD_RELOC_SPARC_TLS_TPOFF64:
510       return &_bfd_sparc_elf_howto_table[R_SPARC_TLS_TPOFF64];
511
512     case BFD_RELOC_SPARC_GOTDATA_HIX22:
513       return &_bfd_sparc_elf_howto_table[R_SPARC_GOTDATA_HIX22];
514
515     case BFD_RELOC_SPARC_GOTDATA_LOX10:
516       return &_bfd_sparc_elf_howto_table[R_SPARC_GOTDATA_LOX10];
517
518     case BFD_RELOC_SPARC_GOTDATA_OP_HIX22:
519       return &_bfd_sparc_elf_howto_table[R_SPARC_GOTDATA_OP_HIX22];
520
521     case BFD_RELOC_SPARC_GOTDATA_OP_LOX10:
522       return &_bfd_sparc_elf_howto_table[R_SPARC_GOTDATA_OP_LOX10];
523
524     case BFD_RELOC_SPARC_GOTDATA_OP:
525       return &_bfd_sparc_elf_howto_table[R_SPARC_GOTDATA_OP];
526
527     case BFD_RELOC_SPARC_JMP_IREL:
528       return &sparc_jmp_irel_howto;
529
530     case BFD_RELOC_SPARC_IRELATIVE:
531       return &sparc_irelative_howto;
532
533     case BFD_RELOC_VTABLE_INHERIT:
534       return &sparc_vtinherit_howto;
535
536     case BFD_RELOC_VTABLE_ENTRY:
537       return &sparc_vtentry_howto;
538
539     case BFD_RELOC_SPARC_REV32:
540       return &sparc_rev32_howto;
541
542     default:
543       break;
544     }
545     bfd_set_error (bfd_error_bad_value);
546     return NULL;
547 }
548
549 reloc_howto_type *
550 _bfd_sparc_elf_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED,
551                                   const char *r_name)
552 {
553   unsigned int i;
554
555   for (i = 0;
556        i < (sizeof (_bfd_sparc_elf_howto_table)
557             / sizeof (_bfd_sparc_elf_howto_table[0]));
558        i++)
559     if (_bfd_sparc_elf_howto_table[i].name != NULL
560         && strcasecmp (_bfd_sparc_elf_howto_table[i].name, r_name) == 0)
561       return &_bfd_sparc_elf_howto_table[i];
562
563   if (strcasecmp (sparc_vtinherit_howto.name, r_name) == 0)
564     return &sparc_vtinherit_howto;
565   if (strcasecmp (sparc_vtentry_howto.name, r_name) == 0)
566     return &sparc_vtentry_howto;
567   if (strcasecmp (sparc_rev32_howto.name, r_name) == 0)
568     return &sparc_rev32_howto;
569
570   return NULL;
571 }
572
573 reloc_howto_type *
574 _bfd_sparc_elf_info_to_howto_ptr (unsigned int r_type)
575 {
576   switch (r_type)
577     {
578     case R_SPARC_JMP_IREL:
579       return &sparc_jmp_irel_howto;
580
581     case R_SPARC_IRELATIVE:
582       return &sparc_irelative_howto;
583
584     case R_SPARC_GNU_VTINHERIT:
585       return &sparc_vtinherit_howto;
586
587     case R_SPARC_GNU_VTENTRY:
588       return &sparc_vtentry_howto;
589
590     case R_SPARC_REV32:
591       return &sparc_rev32_howto;
592
593     default:
594       if (r_type >= (unsigned int) R_SPARC_max_std)
595         {
596           (*_bfd_error_handler) (_("invalid relocation type %d"),
597                                  (int) r_type);
598           r_type = R_SPARC_NONE;
599         }
600       return &_bfd_sparc_elf_howto_table[r_type];
601     }
602 }
603
604 /* Both 32-bit and 64-bit sparc encode this in an identical manner,
605    so just take advantage of that.  */
606 #define SPARC_ELF_R_TYPE(r_info)        \
607         ((r_info) & 0xff)
608
609 void
610 _bfd_sparc_elf_info_to_howto (bfd *abfd ATTRIBUTE_UNUSED, arelent *cache_ptr,
611                               Elf_Internal_Rela *dst)
612 {
613   unsigned int r_type = SPARC_ELF_R_TYPE (dst->r_info);
614
615   cache_ptr->howto = _bfd_sparc_elf_info_to_howto_ptr (r_type);
616 }
617 \f
618
619 /* The nop opcode we use.  */
620 #define SPARC_NOP 0x01000000
621
622 #define SPARC_INSN_BYTES        4
623
624 /* The SPARC linker needs to keep track of the number of relocs that it
625    decides to copy as dynamic relocs in check_relocs for each symbol.
626    This is so that it can later discard them if they are found to be
627    unnecessary.  We store the information in a field extending the
628    regular ELF linker hash table.  */
629
630 struct _bfd_sparc_elf_dyn_relocs
631 {
632   struct _bfd_sparc_elf_dyn_relocs *next;
633
634   /* The input section of the reloc.  */
635   asection *sec;
636
637   /* Total number of relocs copied for the input section.  */
638   bfd_size_type count;
639
640   /* Number of pc-relative relocs copied for the input section.  */
641   bfd_size_type pc_count;
642 };
643
644 /* SPARC ELF linker hash entry.  */
645
646 struct _bfd_sparc_elf_link_hash_entry
647 {
648   struct elf_link_hash_entry elf;
649
650   /* Track dynamic relocs copied for this symbol.  */
651   struct _bfd_sparc_elf_dyn_relocs *dyn_relocs;
652
653 #define GOT_UNKNOWN     0
654 #define GOT_NORMAL      1
655 #define GOT_TLS_GD      2
656 #define GOT_TLS_IE      3
657   unsigned char tls_type;
658 };
659
660 #define _bfd_sparc_elf_hash_entry(ent) ((struct _bfd_sparc_elf_link_hash_entry *)(ent))
661
662 struct _bfd_sparc_elf_obj_tdata
663 {
664   struct elf_obj_tdata root;
665
666   /* tls_type for each local got entry.  */
667   char *local_got_tls_type;
668
669   /* TRUE if TLS GD relocs has been seen for this object.  */
670   bfd_boolean has_tlsgd;
671 };
672
673 #define _bfd_sparc_elf_tdata(abfd) \
674   ((struct _bfd_sparc_elf_obj_tdata *) (abfd)->tdata.any)
675
676 #define _bfd_sparc_elf_local_got_tls_type(abfd) \
677   (_bfd_sparc_elf_tdata (abfd)->local_got_tls_type)
678
679 #define is_sparc_elf(bfd)                               \
680   (bfd_get_flavour (bfd) == bfd_target_elf_flavour      \
681    && elf_tdata (bfd) != NULL                           \
682    && elf_object_id (bfd) == SPARC_ELF_DATA)
683
684 bfd_boolean
685 _bfd_sparc_elf_mkobject (bfd *abfd)
686 {
687   return bfd_elf_allocate_object (abfd, sizeof (struct _bfd_sparc_elf_obj_tdata),
688                                   SPARC_ELF_DATA);
689 }
690
691 static void
692 sparc_put_word_32 (bfd *abfd, bfd_vma val, void *ptr)
693 {
694   bfd_put_32 (abfd, val, ptr);
695 }
696
697 static void
698 sparc_put_word_64 (bfd *abfd, bfd_vma val, void *ptr)
699 {
700   bfd_put_64 (abfd, val, ptr);
701 }
702
703 static void
704 sparc_elf_append_rela (bfd *abfd, asection *s, Elf_Internal_Rela *rel)
705 {
706   const struct elf_backend_data *bed;
707   bfd_byte *loc;
708
709   bed = get_elf_backend_data (abfd);
710   loc = s->contents + (s->reloc_count++ * bed->s->sizeof_rela);
711   bed->s->swap_reloca_out (abfd, rel, loc);
712 }
713
714 static bfd_vma
715 sparc_elf_r_info_64 (Elf_Internal_Rela *in_rel ATTRIBUTE_UNUSED,
716                      bfd_vma rel_index ATTRIBUTE_UNUSED,
717                      bfd_vma type ATTRIBUTE_UNUSED)
718 {
719   return ELF64_R_INFO (rel_index,
720                        (in_rel ?
721                         ELF64_R_TYPE_INFO (ELF64_R_TYPE_DATA (in_rel->r_info),
722                                            type) : type));
723 }
724
725 static bfd_vma
726 sparc_elf_r_info_32 (Elf_Internal_Rela *in_rel ATTRIBUTE_UNUSED,
727                      bfd_vma rel_index, bfd_vma type)
728 {
729   return ELF32_R_INFO (rel_index, type);
730 }
731
732 static bfd_vma
733 sparc_elf_r_symndx_64 (bfd_vma r_info)
734 {
735   bfd_vma r_symndx = ELF32_R_SYM (r_info);
736   return (r_symndx >> 24);
737 }
738
739 static bfd_vma
740 sparc_elf_r_symndx_32 (bfd_vma r_info)
741 {
742   return ELF32_R_SYM (r_info);
743 }
744
745 /* PLT/GOT stuff */
746
747 #define PLT32_ENTRY_SIZE 12
748 #define PLT32_HEADER_SIZE       (4 * PLT32_ENTRY_SIZE)
749
750 /* The first four entries in a 32-bit procedure linkage table are reserved,
751    and the initial contents are unimportant (we zero them out).
752    Subsequent entries look like this.  See the SVR4 ABI SPARC
753    supplement to see how this works.  */
754
755 /* sethi %hi(.-.plt0),%g1.  We fill in the address later.  */
756 #define PLT32_ENTRY_WORD0 0x03000000
757 /* b,a .plt0.  We fill in the offset later.  */
758 #define PLT32_ENTRY_WORD1 0x30800000
759 /* nop.  */
760 #define PLT32_ENTRY_WORD2 SPARC_NOP
761
762 static int
763 sparc32_plt_entry_build (bfd *output_bfd, asection *splt, bfd_vma offset,
764                          bfd_vma max ATTRIBUTE_UNUSED,
765                          bfd_vma *r_offset)
766 {
767       bfd_put_32 (output_bfd,
768                   PLT32_ENTRY_WORD0 + offset,
769                   splt->contents + offset);
770       bfd_put_32 (output_bfd,
771                   (PLT32_ENTRY_WORD1
772                    + (((- (offset + 4)) >> 2) & 0x3fffff)),
773                   splt->contents + offset + 4);
774       bfd_put_32 (output_bfd, (bfd_vma) PLT32_ENTRY_WORD2,
775                   splt->contents + offset + 8);
776
777       *r_offset = offset;
778
779       return offset / PLT32_ENTRY_SIZE - 4;
780 }
781
782 /* Both the headers and the entries are icache aligned.  */
783 #define PLT64_ENTRY_SIZE        32
784 #define PLT64_HEADER_SIZE       (4 * PLT64_ENTRY_SIZE)
785 #define PLT64_LARGE_THRESHOLD   32768
786
787 static int
788 sparc64_plt_entry_build (bfd *output_bfd, asection *splt, bfd_vma offset,
789                          bfd_vma max, bfd_vma *r_offset)
790 {
791   unsigned char *entry = splt->contents + offset;
792   const unsigned int nop = SPARC_NOP;
793   int plt_index;
794
795   if (offset < (PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE))
796     {
797       unsigned int sethi, ba;
798
799       *r_offset = offset;
800
801       plt_index = (offset / PLT64_ENTRY_SIZE);
802
803       sethi = 0x03000000 | (plt_index * PLT64_ENTRY_SIZE);
804       ba = 0x30680000
805         | (((splt->contents + PLT64_ENTRY_SIZE) - (entry + 4)) / 4 & 0x7ffff);
806
807       bfd_put_32 (output_bfd, (bfd_vma) sethi, entry);
808       bfd_put_32 (output_bfd, (bfd_vma) ba,    entry + 4);
809       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 8);
810       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 12);
811       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 16);
812       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 20);
813       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 24);
814       bfd_put_32 (output_bfd, (bfd_vma) nop,   entry + 28);
815     }
816   else
817     {
818       unsigned char *ptr;
819       unsigned int ldx;
820       int block, last_block, ofs, last_ofs, chunks_this_block;
821       const int insn_chunk_size = (6 * 4);
822       const int ptr_chunk_size = (1 * 8);
823       const int entries_per_block = 160;
824       const int block_size = entries_per_block * (insn_chunk_size
825                                                   + ptr_chunk_size);
826
827       /* Entries 32768 and higher are grouped into blocks of 160.
828          The blocks are further subdivided into 160 sequences of
829          6 instructions and 160 pointers.  If a block does not require
830          the full 160 entries, let's say it requires N, then there
831          will be N sequences of 6 instructions and N pointers.  */
832
833       offset -= (PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE);
834       max -= (PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE);
835
836       block = offset / block_size;
837       last_block = max / block_size;
838       if (block != last_block)
839         {
840           chunks_this_block = 160;
841         }
842       else
843         {
844           last_ofs = max % block_size;
845           chunks_this_block = last_ofs / (insn_chunk_size + ptr_chunk_size);
846         }
847
848       ofs = offset % block_size;
849
850       plt_index = (PLT64_LARGE_THRESHOLD +
851                (block * 160) +
852                (ofs / insn_chunk_size));
853
854       ptr = splt->contents
855         + (PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE)
856         + (block * block_size)
857         + (chunks_this_block * insn_chunk_size)
858         + (ofs / insn_chunk_size) * ptr_chunk_size;
859
860       *r_offset = (bfd_vma) (ptr - splt->contents);
861
862       ldx = 0xc25be000 | ((ptr - (entry+4)) & 0x1fff);
863
864       /* mov %o7,%g5
865          call .+8
866          nop
867          ldx [%o7+P],%g1
868          jmpl %o7+%g1,%g1
869          mov %g5,%o7  */
870       bfd_put_32 (output_bfd, (bfd_vma) 0x8a10000f, entry);
871       bfd_put_32 (output_bfd, (bfd_vma) 0x40000002, entry + 4);
872       bfd_put_32 (output_bfd, (bfd_vma) SPARC_NOP,  entry + 8);
873       bfd_put_32 (output_bfd, (bfd_vma) ldx,        entry + 12);
874       bfd_put_32 (output_bfd, (bfd_vma) 0x83c3c001, entry + 16);
875       bfd_put_32 (output_bfd, (bfd_vma) 0x9e100005, entry + 20);
876
877       bfd_put_64 (output_bfd, (bfd_vma) (splt->contents - (entry + 4)), ptr);
878     }
879
880   return plt_index - 4;
881 }
882
883 /* The format of the first PLT entry in a VxWorks executable.  */
884 static const bfd_vma sparc_vxworks_exec_plt0_entry[] =
885   {
886     0x05000000, /* sethi  %hi(_GLOBAL_OFFSET_TABLE_+8), %g2 */
887     0x8410a000, /* or     %g2, %lo(_GLOBAL_OFFSET_TABLE_+8), %g2 */
888     0xc4008000, /* ld     [ %g2 ], %g2 */
889     0x81c08000, /* jmp    %g2 */
890     0x01000000  /* nop */
891   };
892
893 /* The format of subsequent PLT entries.  */
894 static const bfd_vma sparc_vxworks_exec_plt_entry[] =
895   {
896     0x03000000, /* sethi  %hi(_GLOBAL_OFFSET_TABLE_+f@got), %g1 */
897     0x82106000, /* or     %g1, %lo(_GLOBAL_OFFSET_TABLE_+f@got), %g1 */
898     0xc2004000, /* ld     [ %g1 ], %g1 */
899     0x81c04000, /* jmp    %g1 */
900     0x01000000, /* nop */
901     0x03000000, /* sethi  %hi(f@pltindex), %g1 */
902     0x10800000, /* b      _PLT_resolve */
903     0x82106000  /* or     %g1, %lo(f@pltindex), %g1 */
904   };
905
906 /* The format of the first PLT entry in a VxWorks shared object.  */
907 static const bfd_vma sparc_vxworks_shared_plt0_entry[] =
908   {
909     0xc405e008, /* ld     [ %l7 + 8 ], %g2 */
910     0x81c08000, /* jmp    %g2 */
911     0x01000000  /* nop */
912   };
913
914 /* The format of subsequent PLT entries.  */
915 static const bfd_vma sparc_vxworks_shared_plt_entry[] =
916   {
917     0x03000000, /* sethi  %hi(f@got), %g1 */
918     0x82106000, /* or     %g1, %lo(f@got), %g1 */
919     0xc205c001, /* ld     [ %l7 + %g1 ], %g1 */
920     0x81c04000, /* jmp    %g1 */
921     0x01000000, /* nop */
922     0x03000000, /* sethi  %hi(f@pltindex), %g1 */
923     0x10800000, /* b      _PLT_resolve */
924     0x82106000  /* or     %g1, %lo(f@pltindex), %g1 */
925   };
926
927 #define SPARC_ELF_PUT_WORD(htab, bfd, val, ptr) \
928         htab->put_word(bfd, val, ptr)
929
930 #define SPARC_ELF_R_INFO(htab, in_rel, index, type)     \
931         htab->r_info(in_rel, index, type)
932
933 #define SPARC_ELF_R_SYMNDX(htab, r_info)        \
934         htab->r_symndx(r_info)
935
936 #define SPARC_ELF_WORD_BYTES(htab)      \
937         htab->bytes_per_word
938
939 #define SPARC_ELF_RELA_BYTES(htab)      \
940         htab->bytes_per_rela
941
942 #define SPARC_ELF_DTPOFF_RELOC(htab)    \
943         htab->dtpoff_reloc
944
945 #define SPARC_ELF_DTPMOD_RELOC(htab)    \
946         htab->dtpmod_reloc
947
948 #define SPARC_ELF_TPOFF_RELOC(htab)     \
949         htab->tpoff_reloc
950
951 #define SPARC_ELF_BUILD_PLT_ENTRY(htab, obfd, splt, off, max, r_off) \
952         htab->build_plt_entry (obfd, splt, off, max, r_off)
953
954 /* Create an entry in an SPARC ELF linker hash table.  */
955
956 static struct bfd_hash_entry *
957 link_hash_newfunc (struct bfd_hash_entry *entry,
958                    struct bfd_hash_table *table, const char *string)
959 {
960   /* Allocate the structure if it has not already been allocated by a
961      subclass.  */
962   if (entry == NULL)
963     {
964       entry = bfd_hash_allocate (table,
965                                  sizeof (struct _bfd_sparc_elf_link_hash_entry));
966       if (entry == NULL)
967         return entry;
968     }
969
970   /* Call the allocation method of the superclass.  */
971   entry = _bfd_elf_link_hash_newfunc (entry, table, string);
972   if (entry != NULL)
973     {
974       struct _bfd_sparc_elf_link_hash_entry *eh;
975
976       eh = (struct _bfd_sparc_elf_link_hash_entry *) entry;
977       eh->dyn_relocs = NULL;
978       eh->tls_type = GOT_UNKNOWN;
979     }
980
981   return entry;
982 }
983
984 /* The name of the dynamic interpreter.  This is put in the .interp
985    section.  */
986
987 #define ELF32_DYNAMIC_INTERPRETER "/usr/lib/ld.so.1"
988 #define ELF64_DYNAMIC_INTERPRETER "/usr/lib/sparcv9/ld.so.1"
989
990 /* Compute a hash of a local hash entry.  We use elf_link_hash_entry
991    for local symbol so that we can handle local STT_GNU_IFUNC symbols
992    as global symbol.  We reuse indx and dynstr_index for local symbol
993    hash since they aren't used by global symbols in this backend.  */
994
995 static hashval_t
996 elf_sparc_local_htab_hash (const void *ptr)
997 {
998   struct elf_link_hash_entry *h
999     = (struct elf_link_hash_entry *) ptr;
1000   return ELF_LOCAL_SYMBOL_HASH (h->indx, h->dynstr_index);
1001 }
1002
1003 /* Compare local hash entries.  */
1004
1005 static int
1006 elf_sparc_local_htab_eq (const void *ptr1, const void *ptr2)
1007 {
1008   struct elf_link_hash_entry *h1
1009      = (struct elf_link_hash_entry *) ptr1;
1010   struct elf_link_hash_entry *h2
1011     = (struct elf_link_hash_entry *) ptr2;
1012
1013   return h1->indx == h2->indx && h1->dynstr_index == h2->dynstr_index;
1014 }
1015
1016 /* Find and/or create a hash entry for local symbol.  */
1017
1018 static struct elf_link_hash_entry *
1019 elf_sparc_get_local_sym_hash (struct _bfd_sparc_elf_link_hash_table *htab,
1020                               bfd *abfd, const Elf_Internal_Rela *rel,
1021                               bfd_boolean create)
1022 {
1023   struct _bfd_sparc_elf_link_hash_entry e, *ret;
1024   asection *sec = abfd->sections;
1025   unsigned long r_symndx;
1026   hashval_t h;
1027   void **slot;
1028
1029   r_symndx = SPARC_ELF_R_SYMNDX (htab, rel->r_info);
1030   h = ELF_LOCAL_SYMBOL_HASH (sec->id, r_symndx);
1031
1032   e.elf.indx = sec->id;
1033   e.elf.dynstr_index = r_symndx;
1034   slot = htab_find_slot_with_hash (htab->loc_hash_table, &e, h,
1035                                    create ? INSERT : NO_INSERT);
1036
1037   if (!slot)
1038     return NULL;
1039
1040   if (*slot)
1041     {
1042       ret = (struct _bfd_sparc_elf_link_hash_entry *) *slot;
1043       return &ret->elf;
1044     }
1045
1046   ret = (struct _bfd_sparc_elf_link_hash_entry *)
1047         objalloc_alloc ((struct objalloc *) htab->loc_hash_memory,
1048                         sizeof (struct _bfd_sparc_elf_link_hash_entry));
1049   if (ret)
1050     {
1051       memset (ret, 0, sizeof (*ret));
1052       ret->elf.indx = sec->id;
1053       ret->elf.dynstr_index = r_symndx;
1054       ret->elf.dynindx = -1;
1055       ret->elf.plt.offset = (bfd_vma) -1;
1056       ret->elf.got.offset = (bfd_vma) -1;
1057       *slot = ret;
1058     }
1059   return &ret->elf;
1060 }
1061
1062 /* Create a SPARC ELF linker hash table.  */
1063
1064 struct bfd_link_hash_table *
1065 _bfd_sparc_elf_link_hash_table_create (bfd *abfd)
1066 {
1067   struct _bfd_sparc_elf_link_hash_table *ret;
1068   bfd_size_type amt = sizeof (struct _bfd_sparc_elf_link_hash_table);
1069
1070   ret = (struct _bfd_sparc_elf_link_hash_table *) bfd_zmalloc (amt);
1071   if (ret == NULL)
1072     return NULL;
1073
1074   if (ABI_64_P (abfd))
1075     {
1076       ret->put_word = sparc_put_word_64;
1077       ret->r_info = sparc_elf_r_info_64;
1078       ret->r_symndx = sparc_elf_r_symndx_64;
1079       ret->dtpoff_reloc = R_SPARC_TLS_DTPOFF64;
1080       ret->dtpmod_reloc = R_SPARC_TLS_DTPMOD64;
1081       ret->tpoff_reloc = R_SPARC_TLS_TPOFF64;
1082       ret->word_align_power = 3;
1083       ret->align_power_max = 4;
1084       ret->bytes_per_word = 8;
1085       ret->bytes_per_rela = sizeof (Elf64_External_Rela);
1086       ret->dynamic_interpreter = ELF64_DYNAMIC_INTERPRETER;
1087       ret->dynamic_interpreter_size = sizeof ELF64_DYNAMIC_INTERPRETER;
1088
1089       ret->build_plt_entry = sparc64_plt_entry_build;
1090       ret->plt_header_size = PLT64_HEADER_SIZE;
1091       ret->plt_entry_size = PLT64_ENTRY_SIZE;
1092     }
1093   else
1094     {
1095       ret->put_word = sparc_put_word_32;
1096       ret->r_info = sparc_elf_r_info_32;
1097       ret->r_symndx = sparc_elf_r_symndx_32;
1098       ret->dtpoff_reloc = R_SPARC_TLS_DTPOFF32;
1099       ret->dtpmod_reloc = R_SPARC_TLS_DTPMOD32;
1100       ret->tpoff_reloc = R_SPARC_TLS_TPOFF32;
1101       ret->word_align_power = 2;
1102       ret->align_power_max = 3;
1103       ret->bytes_per_word = 4;
1104       ret->bytes_per_rela = sizeof (Elf32_External_Rela);
1105       ret->dynamic_interpreter = ELF32_DYNAMIC_INTERPRETER;
1106       ret->dynamic_interpreter_size = sizeof ELF32_DYNAMIC_INTERPRETER;
1107
1108       ret->build_plt_entry = sparc32_plt_entry_build;
1109       ret->plt_header_size = PLT32_HEADER_SIZE;
1110       ret->plt_entry_size = PLT32_ENTRY_SIZE;
1111     }
1112
1113   if (!_bfd_elf_link_hash_table_init (&ret->elf, abfd, link_hash_newfunc,
1114                                       sizeof (struct _bfd_sparc_elf_link_hash_entry),
1115                                       SPARC_ELF_DATA))
1116     {
1117       free (ret);
1118       return NULL;
1119     }
1120
1121   ret->loc_hash_table = htab_try_create (1024,
1122                                          elf_sparc_local_htab_hash,
1123                                          elf_sparc_local_htab_eq,
1124                                          NULL);
1125   ret->loc_hash_memory = objalloc_create ();
1126   if (!ret->loc_hash_table || !ret->loc_hash_memory)
1127     {
1128       free (ret);
1129       return NULL;
1130     }
1131
1132   return &ret->elf.root;
1133 }
1134
1135 /* Destroy a SPARC ELF linker hash table.  */
1136
1137 void
1138 _bfd_sparc_elf_link_hash_table_free (struct bfd_link_hash_table *hash)
1139 {
1140   struct _bfd_sparc_elf_link_hash_table *htab
1141     = (struct _bfd_sparc_elf_link_hash_table *) hash;
1142
1143   if (htab->loc_hash_table)
1144     htab_delete (htab->loc_hash_table);
1145   if (htab->loc_hash_memory)
1146     objalloc_free ((struct objalloc *) htab->loc_hash_memory);
1147   _bfd_generic_link_hash_table_free (hash);
1148 }
1149
1150 /* Create .plt, .rela.plt, .got, .rela.got, .dynbss, and
1151    .rela.bss sections in DYNOBJ, and set up shortcuts to them in our
1152    hash table.  */
1153
1154 bfd_boolean
1155 _bfd_sparc_elf_create_dynamic_sections (bfd *dynobj,
1156                                         struct bfd_link_info *info)
1157 {
1158   struct _bfd_sparc_elf_link_hash_table *htab;
1159
1160   htab = _bfd_sparc_elf_hash_table (info);
1161   BFD_ASSERT (htab != NULL);
1162
1163   if (!_bfd_elf_create_dynamic_sections (dynobj, info))
1164     return FALSE;
1165
1166   htab->sdynbss = bfd_get_section_by_name (dynobj, ".dynbss");
1167   if (!info->shared)
1168     htab->srelbss = bfd_get_section_by_name (dynobj, ".rela.bss");
1169
1170   if (htab->is_vxworks)
1171     {
1172       if (!elf_vxworks_create_dynamic_sections (dynobj, info, &htab->srelplt2))
1173         return FALSE;
1174       if (info->shared)
1175         {
1176           htab->plt_header_size
1177             = 4 * ARRAY_SIZE (sparc_vxworks_shared_plt0_entry);
1178           htab->plt_entry_size
1179             = 4 * ARRAY_SIZE (sparc_vxworks_shared_plt_entry);
1180         }
1181       else
1182         {
1183           htab->plt_header_size
1184             = 4 * ARRAY_SIZE (sparc_vxworks_exec_plt0_entry);
1185           htab->plt_entry_size
1186             = 4 * ARRAY_SIZE (sparc_vxworks_exec_plt_entry);
1187         }
1188     }
1189
1190   if (!htab->elf.splt || !htab->elf.srelplt || !htab->sdynbss
1191       || (!info->shared && !htab->srelbss))
1192     abort ();
1193
1194   return TRUE;
1195 }
1196
1197 static bfd_boolean
1198 create_ifunc_sections (bfd *abfd, struct bfd_link_info *info)
1199 {
1200   const struct elf_backend_data *bed = get_elf_backend_data (abfd);
1201   struct elf_link_hash_table *htab = elf_hash_table (info);
1202   flagword flags, pltflags;
1203   asection *s;
1204
1205   if (htab->irelifunc != NULL || htab->iplt != NULL)
1206     return TRUE;
1207
1208   flags = bed->dynamic_sec_flags;
1209   pltflags = flags | SEC_ALLOC | SEC_CODE | SEC_LOAD;
1210
1211   s = bfd_make_section_with_flags (abfd, ".iplt", pltflags);
1212   if (s == NULL
1213       || ! bfd_set_section_alignment (abfd, s, bed->plt_alignment))
1214     return FALSE;
1215   htab->iplt = s;
1216
1217   s = bfd_make_section_with_flags (abfd, ".rela.iplt",
1218                                    flags | SEC_READONLY);
1219   if (s == NULL
1220       || ! bfd_set_section_alignment (abfd, s,
1221                                       bed->s->log_file_align))
1222     return FALSE;
1223   htab->irelplt = s;
1224
1225   return TRUE;
1226 }
1227
1228 /* Copy the extra info we tack onto an elf_link_hash_entry.  */
1229
1230 void
1231 _bfd_sparc_elf_copy_indirect_symbol (struct bfd_link_info *info,
1232                                      struct elf_link_hash_entry *dir,
1233                                      struct elf_link_hash_entry *ind)
1234 {
1235   struct _bfd_sparc_elf_link_hash_entry *edir, *eind;
1236
1237   edir = (struct _bfd_sparc_elf_link_hash_entry *) dir;
1238   eind = (struct _bfd_sparc_elf_link_hash_entry *) ind;
1239
1240   if (eind->dyn_relocs != NULL)
1241     {
1242       if (edir->dyn_relocs != NULL)
1243         {
1244           struct _bfd_sparc_elf_dyn_relocs **pp;
1245           struct _bfd_sparc_elf_dyn_relocs *p;
1246
1247           /* Add reloc counts against the indirect sym to the direct sym
1248              list.  Merge any entries against the same section.  */
1249           for (pp = &eind->dyn_relocs; (p = *pp) != NULL; )
1250             {
1251               struct _bfd_sparc_elf_dyn_relocs *q;
1252
1253               for (q = edir->dyn_relocs; q != NULL; q = q->next)
1254                 if (q->sec == p->sec)
1255                   {
1256                     q->pc_count += p->pc_count;
1257                     q->count += p->count;
1258                     *pp = p->next;
1259                     break;
1260                   }
1261               if (q == NULL)
1262                 pp = &p->next;
1263             }
1264           *pp = edir->dyn_relocs;
1265         }
1266
1267       edir->dyn_relocs = eind->dyn_relocs;
1268       eind->dyn_relocs = NULL;
1269     }
1270
1271   if (ind->root.type == bfd_link_hash_indirect
1272       && dir->got.refcount <= 0)
1273     {
1274       edir->tls_type = eind->tls_type;
1275       eind->tls_type = GOT_UNKNOWN;
1276     }
1277   _bfd_elf_link_hash_copy_indirect (info, dir, ind);
1278 }
1279
1280 static int
1281 sparc_elf_tls_transition (struct bfd_link_info *info, bfd *abfd,
1282                           int r_type, int is_local)
1283 {
1284   if (! ABI_64_P (abfd)
1285       && r_type == R_SPARC_TLS_GD_HI22
1286       && ! _bfd_sparc_elf_tdata (abfd)->has_tlsgd)
1287     r_type = R_SPARC_REV32;
1288
1289   if (info->shared)
1290     return r_type;
1291
1292   switch (r_type)
1293     {
1294     case R_SPARC_TLS_GD_HI22:
1295       if (is_local)
1296         return R_SPARC_TLS_LE_HIX22;
1297       return R_SPARC_TLS_IE_HI22;
1298     case R_SPARC_TLS_GD_LO10:
1299       if (is_local)
1300         return R_SPARC_TLS_LE_LOX10;
1301       return R_SPARC_TLS_IE_LO10;
1302     case R_SPARC_TLS_IE_HI22:
1303       if (is_local)
1304         return R_SPARC_TLS_LE_HIX22;
1305       return r_type;
1306     case R_SPARC_TLS_IE_LO10:
1307       if (is_local)
1308         return R_SPARC_TLS_LE_LOX10;
1309       return r_type;
1310     case R_SPARC_TLS_LDM_HI22:
1311       return R_SPARC_TLS_LE_HIX22;
1312     case R_SPARC_TLS_LDM_LO10:
1313       return R_SPARC_TLS_LE_LOX10;
1314     }
1315
1316   return r_type;
1317 }
1318 \f
1319 /* Look through the relocs for a section during the first phase, and
1320    allocate space in the global offset table or procedure linkage
1321    table.  */
1322
1323 bfd_boolean
1324 _bfd_sparc_elf_check_relocs (bfd *abfd, struct bfd_link_info *info,
1325                              asection *sec, const Elf_Internal_Rela *relocs)
1326 {
1327   struct _bfd_sparc_elf_link_hash_table *htab;
1328   Elf_Internal_Shdr *symtab_hdr;
1329   struct elf_link_hash_entry **sym_hashes;
1330   const Elf_Internal_Rela *rel;
1331   const Elf_Internal_Rela *rel_end;
1332   asection *sreloc;
1333   int num_relocs;
1334   bfd_boolean checked_tlsgd = FALSE;
1335
1336   if (info->relocatable)
1337     return TRUE;
1338
1339   htab = _bfd_sparc_elf_hash_table (info);
1340   BFD_ASSERT (htab != NULL);
1341   symtab_hdr = &elf_symtab_hdr (abfd);
1342   sym_hashes = elf_sym_hashes (abfd);
1343
1344   sreloc = NULL;
1345
1346   if (ABI_64_P (abfd))
1347     num_relocs = NUM_SHDR_ENTRIES (_bfd_elf_single_rel_hdr (sec));
1348   else
1349     num_relocs = sec->reloc_count;
1350
1351   BFD_ASSERT (is_sparc_elf (abfd) || num_relocs == 0);
1352
1353   if (htab->elf.dynobj == NULL)
1354     htab->elf.dynobj = abfd;
1355   if (!create_ifunc_sections (htab->elf.dynobj, info))
1356     return FALSE;
1357
1358   rel_end = relocs + num_relocs;
1359   for (rel = relocs; rel < rel_end; rel++)
1360     {
1361       unsigned int r_type;
1362       unsigned long r_symndx;
1363       struct elf_link_hash_entry *h;
1364       Elf_Internal_Sym *isym;
1365
1366       r_symndx = SPARC_ELF_R_SYMNDX (htab, rel->r_info);
1367       r_type = SPARC_ELF_R_TYPE (rel->r_info);
1368
1369       if (r_symndx >= NUM_SHDR_ENTRIES (symtab_hdr))
1370         {
1371           (*_bfd_error_handler) (_("%B: bad symbol index: %d"),
1372                                  abfd, r_symndx);
1373           return FALSE;
1374         }
1375
1376       isym = NULL;
1377       if (r_symndx < symtab_hdr->sh_info)
1378         {
1379           /* A local symbol.  */
1380           isym = bfd_sym_from_r_symndx (&htab->sym_cache,
1381                                         abfd, r_symndx);
1382           if (isym == NULL)
1383             return FALSE;
1384
1385           /* Check relocation against local STT_GNU_IFUNC symbol.  */
1386           if (ELF_ST_TYPE (isym->st_info) == STT_GNU_IFUNC)
1387             {
1388               h = elf_sparc_get_local_sym_hash (htab, abfd, rel,
1389                                                 TRUE);
1390               if (h == NULL)
1391                 return FALSE;
1392               
1393               /* Fake a STT_GNU_IFUNC symbol.  */
1394               h->type = STT_GNU_IFUNC;
1395               h->def_regular = 1;
1396               h->ref_regular = 1;
1397               h->forced_local = 1;
1398               h->root.type = bfd_link_hash_defined;
1399             }
1400           else
1401             h = NULL;
1402         }
1403       else
1404         {
1405           h = sym_hashes[r_symndx - symtab_hdr->sh_info];
1406           while (h->root.type == bfd_link_hash_indirect
1407                  || h->root.type == bfd_link_hash_warning)
1408             h = (struct elf_link_hash_entry *) h->root.u.i.link;
1409         }
1410
1411       if (h && h->type == STT_GNU_IFUNC)
1412         {
1413           if (h->def_regular)
1414             {
1415               h->ref_regular = 1;
1416               h->plt.refcount += 1;
1417             }
1418         }
1419
1420       /* Compatibility with old R_SPARC_REV32 reloc conflicting
1421          with R_SPARC_TLS_GD_HI22.  */
1422       if (! ABI_64_P (abfd) && ! checked_tlsgd)
1423         switch (r_type)
1424           {
1425           case R_SPARC_TLS_GD_HI22:
1426             {
1427               const Elf_Internal_Rela *relt;
1428
1429               for (relt = rel + 1; relt < rel_end; relt++)
1430                 if (ELF32_R_TYPE (relt->r_info) == R_SPARC_TLS_GD_LO10
1431                     || ELF32_R_TYPE (relt->r_info) == R_SPARC_TLS_GD_ADD
1432                     || ELF32_R_TYPE (relt->r_info) == R_SPARC_TLS_GD_CALL)
1433                   break;
1434               checked_tlsgd = TRUE;
1435               _bfd_sparc_elf_tdata (abfd)->has_tlsgd = relt < rel_end;
1436             }
1437             break;
1438           case R_SPARC_TLS_GD_LO10:
1439           case R_SPARC_TLS_GD_ADD:
1440           case R_SPARC_TLS_GD_CALL:
1441             checked_tlsgd = TRUE;
1442             _bfd_sparc_elf_tdata (abfd)->has_tlsgd = TRUE;
1443             break;
1444           }
1445
1446       r_type = sparc_elf_tls_transition (info, abfd, r_type, h == NULL);
1447       switch (r_type)
1448         {
1449         case R_SPARC_TLS_LDM_HI22:
1450         case R_SPARC_TLS_LDM_LO10:
1451           htab->tls_ldm_got.refcount += 1;
1452           break;
1453
1454         case R_SPARC_TLS_LE_HIX22:
1455         case R_SPARC_TLS_LE_LOX10:
1456           if (info->shared)
1457             goto r_sparc_plt32;
1458           break;
1459
1460         case R_SPARC_TLS_IE_HI22:
1461         case R_SPARC_TLS_IE_LO10:
1462           if (info->shared)
1463             info->flags |= DF_STATIC_TLS;
1464           /* Fall through */
1465
1466         case R_SPARC_GOT10:
1467         case R_SPARC_GOT13:
1468         case R_SPARC_GOT22:
1469         case R_SPARC_GOTDATA_HIX22:
1470         case R_SPARC_GOTDATA_LOX10:
1471         case R_SPARC_GOTDATA_OP_HIX22:
1472         case R_SPARC_GOTDATA_OP_LOX10:
1473         case R_SPARC_TLS_GD_HI22:
1474         case R_SPARC_TLS_GD_LO10:
1475           /* This symbol requires a global offset table entry.  */
1476           {
1477             int tls_type, old_tls_type;
1478
1479             switch (r_type)
1480               {
1481               default:
1482               case R_SPARC_GOT10:
1483               case R_SPARC_GOT13:
1484               case R_SPARC_GOT22:
1485               case R_SPARC_GOTDATA_OP_HIX22:
1486               case R_SPARC_GOTDATA_OP_LOX10:
1487                 tls_type = GOT_NORMAL;
1488                 break;
1489               case R_SPARC_TLS_GD_HI22:
1490               case R_SPARC_TLS_GD_LO10:
1491                 tls_type = GOT_TLS_GD;
1492                 break;
1493               case R_SPARC_TLS_IE_HI22:
1494               case R_SPARC_TLS_IE_LO10:
1495                 tls_type = GOT_TLS_IE;
1496                 break;
1497               }
1498
1499             if (h != NULL)
1500               {
1501                 h->got.refcount += 1;
1502                 old_tls_type = _bfd_sparc_elf_hash_entry(h)->tls_type;
1503               }
1504             else
1505               {
1506                 bfd_signed_vma *local_got_refcounts;
1507
1508                 /* This is a global offset table entry for a local symbol.  */
1509                 local_got_refcounts = elf_local_got_refcounts (abfd);
1510                 if (local_got_refcounts == NULL)
1511                   {
1512                     bfd_size_type size;
1513
1514                     size = symtab_hdr->sh_info;
1515                     size *= (sizeof (bfd_signed_vma) + sizeof(char));
1516                     local_got_refcounts = ((bfd_signed_vma *)
1517                                            bfd_zalloc (abfd, size));
1518                     if (local_got_refcounts == NULL)
1519                       return FALSE;
1520                     elf_local_got_refcounts (abfd) = local_got_refcounts;
1521                     _bfd_sparc_elf_local_got_tls_type (abfd)
1522                       = (char *) (local_got_refcounts + symtab_hdr->sh_info);
1523                   }
1524                 switch (r_type)
1525                   {
1526                   case R_SPARC_GOTDATA_OP_HIX22:
1527                   case R_SPARC_GOTDATA_OP_LOX10:
1528                     break;
1529
1530                   default:
1531                     local_got_refcounts[r_symndx] += 1;
1532                     break;
1533                   }
1534                 old_tls_type = _bfd_sparc_elf_local_got_tls_type (abfd) [r_symndx];
1535               }
1536
1537             /* If a TLS symbol is accessed using IE at least once,
1538                there is no point to use dynamic model for it.  */
1539             if (old_tls_type != tls_type && old_tls_type != GOT_UNKNOWN
1540                 && (old_tls_type != GOT_TLS_GD
1541                     || tls_type != GOT_TLS_IE))
1542               {
1543                 if (old_tls_type == GOT_TLS_IE && tls_type == GOT_TLS_GD)
1544                   tls_type = old_tls_type;
1545                 else
1546                   {
1547                     (*_bfd_error_handler)
1548                       (_("%B: `%s' accessed both as normal and thread local symbol"),
1549                        abfd, h ? h->root.root.string : "<local>");
1550                     return FALSE;
1551                   }
1552               }
1553
1554             if (old_tls_type != tls_type)
1555               {
1556                 if (h != NULL)
1557                   _bfd_sparc_elf_hash_entry (h)->tls_type = tls_type;
1558                 else
1559                   _bfd_sparc_elf_local_got_tls_type (abfd) [r_symndx] = tls_type;
1560               }
1561           }
1562
1563           if (htab->elf.sgot == NULL)
1564             {
1565               if (!_bfd_elf_create_got_section (htab->elf.dynobj, info))
1566                 return FALSE;
1567             }
1568           break;
1569
1570         case R_SPARC_TLS_GD_CALL:
1571         case R_SPARC_TLS_LDM_CALL:
1572           if (info->shared)
1573             {
1574               /* These are basically R_SPARC_TLS_WPLT30 relocs against
1575                  __tls_get_addr.  */
1576               struct bfd_link_hash_entry *bh = NULL;
1577               if (! _bfd_generic_link_add_one_symbol (info, abfd,
1578                                                       "__tls_get_addr", 0,
1579                                                       bfd_und_section_ptr, 0,
1580                                                       NULL, FALSE, FALSE,
1581                                                       &bh))
1582                 return FALSE;
1583               h = (struct elf_link_hash_entry *) bh;
1584             }
1585           else
1586             break;
1587           /* Fall through */
1588
1589         case R_SPARC_PLT32:
1590         case R_SPARC_WPLT30:
1591         case R_SPARC_HIPLT22:
1592         case R_SPARC_LOPLT10:
1593         case R_SPARC_PCPLT32:
1594         case R_SPARC_PCPLT22:
1595         case R_SPARC_PCPLT10:
1596         case R_SPARC_PLT64:
1597           /* This symbol requires a procedure linkage table entry.  We
1598              actually build the entry in adjust_dynamic_symbol,
1599              because this might be a case of linking PIC code without
1600              linking in any dynamic objects, in which case we don't
1601              need to generate a procedure linkage table after all.  */
1602
1603           if (h == NULL)
1604             {
1605               if (! ABI_64_P (abfd))
1606                 {
1607                   /* The Solaris native assembler will generate a WPLT30
1608                      reloc for a local symbol if you assemble a call from
1609                      one section to another when using -K pic.  We treat
1610                      it as WDISP30.  */
1611                   if (ELF32_R_TYPE (rel->r_info) == R_SPARC_PLT32)
1612                     goto r_sparc_plt32;
1613                   break;
1614                 }
1615               /* PR 7027: We need similar behaviour for 64-bit binaries.  */
1616               else if (r_type == R_SPARC_WPLT30)
1617                 break;
1618
1619               /* It does not make sense to have a procedure linkage
1620                  table entry for a local symbol.  */
1621               bfd_set_error (bfd_error_bad_value);
1622               return FALSE;
1623             }
1624
1625           h->needs_plt = 1;
1626
1627           {
1628             int this_r_type;
1629
1630             this_r_type = SPARC_ELF_R_TYPE (rel->r_info);
1631             if (this_r_type == R_SPARC_PLT32
1632                 || this_r_type == R_SPARC_PLT64)
1633               goto r_sparc_plt32;
1634           }
1635           h->plt.refcount += 1;
1636           break;
1637
1638         case R_SPARC_PC10:
1639         case R_SPARC_PC22:
1640         case R_SPARC_PC_HH22:
1641         case R_SPARC_PC_HM10:
1642         case R_SPARC_PC_LM22:
1643           if (h != NULL)
1644             h->non_got_ref = 1;
1645
1646           if (h != NULL
1647               && strcmp (h->root.root.string, "_GLOBAL_OFFSET_TABLE_") == 0)
1648             break;
1649           /* Fall through.  */
1650
1651         case R_SPARC_DISP8:
1652         case R_SPARC_DISP16:
1653         case R_SPARC_DISP32:
1654         case R_SPARC_DISP64:
1655         case R_SPARC_WDISP30:
1656         case R_SPARC_WDISP22:
1657         case R_SPARC_WDISP19:
1658         case R_SPARC_WDISP16:
1659         case R_SPARC_8:
1660         case R_SPARC_16:
1661         case R_SPARC_32:
1662         case R_SPARC_HI22:
1663         case R_SPARC_22:
1664         case R_SPARC_13:
1665         case R_SPARC_LO10:
1666         case R_SPARC_UA16:
1667         case R_SPARC_UA32:
1668         case R_SPARC_10:
1669         case R_SPARC_11:
1670         case R_SPARC_64:
1671         case R_SPARC_OLO10:
1672         case R_SPARC_HH22:
1673         case R_SPARC_HM10:
1674         case R_SPARC_LM22:
1675         case R_SPARC_7:
1676         case R_SPARC_5:
1677         case R_SPARC_6:
1678         case R_SPARC_HIX22:
1679         case R_SPARC_LOX10:
1680         case R_SPARC_H44:
1681         case R_SPARC_M44:
1682         case R_SPARC_L44:
1683         case R_SPARC_UA64:
1684           if (h != NULL)
1685             h->non_got_ref = 1;
1686
1687         r_sparc_plt32:
1688           if (h != NULL && !info->shared)
1689             {
1690               /* We may need a .plt entry if the function this reloc
1691                  refers to is in a shared lib.  */
1692               h->plt.refcount += 1;
1693             }
1694
1695           /* If we are creating a shared library, and this is a reloc
1696              against a global symbol, or a non PC relative reloc
1697              against a local symbol, then we need to copy the reloc
1698              into the shared library.  However, if we are linking with
1699              -Bsymbolic, we do not need to copy a reloc against a
1700              global symbol which is defined in an object we are
1701              including in the link (i.e., DEF_REGULAR is set).  At
1702              this point we have not seen all the input files, so it is
1703              possible that DEF_REGULAR is not set now but will be set
1704              later (it is never cleared).  In case of a weak definition,
1705              DEF_REGULAR may be cleared later by a strong definition in
1706              a shared library.  We account for that possibility below by
1707              storing information in the relocs_copied field of the hash
1708              table entry.  A similar situation occurs when creating
1709              shared libraries and symbol visibility changes render the
1710              symbol local.
1711
1712              If on the other hand, we are creating an executable, we
1713              may need to keep relocations for symbols satisfied by a
1714              dynamic library if we manage to avoid copy relocs for the
1715              symbol.  */
1716           if ((info->shared
1717                && (sec->flags & SEC_ALLOC) != 0
1718                && (! _bfd_sparc_elf_howto_table[r_type].pc_relative
1719                    || (h != NULL
1720                        && (! SYMBOLIC_BIND (info, h)
1721                            || h->root.type == bfd_link_hash_defweak
1722                            || !h->def_regular))))
1723               || (!info->shared
1724                   && (sec->flags & SEC_ALLOC) != 0
1725                   && h != NULL
1726                   && (h->root.type == bfd_link_hash_defweak
1727                       || !h->def_regular))
1728               || (!info->shared
1729                   && h != NULL
1730                   && h->type == STT_GNU_IFUNC))
1731             {
1732               struct _bfd_sparc_elf_dyn_relocs *p;
1733               struct _bfd_sparc_elf_dyn_relocs **head;
1734
1735               /* When creating a shared object, we must copy these
1736                  relocs into the output file.  We create a reloc
1737                  section in dynobj and make room for the reloc.  */
1738               if (sreloc == NULL)
1739                 {
1740                   sreloc = _bfd_elf_make_dynamic_reloc_section
1741                     (sec, htab->elf.dynobj, htab->word_align_power,
1742                      abfd, /*rela?*/ TRUE);
1743
1744                   if (sreloc == NULL)
1745                     return FALSE;
1746                 }
1747
1748               /* If this is a global symbol, we count the number of
1749                  relocations we need for this symbol.  */
1750               if (h != NULL)
1751                 head = &((struct _bfd_sparc_elf_link_hash_entry *) h)->dyn_relocs;
1752               else
1753                 {
1754                   /* Track dynamic relocs needed for local syms too.
1755                      We really need local syms available to do this
1756                      easily.  Oh well.  */
1757                   asection *s;
1758                   void *vpp;
1759
1760                   BFD_ASSERT (isym != NULL);
1761                   s = bfd_section_from_elf_index (abfd, isym->st_shndx);
1762                   if (s == NULL)
1763                     s = sec;
1764
1765                   vpp = &elf_section_data (s)->local_dynrel;
1766                   head = (struct _bfd_sparc_elf_dyn_relocs **) vpp;
1767                 }
1768
1769               p = *head;
1770               if (p == NULL || p->sec != sec)
1771                 {
1772                   bfd_size_type amt = sizeof *p;
1773                   p = ((struct _bfd_sparc_elf_dyn_relocs *)
1774                        bfd_alloc (htab->elf.dynobj, amt));
1775                   if (p == NULL)
1776                     return FALSE;
1777                   p->next = *head;
1778                   *head = p;
1779                   p->sec = sec;
1780                   p->count = 0;
1781                   p->pc_count = 0;
1782                 }
1783
1784               p->count += 1;
1785               if (_bfd_sparc_elf_howto_table[r_type].pc_relative)
1786                 p->pc_count += 1;
1787             }
1788
1789           break;
1790
1791         case R_SPARC_GNU_VTINHERIT:
1792           if (!bfd_elf_gc_record_vtinherit (abfd, sec, h, rel->r_offset))
1793             return FALSE;
1794           break;
1795
1796         case R_SPARC_GNU_VTENTRY:
1797           BFD_ASSERT (h != NULL);
1798           if (h != NULL
1799               && !bfd_elf_gc_record_vtentry (abfd, sec, h, rel->r_addend))
1800             return FALSE;
1801           break;
1802
1803         case R_SPARC_REGISTER:
1804           /* Nothing to do.  */
1805           break;
1806
1807         default:
1808           break;
1809         }
1810     }
1811
1812   return TRUE;
1813 }
1814 \f
1815 asection *
1816 _bfd_sparc_elf_gc_mark_hook (asection *sec,
1817                              struct bfd_link_info *info,
1818                              Elf_Internal_Rela *rel,
1819                              struct elf_link_hash_entry *h,
1820                              Elf_Internal_Sym *sym)
1821 {
1822   if (h != NULL)
1823     switch (SPARC_ELF_R_TYPE (rel->r_info))
1824       {
1825       case R_SPARC_GNU_VTINHERIT:
1826       case R_SPARC_GNU_VTENTRY:
1827         return NULL;
1828       }
1829
1830   return _bfd_elf_gc_mark_hook (sec, info, rel, h, sym);
1831 }
1832
1833 static Elf_Internal_Rela *
1834 sparc_elf_find_reloc_at_ofs (Elf_Internal_Rela *rel,
1835                              Elf_Internal_Rela *relend,
1836                              bfd_vma offset)
1837 {
1838   while (rel < relend)
1839     {
1840       if (rel->r_offset == offset)
1841         return rel;
1842       rel++;
1843     }
1844   return NULL;
1845 }
1846
1847 /* Update the got entry reference counts for the section being removed.  */
1848 bfd_boolean
1849 _bfd_sparc_elf_gc_sweep_hook (bfd *abfd, struct bfd_link_info *info,
1850                               asection *sec, const Elf_Internal_Rela *relocs)
1851 {
1852   struct _bfd_sparc_elf_link_hash_table *htab;
1853   Elf_Internal_Shdr *symtab_hdr;
1854   struct elf_link_hash_entry **sym_hashes;
1855   bfd_signed_vma *local_got_refcounts;
1856   const Elf_Internal_Rela *rel, *relend;
1857
1858   if (info->relocatable)
1859     return TRUE;
1860
1861   BFD_ASSERT (is_sparc_elf (abfd) || sec->reloc_count == 0);
1862
1863   elf_section_data (sec)->local_dynrel = NULL;
1864
1865   htab = _bfd_sparc_elf_hash_table (info);
1866   BFD_ASSERT (htab != NULL);
1867   symtab_hdr = &elf_symtab_hdr (abfd);
1868   sym_hashes = elf_sym_hashes (abfd);
1869   local_got_refcounts = elf_local_got_refcounts (abfd);
1870
1871   relend = relocs + sec->reloc_count;
1872   for (rel = relocs; rel < relend; rel++)
1873     {
1874       unsigned long r_symndx;
1875       unsigned int r_type;
1876       struct elf_link_hash_entry *h = NULL;
1877
1878       r_symndx = SPARC_ELF_R_SYMNDX (htab, rel->r_info);
1879       if (r_symndx >= symtab_hdr->sh_info)
1880         {
1881           struct _bfd_sparc_elf_link_hash_entry *eh;
1882           struct _bfd_sparc_elf_dyn_relocs **pp;
1883           struct _bfd_sparc_elf_dyn_relocs *p;
1884
1885           h = sym_hashes[r_symndx - symtab_hdr->sh_info];
1886           while (h->root.type == bfd_link_hash_indirect
1887                  || h->root.type == bfd_link_hash_warning)
1888             h = (struct elf_link_hash_entry *) h->root.u.i.link;
1889           eh = (struct _bfd_sparc_elf_link_hash_entry *) h;
1890           for (pp = &eh->dyn_relocs; (p = *pp) != NULL; pp = &p->next)
1891             if (p->sec == sec)
1892               {
1893                 /* Everything must go for SEC.  */
1894                 *pp = p->next;
1895                 break;
1896               }
1897         }
1898
1899       r_type = SPARC_ELF_R_TYPE (rel->r_info);
1900       r_type = sparc_elf_tls_transition (info, abfd, r_type, h != NULL);
1901       switch (r_type)
1902         {
1903         case R_SPARC_TLS_LDM_HI22:
1904         case R_SPARC_TLS_LDM_LO10:
1905           if (_bfd_sparc_elf_hash_table (info)->tls_ldm_got.refcount > 0)
1906             _bfd_sparc_elf_hash_table (info)->tls_ldm_got.refcount -= 1;
1907           break;
1908
1909         case R_SPARC_TLS_GD_HI22:
1910         case R_SPARC_TLS_GD_LO10:
1911         case R_SPARC_TLS_IE_HI22:
1912         case R_SPARC_TLS_IE_LO10:
1913         case R_SPARC_GOT10:
1914         case R_SPARC_GOT13:
1915         case R_SPARC_GOT22:
1916         case R_SPARC_GOTDATA_HIX22:
1917         case R_SPARC_GOTDATA_LOX10:
1918         case R_SPARC_GOTDATA_OP_HIX22:
1919         case R_SPARC_GOTDATA_OP_LOX10:
1920           if (h != NULL)
1921             {
1922               if (h->got.refcount > 0)
1923                 h->got.refcount--;
1924             }
1925           else
1926             {
1927               switch (r_type)
1928                 {
1929                 case R_SPARC_GOTDATA_OP_HIX22:
1930                 case R_SPARC_GOTDATA_OP_LOX10:
1931                   break;
1932
1933                 default:
1934                   if (local_got_refcounts[r_symndx] > 0)
1935                     local_got_refcounts[r_symndx]--;
1936                   break;
1937                 }
1938             }
1939           break;
1940
1941         case R_SPARC_PC10:
1942         case R_SPARC_PC22:
1943         case R_SPARC_PC_HH22:
1944         case R_SPARC_PC_HM10:
1945         case R_SPARC_PC_LM22:
1946           if (h != NULL
1947               && strcmp (h->root.root.string, "_GLOBAL_OFFSET_TABLE_") == 0)
1948             break;
1949           /* Fall through.  */
1950
1951         case R_SPARC_DISP8:
1952         case R_SPARC_DISP16:
1953         case R_SPARC_DISP32:
1954         case R_SPARC_DISP64:
1955         case R_SPARC_WDISP30:
1956         case R_SPARC_WDISP22:
1957         case R_SPARC_WDISP19:
1958         case R_SPARC_WDISP16:
1959         case R_SPARC_8:
1960         case R_SPARC_16:
1961         case R_SPARC_32:
1962         case R_SPARC_HI22:
1963         case R_SPARC_22:
1964         case R_SPARC_13:
1965         case R_SPARC_LO10:
1966         case R_SPARC_UA16:
1967         case R_SPARC_UA32:
1968         case R_SPARC_PLT32:
1969         case R_SPARC_10:
1970         case R_SPARC_11:
1971         case R_SPARC_64:
1972         case R_SPARC_OLO10:
1973         case R_SPARC_HH22:
1974         case R_SPARC_HM10:
1975         case R_SPARC_LM22:
1976         case R_SPARC_7:
1977         case R_SPARC_5:
1978         case R_SPARC_6:
1979         case R_SPARC_HIX22:
1980         case R_SPARC_LOX10:
1981         case R_SPARC_H44:
1982         case R_SPARC_M44:
1983         case R_SPARC_L44:
1984         case R_SPARC_UA64:
1985           if (info->shared)
1986             break;
1987           /* Fall through.  */
1988
1989         case R_SPARC_WPLT30:
1990           if (h != NULL)
1991             {
1992               if (h->plt.refcount > 0)
1993                 h->plt.refcount--;
1994             }
1995           break;
1996
1997         default:
1998           break;
1999         }
2000     }
2001
2002   return TRUE;
2003 }
2004
2005 /* Adjust a symbol defined by a dynamic object and referenced by a
2006    regular object.  The current definition is in some section of the
2007    dynamic object, but we're not including those sections.  We have to
2008    change the definition to something the rest of the link can
2009    understand.  */
2010
2011 bfd_boolean
2012 _bfd_sparc_elf_adjust_dynamic_symbol (struct bfd_link_info *info,
2013                                      struct elf_link_hash_entry *h)
2014 {
2015   struct _bfd_sparc_elf_link_hash_table *htab;
2016   struct _bfd_sparc_elf_link_hash_entry * eh;
2017   struct _bfd_sparc_elf_dyn_relocs *p;
2018   asection *s;
2019
2020   htab = _bfd_sparc_elf_hash_table (info);
2021   BFD_ASSERT (htab != NULL);
2022
2023   /* Make sure we know what is going on here.  */
2024   BFD_ASSERT (htab->elf.dynobj != NULL
2025               && (h->needs_plt
2026                   || h->type == STT_GNU_IFUNC
2027                   || h->u.weakdef != NULL
2028                   || (h->def_dynamic
2029                       && h->ref_regular
2030                       && !h->def_regular)));
2031
2032   /* If this is a function, put it in the procedure linkage table.  We
2033      will fill in the contents of the procedure linkage table later
2034      (although we could actually do it here).  The STT_NOTYPE
2035      condition is a hack specifically for the Oracle libraries
2036      delivered for Solaris; for some inexplicable reason, they define
2037      some of their functions as STT_NOTYPE when they really should be
2038      STT_FUNC.  */
2039   if (h->type == STT_FUNC
2040       || h->type == STT_GNU_IFUNC
2041       || h->needs_plt
2042       || (h->type == STT_NOTYPE
2043           && (h->root.type == bfd_link_hash_defined
2044               || h->root.type == bfd_link_hash_defweak)
2045           && (h->root.u.def.section->flags & SEC_CODE) != 0))
2046     {
2047       if (h->plt.refcount <= 0
2048           || (h->type != STT_GNU_IFUNC
2049               && (SYMBOL_CALLS_LOCAL (info, h)
2050                   || (ELF_ST_VISIBILITY (h->other) != STV_DEFAULT
2051                       && h->root.type == bfd_link_hash_undefweak))))
2052         {
2053           /* This case can occur if we saw a WPLT30 reloc in an input
2054              file, but the symbol was never referred to by a dynamic
2055              object, or if all references were garbage collected.  In
2056              such a case, we don't actually need to build a procedure
2057              linkage table, and we can just do a WDISP30 reloc instead.  */
2058           h->plt.offset = (bfd_vma) -1;
2059           h->needs_plt = 0;
2060         }
2061
2062       return TRUE;
2063     }
2064   else
2065     h->plt.offset = (bfd_vma) -1;
2066
2067   /* If this is a weak symbol, and there is a real definition, the
2068      processor independent code will have arranged for us to see the
2069      real definition first, and we can just use the same value.  */
2070   if (h->u.weakdef != NULL)
2071     {
2072       BFD_ASSERT (h->u.weakdef->root.type == bfd_link_hash_defined
2073                   || h->u.weakdef->root.type == bfd_link_hash_defweak);
2074       h->root.u.def.section = h->u.weakdef->root.u.def.section;
2075       h->root.u.def.value = h->u.weakdef->root.u.def.value;
2076       return TRUE;
2077     }
2078
2079   /* This is a reference to a symbol defined by a dynamic object which
2080      is not a function.  */
2081
2082   /* If we are creating a shared library, we must presume that the
2083      only references to the symbol are via the global offset table.
2084      For such cases we need not do anything here; the relocations will
2085      be handled correctly by relocate_section.  */
2086   if (info->shared)
2087     return TRUE;
2088
2089   /* If there are no references to this symbol that do not use the
2090      GOT, we don't need to generate a copy reloc.  */
2091   if (!h->non_got_ref)
2092     return TRUE;
2093
2094   /* If -z nocopyreloc was given, we won't generate them either.  */
2095   if (info->nocopyreloc)
2096     {
2097       h->non_got_ref = 0;
2098       return TRUE;
2099     }
2100
2101   eh = (struct _bfd_sparc_elf_link_hash_entry *) h;
2102   for (p = eh->dyn_relocs; p != NULL; p = p->next)
2103     {
2104       s = p->sec->output_section;
2105       if (s != NULL && (s->flags & SEC_READONLY) != 0)
2106         break;
2107     }
2108
2109   /* If we didn't find any dynamic relocs in read-only sections, then
2110      we'll be keeping the dynamic relocs and avoiding the copy reloc.  */
2111   if (p == NULL)
2112     {
2113       h->non_got_ref = 0;
2114       return TRUE;
2115     }
2116
2117   /* We must allocate the symbol in our .dynbss section, which will
2118      become part of the .bss section of the executable.  There will be
2119      an entry for this symbol in the .dynsym section.  The dynamic
2120      object will contain position independent code, so all references
2121      from the dynamic object to this symbol will go through the global
2122      offset table.  The dynamic linker will use the .dynsym entry to
2123      determine the address it must put in the global offset table, so
2124      both the dynamic object and the regular object will refer to the
2125      same memory location for the variable.  */
2126
2127   /* We must generate a R_SPARC_COPY reloc to tell the dynamic linker
2128      to copy the initial value out of the dynamic object and into the
2129      runtime process image.  We need to remember the offset into the
2130      .rel.bss section we are going to use.  */
2131   if ((h->root.u.def.section->flags & SEC_ALLOC) != 0 && h->size != 0)
2132     {
2133       htab->srelbss->size += SPARC_ELF_RELA_BYTES (htab);
2134       h->needs_copy = 1;
2135     }
2136
2137   s = htab->sdynbss;
2138
2139   return _bfd_elf_adjust_dynamic_copy (h, s);
2140 }
2141
2142 /* Allocate space in .plt, .got and associated reloc sections for
2143    dynamic relocs.  */
2144
2145 static bfd_boolean
2146 allocate_dynrelocs (struct elf_link_hash_entry *h, PTR inf)
2147 {
2148   struct bfd_link_info *info;
2149   struct _bfd_sparc_elf_link_hash_table *htab;
2150   struct _bfd_sparc_elf_link_hash_entry *eh;
2151   struct _bfd_sparc_elf_dyn_relocs *p;
2152
2153   if (h->root.type == bfd_link_hash_indirect)
2154     return TRUE;
2155
2156   info = (struct bfd_link_info *) inf;
2157   htab = _bfd_sparc_elf_hash_table (info);
2158   BFD_ASSERT (htab != NULL);
2159
2160   if ((htab->elf.dynamic_sections_created
2161        && h->plt.refcount > 0)
2162       || (h->type == STT_GNU_IFUNC
2163           && h->def_regular
2164           && h->ref_regular))
2165     {
2166       /* Make sure this symbol is output as a dynamic symbol.
2167          Undefined weak syms won't yet be marked as dynamic.  */
2168       if (h->dynindx == -1
2169           && !h->forced_local)
2170         {
2171           if (! bfd_elf_link_record_dynamic_symbol (info, h))
2172             return FALSE;
2173         }
2174
2175       if (WILL_CALL_FINISH_DYNAMIC_SYMBOL (1, info->shared, h)
2176           || (h->type == STT_GNU_IFUNC
2177               && h->def_regular))
2178         {
2179           asection *s = htab->elf.splt;
2180
2181           if (s == NULL)
2182             s = htab->elf.iplt;
2183
2184           /* Allocate room for the header.  */
2185           if (s->size == 0)
2186             {
2187               s->size = htab->plt_header_size;
2188
2189               /* Allocate space for the .rela.plt.unloaded relocations.  */
2190               if (htab->is_vxworks && !info->shared)
2191                 htab->srelplt2->size = sizeof (Elf32_External_Rela) * 2;
2192             }
2193
2194           /* The procedure linkage table size is bounded by the magnitude
2195              of the offset we can describe in the entry.  */
2196           if (s->size >= (SPARC_ELF_WORD_BYTES(htab) == 8 ?
2197                           (((bfd_vma)1 << 31) << 1) : 0x400000))
2198             {
2199               bfd_set_error (bfd_error_bad_value);
2200               return FALSE;
2201             }
2202
2203           if (SPARC_ELF_WORD_BYTES(htab) == 8
2204               && s->size >= PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE)
2205             {
2206               bfd_vma off = s->size - PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE;
2207
2208
2209               off = (off % (160 * PLT64_ENTRY_SIZE)) / PLT64_ENTRY_SIZE;
2210
2211               h->plt.offset = (s->size - (off * 8));
2212             }
2213           else
2214             h->plt.offset = s->size;
2215
2216           /* If this symbol is not defined in a regular file, and we are
2217              not generating a shared library, then set the symbol to this
2218              location in the .plt.  This is required to make function
2219              pointers compare as equal between the normal executable and
2220              the shared library.  */
2221           if (! info->shared
2222               && !h->def_regular)
2223             {
2224               h->root.u.def.section = s;
2225               h->root.u.def.value = h->plt.offset;
2226             }
2227
2228           /* Make room for this entry.  */
2229           s->size += htab->plt_entry_size;
2230
2231           /* We also need to make an entry in the .rela.plt section.  */
2232           if (s == htab->elf.splt)
2233             htab->elf.srelplt->size += SPARC_ELF_RELA_BYTES (htab);
2234           else
2235             htab->elf.irelplt->size += SPARC_ELF_RELA_BYTES (htab);
2236
2237           if (htab->is_vxworks)
2238             {
2239               /* Allocate space for the .got.plt entry.  */
2240               htab->elf.sgotplt->size += 4;
2241
2242               /* ...and for the .rela.plt.unloaded relocations.  */
2243               if (!info->shared)
2244                 htab->srelplt2->size += sizeof (Elf32_External_Rela) * 3;
2245             }
2246         }
2247       else
2248         {
2249           h->plt.offset = (bfd_vma) -1;
2250           h->needs_plt = 0;
2251         }
2252     }
2253   else
2254     {
2255       h->plt.offset = (bfd_vma) -1;
2256       h->needs_plt = 0;
2257     }
2258
2259   /* If R_SPARC_TLS_IE_{HI22,LO10} symbol is now local to the binary,
2260      make it a R_SPARC_TLS_LE_{HI22,LO10} requiring no TLS entry.  */
2261   if (h->got.refcount > 0
2262       && !info->shared
2263       && h->dynindx == -1
2264       && _bfd_sparc_elf_hash_entry(h)->tls_type == GOT_TLS_IE)
2265     h->got.offset = (bfd_vma) -1;
2266   else if (h->got.refcount > 0)
2267     {
2268       asection *s;
2269       bfd_boolean dyn;
2270       int tls_type = _bfd_sparc_elf_hash_entry(h)->tls_type;
2271
2272       /* Make sure this symbol is output as a dynamic symbol.
2273          Undefined weak syms won't yet be marked as dynamic.  */
2274       if (h->dynindx == -1
2275           && !h->forced_local)
2276         {
2277           if (! bfd_elf_link_record_dynamic_symbol (info, h))
2278             return FALSE;
2279         }
2280
2281       s = htab->elf.sgot;
2282       h->got.offset = s->size;
2283       s->size += SPARC_ELF_WORD_BYTES (htab);
2284       /* R_SPARC_TLS_GD_HI{22,LO10} needs 2 consecutive GOT slots.  */
2285       if (tls_type == GOT_TLS_GD)
2286         s->size += SPARC_ELF_WORD_BYTES (htab);
2287       dyn = htab->elf.dynamic_sections_created;
2288       /* R_SPARC_TLS_IE_{HI22,LO10} needs one dynamic relocation,
2289          R_SPARC_TLS_GD_{HI22,LO10} needs one if local symbol and two if
2290          global.  */
2291       if ((tls_type == GOT_TLS_GD && h->dynindx == -1)
2292           || tls_type == GOT_TLS_IE
2293           || h->type == STT_GNU_IFUNC)
2294         htab->elf.srelgot->size += SPARC_ELF_RELA_BYTES (htab);
2295       else if (tls_type == GOT_TLS_GD)
2296         htab->elf.srelgot->size += 2 * SPARC_ELF_RELA_BYTES (htab);
2297       else if (WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn, info->shared, h))
2298         htab->elf.srelgot->size += SPARC_ELF_RELA_BYTES (htab);
2299     }
2300   else
2301     h->got.offset = (bfd_vma) -1;
2302
2303   eh = (struct _bfd_sparc_elf_link_hash_entry *) h;
2304   if (eh->dyn_relocs == NULL)
2305     return TRUE;
2306
2307   /* In the shared -Bsymbolic case, discard space allocated for
2308      dynamic pc-relative relocs against symbols which turn out to be
2309      defined in regular objects.  For the normal shared case, discard
2310      space for pc-relative relocs that have become local due to symbol
2311      visibility changes.  */
2312
2313   if (info->shared)
2314     {
2315       if (SYMBOL_CALLS_LOCAL (info, h))
2316         {
2317           struct _bfd_sparc_elf_dyn_relocs **pp;
2318
2319           for (pp = &eh->dyn_relocs; (p = *pp) != NULL; )
2320             {
2321               p->count -= p->pc_count;
2322               p->pc_count = 0;
2323               if (p->count == 0)
2324                 *pp = p->next;
2325               else
2326                 pp = &p->next;
2327             }
2328         }
2329
2330       if (htab->is_vxworks)
2331         {
2332           struct _bfd_sparc_elf_dyn_relocs **pp;
2333
2334           for (pp = &eh->dyn_relocs; (p = *pp) != NULL; )
2335             {
2336               if (strcmp (p->sec->output_section->name, ".tls_vars") == 0)
2337                 *pp = p->next;
2338               else
2339                 pp = &p->next;
2340             }
2341         }
2342
2343       /* Also discard relocs on undefined weak syms with non-default
2344          visibility.  */
2345       if (eh->dyn_relocs != NULL
2346           && h->root.type == bfd_link_hash_undefweak)
2347         {
2348           if (ELF_ST_VISIBILITY (h->other) != STV_DEFAULT)
2349             eh->dyn_relocs = NULL;
2350
2351           /* Make sure undefined weak symbols are output as a dynamic
2352              symbol in PIEs.  */
2353           else if (h->dynindx == -1
2354                    && !h->forced_local)
2355             {
2356               if (! bfd_elf_link_record_dynamic_symbol (info, h))
2357                 return FALSE;
2358             }
2359         }
2360     }
2361   else
2362     {
2363       /* For the non-shared case, discard space for relocs against
2364          symbols which turn out to need copy relocs or are not
2365          dynamic.  */
2366
2367       if (!h->non_got_ref
2368           && ((h->def_dynamic
2369                && !h->def_regular)
2370               || (htab->elf.dynamic_sections_created
2371                   && (h->root.type == bfd_link_hash_undefweak
2372                       || h->root.type == bfd_link_hash_undefined))))
2373         {
2374           /* Make sure this symbol is output as a dynamic symbol.
2375              Undefined weak syms won't yet be marked as dynamic.  */
2376           if (h->dynindx == -1
2377               && !h->forced_local)
2378             {
2379               if (! bfd_elf_link_record_dynamic_symbol (info, h))
2380                 return FALSE;
2381             }
2382
2383           /* If that succeeded, we know we'll be keeping all the
2384              relocs.  */
2385           if (h->dynindx != -1)
2386             goto keep;
2387         }
2388
2389       eh->dyn_relocs = NULL;
2390
2391     keep: ;
2392     }
2393
2394   /* Finally, allocate space.  */
2395   for (p = eh->dyn_relocs; p != NULL; p = p->next)
2396     {
2397       asection *sreloc = elf_section_data (p->sec)->sreloc;
2398       sreloc->size += p->count * SPARC_ELF_RELA_BYTES (htab);
2399     }
2400
2401   return TRUE;
2402 }
2403
2404 /* Allocate space in .plt, .got and associated reloc sections for
2405    local dynamic relocs.  */
2406
2407 static bfd_boolean
2408 allocate_local_dynrelocs (void **slot, void *inf)
2409 {
2410   struct elf_link_hash_entry *h
2411     = (struct elf_link_hash_entry *) *slot;
2412
2413   if (h->type != STT_GNU_IFUNC
2414       || !h->def_regular
2415       || !h->ref_regular
2416       || !h->forced_local
2417       || h->root.type != bfd_link_hash_defined)
2418     abort ();
2419
2420   return allocate_dynrelocs (h, inf);
2421 }
2422
2423 /* Find any dynamic relocs that apply to read-only sections.  */
2424
2425 static bfd_boolean
2426 readonly_dynrelocs (struct elf_link_hash_entry *h, PTR inf)
2427 {
2428   struct _bfd_sparc_elf_link_hash_entry *eh;
2429   struct _bfd_sparc_elf_dyn_relocs *p;
2430
2431   eh = (struct _bfd_sparc_elf_link_hash_entry *) h;
2432   for (p = eh->dyn_relocs; p != NULL; p = p->next)
2433     {
2434       asection *s = p->sec->output_section;
2435
2436       if (s != NULL && (s->flags & SEC_READONLY) != 0)
2437         {
2438           struct bfd_link_info *info = (struct bfd_link_info *) inf;
2439
2440           info->flags |= DF_TEXTREL;
2441
2442           /* Not an error, just cut short the traversal.  */
2443           return FALSE;
2444         }
2445     }
2446   return TRUE;
2447 }
2448
2449 /* Return true if the dynamic symbol for a given section should be
2450    omitted when creating a shared library.  */
2451
2452 bfd_boolean
2453 _bfd_sparc_elf_omit_section_dynsym (bfd *output_bfd,
2454                                     struct bfd_link_info *info,
2455                                     asection *p)
2456 {
2457   /* We keep the .got section symbol so that explicit relocations
2458      against the _GLOBAL_OFFSET_TABLE_ symbol emitted in PIC mode
2459      can be turned into relocations against the .got symbol.  */
2460   if (strcmp (p->name, ".got") == 0)
2461     return FALSE;
2462
2463   return _bfd_elf_link_omit_section_dynsym (output_bfd, info, p);
2464 }
2465
2466 /* Set the sizes of the dynamic sections.  */
2467
2468 bfd_boolean
2469 _bfd_sparc_elf_size_dynamic_sections (bfd *output_bfd,
2470                                       struct bfd_link_info *info)
2471 {
2472   struct _bfd_sparc_elf_link_hash_table *htab;
2473   bfd *dynobj;
2474   asection *s;
2475   bfd *ibfd;
2476
2477   htab = _bfd_sparc_elf_hash_table (info);
2478   BFD_ASSERT (htab != NULL);
2479   dynobj = htab->elf.dynobj;
2480   BFD_ASSERT (dynobj != NULL);
2481
2482   if (elf_hash_table (info)->dynamic_sections_created)
2483     {
2484       /* Set the contents of the .interp section to the interpreter.  */
2485       if (info->executable)
2486         {
2487           s = bfd_get_section_by_name (dynobj, ".interp");
2488           BFD_ASSERT (s != NULL);
2489           s->size = htab->dynamic_interpreter_size;
2490           s->contents = (unsigned char *) htab->dynamic_interpreter;
2491         }
2492     }
2493
2494   /* Set up .got offsets for local syms, and space for local dynamic
2495      relocs.  */
2496   for (ibfd = info->input_bfds; ibfd != NULL; ibfd = ibfd->link_next)
2497     {
2498       bfd_signed_vma *local_got;
2499       bfd_signed_vma *end_local_got;
2500       char *local_tls_type;
2501       bfd_size_type locsymcount;
2502       Elf_Internal_Shdr *symtab_hdr;
2503       asection *srel;
2504
2505       if (! is_sparc_elf (ibfd))
2506         continue;
2507
2508       for (s = ibfd->sections; s != NULL; s = s->next)
2509         {
2510           struct _bfd_sparc_elf_dyn_relocs *p;
2511
2512           for (p = elf_section_data (s)->local_dynrel; p != NULL; p = p->next)
2513             {
2514               if (!bfd_is_abs_section (p->sec)
2515                   && bfd_is_abs_section (p->sec->output_section))
2516                 {
2517                   /* Input section has been discarded, either because
2518                      it is a copy of a linkonce section or due to
2519                      linker script /DISCARD/, so we'll be discarding
2520                      the relocs too.  */
2521                 }
2522               else if (htab->is_vxworks
2523                        && strcmp (p->sec->output_section->name,
2524                                   ".tls_vars") == 0)
2525                 {
2526                   /* Relocations in vxworks .tls_vars sections are
2527                      handled specially by the loader.  */
2528                 }
2529               else if (p->count != 0)
2530                 {
2531                   srel = elf_section_data (p->sec)->sreloc;
2532                   if (!htab->elf.dynamic_sections_created)
2533                     srel = htab->elf.irelplt;
2534                   srel->size += p->count * SPARC_ELF_RELA_BYTES (htab);
2535                   if ((p->sec->output_section->flags & SEC_READONLY) != 0)
2536                     info->flags |= DF_TEXTREL;
2537                 }
2538             }
2539         }
2540
2541       local_got = elf_local_got_refcounts (ibfd);
2542       if (!local_got)
2543         continue;
2544
2545       symtab_hdr = &elf_symtab_hdr (ibfd);
2546       locsymcount = symtab_hdr->sh_info;
2547       end_local_got = local_got + locsymcount;
2548       local_tls_type = _bfd_sparc_elf_local_got_tls_type (ibfd);
2549       s = htab->elf.sgot;
2550       srel = htab->elf.srelgot;
2551       for (; local_got < end_local_got; ++local_got, ++local_tls_type)
2552         {
2553           if (*local_got > 0)
2554             {
2555               *local_got = s->size;
2556               s->size += SPARC_ELF_WORD_BYTES (htab);
2557               if (*local_tls_type == GOT_TLS_GD)
2558                 s->size += SPARC_ELF_WORD_BYTES (htab);
2559               if (info->shared
2560                   || *local_tls_type == GOT_TLS_GD
2561                   || *local_tls_type == GOT_TLS_IE)
2562                 srel->size += SPARC_ELF_RELA_BYTES (htab);
2563             }
2564           else
2565             *local_got = (bfd_vma) -1;
2566         }
2567     }
2568
2569   if (htab->tls_ldm_got.refcount > 0)
2570     {
2571       /* Allocate 2 got entries and 1 dynamic reloc for
2572          R_SPARC_TLS_LDM_{HI22,LO10} relocs.  */
2573       htab->tls_ldm_got.offset = htab->elf.sgot->size;
2574       htab->elf.sgot->size += (2 * SPARC_ELF_WORD_BYTES (htab));
2575       htab->elf.srelgot->size += SPARC_ELF_RELA_BYTES (htab);
2576     }
2577   else
2578     htab->tls_ldm_got.offset = -1;
2579
2580   /* Allocate global sym .plt and .got entries, and space for global
2581      sym dynamic relocs.  */
2582   elf_link_hash_traverse (&htab->elf, allocate_dynrelocs, (PTR) info);
2583
2584   /* Allocate .plt and .got entries, and space for local symbols.  */
2585   htab_traverse (htab->loc_hash_table, allocate_local_dynrelocs, info);
2586
2587   if (! ABI_64_P (output_bfd)
2588       && !htab->is_vxworks
2589       && elf_hash_table (info)->dynamic_sections_created)
2590     {
2591       /* Make space for the trailing nop in .plt.  */
2592       if (htab->elf.splt->size > 0)
2593         htab->elf.splt->size += 1 * SPARC_INSN_BYTES;
2594
2595       /* If the .got section is more than 0x1000 bytes, we add
2596          0x1000 to the value of _GLOBAL_OFFSET_TABLE_, so that 13
2597          bit relocations have a greater chance of working.
2598
2599          FIXME: Make this optimization work for 64-bit too.  */
2600       if (htab->elf.sgot->size >= 0x1000
2601           && elf_hash_table (info)->hgot->root.u.def.value == 0)
2602         elf_hash_table (info)->hgot->root.u.def.value = 0x1000;
2603     }
2604
2605   /* The check_relocs and adjust_dynamic_symbol entry points have
2606      determined the sizes of the various dynamic sections.  Allocate
2607      memory for them.  */
2608   for (s = dynobj->sections; s != NULL; s = s->next)
2609     {
2610       if ((s->flags & SEC_LINKER_CREATED) == 0)
2611         continue;
2612
2613       if (s == htab->elf.splt
2614           || s == htab->elf.sgot
2615           || s == htab->sdynbss
2616           || s == htab->elf.iplt
2617           || s == htab->elf.sgotplt)
2618         {
2619           /* Strip this section if we don't need it; see the
2620              comment below.  */
2621         }
2622       else if (CONST_STRNEQ (s->name, ".rela"))
2623         {
2624           if (s->size != 0)
2625             {
2626               /* We use the reloc_count field as a counter if we need
2627                  to copy relocs into the output file.  */
2628               s->reloc_count = 0;
2629             }
2630         }
2631       else
2632         {
2633           /* It's not one of our sections.  */
2634           continue;
2635         }
2636
2637       if (s->size == 0)
2638         {
2639           /* If we don't need this section, strip it from the
2640              output file.  This is mostly to handle .rela.bss and
2641              .rela.plt.  We must create both sections in
2642              create_dynamic_sections, because they must be created
2643              before the linker maps input sections to output
2644              sections.  The linker does that before
2645              adjust_dynamic_symbol is called, and it is that
2646              function which decides whether anything needs to go
2647              into these sections.  */
2648           s->flags |= SEC_EXCLUDE;
2649           continue;
2650         }
2651
2652       if ((s->flags & SEC_HAS_CONTENTS) == 0)
2653         continue;
2654
2655       /* Allocate memory for the section contents.  Zero the memory
2656          for the benefit of .rela.plt, which has 4 unused entries
2657          at the beginning, and we don't want garbage.  */
2658       s->contents = (bfd_byte *) bfd_zalloc (dynobj, s->size);
2659       if (s->contents == NULL)
2660         return FALSE;
2661     }
2662
2663   if (elf_hash_table (info)->dynamic_sections_created)
2664     {
2665       /* Add some entries to the .dynamic section.  We fill in the
2666          values later, in _bfd_sparc_elf_finish_dynamic_sections, but we
2667          must add the entries now so that we get the correct size for
2668          the .dynamic section.  The DT_DEBUG entry is filled in by the
2669          dynamic linker and used by the debugger.  */
2670 #define add_dynamic_entry(TAG, VAL) \
2671   _bfd_elf_add_dynamic_entry (info, TAG, VAL)
2672
2673       if (info->executable)
2674         {
2675           if (!add_dynamic_entry (DT_DEBUG, 0))
2676             return FALSE;
2677         }
2678
2679       if (htab->elf.srelplt->size != 0)
2680         {
2681           if (!add_dynamic_entry (DT_PLTGOT, 0)
2682               || !add_dynamic_entry (DT_PLTRELSZ, 0)
2683               || !add_dynamic_entry (DT_PLTREL, DT_RELA)
2684               || !add_dynamic_entry (DT_JMPREL, 0))
2685             return FALSE;
2686         }
2687
2688       if (!add_dynamic_entry (DT_RELA, 0)
2689           || !add_dynamic_entry (DT_RELASZ, 0)
2690           || !add_dynamic_entry (DT_RELAENT,
2691                                  SPARC_ELF_RELA_BYTES (htab)))
2692         return FALSE;
2693
2694       /* If any dynamic relocs apply to a read-only section,
2695          then we need a DT_TEXTREL entry.  */
2696       if ((info->flags & DF_TEXTREL) == 0)
2697         elf_link_hash_traverse (&htab->elf, readonly_dynrelocs,
2698                                 (PTR) info);
2699
2700       if (info->flags & DF_TEXTREL)
2701         {
2702           if (!add_dynamic_entry (DT_TEXTREL, 0))
2703             return FALSE;
2704         }
2705
2706       if (ABI_64_P (output_bfd))
2707         {
2708           int reg;
2709           struct _bfd_sparc_elf_app_reg * app_regs;
2710           struct elf_strtab_hash *dynstr;
2711           struct elf_link_hash_table *eht = elf_hash_table (info);
2712
2713           /* Add dynamic STT_REGISTER symbols and corresponding DT_SPARC_REGISTER
2714              entries if needed.  */
2715           app_regs = _bfd_sparc_elf_hash_table (info)->app_regs;
2716           dynstr = eht->dynstr;
2717
2718           for (reg = 0; reg < 4; reg++)
2719             if (app_regs [reg].name != NULL)
2720               {
2721                 struct elf_link_local_dynamic_entry *entry, *e;
2722
2723                 if (!add_dynamic_entry (DT_SPARC_REGISTER, 0))
2724                   return FALSE;
2725
2726                 entry = (struct elf_link_local_dynamic_entry *)
2727                   bfd_hash_allocate (&info->hash->table, sizeof (*entry));
2728                 if (entry == NULL)
2729                   return FALSE;
2730
2731                 /* We cheat here a little bit: the symbol will not be local, so we
2732                    put it at the end of the dynlocal linked list.  We will fix it
2733                    later on, as we have to fix other fields anyway.  */
2734                 entry->isym.st_value = reg < 2 ? reg + 2 : reg + 4;
2735                 entry->isym.st_size = 0;
2736                 if (*app_regs [reg].name != '\0')
2737                   entry->isym.st_name
2738                     = _bfd_elf_strtab_add (dynstr, app_regs[reg].name, FALSE);
2739                 else
2740                   entry->isym.st_name = 0;
2741                 entry->isym.st_other = 0;
2742                 entry->isym.st_info = ELF_ST_INFO (app_regs [reg].bind,
2743                                                    STT_REGISTER);
2744                 entry->isym.st_shndx = app_regs [reg].shndx;
2745                 entry->isym.st_target_internal = 0;
2746                 entry->next = NULL;
2747                 entry->input_bfd = output_bfd;
2748                 entry->input_indx = -1;
2749
2750                 if (eht->dynlocal == NULL)
2751                   eht->dynlocal = entry;
2752                 else
2753                   {
2754                     for (e = eht->dynlocal; e->next; e = e->next)
2755                       ;
2756                     e->next = entry;
2757                   }
2758                 eht->dynsymcount++;
2759               }
2760         }
2761       if (htab->is_vxworks
2762           && !elf_vxworks_add_dynamic_entries (output_bfd, info))
2763         return FALSE;
2764     }
2765 #undef add_dynamic_entry
2766
2767   return TRUE;
2768 }
2769 \f
2770 bfd_boolean
2771 _bfd_sparc_elf_new_section_hook (bfd *abfd, asection *sec)
2772 {
2773   if (!sec->used_by_bfd)
2774     {
2775       struct _bfd_sparc_elf_section_data *sdata;
2776       bfd_size_type amt = sizeof (*sdata);
2777
2778       sdata = bfd_zalloc (abfd, amt);
2779       if (sdata == NULL)
2780         return FALSE;
2781       sec->used_by_bfd = sdata;
2782     }
2783
2784   return _bfd_elf_new_section_hook (abfd, sec);
2785 }
2786
2787 bfd_boolean
2788 _bfd_sparc_elf_relax_section (bfd *abfd ATTRIBUTE_UNUSED,
2789                               struct bfd_section *section,
2790                               struct bfd_link_info *link_info ATTRIBUTE_UNUSED,
2791                               bfd_boolean *again)
2792 {
2793   if (link_info->relocatable)
2794     (*link_info->callbacks->einfo)
2795       (_("%P%F: --relax and -r may not be used together\n"));
2796
2797   *again = FALSE;
2798   sec_do_relax (section) = 1;
2799   return TRUE;
2800 }
2801 \f
2802 /* Return the base VMA address which should be subtracted from real addresses
2803    when resolving @dtpoff relocation.
2804    This is PT_TLS segment p_vaddr.  */
2805
2806 static bfd_vma
2807 dtpoff_base (struct bfd_link_info *info)
2808 {
2809   /* If tls_sec is NULL, we should have signalled an error already.  */
2810   if (elf_hash_table (info)->tls_sec == NULL)
2811     return 0;
2812   return elf_hash_table (info)->tls_sec->vma;
2813 }
2814
2815 /* Return the relocation value for @tpoff relocation
2816    if STT_TLS virtual address is ADDRESS.  */
2817
2818 static bfd_vma
2819 tpoff (struct bfd_link_info *info, bfd_vma address)
2820 {
2821   struct elf_link_hash_table *htab = elf_hash_table (info);
2822   const struct elf_backend_data *bed = get_elf_backend_data (info->output_bfd);
2823   bfd_vma static_tls_size;
2824
2825   /* If tls_sec is NULL, we should have signalled an error already.  */
2826   if (htab->tls_sec == NULL)
2827     return 0;
2828
2829   /* Consider special static TLS alignment requirements.  */
2830   static_tls_size = BFD_ALIGN (htab->tls_size, bed->static_tls_alignment);
2831   return address - static_tls_size - htab->tls_sec->vma;
2832 }
2833
2834 /* Return the relocation value for a %gdop relocation.  */
2835
2836 static bfd_vma
2837 gdopoff (struct bfd_link_info *info, bfd_vma address)
2838 {
2839   struct elf_link_hash_table *htab = elf_hash_table (info);
2840   bfd_vma got_base;
2841
2842   got_base = (htab->hgot->root.u.def.value
2843               + htab->hgot->root.u.def.section->output_offset
2844               + htab->hgot->root.u.def.section->output_section->vma);
2845
2846   return address - got_base;
2847 }
2848
2849 /* Relocate a SPARC ELF section.  */
2850
2851 bfd_boolean
2852 _bfd_sparc_elf_relocate_section (bfd *output_bfd,
2853                                  struct bfd_link_info *info,
2854                                  bfd *input_bfd,
2855                                  asection *input_section,
2856                                  bfd_byte *contents,
2857                                  Elf_Internal_Rela *relocs,
2858                                  Elf_Internal_Sym *local_syms,
2859                                  asection **local_sections)
2860 {
2861   struct _bfd_sparc_elf_link_hash_table *htab;
2862   Elf_Internal_Shdr *symtab_hdr;
2863   struct elf_link_hash_entry **sym_hashes;
2864   bfd_vma *local_got_offsets;
2865   bfd_vma got_base;
2866   asection *sreloc;
2867   Elf_Internal_Rela *rel;
2868   Elf_Internal_Rela *relend;
2869   int num_relocs;
2870   bfd_boolean is_vxworks_tls;
2871
2872   htab = _bfd_sparc_elf_hash_table (info);
2873   BFD_ASSERT (htab != NULL);
2874   symtab_hdr = &elf_symtab_hdr (input_bfd);
2875   sym_hashes = elf_sym_hashes (input_bfd);
2876   local_got_offsets = elf_local_got_offsets (input_bfd);
2877
2878   if (elf_hash_table (info)->hgot == NULL)
2879     got_base = 0;
2880   else
2881     got_base = elf_hash_table (info)->hgot->root.u.def.value;
2882
2883   sreloc = elf_section_data (input_section)->sreloc;
2884   /* We have to handle relocations in vxworks .tls_vars sections
2885      specially, because the dynamic loader is 'weird'.  */
2886   is_vxworks_tls = (htab->is_vxworks && info->shared
2887                     && !strcmp (input_section->output_section->name,
2888                                 ".tls_vars"));
2889
2890   rel = relocs;
2891   if (ABI_64_P (output_bfd))
2892     num_relocs = NUM_SHDR_ENTRIES (_bfd_elf_single_rel_hdr (input_section));
2893   else
2894     num_relocs = input_section->reloc_count;
2895   relend = relocs + num_relocs;
2896   for (; rel < relend; rel++)
2897     {
2898       int r_type, tls_type;
2899       reloc_howto_type *howto;
2900       unsigned long r_symndx;
2901       struct elf_link_hash_entry *h;
2902       Elf_Internal_Sym *sym;
2903       asection *sec;
2904       bfd_vma relocation, off;
2905       bfd_reloc_status_type r;
2906       bfd_boolean is_plt = FALSE;
2907       bfd_boolean unresolved_reloc;
2908
2909       r_type = SPARC_ELF_R_TYPE (rel->r_info);
2910       if (r_type == R_SPARC_GNU_VTINHERIT
2911           || r_type == R_SPARC_GNU_VTENTRY)
2912         continue;
2913
2914       if (r_type < 0 || r_type >= (int) R_SPARC_max_std)
2915         {
2916           bfd_set_error (bfd_error_bad_value);
2917           return FALSE;
2918         }
2919       howto = _bfd_sparc_elf_howto_table + r_type;
2920
2921       r_symndx = SPARC_ELF_R_SYMNDX (htab, rel->r_info);
2922       h = NULL;
2923       sym = NULL;
2924       sec = NULL;
2925       unresolved_reloc = FALSE;
2926       if (r_symndx < symtab_hdr->sh_info)
2927         {
2928           sym = local_syms + r_symndx;
2929           sec = local_sections[r_symndx];
2930           relocation = _bfd_elf_rela_local_sym (output_bfd, sym, &sec, rel);
2931
2932           if (!info->relocatable
2933               && ELF_ST_TYPE (sym->st_info) == STT_GNU_IFUNC)
2934             {
2935               /* Relocate against local STT_GNU_IFUNC symbol.  */
2936               h = elf_sparc_get_local_sym_hash (htab, input_bfd,
2937                                                 rel, FALSE);
2938               if (h == NULL)
2939                 abort ();
2940
2941               /* Set STT_GNU_IFUNC symbol value.  */ 
2942               h->root.u.def.value = sym->st_value;
2943               h->root.u.def.section = sec;
2944             }
2945         }
2946       else
2947         {
2948           bfd_boolean warned;
2949
2950           RELOC_FOR_GLOBAL_SYMBOL (info, input_bfd, input_section, rel,
2951                                    r_symndx, symtab_hdr, sym_hashes,
2952                                    h, sec, relocation,
2953                                    unresolved_reloc, warned);
2954           if (warned)
2955             {
2956               /* To avoid generating warning messages about truncated
2957                  relocations, set the relocation's address to be the same as
2958                  the start of this section.  */
2959               if (input_section->output_section != NULL)
2960                 relocation = input_section->output_section->vma;
2961               else
2962                 relocation = 0;
2963             }
2964         }
2965
2966       if (sec != NULL && elf_discarded_section (sec))
2967         RELOC_AGAINST_DISCARDED_SECTION (info, input_bfd, input_section,
2968                                          rel, relend, howto, contents);
2969
2970       if (info->relocatable)
2971         continue;
2972
2973       if (h != NULL
2974           && h->type == STT_GNU_IFUNC
2975           && h->def_regular)
2976         {
2977           asection *plt_sec;
2978           const char *name;
2979
2980           if ((input_section->flags & SEC_ALLOC) == 0
2981               || h->plt.offset == (bfd_vma) -1)
2982             abort ();
2983
2984           plt_sec = htab->elf.splt;
2985           if (! plt_sec)
2986             plt_sec =htab->elf.iplt;
2987
2988           switch (r_type)
2989             {
2990             case R_SPARC_GOTDATA_OP:
2991               continue;
2992
2993             case R_SPARC_GOTDATA_OP_HIX22:
2994             case R_SPARC_GOTDATA_OP_LOX10:
2995               r_type = (r_type == R_SPARC_GOTDATA_OP_HIX22
2996                         ? R_SPARC_GOT22
2997                         : R_SPARC_GOT10);
2998               howto = _bfd_sparc_elf_howto_table + r_type;
2999               /* Fall through.  */
3000
3001             case R_SPARC_GOT10:
3002             case R_SPARC_GOT13:
3003             case R_SPARC_GOT22:
3004               if (htab->elf.sgot == NULL)
3005                 abort ();
3006               off = h->got.offset;
3007               if (off == (bfd_vma) -1)
3008                 abort();
3009               relocation = htab->elf.sgot->output_offset + off - got_base;
3010               goto do_relocation;
3011
3012             case R_SPARC_WPLT30:
3013             case R_SPARC_WDISP30:
3014               relocation = (plt_sec->output_section->vma
3015                             + plt_sec->output_offset + h->plt.offset);
3016               goto do_relocation;
3017
3018             case R_SPARC_32:
3019             case R_SPARC_64:
3020               if (info->shared && h->non_got_ref)
3021                 {
3022                   Elf_Internal_Rela outrel;
3023                   bfd_vma offset;
3024
3025                   offset = _bfd_elf_section_offset (output_bfd, info,
3026                                                     input_section,
3027                                                     rel->r_offset);
3028                   if (offset == (bfd_vma) -1
3029                       || offset == (bfd_vma) -2)
3030                     abort();
3031
3032                   outrel.r_offset = (input_section->output_section->vma
3033                                      + input_section->output_offset
3034                                      + offset);
3035
3036                   if (h->dynindx == -1
3037                       || h->forced_local
3038                       || info->executable)
3039                     {
3040                       outrel.r_info = SPARC_ELF_R_INFO (htab, NULL,
3041                                                         0, R_SPARC_IRELATIVE);
3042                       outrel.r_addend = relocation + rel->r_addend;
3043                     }
3044                   else
3045                     {
3046                       if (h->dynindx == -1)
3047                         abort();
3048                       outrel.r_info = SPARC_ELF_R_INFO (htab, rel, h->dynindx, r_type);
3049                       outrel.r_addend = rel->r_addend;
3050                     }
3051
3052                   sparc_elf_append_rela (output_bfd, sreloc, &outrel);
3053                   continue;
3054                 }
3055
3056               relocation = (plt_sec->output_section->vma
3057                             + plt_sec->output_offset + h->plt.offset);
3058               goto do_relocation;
3059
3060             case R_SPARC_HI22:
3061             case R_SPARC_LO10:
3062               /* We should only see such relocs in static links.  */
3063               if (info->shared)
3064                 abort();
3065               relocation = (plt_sec->output_section->vma
3066                             + plt_sec->output_offset + h->plt.offset);
3067               goto do_relocation;
3068
3069             default:
3070               if (h->root.root.string)
3071                 name = h->root.root.string;
3072               else
3073                 name = bfd_elf_sym_name (input_bfd, symtab_hdr, sym,
3074                                          NULL);
3075               (*_bfd_error_handler)
3076                 (_("%B: relocation %s against STT_GNU_IFUNC "
3077                    "symbol `%s' isn't handled by %s"), input_bfd,
3078                  _bfd_sparc_elf_howto_table[r_type].name,
3079                  name, __FUNCTION__);
3080               bfd_set_error (bfd_error_bad_value);
3081               return FALSE;
3082             }
3083         }
3084
3085       switch (r_type)
3086         {
3087         case R_SPARC_GOTDATA_OP_HIX22:
3088         case R_SPARC_GOTDATA_OP_LOX10:
3089           if (SYMBOL_REFERENCES_LOCAL (info, h))
3090             r_type = (r_type == R_SPARC_GOTDATA_OP_HIX22
3091                       ? R_SPARC_GOTDATA_HIX22
3092                       : R_SPARC_GOTDATA_LOX10);
3093           else
3094             r_type = (r_type == R_SPARC_GOTDATA_OP_HIX22
3095                       ? R_SPARC_GOT22
3096                       : R_SPARC_GOT10);
3097           howto = _bfd_sparc_elf_howto_table + r_type;
3098           break;
3099
3100         case R_SPARC_GOTDATA_OP:
3101           if (SYMBOL_REFERENCES_LOCAL (info, h))
3102             {
3103               bfd_vma insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
3104
3105               /* {ld,ldx} [%rs1 + %rs2], %rd --> add %rs1, %rs2, %rd */
3106               relocation = 0x80000000 | (insn & 0x3e07c01f);
3107               bfd_put_32 (output_bfd, relocation, contents + rel->r_offset);
3108             }
3109           continue;
3110         }
3111
3112       switch (r_type)
3113         {
3114         case R_SPARC_GOTDATA_HIX22:
3115         case R_SPARC_GOTDATA_LOX10:
3116           relocation = gdopoff (info, relocation);
3117           break;
3118
3119         case R_SPARC_GOT10:
3120         case R_SPARC_GOT13:
3121         case R_SPARC_GOT22:
3122           /* Relocation is to the entry for this symbol in the global
3123              offset table.  */
3124           if (htab->elf.sgot == NULL)
3125             abort ();
3126
3127           if (h != NULL)
3128             {
3129               bfd_boolean dyn;
3130
3131               off = h->got.offset;
3132               BFD_ASSERT (off != (bfd_vma) -1);
3133               dyn = elf_hash_table (info)->dynamic_sections_created;
3134
3135               if (! WILL_CALL_FINISH_DYNAMIC_SYMBOL (dyn, info->shared, h)
3136                   || (info->shared
3137                       && SYMBOL_REFERENCES_LOCAL (info, h)))
3138                 {
3139                   /* This is actually a static link, or it is a
3140                      -Bsymbolic link and the symbol is defined
3141                      locally, or the symbol was forced to be local
3142                      because of a version file.  We must initialize
3143                      this entry in the global offset table.  Since the
3144                      offset must always be a multiple of 8 for 64-bit
3145                      and 4 for 32-bit, we use the least significant bit
3146                      to record whether we have initialized it already.
3147
3148                      When doing a dynamic link, we create a .rela.got
3149                      relocation entry to initialize the value.  This
3150                      is done in the finish_dynamic_symbol routine.  */
3151                   if ((off & 1) != 0)
3152                     off &= ~1;
3153                   else
3154                     {
3155                       SPARC_ELF_PUT_WORD (htab, output_bfd, relocation,
3156                                           htab->elf.sgot->contents + off);
3157                       h->got.offset |= 1;
3158                     }
3159                 }
3160               else
3161                 unresolved_reloc = FALSE;
3162             }
3163           else
3164             {
3165               BFD_ASSERT (local_got_offsets != NULL
3166                           && local_got_offsets[r_symndx] != (bfd_vma) -1);
3167
3168               off = local_got_offsets[r_symndx];
3169
3170               /* The offset must always be a multiple of 8 on 64-bit and
3171                  4 on 32-bit.  We use the least significant bit to record
3172                  whether we have already processed this entry.  */
3173               if ((off & 1) != 0)
3174                 off &= ~1;
3175               else
3176                 {
3177
3178                   if (info->shared)
3179                     {
3180                       asection *s;
3181                       Elf_Internal_Rela outrel;
3182
3183                       /* We need to generate a R_SPARC_RELATIVE reloc
3184                          for the dynamic linker.  */
3185                       s = htab->elf.srelgot;
3186                       BFD_ASSERT (s != NULL);
3187
3188                       outrel.r_offset = (htab->elf.sgot->output_section->vma
3189                                          + htab->elf.sgot->output_offset
3190                                          + off);
3191                       outrel.r_info = SPARC_ELF_R_INFO (htab, NULL,
3192                                                         0, R_SPARC_RELATIVE);
3193                       outrel.r_addend = relocation;
3194                       relocation = 0;
3195                       sparc_elf_append_rela (output_bfd, s, &outrel);
3196                     }
3197
3198                   SPARC_ELF_PUT_WORD (htab, output_bfd, relocation,
3199                                       htab->elf.sgot->contents + off);
3200                   local_got_offsets[r_symndx] |= 1;
3201                 }
3202             }
3203           relocation = htab->elf.sgot->output_offset + off - got_base;
3204           break;
3205
3206         case R_SPARC_PLT32:
3207         case R_SPARC_PLT64:
3208           if (h == NULL || h->plt.offset == (bfd_vma) -1)
3209             {
3210               r_type = (r_type == R_SPARC_PLT32) ? R_SPARC_32 : R_SPARC_64;
3211               goto r_sparc_plt32;
3212             }
3213           /* Fall through.  */
3214
3215         case R_SPARC_WPLT30:
3216         case R_SPARC_HIPLT22:
3217         case R_SPARC_LOPLT10:
3218         case R_SPARC_PCPLT32:
3219         case R_SPARC_PCPLT22:
3220         case R_SPARC_PCPLT10:
3221         r_sparc_wplt30:
3222           /* Relocation is to the entry for this symbol in the
3223              procedure linkage table.  */
3224
3225           if (! ABI_64_P (output_bfd))
3226             {
3227               /* The Solaris native assembler will generate a WPLT30 reloc
3228                  for a local symbol if you assemble a call from one
3229                  section to another when using -K pic.  We treat it as
3230                  WDISP30.  */
3231               if (h == NULL)
3232                 break;
3233             }
3234           /* PR 7027: We need similar behaviour for 64-bit binaries.  */ 
3235           else if (r_type == R_SPARC_WPLT30 && h == NULL)
3236             break;
3237           else
3238             {
3239               BFD_ASSERT (h != NULL);
3240             }
3241
3242           if (h->plt.offset == (bfd_vma) -1 || htab->elf.splt == NULL)
3243             {
3244               /* We didn't make a PLT entry for this symbol.  This
3245                  happens when statically linking PIC code, or when
3246                  using -Bsymbolic.  */
3247               break;
3248             }
3249
3250           relocation = (htab->elf.splt->output_section->vma
3251                         + htab->elf.splt->output_offset
3252                         + h->plt.offset);
3253           unresolved_reloc = FALSE;
3254           if (r_type == R_SPARC_PLT32 || r_type == R_SPARC_PLT64)
3255             {
3256               r_type = r_type == R_SPARC_PLT32 ? R_SPARC_32 : R_SPARC_64;
3257               is_plt = TRUE;
3258               goto r_sparc_plt32;
3259             }
3260           break;
3261
3262         case R_SPARC_PC10:
3263         case R_SPARC_PC22:
3264         case R_SPARC_PC_HH22:
3265         case R_SPARC_PC_HM10:
3266         case R_SPARC_PC_LM22:
3267           if (h != NULL
3268               && strcmp (h->root.root.string, "_GLOBAL_OFFSET_TABLE_") == 0)
3269             break;
3270           /* Fall through.  */
3271         case R_SPARC_DISP8:
3272         case R_SPARC_DISP16:
3273         case R_SPARC_DISP32:
3274         case R_SPARC_DISP64:
3275         case R_SPARC_WDISP30:
3276         case R_SPARC_WDISP22:
3277         case R_SPARC_WDISP19:
3278         case R_SPARC_WDISP16:
3279         case R_SPARC_8:
3280         case R_SPARC_16:
3281         case R_SPARC_32:
3282         case R_SPARC_HI22:
3283         case R_SPARC_22:
3284         case R_SPARC_13:
3285         case R_SPARC_LO10:
3286         case R_SPARC_UA16:
3287         case R_SPARC_UA32:
3288         case R_SPARC_10:
3289         case R_SPARC_11:
3290         case R_SPARC_64:
3291         case R_SPARC_OLO10:
3292         case R_SPARC_HH22:
3293         case R_SPARC_HM10:
3294         case R_SPARC_LM22:
3295         case R_SPARC_7:
3296         case R_SPARC_5:
3297         case R_SPARC_6:
3298         case R_SPARC_HIX22:
3299         case R_SPARC_LOX10:
3300         case R_SPARC_H44:
3301         case R_SPARC_M44:
3302         case R_SPARC_L44:
3303         case R_SPARC_UA64:
3304         r_sparc_plt32:
3305           if ((input_section->flags & SEC_ALLOC) == 0
3306               || is_vxworks_tls)
3307             break;
3308
3309           if ((info->shared
3310                && (h == NULL
3311                    || ELF_ST_VISIBILITY (h->other) == STV_DEFAULT
3312                    || h->root.type != bfd_link_hash_undefweak)
3313                && (! howto->pc_relative
3314                    || !SYMBOL_CALLS_LOCAL (info, h)))
3315               || (!info->shared
3316                   && h != NULL
3317                   && h->dynindx != -1
3318                   && !h->non_got_ref
3319                   && ((h->def_dynamic
3320                        && !h->def_regular)
3321                       || h->root.type == bfd_link_hash_undefweak
3322                       || h->root.type == bfd_link_hash_undefined)))
3323             {
3324               Elf_Internal_Rela outrel;
3325               bfd_boolean skip, relocate = FALSE;
3326
3327               /* When generating a shared object, these relocations
3328                  are copied into the output file to be resolved at run
3329                  time.  */
3330
3331               BFD_ASSERT (sreloc != NULL);
3332
3333               skip = FALSE;
3334
3335               outrel.r_offset =
3336                 _bfd_elf_section_offset (output_bfd, info, input_section,
3337                                          rel->r_offset);
3338               if (outrel.r_offset == (bfd_vma) -1)
3339                 skip = TRUE;
3340               else if (outrel.r_offset == (bfd_vma) -2)
3341                 skip = TRUE, relocate = TRUE;
3342               outrel.r_offset += (input_section->output_section->vma
3343                                   + input_section->output_offset);
3344
3345               /* Optimize unaligned reloc usage now that we know where
3346                  it finally resides.  */
3347               switch (r_type)
3348                 {
3349                 case R_SPARC_16:
3350                   if (outrel.r_offset & 1)
3351                     r_type = R_SPARC_UA16;
3352                   break;
3353                 case R_SPARC_UA16:
3354                   if (!(outrel.r_offset & 1))
3355                     r_type = R_SPARC_16;
3356                   break;
3357                 case R_SPARC_32:
3358                   if (outrel.r_offset & 3)
3359                     r_type = R_SPARC_UA32;
3360                   break;
3361                 case R_SPARC_UA32:
3362                   if (!(outrel.r_offset & 3))
3363                     r_type = R_SPARC_32;
3364                   break;
3365                 case R_SPARC_64:
3366                   if (outrel.r_offset & 7)
3367                     r_type = R_SPARC_UA64;
3368                   break;
3369                 case R_SPARC_UA64:
3370                   if (!(outrel.r_offset & 7))
3371                     r_type = R_SPARC_64;
3372                   break;
3373                 case R_SPARC_DISP8:
3374                 case R_SPARC_DISP16:
3375                 case R_SPARC_DISP32:
3376                 case R_SPARC_DISP64:
3377                   /* If the symbol is not dynamic, we should not keep
3378                      a dynamic relocation.  But an .rela.* slot has been
3379                      allocated for it, output R_SPARC_NONE.
3380                      FIXME: Add code tracking needed dynamic relocs as
3381                      e.g. i386 has.  */
3382                   if (h->dynindx == -1)
3383                     skip = TRUE, relocate = TRUE;
3384                   break;
3385                 }
3386
3387               if (skip)
3388                 memset (&outrel, 0, sizeof outrel);
3389               /* h->dynindx may be -1 if the symbol was marked to
3390                  become local.  */
3391               else if (h != NULL &&
3392                        h->dynindx != -1
3393                        && (! is_plt
3394                            || !info->shared
3395                            || !SYMBOLIC_BIND (info, h)
3396                            || !h->def_regular))
3397                 {
3398                   BFD_ASSERT (h->dynindx != -1);
3399                   outrel.r_info = SPARC_ELF_R_INFO (htab, rel, h->dynindx, r_type);
3400                   outrel.r_addend = rel->r_addend;
3401                 }
3402               else
3403                 {
3404                   if (r_type == R_SPARC_32 || r_type == R_SPARC_64)
3405                     {
3406                       outrel.r_info = SPARC_ELF_R_INFO (htab, NULL,
3407                                                         0, R_SPARC_RELATIVE);
3408                       outrel.r_addend = relocation + rel->r_addend;
3409                     }
3410                   else
3411                     {
3412                       long indx;
3413
3414                       outrel.r_addend = relocation + rel->r_addend;
3415
3416                       if (is_plt)
3417                         sec = htab->elf.splt;
3418
3419                       if (bfd_is_abs_section (sec))
3420                         indx = 0;
3421                       else if (sec == NULL || sec->owner == NULL)
3422                         {
3423                           bfd_set_error (bfd_error_bad_value);
3424                           return FALSE;
3425                         }
3426                       else
3427                         {
3428                           asection *osec;
3429
3430                           /* We are turning this relocation into one
3431                              against a section symbol.  It would be
3432                              proper to subtract the symbol's value,
3433                              osec->vma, from the emitted reloc addend,
3434                              but ld.so expects buggy relocs.  */
3435                           osec = sec->output_section;
3436                           indx = elf_section_data (osec)->dynindx;
3437
3438                           if (indx == 0)
3439                             {
3440                               osec = htab->elf.text_index_section;
3441                               indx = elf_section_data (osec)->dynindx;
3442                             }
3443
3444                           /* FIXME: we really should be able to link non-pic
3445                              shared libraries.  */
3446                           if (indx == 0)
3447                             {
3448                               BFD_FAIL ();
3449                               (*_bfd_error_handler)
3450                                 (_("%B: probably compiled without -fPIC?"),
3451                                  input_bfd);
3452                               bfd_set_error (bfd_error_bad_value);
3453                               return FALSE;
3454                             }
3455                         }
3456
3457                       outrel.r_info = SPARC_ELF_R_INFO (htab, rel, indx,
3458                                                         r_type);
3459                     }
3460                 }
3461
3462               sparc_elf_append_rela (output_bfd, sreloc, &outrel);
3463
3464               /* This reloc will be computed at runtime, so there's no
3465                  need to do anything now.  */
3466               if (! relocate)
3467                 continue;
3468             }
3469           break;
3470
3471         case R_SPARC_TLS_GD_HI22:
3472           if (! ABI_64_P (input_bfd)
3473               && ! _bfd_sparc_elf_tdata (input_bfd)->has_tlsgd)
3474             {
3475               /* R_SPARC_REV32 used the same reloc number as
3476                  R_SPARC_TLS_GD_HI22.  */
3477               r_type = R_SPARC_REV32;
3478               break;
3479             }
3480           /* Fall through */
3481
3482         case R_SPARC_TLS_GD_LO10:
3483         case R_SPARC_TLS_IE_HI22:
3484         case R_SPARC_TLS_IE_LO10:
3485           r_type = sparc_elf_tls_transition (info, input_bfd, r_type, h == NULL);
3486           tls_type = GOT_UNKNOWN;
3487           if (h == NULL && local_got_offsets)
3488             tls_type = _bfd_sparc_elf_local_got_tls_type (input_bfd) [r_symndx];
3489           else if (h != NULL)
3490             {
3491               tls_type = _bfd_sparc_elf_hash_entry(h)->tls_type;
3492               if (!info->shared && h->dynindx == -1 && tls_type == GOT_TLS_IE)
3493                 switch (SPARC_ELF_R_TYPE (rel->r_info))
3494                   {
3495                   case R_SPARC_TLS_GD_HI22:
3496                   case R_SPARC_TLS_IE_HI22:
3497                     r_type = R_SPARC_TLS_LE_HIX22;
3498                     break;
3499                   default:
3500                     r_type = R_SPARC_TLS_LE_LOX10;
3501                     break;
3502                   }
3503             }
3504           if (tls_type == GOT_TLS_IE)
3505             switch (r_type)
3506               {
3507               case R_SPARC_TLS_GD_HI22:
3508                 r_type = R_SPARC_TLS_IE_HI22;
3509                 break;
3510               case R_SPARC_TLS_GD_LO10:
3511                 r_type = R_SPARC_TLS_IE_LO10;
3512                 break;
3513               }
3514
3515           if (r_type == R_SPARC_TLS_LE_HIX22)
3516             {
3517               relocation = tpoff (info, relocation);
3518               break;
3519             }
3520           if (r_type == R_SPARC_TLS_LE_LOX10)
3521             {
3522               /* Change add into xor.  */
3523               relocation = tpoff (info, relocation);
3524               bfd_put_32 (output_bfd, (bfd_get_32 (input_bfd,
3525                                                    contents + rel->r_offset)
3526                                        | 0x80182000), contents + rel->r_offset);
3527               break;
3528             }
3529
3530           if (h != NULL)
3531             {
3532               off = h->got.offset;
3533               h->got.offset |= 1;
3534             }
3535           else
3536             {
3537               BFD_ASSERT (local_got_offsets != NULL);
3538               off = local_got_offsets[r_symndx];
3539               local_got_offsets[r_symndx] |= 1;
3540             }
3541
3542         r_sparc_tlsldm:
3543           if (htab->elf.sgot == NULL)
3544             abort ();
3545
3546           if ((off & 1) != 0)
3547             off &= ~1;
3548           else
3549             {
3550               Elf_Internal_Rela outrel;
3551               int dr_type, indx;
3552
3553               if (htab->elf.srelgot == NULL)
3554                 abort ();
3555
3556               SPARC_ELF_PUT_WORD (htab, output_bfd, 0,
3557                                   htab->elf.sgot->contents + off);
3558               outrel.r_offset = (htab->elf.sgot->output_section->vma
3559                                  + htab->elf.sgot->output_offset + off);
3560               indx = h && h->dynindx != -1 ? h->dynindx : 0;
3561               if (r_type == R_SPARC_TLS_IE_HI22
3562                   || r_type == R_SPARC_TLS_IE_LO10)
3563                 dr_type = SPARC_ELF_TPOFF_RELOC (htab);
3564               else
3565                 dr_type = SPARC_ELF_DTPMOD_RELOC (htab);
3566               if (dr_type == SPARC_ELF_TPOFF_RELOC (htab) && indx == 0)
3567                 outrel.r_addend = relocation - dtpoff_base (info);
3568               else
3569                 outrel.r_addend = 0;
3570               outrel.r_info = SPARC_ELF_R_INFO (htab, NULL, indx, dr_type);
3571               sparc_elf_append_rela (output_bfd, htab->elf.srelgot, &outrel);
3572
3573               if (r_type == R_SPARC_TLS_GD_HI22
3574                   || r_type == R_SPARC_TLS_GD_LO10)
3575                 {
3576                   if (indx == 0)
3577                     {
3578                       BFD_ASSERT (! unresolved_reloc);
3579                       SPARC_ELF_PUT_WORD (htab, output_bfd,
3580                                           relocation - dtpoff_base (info),
3581                                           (htab->elf.sgot->contents + off
3582                                            + SPARC_ELF_WORD_BYTES (htab)));
3583                     }
3584                   else
3585                     {
3586                       SPARC_ELF_PUT_WORD (htab, output_bfd, 0,
3587                                           (htab->elf.sgot->contents + off
3588                                            + SPARC_ELF_WORD_BYTES (htab)));
3589                       outrel.r_info = SPARC_ELF_R_INFO (htab, NULL, indx,
3590                                                         SPARC_ELF_DTPOFF_RELOC (htab));
3591                       outrel.r_offset += SPARC_ELF_WORD_BYTES (htab);
3592                       sparc_elf_append_rela (output_bfd, htab->elf.srelgot,
3593                                              &outrel);
3594                     }
3595                 }
3596               else if (dr_type == SPARC_ELF_DTPMOD_RELOC (htab))
3597                 {
3598                   SPARC_ELF_PUT_WORD (htab, output_bfd, 0,
3599                                       (htab->elf.sgot->contents + off
3600                                        + SPARC_ELF_WORD_BYTES (htab)));
3601                 }
3602             }
3603
3604           if (off >= (bfd_vma) -2)
3605             abort ();
3606
3607           relocation = htab->elf.sgot->output_offset + off - got_base;
3608           unresolved_reloc = FALSE;
3609           howto = _bfd_sparc_elf_howto_table + r_type;
3610           break;
3611
3612         case R_SPARC_TLS_LDM_HI22:
3613         case R_SPARC_TLS_LDM_LO10:
3614           if (! info->shared)
3615             {
3616               bfd_put_32 (output_bfd, SPARC_NOP, contents + rel->r_offset);
3617               continue;
3618             }
3619           off = htab->tls_ldm_got.offset;
3620           htab->tls_ldm_got.offset |= 1;
3621           goto r_sparc_tlsldm;
3622
3623         case R_SPARC_TLS_LDO_HIX22:
3624         case R_SPARC_TLS_LDO_LOX10:
3625           if (info->shared)
3626             {
3627               relocation -= dtpoff_base (info);
3628               break;
3629             }
3630
3631           r_type = (r_type == R_SPARC_TLS_LDO_HIX22
3632                     ? R_SPARC_TLS_LE_HIX22 : R_SPARC_TLS_LE_LOX10);
3633           /* Fall through.  */
3634
3635         case R_SPARC_TLS_LE_HIX22:
3636         case R_SPARC_TLS_LE_LOX10:
3637           if (info->shared)
3638             {
3639               Elf_Internal_Rela outrel;
3640               bfd_boolean skip;
3641
3642               BFD_ASSERT (sreloc != NULL);
3643               skip = FALSE;
3644               outrel.r_offset =
3645                 _bfd_elf_section_offset (output_bfd, info, input_section,
3646                                          rel->r_offset);
3647               if (outrel.r_offset == (bfd_vma) -1)
3648                 skip = TRUE;
3649               else if (outrel.r_offset == (bfd_vma) -2)
3650                 skip = TRUE;
3651               outrel.r_offset += (input_section->output_section->vma
3652                                   + input_section->output_offset);
3653               if (skip)
3654                 memset (&outrel, 0, sizeof outrel);
3655               else
3656                 {
3657                   outrel.r_info = SPARC_ELF_R_INFO (htab, NULL, 0, r_type);
3658                   outrel.r_addend = relocation - dtpoff_base (info)
3659                                     + rel->r_addend;
3660                 }
3661
3662               sparc_elf_append_rela (output_bfd, sreloc, &outrel);
3663               continue;
3664             }
3665           relocation = tpoff (info, relocation);
3666           break;
3667
3668         case R_SPARC_TLS_LDM_CALL:
3669           if (! info->shared)
3670             {
3671               /* mov %g0, %o0 */
3672               bfd_put_32 (output_bfd, 0x90100000, contents + rel->r_offset);
3673               continue;
3674             }
3675           /* Fall through */
3676
3677         case R_SPARC_TLS_GD_CALL:
3678           tls_type = GOT_UNKNOWN;
3679           if (h == NULL && local_got_offsets)
3680             tls_type = _bfd_sparc_elf_local_got_tls_type (input_bfd) [r_symndx];
3681           else if (h != NULL)
3682             tls_type = _bfd_sparc_elf_hash_entry(h)->tls_type;
3683           if (! info->shared
3684               || (r_type == R_SPARC_TLS_GD_CALL && tls_type == GOT_TLS_IE))
3685             {
3686               Elf_Internal_Rela *rel2;
3687               bfd_vma insn;
3688
3689               if (!info->shared && (h == NULL || h->dynindx == -1))
3690                 {
3691                   /* GD -> LE */
3692                   bfd_put_32 (output_bfd, SPARC_NOP, contents + rel->r_offset);
3693                   continue;
3694                 }
3695
3696               /* GD -> IE */
3697               if (rel + 1 < relend
3698                   && SPARC_ELF_R_TYPE (rel[1].r_info) == R_SPARC_TLS_GD_ADD
3699                   && rel[1].r_offset == rel->r_offset + 4
3700                   && SPARC_ELF_R_SYMNDX (htab, rel[1].r_info) == r_symndx
3701                   && (((insn = bfd_get_32 (input_bfd,
3702                                            contents + rel[1].r_offset))
3703                        >> 25) & 0x1f) == 8)
3704                 {
3705                   /* We have
3706                      call __tls_get_addr, %tgd_call(foo)
3707                       add %reg1, %reg2, %o0, %tgd_add(foo)
3708                      and change it into IE:
3709                      {ld,ldx} [%reg1 + %reg2], %o0, %tie_ldx(foo)
3710                      add %g7, %o0, %o0, %tie_add(foo).
3711                      add is 0x80000000 | (rd << 25) | (rs1 << 14) | rs2,
3712                      ld is 0xc0000000 | (rd << 25) | (rs1 << 14) | rs2,
3713                      ldx is 0xc0580000 | (rd << 25) | (rs1 << 14) | rs2.  */
3714                   bfd_put_32 (output_bfd, insn | (ABI_64_P (output_bfd) ? 0xc0580000 : 0xc0000000),
3715                               contents + rel->r_offset);
3716                   bfd_put_32 (output_bfd, 0x9001c008,
3717                               contents + rel->r_offset + 4);
3718                   rel++;
3719                   continue;
3720                 }
3721
3722               /* We cannot just overwrite the delay slot instruction,
3723                  as it might be what puts the %o0 argument to
3724                  __tls_get_addr into place.  So we have to transpose
3725                  the delay slot with the add we patch in.  */
3726               insn = bfd_get_32 (input_bfd, contents + rel->r_offset + 4);
3727               bfd_put_32 (output_bfd, insn,
3728                           contents + rel->r_offset);
3729               bfd_put_32 (output_bfd, 0x9001c008,
3730                           contents + rel->r_offset + 4);
3731
3732               rel2 = rel;
3733               while ((rel2 = sparc_elf_find_reloc_at_ofs (rel2 + 1, relend,
3734                                                           rel->r_offset + 4))
3735                      != NULL)
3736                 {
3737                   /* If the instruction we moved has a relocation attached to
3738                      it, adjust the offset so that it will apply to the correct
3739                      instruction.  */
3740                   rel2->r_offset -= 4;
3741                 }
3742               continue;
3743             }
3744
3745           h = (struct elf_link_hash_entry *)
3746               bfd_link_hash_lookup (info->hash, "__tls_get_addr", FALSE,
3747                                     FALSE, TRUE);
3748           BFD_ASSERT (h != NULL);
3749           r_type = R_SPARC_WPLT30;
3750           howto = _bfd_sparc_elf_howto_table + r_type;
3751           goto r_sparc_wplt30;
3752
3753         case R_SPARC_TLS_GD_ADD:
3754           tls_type = GOT_UNKNOWN;
3755           if (h == NULL && local_got_offsets)
3756             tls_type = _bfd_sparc_elf_local_got_tls_type (input_bfd) [r_symndx];
3757           else if (h != NULL)
3758             tls_type = _bfd_sparc_elf_hash_entry(h)->tls_type;
3759           if (! info->shared || tls_type == GOT_TLS_IE)
3760             {
3761               /* add %reg1, %reg2, %reg3, %tgd_add(foo)
3762                  changed into IE:
3763                  {ld,ldx} [%reg1 + %reg2], %reg3, %tie_ldx(foo)
3764                  or LE:
3765                  add %g7, %reg2, %reg3.  */
3766               bfd_vma insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
3767               if ((h != NULL && h->dynindx != -1) || info->shared)
3768                 relocation = insn | (ABI_64_P (output_bfd) ? 0xc0580000 : 0xc0000000);
3769               else
3770                 relocation = (insn & ~0x7c000) | 0x1c000;
3771               bfd_put_32 (output_bfd, relocation, contents + rel->r_offset);
3772             }
3773           continue;
3774
3775         case R_SPARC_TLS_LDM_ADD:
3776           if (! info->shared)
3777             bfd_put_32 (output_bfd, SPARC_NOP, contents + rel->r_offset);
3778           continue;
3779
3780         case R_SPARC_TLS_LDO_ADD:
3781           if (! info->shared)
3782             {
3783               /* Change rs1 into %g7.  */
3784               bfd_vma insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
3785               insn = (insn & ~0x7c000) | 0x1c000;
3786               bfd_put_32 (output_bfd, insn, contents + rel->r_offset);
3787             }
3788           continue;
3789
3790         case R_SPARC_TLS_IE_LD:
3791         case R_SPARC_TLS_IE_LDX:
3792           if (! info->shared && (h == NULL || h->dynindx == -1))
3793             {
3794               bfd_vma insn = bfd_get_32 (input_bfd, contents + rel->r_offset);
3795               int rs2 = insn & 0x1f;
3796               int rd = (insn >> 25) & 0x1f;
3797
3798               if (rs2 == rd)
3799                 relocation = SPARC_NOP;
3800               else
3801                 relocation = 0x80100000 | (insn & 0x3e00001f);
3802               bfd_put_32 (output_bfd, relocation, contents + rel->r_offset);
3803             }
3804           continue;
3805
3806         case R_SPARC_TLS_IE_ADD:
3807           /* Totally useless relocation.  */
3808           continue;
3809
3810         case R_SPARC_TLS_DTPOFF32:
3811         case R_SPARC_TLS_DTPOFF64:
3812           relocation -= dtpoff_base (info);
3813           break;
3814
3815         default:
3816           break;
3817         }
3818
3819       /* Dynamic relocs are not propagated for SEC_DEBUGGING sections
3820          because such sections are not SEC_ALLOC and thus ld.so will
3821          not process them.  */
3822       if (unresolved_reloc
3823           && !((input_section->flags & SEC_DEBUGGING) != 0
3824                && h->def_dynamic)
3825           && _bfd_elf_section_offset (output_bfd, info, input_section,
3826                                       rel->r_offset) != (bfd_vma) -1)
3827         (*_bfd_error_handler)
3828           (_("%B(%A+0x%lx): unresolvable %s relocation against symbol `%s'"),
3829            input_bfd,
3830            input_section,
3831            (long) rel->r_offset,
3832            howto->name,
3833            h->root.root.string);
3834
3835       r = bfd_reloc_continue;
3836       if (r_type == R_SPARC_OLO10)
3837         {
3838             bfd_vma x;
3839
3840             if (! ABI_64_P (output_bfd))
3841               abort ();
3842
3843             relocation += rel->r_addend;
3844             relocation = (relocation & 0x3ff) + ELF64_R_TYPE_DATA (rel->r_info);
3845
3846             x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3847             x = (x & ~(bfd_vma) 0x1fff) | (relocation & 0x1fff);
3848             bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3849
3850             r = bfd_check_overflow (howto->complain_on_overflow,
3851                                     howto->bitsize, howto->rightshift,
3852                                     bfd_arch_bits_per_address (input_bfd),
3853                                     relocation);
3854         }
3855       else if (r_type == R_SPARC_WDISP16)
3856         {
3857           bfd_vma x;
3858
3859           relocation += rel->r_addend;
3860           relocation -= (input_section->output_section->vma
3861                          + input_section->output_offset);
3862           relocation -= rel->r_offset;
3863
3864           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3865           x |= ((((relocation >> 2) & 0xc000) << 6)
3866                 | ((relocation >> 2) & 0x3fff));
3867           bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3868
3869           r = bfd_check_overflow (howto->complain_on_overflow,
3870                                   howto->bitsize, howto->rightshift,
3871                                   bfd_arch_bits_per_address (input_bfd),
3872                                   relocation);
3873         }
3874       else if (r_type == R_SPARC_REV32)
3875         {
3876           bfd_vma x;
3877
3878           relocation = relocation + rel->r_addend;
3879
3880           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3881           x = x + relocation;
3882           bfd_putl32 (/*input_bfd,*/ x, contents + rel->r_offset);
3883           r = bfd_reloc_ok;
3884         }
3885       else if (r_type == R_SPARC_TLS_LDO_HIX22
3886                || r_type == R_SPARC_TLS_LE_HIX22)
3887         {
3888           bfd_vma x;
3889
3890           relocation += rel->r_addend;
3891           if (r_type == R_SPARC_TLS_LE_HIX22)
3892             relocation ^= MINUS_ONE;
3893
3894           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3895           x = (x & ~(bfd_vma) 0x3fffff) | ((relocation >> 10) & 0x3fffff);
3896           bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3897           r = bfd_reloc_ok;
3898         }
3899       else if (r_type == R_SPARC_TLS_LDO_LOX10
3900                || r_type == R_SPARC_TLS_LE_LOX10)
3901         {
3902           bfd_vma x;
3903
3904           relocation += rel->r_addend;
3905           relocation &= 0x3ff;
3906           if (r_type == R_SPARC_TLS_LE_LOX10)
3907             relocation |= 0x1c00;
3908
3909           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3910           x = (x & ~(bfd_vma) 0x1fff) | relocation;
3911           bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3912
3913           r = bfd_reloc_ok;
3914         }
3915       else if (r_type == R_SPARC_HIX22
3916                || r_type == R_SPARC_GOTDATA_HIX22)
3917         {
3918           bfd_vma x;
3919
3920           relocation += rel->r_addend;
3921           if (r_type == R_SPARC_HIX22
3922               || (bfd_signed_vma) relocation < 0)
3923             relocation = relocation ^ MINUS_ONE;
3924
3925           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3926           x = (x & ~(bfd_vma) 0x3fffff) | ((relocation >> 10) & 0x3fffff);
3927           bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3928
3929           r = bfd_check_overflow (howto->complain_on_overflow,
3930                                   howto->bitsize, howto->rightshift,
3931                                   bfd_arch_bits_per_address (input_bfd),
3932                                   relocation);
3933         }
3934       else if (r_type == R_SPARC_LOX10
3935                || r_type == R_SPARC_GOTDATA_LOX10)
3936         {
3937           bfd_vma x;
3938
3939           relocation += rel->r_addend;
3940           if (r_type == R_SPARC_LOX10
3941               || (bfd_signed_vma) relocation < 0)
3942             relocation = (relocation & 0x3ff) | 0x1c00;
3943           else
3944             relocation = (relocation & 0x3ff);
3945
3946           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3947           x = (x & ~(bfd_vma) 0x1fff) | relocation;
3948           bfd_put_32 (input_bfd, x, contents + rel->r_offset);
3949
3950           r = bfd_reloc_ok;
3951         }
3952       else if ((r_type == R_SPARC_WDISP30 || r_type == R_SPARC_WPLT30)
3953                && sec_do_relax (input_section)
3954                && rel->r_offset + 4 < input_section->size)
3955         {
3956 #define G0              0
3957 #define O7              15
3958 #define XCC             (2 << 20)
3959 #define COND(x)         (((x)&0xf)<<25)
3960 #define CONDA           COND(0x8)
3961 #define INSN_BPA        (F2(0,1) | CONDA | BPRED | XCC)
3962 #define INSN_BA         (F2(0,2) | CONDA)
3963 #define INSN_OR         F3(2, 0x2, 0)
3964 #define INSN_NOP        F2(0,4)
3965
3966           bfd_vma x, y;
3967
3968           /* If the instruction is a call with either:
3969              restore
3970              arithmetic instruction with rd == %o7
3971              where rs1 != %o7 and rs2 if it is register != %o7
3972              then we can optimize if the call destination is near
3973              by changing the call into a branch always.  */
3974           x = bfd_get_32 (input_bfd, contents + rel->r_offset);
3975           y = bfd_get_32 (input_bfd, contents + rel->r_offset + 4);
3976           if ((x & OP(~0)) == OP(1) && (y & OP(~0)) == OP(2))
3977             {
3978               if (((y & OP3(~0)) == OP3(0x3d) /* restore */
3979                    || ((y & OP3(0x28)) == 0 /* arithmetic */
3980                        && (y & RD(~0)) == RD(O7)))
3981                   && (y & RS1(~0)) != RS1(O7)
3982                   && ((y & F3I(~0))
3983                       || (y & RS2(~0)) != RS2(O7)))
3984                 {
3985                   bfd_vma reloc;
3986
3987                   reloc = relocation + rel->r_addend - rel->r_offset;
3988                   reloc -= (input_section->output_section->vma
3989                             + input_section->output_offset);
3990
3991                   /* Ensure the branch fits into simm22.  */
3992                   if ((reloc & 3) == 0
3993                       && ((reloc & ~(bfd_vma)0x7fffff) == 0
3994                           || ((reloc | 0x7fffff) == ~(bfd_vma)0)))
3995                     {
3996                       reloc >>= 2;
3997
3998                       /* Check whether it fits into simm19.  */
3999                       if (((reloc & 0x3c0000) == 0
4000                            || (reloc & 0x3c0000) == 0x3c0000)
4001                           && (ABI_64_P (output_bfd)
4002                               || elf_elfheader (output_bfd)->e_flags & EF_SPARC_32PLUS))
4003                         x = INSN_BPA | (reloc & 0x7ffff); /* ba,pt %xcc */
4004                       else
4005                         x = INSN_BA | (reloc & 0x3fffff); /* ba */
4006                       bfd_put_32 (input_bfd, x, contents + rel->r_offset);
4007                       r = bfd_reloc_ok;
4008                       if (rel->r_offset >= 4
4009                           && (y & (0xffffffff ^ RS1(~0)))
4010                              == (INSN_OR | RD(O7) | RS2(G0)))
4011                         {
4012                           bfd_vma z;
4013                           unsigned int reg;
4014
4015                           z = bfd_get_32 (input_bfd,
4016                                           contents + rel->r_offset - 4);
4017                           if ((z & (0xffffffff ^ RD(~0)))
4018                               != (INSN_OR | RS1(O7) | RS2(G0)))
4019                             break;
4020
4021                           /* The sequence was
4022                              or %o7, %g0, %rN
4023                              call foo
4024                              or %rN, %g0, %o7
4025
4026                              If call foo was replaced with ba, replace
4027                              or %rN, %g0, %o7 with nop.  */
4028
4029                           reg = (y & RS1(~0)) >> 14;
4030                           if (reg != ((z & RD(~0)) >> 25)
4031                               || reg == G0 || reg == O7)
4032                             break;
4033
4034                           bfd_put_32 (input_bfd, (bfd_vma) INSN_NOP,
4035                                       contents + rel->r_offset + 4);
4036                         }
4037
4038                     }
4039                 }
4040             }
4041         }
4042
4043       if (r == bfd_reloc_continue)
4044         {
4045 do_relocation:
4046           r = _bfd_final_link_relocate (howto, input_bfd, input_section,
4047                                         contents, rel->r_offset,
4048                                         relocation, rel->r_addend);
4049         }
4050       if (r != bfd_reloc_ok)
4051         {
4052           switch (r)
4053             {
4054             default:
4055             case bfd_reloc_outofrange:
4056               abort ();
4057             case bfd_reloc_overflow:
4058               {
4059                 const char *name;
4060
4061                 /* The Solaris native linker silently disregards overflows. 
4062                    We don't, but this breaks stabs debugging info, whose
4063                    relocations are only 32-bits wide.  Ignore overflows in
4064                    this case and also for discarded entries.  */
4065                 if ((r_type == R_SPARC_32
4066                      || r_type == R_SPARC_UA32
4067                      || r_type == R_SPARC_DISP32)
4068                     && (((input_section->flags & SEC_DEBUGGING) != 0
4069                          && strcmp (bfd_section_name (input_bfd,
4070                                                       input_section),
4071                                     ".stab") == 0)
4072                         || _bfd_elf_section_offset (output_bfd, info,
4073                                                     input_section,
4074                                                     rel->r_offset)
4075                              == (bfd_vma)-1))
4076                   break;
4077
4078                 if (h != NULL)
4079                   {
4080                     /* Assume this is a call protected by other code that
4081                        detect the symbol is undefined.  If this is the case,
4082                        we can safely ignore the overflow.  If not, the
4083                        program is hosed anyway, and a little warning isn't
4084                        going to help.  */
4085                     if (h->root.type == bfd_link_hash_undefweak
4086                         && howto->pc_relative)
4087                       break;
4088
4089                     name = NULL;
4090                   }
4091                 else
4092                   {
4093                     name = bfd_elf_string_from_elf_section (input_bfd,
4094                                                             symtab_hdr->sh_link,
4095                                                             sym->st_name);
4096                     if (name == NULL)
4097                       return FALSE;
4098                     if (*name == '\0')
4099                       name = bfd_section_name (input_bfd, sec);
4100                   }
4101                 if (! ((*info->callbacks->reloc_overflow)
4102                        (info, (h ? &h->root : NULL), name, howto->name,
4103                         (bfd_vma) 0, input_bfd, input_section,
4104                         rel->r_offset)))
4105                   return FALSE;
4106               }
4107               break;
4108             }
4109         }
4110     }
4111
4112   return TRUE;
4113 }
4114
4115 /* Build a VxWorks PLT entry.  PLT_INDEX is the index of the PLT entry
4116    and PLT_OFFSET is the byte offset from the start of .plt.  GOT_OFFSET
4117    is the offset of the associated .got.plt entry from
4118    _GLOBAL_OFFSET_TABLE_.  */
4119
4120 static void
4121 sparc_vxworks_build_plt_entry (bfd *output_bfd, struct bfd_link_info *info,
4122                                bfd_vma plt_offset, bfd_vma plt_index,
4123                                bfd_vma got_offset)
4124 {
4125   bfd_vma got_base;
4126   const bfd_vma *plt_entry;
4127   struct _bfd_sparc_elf_link_hash_table *htab;
4128   bfd_byte *loc;
4129   Elf_Internal_Rela rela;
4130
4131   htab = _bfd_sparc_elf_hash_table (info);
4132   BFD_ASSERT (htab != NULL);
4133
4134   if (info->shared)
4135     {
4136       plt_entry = sparc_vxworks_shared_plt_entry;
4137       got_base = 0;
4138     }
4139   else
4140     {
4141       plt_entry = sparc_vxworks_exec_plt_entry;
4142       got_base = (htab->elf.hgot->root.u.def.value
4143                   + htab->elf.hgot->root.u.def.section->output_offset
4144                   + htab->elf.hgot->root.u.def.section->output_section->vma);
4145     }
4146
4147   /* Fill in the entry in the procedure linkage table.  */
4148   bfd_put_32 (output_bfd, plt_entry[0] + ((got_base + got_offset) >> 10),
4149               htab->elf.splt->contents + plt_offset);
4150   bfd_put_32 (output_bfd, plt_entry[1] + ((got_base + got_offset) & 0x3ff),
4151               htab->elf.splt->contents + plt_offset + 4);
4152   bfd_put_32 (output_bfd, plt_entry[2],
4153               htab->elf.splt->contents + plt_offset + 8);
4154   bfd_put_32 (output_bfd, plt_entry[3],
4155               htab->elf.splt->contents + plt_offset + 12);
4156   bfd_put_32 (output_bfd, plt_entry[4],
4157               htab->elf.splt->contents + plt_offset + 16);
4158   bfd_put_32 (output_bfd, plt_entry[5] + (plt_index >> 10),
4159               htab->elf.splt->contents + plt_offset + 20);
4160   /* PC-relative displacement for a branch to the start of
4161      the PLT section.  */
4162   bfd_put_32 (output_bfd, plt_entry[6] + (((-plt_offset - 24) >> 2)
4163                                           & 0x003fffff),
4164               htab->elf.splt->contents + plt_offset + 24);
4165   bfd_put_32 (output_bfd, plt_entry[7] + (plt_index & 0x3ff),
4166               htab->elf.splt->contents + plt_offset + 28);
4167
4168   /* Fill in the .got.plt entry, pointing initially at the
4169      second half of the PLT entry.  */
4170   BFD_ASSERT (htab->elf.sgotplt != NULL);
4171   bfd_put_32 (output_bfd,
4172               htab->elf.splt->output_section->vma
4173               + htab->elf.splt->output_offset
4174               + plt_offset + 20,
4175               htab->elf.sgotplt->contents + got_offset);
4176
4177   /* Add relocations to .rela.plt.unloaded.  */
4178   if (!info->shared)
4179     {
4180       loc = (htab->srelplt2->contents
4181              + (2 + 3 * plt_index) * sizeof (Elf32_External_Rela));
4182
4183       /* Relocate the initial sethi.  */
4184       rela.r_offset = (htab->elf.splt->output_section->vma
4185                        + htab->elf.splt->output_offset
4186                        + plt_offset);
4187       rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_HI22);
4188       rela.r_addend = got_offset;
4189       bfd_elf32_swap_reloca_out (output_bfd, &rela, loc);
4190       loc += sizeof (Elf32_External_Rela);
4191
4192       /* Likewise the following or.  */
4193       rela.r_offset += 4;
4194       rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_LO10);
4195       bfd_elf32_swap_reloca_out (output_bfd, &rela, loc);
4196       loc += sizeof (Elf32_External_Rela);
4197
4198       /* Relocate the .got.plt entry.  */
4199       rela.r_offset = (htab->elf.sgotplt->output_section->vma
4200                        + htab->elf.sgotplt->output_offset
4201                        + got_offset);
4202       rela.r_info = ELF32_R_INFO (htab->elf.hplt->indx, R_SPARC_32);
4203       rela.r_addend = plt_offset + 20;
4204       bfd_elf32_swap_reloca_out (output_bfd, &rela, loc);
4205     }
4206 }
4207
4208 /* Finish up dynamic symbol handling.  We set the contents of various
4209    dynamic sections here.  */
4210
4211 bfd_boolean
4212 _bfd_sparc_elf_finish_dynamic_symbol (bfd *output_bfd,
4213                                       struct bfd_link_info *info,
4214                                       struct elf_link_hash_entry *h,
4215                                       Elf_Internal_Sym *sym)
4216 {
4217   struct _bfd_sparc_elf_link_hash_table *htab;
4218   const struct elf_backend_data *bed;
4219
4220   htab = _bfd_sparc_elf_hash_table (info);
4221   BFD_ASSERT (htab != NULL);
4222   bed = get_elf_backend_data (output_bfd);
4223
4224   if (h->plt.offset != (bfd_vma) -1)
4225     {
4226       asection *splt;
4227       asection *srela;
4228       Elf_Internal_Rela rela;
4229       bfd_byte *loc;
4230       bfd_vma r_offset, got_offset;
4231       int rela_index;
4232
4233       /* When building a static executable, use .iplt and
4234          .rela.iplt sections for STT_GNU_IFUNC symbols.  */
4235       if (htab->elf.splt != NULL)
4236         {
4237           splt = htab->elf.splt;
4238           srela = htab->elf.srelplt;
4239         }
4240       else
4241         {
4242           splt = htab->elf.iplt;
4243           srela = htab->elf.irelplt;
4244         }
4245
4246       if (splt == NULL || srela == NULL)
4247         abort ();
4248
4249       /* Fill in the entry in the .rela.plt section.  */
4250       if (htab->is_vxworks)
4251         {
4252           /* Work out the index of this PLT entry.  */
4253           rela_index = ((h->plt.offset - htab->plt_header_size)
4254                         / htab->plt_entry_size);
4255
4256           /* Calculate the offset of the associated .got.plt entry.
4257              The first three entries are reserved.  */
4258           got_offset = (rela_index + 3) * 4;
4259
4260           sparc_vxworks_build_plt_entry (output_bfd, info, h->plt.offset,
4261                                          rela_index, got_offset);
4262
4263
4264           /* On VxWorks, the relocation points to the .got.plt entry,
4265              not the .plt entry.  */
4266           rela.r_offset = (htab->elf.sgotplt->output_section->vma
4267                            + htab->elf.sgotplt->output_offset
4268                            + got_offset);
4269           rela.r_addend = 0;
4270           rela.r_info = SPARC_ELF_R_INFO (htab, NULL, h->dynindx,
4271                                           R_SPARC_JMP_SLOT);
4272         }
4273       else
4274         {
4275           bfd_boolean ifunc = FALSE;
4276
4277           /* Fill in the entry in the procedure linkage table.  */
4278           rela_index = SPARC_ELF_BUILD_PLT_ENTRY (htab, output_bfd, splt,
4279                                                   h->plt.offset, splt->size,
4280                                                   &r_offset);
4281
4282           if (h == NULL
4283               || h->dynindx == -1
4284               || ((info->executable
4285                    || ELF_ST_VISIBILITY (h->other) != STV_DEFAULT)
4286                   && h->def_regular
4287                   && h->type == STT_GNU_IFUNC))
4288             {
4289               ifunc = TRUE;
4290               BFD_ASSERT (h == NULL
4291                           || (h->type == STT_GNU_IFUNC
4292                               && h->def_regular
4293                               && (h->root.type == bfd_link_hash_defined
4294                                   || h->root.type == bfd_link_hash_defweak)));
4295             }
4296
4297           rela.r_offset = r_offset
4298             + (splt->output_section->vma + splt->output_offset);
4299           if (ABI_64_P (output_bfd)
4300               && h->plt.offset >= (PLT64_LARGE_THRESHOLD * PLT64_ENTRY_SIZE))
4301             {
4302               if (ifunc)
4303                 {
4304                   rela.r_addend = (h->root.u.def.section->output_section->vma
4305                                    + h->root.u.def.section->output_offset
4306                                    + h->root.u.def.value);
4307                   rela.r_info = SPARC_ELF_R_INFO (htab, NULL, 0,
4308                                                   R_SPARC_IRELATIVE);
4309                 }
4310               else
4311                 {
4312                   rela.r_addend = (-(h->plt.offset + 4)
4313                                    - splt->output_section->vma
4314                                    - splt->output_offset);
4315                   rela.r_info = SPARC_ELF_R_INFO (htab, NULL, h->dynindx,
4316                                                   R_SPARC_JMP_SLOT);
4317                 }
4318             }
4319           else
4320             {
4321               if (ifunc)
4322                 {
4323                   rela.r_addend = (h->root.u.def.section->output_section->vma
4324                                    + h->root.u.def.section->output_offset
4325                                    + h->root.u.def.value);
4326                   rela.r_info = SPARC_ELF_R_INFO (htab, NULL, 0,
4327                                                   R_SPARC_JMP_IREL);
4328                 }
4329               else
4330                 {
4331                   rela.r_addend = 0;
4332                   rela.r_info = SPARC_ELF_R_INFO (htab, NULL, h->dynindx,
4333                                                   R_SPARC_JMP_SLOT);
4334                 }
4335             }
4336         }
4337
4338       /* Adjust for the first 4 reserved elements in the .plt section
4339          when setting the offset in the .rela.plt section.
4340          Sun forgot to read their own ABI and copied elf32-sparc behaviour,
4341          thus .plt[4] has corresponding .rela.plt[0] and so on.  */
4342
4343       loc = srela->contents;
4344       loc += rela_index * bed->s->sizeof_rela;
4345       bed->s->swap_reloca_out (output_bfd, &rela, loc);
4346
4347       if (!h->def_regular)
4348         {
4349           /* Mark the symbol as undefined, rather than as defined in
4350              the .plt section.  Leave the value alone.  */
4351           sym->st_shndx = SHN_UNDEF;
4352           /* If the symbol is weak, we do need to clear the value.
4353              Otherwise, the PLT entry would provide a definition for
4354              the symbol even if the symbol wasn't defined anywhere,
4355              and so the symbol would never be NULL.  */
4356           if (!h->ref_regular_nonweak)
4357             sym->st_value = 0;
4358         }
4359     }
4360
4361   if (h->got.offset != (bfd_vma) -1
4362       && _bfd_sparc_elf_hash_entry(h)->tls_type != GOT_TLS_GD
4363       && _bfd_sparc_elf_hash_entry(h)->tls_type != GOT_TLS_IE)
4364     {
4365       asection *sgot;
4366       asection *srela;
4367       Elf_Internal_Rela rela;
4368
4369       /* This symbol has an entry in the GOT.  Set it up.  */
4370
4371       sgot = htab->elf.sgot;
4372       srela = htab->elf.srelgot;
4373       BFD_ASSERT (sgot != NULL && srela != NULL);
4374
4375       rela.r_offset = (sgot->output_section->vma
4376                        + sgot->output_offset
4377                        + (h->got.offset &~ (bfd_vma) 1));
4378
4379       /* If this is a -Bsymbolic link, and the symbol is defined
4380          locally, we just want to emit a RELATIVE reloc.  Likewise if
4381          the symbol was forced to be local because of a version file.
4382          The entry in the global offset table will already have been
4383          initialized in the relocate_section function.  */
4384       if (! info->shared
4385           && h->type == STT_GNU_IFUNC
4386           && h->def_regular)
4387         {
4388           asection *plt;
4389
4390           /* We load the GOT entry with the PLT entry.  */
4391           plt = htab->elf.splt ? htab->elf.splt : htab->elf.iplt;
4392           SPARC_ELF_PUT_WORD (htab, output_bfd,
4393                               (plt->output_section->vma
4394                                + plt->output_offset + h->plt.offset),
4395                               htab->elf.sgot->contents
4396                               + (h->got.offset & ~(bfd_vma) 1));
4397           return TRUE;
4398         }
4399       else if (info->shared
4400                && SYMBOL_REFERENCES_LOCAL (info, h))
4401         {
4402           asection *sec = h->root.u.def.section;
4403           if (h->type == STT_GNU_IFUNC)
4404             rela.r_info = SPARC_ELF_R_INFO (htab, NULL, 0, R_SPARC_IRELATIVE);
4405           else
4406             rela.r_info = SPARC_ELF_R_INFO (htab, NULL, 0, R_SPARC_RELATIVE);
4407           rela.r_addend = (h->root.u.def.value
4408                            + sec->output_section->vma
4409                            + sec->output_offset);
4410         }
4411       else
4412         {
4413           rela.r_info = SPARC_ELF_R_INFO (htab, NULL, h->dynindx, R_SPARC_GLOB_DAT);
4414           rela.r_addend = 0;
4415         }
4416
4417       SPARC_ELF_PUT_WORD (htab, output_bfd, 0,
4418                           sgot->contents + (h->got.offset & ~(bfd_vma) 1));
4419       sparc_elf_append_rela (output_bfd, srela, &rela);
4420     }
4421
4422   if (h->needs_copy)
4423     {
4424       asection *s;
4425       Elf_Internal_Rela rela;
4426
4427       /* This symbols needs a copy reloc.  Set it up.  */
4428       BFD_ASSERT (h->dynindx != -1);
4429
4430       s = bfd_get_section_by_name (h->root.u.def.section->owner,
4431                                    ".rela.bss");
4432       BFD_ASSERT (s != NULL);
4433
4434       rela.r_offset = (h->root.u.def.value
4435                        + h->root.u.def.section->output_section->vma
4436                        + h->root.u.def.section->output_offset);
4437       rela.r_info = SPARC_ELF_R_INFO (htab, NULL, h->dynindx, R_SPARC_COPY);
4438       rela.r_addend = 0;
4439       sparc_elf_append_rela (output_bfd, s, &rela);
4440     }
4441
4442   /* Mark some specially defined symbols as absolute.  On VxWorks,
4443      _GLOBAL_OFFSET_TABLE_ is not absolute: it is relative to the
4444      ".got" section.  Likewise _PROCEDURE_LINKAGE_TABLE_ and ".plt".  */
4445   if (sym != NULL
4446       && (strcmp (h->root.root.string, "_DYNAMIC") == 0
4447           || (!htab->is_vxworks
4448               && (h == htab->elf.hgot || h == htab->elf.hplt))))
4449     sym->st_shndx = SHN_ABS;
4450
4451   return TRUE;
4452 }
4453
4454 /* Finish up the dynamic sections.  */
4455
4456 static bfd_boolean
4457 sparc_finish_dyn (bfd *output_bfd, struct bfd_link_info *info,
4458                   bfd *dynobj, asection *sdyn,
4459                   asection *splt ATTRIBUTE_UNUSED)
4460 {
4461   struct _bfd_sparc_elf_link_hash_table *htab;
4462   const struct elf_backend_data *bed;
4463   bfd_byte *dyncon, *dynconend;
4464   size_t dynsize;
4465   int stt_regidx = -1;
4466   bfd_boolean abi_64_p;
4467
4468   htab = _bfd_sparc_elf_hash_table (info);
4469   BFD_ASSERT (htab != NULL);
4470   bed = get_elf_backend_data (output_bfd);
4471   dynsize = bed->s->sizeof_dyn;
4472   dynconend = sdyn->contents + sdyn->size;
4473   abi_64_p = ABI_64_P (output_bfd);
4474   for (dyncon = sdyn->contents; dyncon < dynconend; dyncon += dynsize)
4475     {
4476       Elf_Internal_Dyn dyn;
4477       const char *name;
4478       bfd_boolean size;
4479
4480       bed->s->swap_dyn_in (dynobj, dyncon, &dyn);
4481
4482       if (htab->is_vxworks && dyn.d_tag == DT_RELASZ)
4483         {
4484           /* On VxWorks, DT_RELASZ should not include the relocations
4485              in .rela.plt.  */
4486           if (htab->elf.srelplt)
4487             {
4488               dyn.d_un.d_val -= htab->elf.srelplt->size;
4489               bed->s->swap_dyn_out (output_bfd, &dyn, dyncon);
4490             }
4491         }
4492       else if (htab->is_vxworks && dyn.d_tag == DT_PLTGOT)
4493         {
4494           /* On VxWorks, DT_PLTGOT should point to the start of the GOT,
4495              not to the start of the PLT.  */
4496           if (htab->elf.sgotplt)
4497             {
4498               dyn.d_un.d_val = (htab->elf.sgotplt->output_section->vma
4499                                 + htab->elf.sgotplt->output_offset);
4500               bed->s->swap_dyn_out (output_bfd, &dyn, dyncon);
4501             }
4502         }
4503       else if (htab->is_vxworks
4504                && elf_vxworks_finish_dynamic_entry (output_bfd, &dyn))
4505         bed->s->swap_dyn_out (output_bfd, &dyn, dyncon);
4506       else if (abi_64_p && dyn.d_tag == DT_SPARC_REGISTER)
4507         {
4508           if (stt_regidx == -1)
4509             {
4510               stt_regidx =
4511                 _bfd_elf_link_lookup_local_dynindx (info, output_bfd, -1);
4512               if (stt_regidx == -1)
4513                 return FALSE;
4514             }
4515           dyn.d_un.d_val = stt_regidx++;
4516           bed->s->swap_dyn_out (output_bfd, &dyn, dyncon);
4517         }
4518       else
4519         {
4520           switch (dyn.d_tag)
4521             {
4522             case DT_PLTGOT:   name = ".plt"; size = FALSE; break;
4523             case DT_PLTRELSZ: name = ".rela.plt"; size = TRUE; break;
4524             case DT_JMPREL:   name = ".rela.plt"; size = FALSE; break;
4525             default:          name = NULL; size = FALSE; break;
4526             }
4527
4528           if (name != NULL)
4529             {
4530               asection *s;
4531
4532               s = bfd_get_section_by_name (output_bfd, name);
4533               if (s == NULL)
4534                 dyn.d_un.d_val = 0;
4535               else
4536                 {
4537                   if (! size)
4538                     dyn.d_un.d_ptr = s->vma;
4539                   else
4540                     dyn.d_un.d_val = s->size;
4541                 }
4542               bed->s->swap_dyn_out (output_bfd, &dyn, dyncon);
4543             }
4544         }
4545     }
4546   return TRUE;
4547 }
4548
4549 /* Install the first PLT entry in a VxWorks executable and make sure that
4550    .rela.plt.unloaded relocations have the correct symbol indexes.  */
4551
4552 static void
4553 sparc_vxworks_finish_exec_plt (bfd *output_bfd, struct bfd_link_info *info)
4554 {
4555   struct _bfd_sparc_elf_link_hash_table *htab;
4556   Elf_Internal_Rela rela;
4557   bfd_vma got_base;
4558   bfd_byte *loc;
4559
4560   htab = _bfd_sparc_elf_hash_table (info);
4561   BFD_ASSERT (htab != NULL);
4562
4563   /* Calculate the absolute value of _GLOBAL_OFFSET_TABLE_.  */
4564   got_base = (htab->elf.hgot->root.u.def.section->output_section->vma
4565               + htab->elf.hgot->root.u.def.section->output_offset
4566               + htab->elf.hgot->root.u.def.value);
4567
4568   /* Install the initial PLT entry.  */
4569   bfd_put_32 (output_bfd,
4570               sparc_vxworks_exec_plt0_entry[0] + ((got_base + 8) >> 10),
4571               htab->elf.splt->contents);
4572   bfd_put_32 (output_bfd,
4573               sparc_vxworks_exec_plt0_entry[1] + ((got_base + 8) & 0x3ff),
4574               htab->elf.splt->contents + 4);
4575   bfd_put_32 (output_bfd,
4576               sparc_vxworks_exec_plt0_entry[2],
4577               htab->elf.splt->contents + 8);
4578   bfd_put_32 (output_bfd,
4579               sparc_vxworks_exec_plt0_entry[3],
4580               htab->elf.splt->contents + 12);
4581   bfd_put_32 (output_bfd,
4582               sparc_vxworks_exec_plt0_entry[4],
4583               htab->elf.splt->contents + 16);
4584
4585   loc = htab->srelplt2->contents;
4586
4587   /* Add an unloaded relocation for the initial entry's "sethi".  */
4588   rela.r_offset = (htab->elf.splt->output_section->vma
4589                    + htab->elf.splt->output_offset);
4590   rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_HI22);
4591   rela.r_addend = 8;
4592   bfd_elf32_swap_reloca_out (output_bfd, &rela, loc);
4593   loc += sizeof (Elf32_External_Rela);
4594
4595   /* Likewise the following "or".  */
4596   rela.r_offset += 4;
4597   rela.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_LO10);
4598   bfd_elf32_swap_reloca_out (output_bfd, &rela, loc);
4599   loc += sizeof (Elf32_External_Rela);
4600
4601   /* Fix up the remaining .rela.plt.unloaded relocations.  They may have
4602      the wrong symbol index for _G_O_T_ or _P_L_T_ depending on the order
4603      in which symbols were output.  */
4604   while (loc < htab->srelplt2->contents + htab->srelplt2->size)
4605     {
4606       Elf_Internal_Rela rel;
4607
4608       /* The entry's initial "sethi" (against _G_O_T_).  */
4609       bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
4610       rel.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_HI22);
4611       bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
4612       loc += sizeof (Elf32_External_Rela);
4613
4614       /* The following "or" (also against _G_O_T_).  */
4615       bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
4616       rel.r_info = ELF32_R_INFO (htab->elf.hgot->indx, R_SPARC_LO10);
4617       bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
4618       loc += sizeof (Elf32_External_Rela);
4619
4620       /* The .got.plt entry (against _P_L_T_).  */
4621       bfd_elf32_swap_reloc_in (output_bfd, loc, &rel);
4622       rel.r_info = ELF32_R_INFO (htab->elf.hplt->indx, R_SPARC_32);
4623       bfd_elf32_swap_reloc_out (output_bfd, &rel, loc);
4624       loc += sizeof (Elf32_External_Rela);
4625     }
4626 }
4627
4628 /* Install the first PLT entry in a VxWorks shared object.  */
4629
4630 static void
4631 sparc_vxworks_finish_shared_plt (bfd *output_bfd, struct bfd_link_info *info)
4632 {
4633   struct _bfd_sparc_elf_link_hash_table *htab;
4634   unsigned int i;
4635
4636   htab = _bfd_sparc_elf_hash_table (info);
4637   BFD_ASSERT (htab != NULL);
4638
4639   for (i = 0; i < ARRAY_SIZE (sparc_vxworks_shared_plt0_entry); i++)
4640     bfd_put_32 (output_bfd, sparc_vxworks_shared_plt0_entry[i],
4641                 htab->elf.splt->contents + i * 4);
4642 }
4643
4644 /* Finish up local dynamic symbol handling.  We set the contents of
4645    various dynamic sections here.  */
4646
4647 static bfd_boolean
4648 finish_local_dynamic_symbol (void **slot, void *inf)
4649 {
4650   struct elf_link_hash_entry *h
4651     = (struct elf_link_hash_entry *) *slot;
4652   struct bfd_link_info *info
4653     = (struct bfd_link_info *) inf; 
4654
4655   return _bfd_sparc_elf_finish_dynamic_symbol (info->output_bfd, info,
4656                                                h, NULL);
4657 }
4658
4659 bfd_boolean
4660 _bfd_sparc_elf_finish_dynamic_sections (bfd *output_bfd, struct bfd_link_info *info)
4661 {
4662   bfd *dynobj;
4663   asection *sdyn;
4664   struct _bfd_sparc_elf_link_hash_table *htab;
4665
4666   htab = _bfd_sparc_elf_hash_table (info);
4667   BFD_ASSERT (htab != NULL);
4668   dynobj = htab->elf.dynobj;
4669
4670   sdyn = bfd_get_section_by_name (dynobj, ".dynamic");
4671
4672   if (elf_hash_table (info)->dynamic_sections_created)
4673     {
4674       asection *splt;
4675
4676       splt = bfd_get_section_by_name (dynobj, ".plt");
4677       BFD_ASSERT (splt != NULL && sdyn != NULL);
4678
4679       if (!sparc_finish_dyn (output_bfd, info, dynobj, sdyn, splt))
4680         return FALSE;
4681
4682       /* Initialize the contents of the .plt section.  */
4683       if (splt->size > 0)
4684         {
4685           if (htab->is_vxworks)
4686             {
4687               if (info->shared)
4688                 sparc_vxworks_finish_shared_plt (output_bfd, info);
4689               else
4690                 sparc_vxworks_finish_exec_plt (output_bfd, info);
4691             }
4692           else
4693             {
4694               memset (splt->contents, 0, htab->plt_header_size);
4695               if (!ABI_64_P (output_bfd))
4696                 bfd_put_32 (output_bfd, (bfd_vma) SPARC_NOP,
4697                             splt->contents + splt->size - 4);
4698             }
4699         }
4700
4701       elf_section_data (splt->output_section)->this_hdr.sh_entsize
4702         = (htab->is_vxworks || !ABI_64_P (output_bfd))
4703           ? 0 : htab->plt_entry_size;
4704     }
4705
4706   /* Set the first entry in the global offset table to the address of
4707      the dynamic section.  */
4708   if (htab->elf.sgot && htab->elf.sgot->size > 0)
4709     {
4710       bfd_vma val = (sdyn ?
4711                      sdyn->output_section->vma + sdyn->output_offset :
4712                      0);
4713
4714       SPARC_ELF_PUT_WORD (htab, output_bfd, val, htab->elf.sgot->contents);
4715     }
4716
4717   if (htab->elf.sgot)
4718     elf_section_data (htab->elf.sgot->output_section)->this_hdr.sh_entsize =
4719       SPARC_ELF_WORD_BYTES (htab);
4720
4721   /* Fill PLT and GOT entries for local STT_GNU_IFUNC symbols.  */
4722   htab_traverse (htab->loc_hash_table, finish_local_dynamic_symbol, info);
4723
4724   return TRUE;
4725 }
4726
4727 \f
4728 /* Set the right machine number for a SPARC ELF file.  */
4729
4730 bfd_boolean
4731 _bfd_sparc_elf_object_p (bfd *abfd)
4732 {
4733   if (ABI_64_P (abfd))
4734     {
4735       unsigned long mach = bfd_mach_sparc_v9;
4736
4737       if (elf_elfheader (abfd)->e_flags & EF_SPARC_SUN_US3)
4738         mach = bfd_mach_sparc_v9b;
4739       else if (elf_elfheader (abfd)->e_flags & EF_SPARC_SUN_US1)
4740         mach = bfd_mach_sparc_v9a;
4741       return bfd_default_set_arch_mach (abfd, bfd_arch_sparc, mach);
4742     }
4743   else
4744     {
4745       if (elf_elfheader (abfd)->e_machine == EM_SPARC32PLUS)
4746         {
4747           if (elf_elfheader (abfd)->e_flags & EF_SPARC_SUN_US3)
4748             return bfd_default_set_arch_mach (abfd, bfd_arch_sparc,
4749                                               bfd_mach_sparc_v8plusb);
4750           else if (elf_elfheader (abfd)->e_flags & EF_SPARC_SUN_US1)
4751             return bfd_default_set_arch_mach (abfd, bfd_arch_sparc,
4752                                               bfd_mach_sparc_v8plusa);
4753           else if (elf_elfheader (abfd)->e_flags & EF_SPARC_32PLUS)
4754             return bfd_default_set_arch_mach (abfd, bfd_arch_sparc,
4755                                               bfd_mach_sparc_v8plus);
4756           else
4757             return FALSE;
4758         }
4759       else if (elf_elfheader (abfd)->e_flags & EF_SPARC_LEDATA)
4760         return bfd_default_set_arch_mach (abfd, bfd_arch_sparc,
4761                                           bfd_mach_sparc_sparclite_le);
4762       else
4763         return bfd_default_set_arch_mach (abfd, bfd_arch_sparc, bfd_mach_sparc);
4764     }
4765 }
4766
4767 /* Return address for Ith PLT stub in section PLT, for relocation REL
4768    or (bfd_vma) -1 if it should not be included.  */
4769
4770 bfd_vma
4771 _bfd_sparc_elf_plt_sym_val (bfd_vma i, const asection *plt, const arelent *rel)
4772 {
4773   if (ABI_64_P (plt->owner))
4774     {
4775       bfd_vma j;
4776
4777       i += PLT64_HEADER_SIZE / PLT64_ENTRY_SIZE;
4778       if (i < PLT64_LARGE_THRESHOLD)
4779         return plt->vma + i * PLT64_ENTRY_SIZE;
4780
4781       j = (i - PLT64_LARGE_THRESHOLD) % 160;
4782       i -= j;
4783       return plt->vma + i * PLT64_ENTRY_SIZE + j * 4 * 6;
4784     }
4785   else
4786     return rel->address;
4787 }
4788
4789 /* Merge backend specific data from an object file to the output
4790    object file when linking.  */
4791
4792 bfd_boolean
4793 _bfd_sparc_elf_merge_private_bfd_data (bfd *ibfd, bfd *obfd)
4794 {
4795   obj_attribute *in_attr, *in_attrs;
4796   obj_attribute *out_attr, *out_attrs;
4797
4798   if (!elf_known_obj_attributes_proc (obfd)[0].i)
4799     {
4800       /* This is the first object.  Copy the attributes.  */
4801       _bfd_elf_copy_obj_attributes (ibfd, obfd);
4802
4803       /* Use the Tag_null value to indicate the attributes have been
4804          initialized.  */
4805       elf_known_obj_attributes_proc (obfd)[0].i = 1;
4806
4807       return TRUE;
4808     }
4809
4810   in_attrs = elf_known_obj_attributes (ibfd)[OBJ_ATTR_GNU];
4811   out_attrs = elf_known_obj_attributes (obfd)[OBJ_ATTR_GNU];
4812
4813   in_attr = &in_attrs[Tag_GNU_Sparc_HWCAPS];
4814   out_attr = &out_attrs[Tag_GNU_Sparc_HWCAPS];
4815
4816   out_attr->i |= in_attr->i;
4817
4818   /* Merge Tag_compatibility attributes and any common GNU ones.  */
4819   _bfd_elf_merge_object_attributes (ibfd, obfd);
4820
4821   return TRUE;
4822 }