2004-04-22 Chris Demetriou <cgd@broadcom.com>
[binutils-gdb.git] / bfd / elfxx-mips.c
1 /* MIPS-specific support for ELF
2 Copyright 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
3 2003, 2004 Free Software Foundation, Inc.
4
5 Most of the information added by Ian Lance Taylor, Cygnus Support,
6 <ian@cygnus.com>.
7 N32/64 ABI support added by Mark Mitchell, CodeSourcery, LLC.
8 <mark@codesourcery.com>
9 Traditional MIPS targets support added by Koundinya.K, Dansk Data
10 Elektronik & Operations Research Group. <kk@ddeorg.soft.net>
11
12 This file is part of BFD, the Binary File Descriptor library.
13
14 This program is free software; you can redistribute it and/or modify
15 it under the terms of the GNU General Public License as published by
16 the Free Software Foundation; either version 2 of the License, or
17 (at your option) any later version.
18
19 This program is distributed in the hope that it will be useful,
20 but WITHOUT ANY WARRANTY; without even the implied warranty of
21 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 GNU General Public License for more details.
23
24 You should have received a copy of the GNU General Public License
25 along with this program; if not, write to the Free Software
26 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
27
28 /* This file handles functionality common to the different MIPS ABI's. */
29
30 #include "bfd.h"
31 #include "sysdep.h"
32 #include "libbfd.h"
33 #include "libiberty.h"
34 #include "elf-bfd.h"
35 #include "elfxx-mips.h"
36 #include "elf/mips.h"
37
38 /* Get the ECOFF swapping routines. */
39 #include "coff/sym.h"
40 #include "coff/symconst.h"
41 #include "coff/ecoff.h"
42 #include "coff/mips.h"
43
44 #include "hashtab.h"
45
46 /* This structure is used to hold .got entries while estimating got
47 sizes. */
48 struct mips_got_entry
49 {
50 /* The input bfd in which the symbol is defined. */
51 bfd *abfd;
52 /* The index of the symbol, as stored in the relocation r_info, if
53 we have a local symbol; -1 otherwise. */
54 long symndx;
55 union
56 {
57 /* If abfd == NULL, an address that must be stored in the got. */
58 bfd_vma address;
59 /* If abfd != NULL && symndx != -1, the addend of the relocation
60 that should be added to the symbol value. */
61 bfd_vma addend;
62 /* If abfd != NULL && symndx == -1, the hash table entry
63 corresponding to a global symbol in the got (or, local, if
64 h->forced_local). */
65 struct mips_elf_link_hash_entry *h;
66 } d;
67 /* The offset from the beginning of the .got section to the entry
68 corresponding to this symbol+addend. If it's a global symbol
69 whose offset is yet to be decided, it's going to be -1. */
70 long gotidx;
71 };
72
73 /* This structure is used to hold .got information when linking. */
74
75 struct mips_got_info
76 {
77 /* The global symbol in the GOT with the lowest index in the dynamic
78 symbol table. */
79 struct elf_link_hash_entry *global_gotsym;
80 /* The number of global .got entries. */
81 unsigned int global_gotno;
82 /* The number of local .got entries. */
83 unsigned int local_gotno;
84 /* The number of local .got entries we have used. */
85 unsigned int assigned_gotno;
86 /* A hash table holding members of the got. */
87 struct htab *got_entries;
88 /* A hash table mapping input bfds to other mips_got_info. NULL
89 unless multi-got was necessary. */
90 struct htab *bfd2got;
91 /* In multi-got links, a pointer to the next got (err, rather, most
92 of the time, it points to the previous got). */
93 struct mips_got_info *next;
94 };
95
96 /* Map an input bfd to a got in a multi-got link. */
97
98 struct mips_elf_bfd2got_hash {
99 bfd *bfd;
100 struct mips_got_info *g;
101 };
102
103 /* Structure passed when traversing the bfd2got hash table, used to
104 create and merge bfd's gots. */
105
106 struct mips_elf_got_per_bfd_arg
107 {
108 /* A hashtable that maps bfds to gots. */
109 htab_t bfd2got;
110 /* The output bfd. */
111 bfd *obfd;
112 /* The link information. */
113 struct bfd_link_info *info;
114 /* A pointer to the primary got, i.e., the one that's going to get
115 the implicit relocations from DT_MIPS_LOCAL_GOTNO and
116 DT_MIPS_GOTSYM. */
117 struct mips_got_info *primary;
118 /* A non-primary got we're trying to merge with other input bfd's
119 gots. */
120 struct mips_got_info *current;
121 /* The maximum number of got entries that can be addressed with a
122 16-bit offset. */
123 unsigned int max_count;
124 /* The number of local and global entries in the primary got. */
125 unsigned int primary_count;
126 /* The number of local and global entries in the current got. */
127 unsigned int current_count;
128 };
129
130 /* Another structure used to pass arguments for got entries traversal. */
131
132 struct mips_elf_set_global_got_offset_arg
133 {
134 struct mips_got_info *g;
135 int value;
136 unsigned int needed_relocs;
137 struct bfd_link_info *info;
138 };
139
140 struct _mips_elf_section_data
141 {
142 struct bfd_elf_section_data elf;
143 union
144 {
145 struct mips_got_info *got_info;
146 bfd_byte *tdata;
147 } u;
148 };
149
150 #define mips_elf_section_data(sec) \
151 ((struct _mips_elf_section_data *) elf_section_data (sec))
152
153 /* This structure is passed to mips_elf_sort_hash_table_f when sorting
154 the dynamic symbols. */
155
156 struct mips_elf_hash_sort_data
157 {
158 /* The symbol in the global GOT with the lowest dynamic symbol table
159 index. */
160 struct elf_link_hash_entry *low;
161 /* The least dynamic symbol table index corresponding to a symbol
162 with a GOT entry. */
163 long min_got_dynindx;
164 /* The greatest dynamic symbol table index corresponding to a symbol
165 with a GOT entry that is not referenced (e.g., a dynamic symbol
166 with dynamic relocations pointing to it from non-primary GOTs). */
167 long max_unref_got_dynindx;
168 /* The greatest dynamic symbol table index not corresponding to a
169 symbol without a GOT entry. */
170 long max_non_got_dynindx;
171 };
172
173 /* The MIPS ELF linker needs additional information for each symbol in
174 the global hash table. */
175
176 struct mips_elf_link_hash_entry
177 {
178 struct elf_link_hash_entry root;
179
180 /* External symbol information. */
181 EXTR esym;
182
183 /* Number of R_MIPS_32, R_MIPS_REL32, or R_MIPS_64 relocs against
184 this symbol. */
185 unsigned int possibly_dynamic_relocs;
186
187 /* If the R_MIPS_32, R_MIPS_REL32, or R_MIPS_64 reloc is against
188 a readonly section. */
189 bfd_boolean readonly_reloc;
190
191 /* We must not create a stub for a symbol that has relocations
192 related to taking the function's address, i.e. any but
193 R_MIPS_CALL*16 ones -- see "MIPS ABI Supplement, 3rd Edition",
194 p. 4-20. */
195 bfd_boolean no_fn_stub;
196
197 /* If there is a stub that 32 bit functions should use to call this
198 16 bit function, this points to the section containing the stub. */
199 asection *fn_stub;
200
201 /* Whether we need the fn_stub; this is set if this symbol appears
202 in any relocs other than a 16 bit call. */
203 bfd_boolean need_fn_stub;
204
205 /* If there is a stub that 16 bit functions should use to call this
206 32 bit function, this points to the section containing the stub. */
207 asection *call_stub;
208
209 /* This is like the call_stub field, but it is used if the function
210 being called returns a floating point value. */
211 asection *call_fp_stub;
212
213 /* Are we forced local? .*/
214 bfd_boolean forced_local;
215 };
216
217 /* MIPS ELF linker hash table. */
218
219 struct mips_elf_link_hash_table
220 {
221 struct elf_link_hash_table root;
222 #if 0
223 /* We no longer use this. */
224 /* String section indices for the dynamic section symbols. */
225 bfd_size_type dynsym_sec_strindex[SIZEOF_MIPS_DYNSYM_SECNAMES];
226 #endif
227 /* The number of .rtproc entries. */
228 bfd_size_type procedure_count;
229 /* The size of the .compact_rel section (if SGI_COMPAT). */
230 bfd_size_type compact_rel_size;
231 /* This flag indicates that the value of DT_MIPS_RLD_MAP dynamic
232 entry is set to the address of __rld_obj_head as in IRIX5. */
233 bfd_boolean use_rld_obj_head;
234 /* This is the value of the __rld_map or __rld_obj_head symbol. */
235 bfd_vma rld_value;
236 /* This is set if we see any mips16 stub sections. */
237 bfd_boolean mips16_stubs_seen;
238 };
239
240 /* Structure used to pass information to mips_elf_output_extsym. */
241
242 struct extsym_info
243 {
244 bfd *abfd;
245 struct bfd_link_info *info;
246 struct ecoff_debug_info *debug;
247 const struct ecoff_debug_swap *swap;
248 bfd_boolean failed;
249 };
250
251 /* The names of the runtime procedure table symbols used on IRIX5. */
252
253 static const char * const mips_elf_dynsym_rtproc_names[] =
254 {
255 "_procedure_table",
256 "_procedure_string_table",
257 "_procedure_table_size",
258 NULL
259 };
260
261 /* These structures are used to generate the .compact_rel section on
262 IRIX5. */
263
264 typedef struct
265 {
266 unsigned long id1; /* Always one? */
267 unsigned long num; /* Number of compact relocation entries. */
268 unsigned long id2; /* Always two? */
269 unsigned long offset; /* The file offset of the first relocation. */
270 unsigned long reserved0; /* Zero? */
271 unsigned long reserved1; /* Zero? */
272 } Elf32_compact_rel;
273
274 typedef struct
275 {
276 bfd_byte id1[4];
277 bfd_byte num[4];
278 bfd_byte id2[4];
279 bfd_byte offset[4];
280 bfd_byte reserved0[4];
281 bfd_byte reserved1[4];
282 } Elf32_External_compact_rel;
283
284 typedef struct
285 {
286 unsigned int ctype : 1; /* 1: long 0: short format. See below. */
287 unsigned int rtype : 4; /* Relocation types. See below. */
288 unsigned int dist2to : 8;
289 unsigned int relvaddr : 19; /* (VADDR - vaddr of the previous entry)/ 4 */
290 unsigned long konst; /* KONST field. See below. */
291 unsigned long vaddr; /* VADDR to be relocated. */
292 } Elf32_crinfo;
293
294 typedef struct
295 {
296 unsigned int ctype : 1; /* 1: long 0: short format. See below. */
297 unsigned int rtype : 4; /* Relocation types. See below. */
298 unsigned int dist2to : 8;
299 unsigned int relvaddr : 19; /* (VADDR - vaddr of the previous entry)/ 4 */
300 unsigned long konst; /* KONST field. See below. */
301 } Elf32_crinfo2;
302
303 typedef struct
304 {
305 bfd_byte info[4];
306 bfd_byte konst[4];
307 bfd_byte vaddr[4];
308 } Elf32_External_crinfo;
309
310 typedef struct
311 {
312 bfd_byte info[4];
313 bfd_byte konst[4];
314 } Elf32_External_crinfo2;
315
316 /* These are the constants used to swap the bitfields in a crinfo. */
317
318 #define CRINFO_CTYPE (0x1)
319 #define CRINFO_CTYPE_SH (31)
320 #define CRINFO_RTYPE (0xf)
321 #define CRINFO_RTYPE_SH (27)
322 #define CRINFO_DIST2TO (0xff)
323 #define CRINFO_DIST2TO_SH (19)
324 #define CRINFO_RELVADDR (0x7ffff)
325 #define CRINFO_RELVADDR_SH (0)
326
327 /* A compact relocation info has long (3 words) or short (2 words)
328 formats. A short format doesn't have VADDR field and relvaddr
329 fields contains ((VADDR - vaddr of the previous entry) >> 2). */
330 #define CRF_MIPS_LONG 1
331 #define CRF_MIPS_SHORT 0
332
333 /* There are 4 types of compact relocation at least. The value KONST
334 has different meaning for each type:
335
336 (type) (konst)
337 CT_MIPS_REL32 Address in data
338 CT_MIPS_WORD Address in word (XXX)
339 CT_MIPS_GPHI_LO GP - vaddr
340 CT_MIPS_JMPAD Address to jump
341 */
342
343 #define CRT_MIPS_REL32 0xa
344 #define CRT_MIPS_WORD 0xb
345 #define CRT_MIPS_GPHI_LO 0xc
346 #define CRT_MIPS_JMPAD 0xd
347
348 #define mips_elf_set_cr_format(x,format) ((x).ctype = (format))
349 #define mips_elf_set_cr_type(x,type) ((x).rtype = (type))
350 #define mips_elf_set_cr_dist2to(x,v) ((x).dist2to = (v))
351 #define mips_elf_set_cr_relvaddr(x,d) ((x).relvaddr = (d)<<2)
352 \f
353 /* The structure of the runtime procedure descriptor created by the
354 loader for use by the static exception system. */
355
356 typedef struct runtime_pdr {
357 bfd_vma adr; /* Memory address of start of procedure. */
358 long regmask; /* Save register mask. */
359 long regoffset; /* Save register offset. */
360 long fregmask; /* Save floating point register mask. */
361 long fregoffset; /* Save floating point register offset. */
362 long frameoffset; /* Frame size. */
363 short framereg; /* Frame pointer register. */
364 short pcreg; /* Offset or reg of return pc. */
365 long irpss; /* Index into the runtime string table. */
366 long reserved;
367 struct exception_info *exception_info;/* Pointer to exception array. */
368 } RPDR, *pRPDR;
369 #define cbRPDR sizeof (RPDR)
370 #define rpdNil ((pRPDR) 0)
371 \f
372 static struct bfd_hash_entry *mips_elf_link_hash_newfunc
373 (struct bfd_hash_entry *, struct bfd_hash_table *, const char *);
374 static void ecoff_swap_rpdr_out
375 (bfd *, const RPDR *, struct rpdr_ext *);
376 static bfd_boolean mips_elf_create_procedure_table
377 (void *, bfd *, struct bfd_link_info *, asection *,
378 struct ecoff_debug_info *);
379 static bfd_boolean mips_elf_check_mips16_stubs
380 (struct mips_elf_link_hash_entry *, void *);
381 static void bfd_mips_elf32_swap_gptab_in
382 (bfd *, const Elf32_External_gptab *, Elf32_gptab *);
383 static void bfd_mips_elf32_swap_gptab_out
384 (bfd *, const Elf32_gptab *, Elf32_External_gptab *);
385 static void bfd_elf32_swap_compact_rel_out
386 (bfd *, const Elf32_compact_rel *, Elf32_External_compact_rel *);
387 static void bfd_elf32_swap_crinfo_out
388 (bfd *, const Elf32_crinfo *, Elf32_External_crinfo *);
389 static int sort_dynamic_relocs
390 (const void *, const void *);
391 static int sort_dynamic_relocs_64
392 (const void *, const void *);
393 static bfd_boolean mips_elf_output_extsym
394 (struct mips_elf_link_hash_entry *, void *);
395 static int gptab_compare
396 (const void *, const void *);
397 static asection *mips_elf_rel_dyn_section
398 (bfd *, bfd_boolean);
399 static asection *mips_elf_got_section
400 (bfd *, bfd_boolean);
401 static struct mips_got_info *mips_elf_got_info
402 (bfd *, asection **);
403 static bfd_vma mips_elf_local_got_index
404 (bfd *, bfd *, struct bfd_link_info *, bfd_vma);
405 static bfd_vma mips_elf_global_got_index
406 (bfd *, bfd *, struct elf_link_hash_entry *);
407 static bfd_vma mips_elf_got_page
408 (bfd *, bfd *, struct bfd_link_info *, bfd_vma, bfd_vma *);
409 static bfd_vma mips_elf_got16_entry
410 (bfd *, bfd *, struct bfd_link_info *, bfd_vma, bfd_boolean);
411 static bfd_vma mips_elf_got_offset_from_index
412 (bfd *, bfd *, bfd *, bfd_vma);
413 static struct mips_got_entry *mips_elf_create_local_got_entry
414 (bfd *, bfd *, struct mips_got_info *, asection *, bfd_vma);
415 static bfd_boolean mips_elf_sort_hash_table
416 (struct bfd_link_info *, unsigned long);
417 static bfd_boolean mips_elf_sort_hash_table_f
418 (struct mips_elf_link_hash_entry *, void *);
419 static bfd_boolean mips_elf_record_local_got_symbol
420 (bfd *, long, bfd_vma, struct mips_got_info *);
421 static bfd_boolean mips_elf_record_global_got_symbol
422 (struct elf_link_hash_entry *, bfd *, struct bfd_link_info *,
423 struct mips_got_info *);
424 static const Elf_Internal_Rela *mips_elf_next_relocation
425 (bfd *, unsigned int, const Elf_Internal_Rela *, const Elf_Internal_Rela *);
426 static bfd_boolean mips_elf_local_relocation_p
427 (bfd *, const Elf_Internal_Rela *, asection **, bfd_boolean);
428 static bfd_boolean mips_elf_overflow_p
429 (bfd_vma, int);
430 static bfd_vma mips_elf_high
431 (bfd_vma);
432 static bfd_vma mips_elf_higher
433 (bfd_vma);
434 static bfd_vma mips_elf_highest
435 (bfd_vma);
436 static bfd_boolean mips_elf_create_compact_rel_section
437 (bfd *, struct bfd_link_info *);
438 static bfd_boolean mips_elf_create_got_section
439 (bfd *, struct bfd_link_info *, bfd_boolean);
440 static bfd_reloc_status_type mips_elf_calculate_relocation
441 (bfd *, bfd *, asection *, struct bfd_link_info *,
442 const Elf_Internal_Rela *, bfd_vma, reloc_howto_type *,
443 Elf_Internal_Sym *, asection **, bfd_vma *, const char **,
444 bfd_boolean *, bfd_boolean);
445 static bfd_vma mips_elf_obtain_contents
446 (reloc_howto_type *, const Elf_Internal_Rela *, bfd *, bfd_byte *);
447 static bfd_boolean mips_elf_perform_relocation
448 (struct bfd_link_info *, reloc_howto_type *, const Elf_Internal_Rela *,
449 bfd_vma, bfd *, asection *, bfd_byte *, bfd_boolean);
450 static bfd_boolean mips_elf_stub_section_p
451 (bfd *, asection *);
452 static void mips_elf_allocate_dynamic_relocations
453 (bfd *, unsigned int);
454 static bfd_boolean mips_elf_create_dynamic_relocation
455 (bfd *, struct bfd_link_info *, const Elf_Internal_Rela *,
456 struct mips_elf_link_hash_entry *, asection *, bfd_vma,
457 bfd_vma *, asection *);
458 static void mips_set_isa_flags
459 (bfd *);
460 static INLINE char *elf_mips_abi_name
461 (bfd *);
462 static void mips_elf_irix6_finish_dynamic_symbol
463 (bfd *, const char *, Elf_Internal_Sym *);
464 static bfd_boolean mips_mach_extends_p
465 (unsigned long, unsigned long);
466 static bfd_boolean mips_32bit_flags_p
467 (flagword);
468 static INLINE hashval_t mips_elf_hash_bfd_vma
469 (bfd_vma);
470 static hashval_t mips_elf_got_entry_hash
471 (const void *);
472 static int mips_elf_got_entry_eq
473 (const void *, const void *);
474
475 static bfd_boolean mips_elf_multi_got
476 (bfd *, struct bfd_link_info *, struct mips_got_info *,
477 asection *, bfd_size_type);
478 static hashval_t mips_elf_multi_got_entry_hash
479 (const void *);
480 static int mips_elf_multi_got_entry_eq
481 (const void *, const void *);
482 static hashval_t mips_elf_bfd2got_entry_hash
483 (const void *);
484 static int mips_elf_bfd2got_entry_eq
485 (const void *, const void *);
486 static int mips_elf_make_got_per_bfd
487 (void **, void *);
488 static int mips_elf_merge_gots
489 (void **, void *);
490 static int mips_elf_set_global_got_offset
491 (void **, void *);
492 static int mips_elf_set_no_stub
493 (void **, void *);
494 static int mips_elf_resolve_final_got_entry
495 (void **, void *);
496 static void mips_elf_resolve_final_got_entries
497 (struct mips_got_info *);
498 static bfd_vma mips_elf_adjust_gp
499 (bfd *, struct mips_got_info *, bfd *);
500 static struct mips_got_info *mips_elf_got_for_ibfd
501 (struct mips_got_info *, bfd *);
502
503 /* This will be used when we sort the dynamic relocation records. */
504 static bfd *reldyn_sorting_bfd;
505
506 /* Nonzero if ABFD is using the N32 ABI. */
507
508 #define ABI_N32_P(abfd) \
509 ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI2) != 0)
510
511 /* Nonzero if ABFD is using the N64 ABI. */
512 #define ABI_64_P(abfd) \
513 (get_elf_backend_data (abfd)->s->elfclass == ELFCLASS64)
514
515 /* Nonzero if ABFD is using NewABI conventions. */
516 #define NEWABI_P(abfd) (ABI_N32_P (abfd) || ABI_64_P (abfd))
517
518 /* The IRIX compatibility level we are striving for. */
519 #define IRIX_COMPAT(abfd) \
520 (get_elf_backend_data (abfd)->elf_backend_mips_irix_compat (abfd))
521
522 /* Whether we are trying to be compatible with IRIX at all. */
523 #define SGI_COMPAT(abfd) \
524 (IRIX_COMPAT (abfd) != ict_none)
525
526 /* The name of the options section. */
527 #define MIPS_ELF_OPTIONS_SECTION_NAME(abfd) \
528 (NEWABI_P (abfd) ? ".MIPS.options" : ".options")
529
530 /* The name of the stub section. */
531 #define MIPS_ELF_STUB_SECTION_NAME(abfd) ".MIPS.stubs"
532
533 /* The size of an external REL relocation. */
534 #define MIPS_ELF_REL_SIZE(abfd) \
535 (get_elf_backend_data (abfd)->s->sizeof_rel)
536
537 /* The size of an external dynamic table entry. */
538 #define MIPS_ELF_DYN_SIZE(abfd) \
539 (get_elf_backend_data (abfd)->s->sizeof_dyn)
540
541 /* The size of a GOT entry. */
542 #define MIPS_ELF_GOT_SIZE(abfd) \
543 (get_elf_backend_data (abfd)->s->arch_size / 8)
544
545 /* The size of a symbol-table entry. */
546 #define MIPS_ELF_SYM_SIZE(abfd) \
547 (get_elf_backend_data (abfd)->s->sizeof_sym)
548
549 /* The default alignment for sections, as a power of two. */
550 #define MIPS_ELF_LOG_FILE_ALIGN(abfd) \
551 (get_elf_backend_data (abfd)->s->log_file_align)
552
553 /* Get word-sized data. */
554 #define MIPS_ELF_GET_WORD(abfd, ptr) \
555 (ABI_64_P (abfd) ? bfd_get_64 (abfd, ptr) : bfd_get_32 (abfd, ptr))
556
557 /* Put out word-sized data. */
558 #define MIPS_ELF_PUT_WORD(abfd, val, ptr) \
559 (ABI_64_P (abfd) \
560 ? bfd_put_64 (abfd, val, ptr) \
561 : bfd_put_32 (abfd, val, ptr))
562
563 /* Add a dynamic symbol table-entry. */
564 #define MIPS_ELF_ADD_DYNAMIC_ENTRY(info, tag, val) \
565 _bfd_elf_add_dynamic_entry (info, tag, val)
566
567 #define MIPS_ELF_RTYPE_TO_HOWTO(abfd, rtype, rela) \
568 (get_elf_backend_data (abfd)->elf_backend_mips_rtype_to_howto (rtype, rela))
569
570 /* Determine whether the internal relocation of index REL_IDX is REL
571 (zero) or RELA (non-zero). The assumption is that, if there are
572 two relocation sections for this section, one of them is REL and
573 the other is RELA. If the index of the relocation we're testing is
574 in range for the first relocation section, check that the external
575 relocation size is that for RELA. It is also assumed that, if
576 rel_idx is not in range for the first section, and this first
577 section contains REL relocs, then the relocation is in the second
578 section, that is RELA. */
579 #define MIPS_RELOC_RELA_P(abfd, sec, rel_idx) \
580 ((NUM_SHDR_ENTRIES (&elf_section_data (sec)->rel_hdr) \
581 * get_elf_backend_data (abfd)->s->int_rels_per_ext_rel \
582 > (bfd_vma)(rel_idx)) \
583 == (elf_section_data (sec)->rel_hdr.sh_entsize \
584 == (ABI_64_P (abfd) ? sizeof (Elf64_External_Rela) \
585 : sizeof (Elf32_External_Rela))))
586
587 /* In case we're on a 32-bit machine, construct a 64-bit "-1" value
588 from smaller values. Start with zero, widen, *then* decrement. */
589 #define MINUS_ONE (((bfd_vma)0) - 1)
590
591 /* The number of local .got entries we reserve. */
592 #define MIPS_RESERVED_GOTNO (2)
593
594 /* The offset of $gp from the beginning of the .got section. */
595 #define ELF_MIPS_GP_OFFSET(abfd) (0x7ff0)
596
597 /* The maximum size of the GOT for it to be addressable using 16-bit
598 offsets from $gp. */
599 #define MIPS_ELF_GOT_MAX_SIZE(abfd) (ELF_MIPS_GP_OFFSET(abfd) + 0x7fff)
600
601 /* Instructions which appear in a stub. */
602 #define STUB_LW(abfd) \
603 ((ABI_64_P (abfd) \
604 ? 0xdf998010 /* ld t9,0x8010(gp) */ \
605 : 0x8f998010)) /* lw t9,0x8010(gp) */
606 #define STUB_MOVE(abfd) \
607 ((ABI_64_P (abfd) \
608 ? 0x03e0782d /* daddu t7,ra */ \
609 : 0x03e07821)) /* addu t7,ra */
610 #define STUB_JALR 0x0320f809 /* jalr t9,ra */
611 #define STUB_LI16(abfd) \
612 ((ABI_64_P (abfd) \
613 ? 0x64180000 /* daddiu t8,zero,0 */ \
614 : 0x24180000)) /* addiu t8,zero,0 */
615 #define MIPS_FUNCTION_STUB_SIZE (16)
616
617 /* The name of the dynamic interpreter. This is put in the .interp
618 section. */
619
620 #define ELF_DYNAMIC_INTERPRETER(abfd) \
621 (ABI_N32_P (abfd) ? "/usr/lib32/libc.so.1" \
622 : ABI_64_P (abfd) ? "/usr/lib64/libc.so.1" \
623 : "/usr/lib/libc.so.1")
624
625 #ifdef BFD64
626 #define MNAME(bfd,pre,pos) \
627 (ABI_64_P (bfd) ? CONCAT4 (pre,64,_,pos) : CONCAT4 (pre,32,_,pos))
628 #define ELF_R_SYM(bfd, i) \
629 (ABI_64_P (bfd) ? ELF64_R_SYM (i) : ELF32_R_SYM (i))
630 #define ELF_R_TYPE(bfd, i) \
631 (ABI_64_P (bfd) ? ELF64_MIPS_R_TYPE (i) : ELF32_R_TYPE (i))
632 #define ELF_R_INFO(bfd, s, t) \
633 (ABI_64_P (bfd) ? ELF64_R_INFO (s, t) : ELF32_R_INFO (s, t))
634 #else
635 #define MNAME(bfd,pre,pos) CONCAT4 (pre,32,_,pos)
636 #define ELF_R_SYM(bfd, i) \
637 (ELF32_R_SYM (i))
638 #define ELF_R_TYPE(bfd, i) \
639 (ELF32_R_TYPE (i))
640 #define ELF_R_INFO(bfd, s, t) \
641 (ELF32_R_INFO (s, t))
642 #endif
643 \f
644 /* The mips16 compiler uses a couple of special sections to handle
645 floating point arguments.
646
647 Section names that look like .mips16.fn.FNNAME contain stubs that
648 copy floating point arguments from the fp regs to the gp regs and
649 then jump to FNNAME. If any 32 bit function calls FNNAME, the
650 call should be redirected to the stub instead. If no 32 bit
651 function calls FNNAME, the stub should be discarded. We need to
652 consider any reference to the function, not just a call, because
653 if the address of the function is taken we will need the stub,
654 since the address might be passed to a 32 bit function.
655
656 Section names that look like .mips16.call.FNNAME contain stubs
657 that copy floating point arguments from the gp regs to the fp
658 regs and then jump to FNNAME. If FNNAME is a 32 bit function,
659 then any 16 bit function that calls FNNAME should be redirected
660 to the stub instead. If FNNAME is not a 32 bit function, the
661 stub should be discarded.
662
663 .mips16.call.fp.FNNAME sections are similar, but contain stubs
664 which call FNNAME and then copy the return value from the fp regs
665 to the gp regs. These stubs store the return value in $18 while
666 calling FNNAME; any function which might call one of these stubs
667 must arrange to save $18 around the call. (This case is not
668 needed for 32 bit functions that call 16 bit functions, because
669 16 bit functions always return floating point values in both
670 $f0/$f1 and $2/$3.)
671
672 Note that in all cases FNNAME might be defined statically.
673 Therefore, FNNAME is not used literally. Instead, the relocation
674 information will indicate which symbol the section is for.
675
676 We record any stubs that we find in the symbol table. */
677
678 #define FN_STUB ".mips16.fn."
679 #define CALL_STUB ".mips16.call."
680 #define CALL_FP_STUB ".mips16.call.fp."
681 \f
682 /* Look up an entry in a MIPS ELF linker hash table. */
683
684 #define mips_elf_link_hash_lookup(table, string, create, copy, follow) \
685 ((struct mips_elf_link_hash_entry *) \
686 elf_link_hash_lookup (&(table)->root, (string), (create), \
687 (copy), (follow)))
688
689 /* Traverse a MIPS ELF linker hash table. */
690
691 #define mips_elf_link_hash_traverse(table, func, info) \
692 (elf_link_hash_traverse \
693 (&(table)->root, \
694 (bfd_boolean (*) (struct elf_link_hash_entry *, void *)) (func), \
695 (info)))
696
697 /* Get the MIPS ELF linker hash table from a link_info structure. */
698
699 #define mips_elf_hash_table(p) \
700 ((struct mips_elf_link_hash_table *) ((p)->hash))
701
702 /* Create an entry in a MIPS ELF linker hash table. */
703
704 static struct bfd_hash_entry *
705 mips_elf_link_hash_newfunc (struct bfd_hash_entry *entry,
706 struct bfd_hash_table *table, const char *string)
707 {
708 struct mips_elf_link_hash_entry *ret =
709 (struct mips_elf_link_hash_entry *) entry;
710
711 /* Allocate the structure if it has not already been allocated by a
712 subclass. */
713 if (ret == NULL)
714 ret = bfd_hash_allocate (table, sizeof (struct mips_elf_link_hash_entry));
715 if (ret == NULL)
716 return (struct bfd_hash_entry *) ret;
717
718 /* Call the allocation method of the superclass. */
719 ret = ((struct mips_elf_link_hash_entry *)
720 _bfd_elf_link_hash_newfunc ((struct bfd_hash_entry *) ret,
721 table, string));
722 if (ret != NULL)
723 {
724 /* Set local fields. */
725 memset (&ret->esym, 0, sizeof (EXTR));
726 /* We use -2 as a marker to indicate that the information has
727 not been set. -1 means there is no associated ifd. */
728 ret->esym.ifd = -2;
729 ret->possibly_dynamic_relocs = 0;
730 ret->readonly_reloc = FALSE;
731 ret->no_fn_stub = FALSE;
732 ret->fn_stub = NULL;
733 ret->need_fn_stub = FALSE;
734 ret->call_stub = NULL;
735 ret->call_fp_stub = NULL;
736 ret->forced_local = FALSE;
737 }
738
739 return (struct bfd_hash_entry *) ret;
740 }
741
742 bfd_boolean
743 _bfd_mips_elf_new_section_hook (bfd *abfd, asection *sec)
744 {
745 struct _mips_elf_section_data *sdata;
746 bfd_size_type amt = sizeof (*sdata);
747
748 sdata = bfd_zalloc (abfd, amt);
749 if (sdata == NULL)
750 return FALSE;
751 sec->used_by_bfd = sdata;
752
753 return _bfd_elf_new_section_hook (abfd, sec);
754 }
755 \f
756 /* Read ECOFF debugging information from a .mdebug section into a
757 ecoff_debug_info structure. */
758
759 bfd_boolean
760 _bfd_mips_elf_read_ecoff_info (bfd *abfd, asection *section,
761 struct ecoff_debug_info *debug)
762 {
763 HDRR *symhdr;
764 const struct ecoff_debug_swap *swap;
765 char *ext_hdr;
766
767 swap = get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
768 memset (debug, 0, sizeof (*debug));
769
770 ext_hdr = bfd_malloc (swap->external_hdr_size);
771 if (ext_hdr == NULL && swap->external_hdr_size != 0)
772 goto error_return;
773
774 if (! bfd_get_section_contents (abfd, section, ext_hdr, 0,
775 swap->external_hdr_size))
776 goto error_return;
777
778 symhdr = &debug->symbolic_header;
779 (*swap->swap_hdr_in) (abfd, ext_hdr, symhdr);
780
781 /* The symbolic header contains absolute file offsets and sizes to
782 read. */
783 #define READ(ptr, offset, count, size, type) \
784 if (symhdr->count == 0) \
785 debug->ptr = NULL; \
786 else \
787 { \
788 bfd_size_type amt = (bfd_size_type) size * symhdr->count; \
789 debug->ptr = bfd_malloc (amt); \
790 if (debug->ptr == NULL) \
791 goto error_return; \
792 if (bfd_seek (abfd, symhdr->offset, SEEK_SET) != 0 \
793 || bfd_bread (debug->ptr, amt, abfd) != amt) \
794 goto error_return; \
795 }
796
797 READ (line, cbLineOffset, cbLine, sizeof (unsigned char), unsigned char *);
798 READ (external_dnr, cbDnOffset, idnMax, swap->external_dnr_size, void *);
799 READ (external_pdr, cbPdOffset, ipdMax, swap->external_pdr_size, void *);
800 READ (external_sym, cbSymOffset, isymMax, swap->external_sym_size, void *);
801 READ (external_opt, cbOptOffset, ioptMax, swap->external_opt_size, void *);
802 READ (external_aux, cbAuxOffset, iauxMax, sizeof (union aux_ext),
803 union aux_ext *);
804 READ (ss, cbSsOffset, issMax, sizeof (char), char *);
805 READ (ssext, cbSsExtOffset, issExtMax, sizeof (char), char *);
806 READ (external_fdr, cbFdOffset, ifdMax, swap->external_fdr_size, void *);
807 READ (external_rfd, cbRfdOffset, crfd, swap->external_rfd_size, void *);
808 READ (external_ext, cbExtOffset, iextMax, swap->external_ext_size, void *);
809 #undef READ
810
811 debug->fdr = NULL;
812 debug->adjust = NULL;
813
814 return TRUE;
815
816 error_return:
817 if (ext_hdr != NULL)
818 free (ext_hdr);
819 if (debug->line != NULL)
820 free (debug->line);
821 if (debug->external_dnr != NULL)
822 free (debug->external_dnr);
823 if (debug->external_pdr != NULL)
824 free (debug->external_pdr);
825 if (debug->external_sym != NULL)
826 free (debug->external_sym);
827 if (debug->external_opt != NULL)
828 free (debug->external_opt);
829 if (debug->external_aux != NULL)
830 free (debug->external_aux);
831 if (debug->ss != NULL)
832 free (debug->ss);
833 if (debug->ssext != NULL)
834 free (debug->ssext);
835 if (debug->external_fdr != NULL)
836 free (debug->external_fdr);
837 if (debug->external_rfd != NULL)
838 free (debug->external_rfd);
839 if (debug->external_ext != NULL)
840 free (debug->external_ext);
841 return FALSE;
842 }
843 \f
844 /* Swap RPDR (runtime procedure table entry) for output. */
845
846 static void
847 ecoff_swap_rpdr_out (bfd *abfd, const RPDR *in, struct rpdr_ext *ex)
848 {
849 H_PUT_S32 (abfd, in->adr, ex->p_adr);
850 H_PUT_32 (abfd, in->regmask, ex->p_regmask);
851 H_PUT_32 (abfd, in->regoffset, ex->p_regoffset);
852 H_PUT_32 (abfd, in->fregmask, ex->p_fregmask);
853 H_PUT_32 (abfd, in->fregoffset, ex->p_fregoffset);
854 H_PUT_32 (abfd, in->frameoffset, ex->p_frameoffset);
855
856 H_PUT_16 (abfd, in->framereg, ex->p_framereg);
857 H_PUT_16 (abfd, in->pcreg, ex->p_pcreg);
858
859 H_PUT_32 (abfd, in->irpss, ex->p_irpss);
860 #if 0 /* FIXME */
861 H_PUT_S32 (abfd, in->exception_info, ex->p_exception_info);
862 #endif
863 }
864
865 /* Create a runtime procedure table from the .mdebug section. */
866
867 static bfd_boolean
868 mips_elf_create_procedure_table (void *handle, bfd *abfd,
869 struct bfd_link_info *info, asection *s,
870 struct ecoff_debug_info *debug)
871 {
872 const struct ecoff_debug_swap *swap;
873 HDRR *hdr = &debug->symbolic_header;
874 RPDR *rpdr, *rp;
875 struct rpdr_ext *erp;
876 void *rtproc;
877 struct pdr_ext *epdr;
878 struct sym_ext *esym;
879 char *ss, **sv;
880 char *str;
881 bfd_size_type size;
882 bfd_size_type count;
883 unsigned long sindex;
884 unsigned long i;
885 PDR pdr;
886 SYMR sym;
887 const char *no_name_func = _("static procedure (no name)");
888
889 epdr = NULL;
890 rpdr = NULL;
891 esym = NULL;
892 ss = NULL;
893 sv = NULL;
894
895 swap = get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
896
897 sindex = strlen (no_name_func) + 1;
898 count = hdr->ipdMax;
899 if (count > 0)
900 {
901 size = swap->external_pdr_size;
902
903 epdr = bfd_malloc (size * count);
904 if (epdr == NULL)
905 goto error_return;
906
907 if (! _bfd_ecoff_get_accumulated_pdr (handle, (bfd_byte *) epdr))
908 goto error_return;
909
910 size = sizeof (RPDR);
911 rp = rpdr = bfd_malloc (size * count);
912 if (rpdr == NULL)
913 goto error_return;
914
915 size = sizeof (char *);
916 sv = bfd_malloc (size * count);
917 if (sv == NULL)
918 goto error_return;
919
920 count = hdr->isymMax;
921 size = swap->external_sym_size;
922 esym = bfd_malloc (size * count);
923 if (esym == NULL)
924 goto error_return;
925
926 if (! _bfd_ecoff_get_accumulated_sym (handle, (bfd_byte *) esym))
927 goto error_return;
928
929 count = hdr->issMax;
930 ss = bfd_malloc (count);
931 if (ss == NULL)
932 goto error_return;
933 if (! _bfd_ecoff_get_accumulated_ss (handle, ss))
934 goto error_return;
935
936 count = hdr->ipdMax;
937 for (i = 0; i < (unsigned long) count; i++, rp++)
938 {
939 (*swap->swap_pdr_in) (abfd, epdr + i, &pdr);
940 (*swap->swap_sym_in) (abfd, &esym[pdr.isym], &sym);
941 rp->adr = sym.value;
942 rp->regmask = pdr.regmask;
943 rp->regoffset = pdr.regoffset;
944 rp->fregmask = pdr.fregmask;
945 rp->fregoffset = pdr.fregoffset;
946 rp->frameoffset = pdr.frameoffset;
947 rp->framereg = pdr.framereg;
948 rp->pcreg = pdr.pcreg;
949 rp->irpss = sindex;
950 sv[i] = ss + sym.iss;
951 sindex += strlen (sv[i]) + 1;
952 }
953 }
954
955 size = sizeof (struct rpdr_ext) * (count + 2) + sindex;
956 size = BFD_ALIGN (size, 16);
957 rtproc = bfd_alloc (abfd, size);
958 if (rtproc == NULL)
959 {
960 mips_elf_hash_table (info)->procedure_count = 0;
961 goto error_return;
962 }
963
964 mips_elf_hash_table (info)->procedure_count = count + 2;
965
966 erp = rtproc;
967 memset (erp, 0, sizeof (struct rpdr_ext));
968 erp++;
969 str = (char *) rtproc + sizeof (struct rpdr_ext) * (count + 2);
970 strcpy (str, no_name_func);
971 str += strlen (no_name_func) + 1;
972 for (i = 0; i < count; i++)
973 {
974 ecoff_swap_rpdr_out (abfd, rpdr + i, erp + i);
975 strcpy (str, sv[i]);
976 str += strlen (sv[i]) + 1;
977 }
978 H_PUT_S32 (abfd, -1, (erp + count)->p_adr);
979
980 /* Set the size and contents of .rtproc section. */
981 s->_raw_size = size;
982 s->contents = rtproc;
983
984 /* Skip this section later on (I don't think this currently
985 matters, but someday it might). */
986 s->link_order_head = NULL;
987
988 if (epdr != NULL)
989 free (epdr);
990 if (rpdr != NULL)
991 free (rpdr);
992 if (esym != NULL)
993 free (esym);
994 if (ss != NULL)
995 free (ss);
996 if (sv != NULL)
997 free (sv);
998
999 return TRUE;
1000
1001 error_return:
1002 if (epdr != NULL)
1003 free (epdr);
1004 if (rpdr != NULL)
1005 free (rpdr);
1006 if (esym != NULL)
1007 free (esym);
1008 if (ss != NULL)
1009 free (ss);
1010 if (sv != NULL)
1011 free (sv);
1012 return FALSE;
1013 }
1014
1015 /* Check the mips16 stubs for a particular symbol, and see if we can
1016 discard them. */
1017
1018 static bfd_boolean
1019 mips_elf_check_mips16_stubs (struct mips_elf_link_hash_entry *h,
1020 void *data ATTRIBUTE_UNUSED)
1021 {
1022 if (h->root.root.type == bfd_link_hash_warning)
1023 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
1024
1025 if (h->fn_stub != NULL
1026 && ! h->need_fn_stub)
1027 {
1028 /* We don't need the fn_stub; the only references to this symbol
1029 are 16 bit calls. Clobber the size to 0 to prevent it from
1030 being included in the link. */
1031 h->fn_stub->_raw_size = 0;
1032 h->fn_stub->_cooked_size = 0;
1033 h->fn_stub->flags &= ~SEC_RELOC;
1034 h->fn_stub->reloc_count = 0;
1035 h->fn_stub->flags |= SEC_EXCLUDE;
1036 }
1037
1038 if (h->call_stub != NULL
1039 && h->root.other == STO_MIPS16)
1040 {
1041 /* We don't need the call_stub; this is a 16 bit function, so
1042 calls from other 16 bit functions are OK. Clobber the size
1043 to 0 to prevent it from being included in the link. */
1044 h->call_stub->_raw_size = 0;
1045 h->call_stub->_cooked_size = 0;
1046 h->call_stub->flags &= ~SEC_RELOC;
1047 h->call_stub->reloc_count = 0;
1048 h->call_stub->flags |= SEC_EXCLUDE;
1049 }
1050
1051 if (h->call_fp_stub != NULL
1052 && h->root.other == STO_MIPS16)
1053 {
1054 /* We don't need the call_stub; this is a 16 bit function, so
1055 calls from other 16 bit functions are OK. Clobber the size
1056 to 0 to prevent it from being included in the link. */
1057 h->call_fp_stub->_raw_size = 0;
1058 h->call_fp_stub->_cooked_size = 0;
1059 h->call_fp_stub->flags &= ~SEC_RELOC;
1060 h->call_fp_stub->reloc_count = 0;
1061 h->call_fp_stub->flags |= SEC_EXCLUDE;
1062 }
1063
1064 return TRUE;
1065 }
1066 \f
1067 bfd_reloc_status_type
1068 _bfd_mips_elf_gprel16_with_gp (bfd *abfd, asymbol *symbol,
1069 arelent *reloc_entry, asection *input_section,
1070 bfd_boolean relocatable, void *data, bfd_vma gp)
1071 {
1072 bfd_vma relocation;
1073 bfd_signed_vma val;
1074 bfd_reloc_status_type status;
1075
1076 if (bfd_is_com_section (symbol->section))
1077 relocation = 0;
1078 else
1079 relocation = symbol->value;
1080
1081 relocation += symbol->section->output_section->vma;
1082 relocation += symbol->section->output_offset;
1083
1084 if (reloc_entry->address > input_section->_cooked_size)
1085 return bfd_reloc_outofrange;
1086
1087 /* Set val to the offset into the section or symbol. */
1088 val = reloc_entry->addend;
1089
1090 _bfd_mips_elf_sign_extend (val, 16);
1091
1092 /* Adjust val for the final section location and GP value. If we
1093 are producing relocatable output, we don't want to do this for
1094 an external symbol. */
1095 if (! relocatable
1096 || (symbol->flags & BSF_SECTION_SYM) != 0)
1097 val += relocation - gp;
1098
1099 if (reloc_entry->howto->partial_inplace)
1100 {
1101 status = _bfd_relocate_contents (reloc_entry->howto, abfd, val,
1102 (bfd_byte *) data
1103 + reloc_entry->address);
1104 if (status != bfd_reloc_ok)
1105 return status;
1106 }
1107 else
1108 reloc_entry->addend = val;
1109
1110 if (relocatable)
1111 reloc_entry->address += input_section->output_offset;
1112
1113 return bfd_reloc_ok;
1114 }
1115
1116 /* Used to store a REL high-part relocation such as R_MIPS_HI16 or
1117 R_MIPS_GOT16. REL is the relocation, INPUT_SECTION is the section
1118 that contains the relocation field and DATA points to the start of
1119 INPUT_SECTION. */
1120
1121 struct mips_hi16
1122 {
1123 struct mips_hi16 *next;
1124 bfd_byte *data;
1125 asection *input_section;
1126 arelent rel;
1127 };
1128
1129 /* FIXME: This should not be a static variable. */
1130
1131 static struct mips_hi16 *mips_hi16_list;
1132
1133 /* A howto special_function for REL *HI16 relocations. We can only
1134 calculate the correct value once we've seen the partnering
1135 *LO16 relocation, so just save the information for later.
1136
1137 The ABI requires that the *LO16 immediately follow the *HI16.
1138 However, as a GNU extension, we permit an arbitrary number of
1139 *HI16s to be associated with a single *LO16. This significantly
1140 simplies the relocation handling in gcc. */
1141
1142 bfd_reloc_status_type
1143 _bfd_mips_elf_hi16_reloc (bfd *abfd ATTRIBUTE_UNUSED, arelent *reloc_entry,
1144 asymbol *symbol ATTRIBUTE_UNUSED, void *data,
1145 asection *input_section, bfd *output_bfd,
1146 char **error_message ATTRIBUTE_UNUSED)
1147 {
1148 struct mips_hi16 *n;
1149
1150 if (reloc_entry->address > input_section->_cooked_size)
1151 return bfd_reloc_outofrange;
1152
1153 n = bfd_malloc (sizeof *n);
1154 if (n == NULL)
1155 return bfd_reloc_outofrange;
1156
1157 n->next = mips_hi16_list;
1158 n->data = data;
1159 n->input_section = input_section;
1160 n->rel = *reloc_entry;
1161 mips_hi16_list = n;
1162
1163 if (output_bfd != NULL)
1164 reloc_entry->address += input_section->output_offset;
1165
1166 return bfd_reloc_ok;
1167 }
1168
1169 /* A howto special_function for REL R_MIPS_GOT16 relocations. This is just
1170 like any other 16-bit relocation when applied to global symbols, but is
1171 treated in the same as R_MIPS_HI16 when applied to local symbols. */
1172
1173 bfd_reloc_status_type
1174 _bfd_mips_elf_got16_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
1175 void *data, asection *input_section,
1176 bfd *output_bfd, char **error_message)
1177 {
1178 if ((symbol->flags & (BSF_GLOBAL | BSF_WEAK)) != 0
1179 || bfd_is_und_section (bfd_get_section (symbol))
1180 || bfd_is_com_section (bfd_get_section (symbol)))
1181 /* The relocation is against a global symbol. */
1182 return _bfd_mips_elf_generic_reloc (abfd, reloc_entry, symbol, data,
1183 input_section, output_bfd,
1184 error_message);
1185
1186 return _bfd_mips_elf_hi16_reloc (abfd, reloc_entry, symbol, data,
1187 input_section, output_bfd, error_message);
1188 }
1189
1190 /* A howto special_function for REL *LO16 relocations. The *LO16 itself
1191 is a straightforward 16 bit inplace relocation, but we must deal with
1192 any partnering high-part relocations as well. */
1193
1194 bfd_reloc_status_type
1195 _bfd_mips_elf_lo16_reloc (bfd *abfd, arelent *reloc_entry, asymbol *symbol,
1196 void *data, asection *input_section,
1197 bfd *output_bfd, char **error_message)
1198 {
1199 bfd_vma vallo;
1200
1201 if (reloc_entry->address > input_section->_cooked_size)
1202 return bfd_reloc_outofrange;
1203
1204 vallo = bfd_get_32 (abfd, (bfd_byte *) data + reloc_entry->address);
1205 while (mips_hi16_list != NULL)
1206 {
1207 bfd_reloc_status_type ret;
1208 struct mips_hi16 *hi;
1209
1210 hi = mips_hi16_list;
1211
1212 /* R_MIPS_GOT16 relocations are something of a special case. We
1213 want to install the addend in the same way as for a R_MIPS_HI16
1214 relocation (with a rightshift of 16). However, since GOT16
1215 relocations can also be used with global symbols, their howto
1216 has a rightshift of 0. */
1217 if (hi->rel.howto->type == R_MIPS_GOT16)
1218 hi->rel.howto = MIPS_ELF_RTYPE_TO_HOWTO (abfd, R_MIPS_HI16, FALSE);
1219
1220 /* VALLO is a signed 16-bit number. Bias it by 0x8000 so that any
1221 carry or borrow will induce a change of +1 or -1 in the high part. */
1222 hi->rel.addend += (vallo + 0x8000) & 0xffff;
1223
1224 /* R_MIPS_GNU_REL_HI16 relocations are relative to the address of the
1225 lo16 relocation, not their own address. If we're calculating the
1226 final value, and hence subtracting the "PC", subtract the offset
1227 of the lo16 relocation from here. */
1228 if (output_bfd == NULL && hi->rel.howto->type == R_MIPS_GNU_REL_HI16)
1229 hi->rel.addend -= reloc_entry->address - hi->rel.address;
1230
1231 ret = _bfd_mips_elf_generic_reloc (abfd, &hi->rel, symbol, hi->data,
1232 hi->input_section, output_bfd,
1233 error_message);
1234 if (ret != bfd_reloc_ok)
1235 return ret;
1236
1237 mips_hi16_list = hi->next;
1238 free (hi);
1239 }
1240
1241 return _bfd_mips_elf_generic_reloc (abfd, reloc_entry, symbol, data,
1242 input_section, output_bfd,
1243 error_message);
1244 }
1245
1246 /* A generic howto special_function. This calculates and installs the
1247 relocation itself, thus avoiding the oft-discussed problems in
1248 bfd_perform_relocation and bfd_install_relocation. */
1249
1250 bfd_reloc_status_type
1251 _bfd_mips_elf_generic_reloc (bfd *abfd ATTRIBUTE_UNUSED, arelent *reloc_entry,
1252 asymbol *symbol, void *data ATTRIBUTE_UNUSED,
1253 asection *input_section, bfd *output_bfd,
1254 char **error_message ATTRIBUTE_UNUSED)
1255 {
1256 bfd_signed_vma val;
1257 bfd_reloc_status_type status;
1258 bfd_boolean relocatable;
1259
1260 relocatable = (output_bfd != NULL);
1261
1262 if (reloc_entry->address > input_section->_cooked_size)
1263 return bfd_reloc_outofrange;
1264
1265 /* Build up the field adjustment in VAL. */
1266 val = 0;
1267 if (!relocatable || (symbol->flags & BSF_SECTION_SYM) != 0)
1268 {
1269 /* Either we're calculating the final field value or we have a
1270 relocation against a section symbol. Add in the section's
1271 offset or address. */
1272 val += symbol->section->output_section->vma;
1273 val += symbol->section->output_offset;
1274 }
1275
1276 if (!relocatable)
1277 {
1278 /* We're calculating the final field value. Add in the symbol's value
1279 and, if pc-relative, subtract the address of the field itself. */
1280 val += symbol->value;
1281 if (reloc_entry->howto->pc_relative)
1282 {
1283 val -= input_section->output_section->vma;
1284 val -= input_section->output_offset;
1285 val -= reloc_entry->address;
1286 }
1287 }
1288
1289 /* VAL is now the final adjustment. If we're keeping this relocation
1290 in the output file, and if the relocation uses a separate addend,
1291 we just need to add VAL to that addend. Otherwise we need to add
1292 VAL to the relocation field itself. */
1293 if (relocatable && !reloc_entry->howto->partial_inplace)
1294 reloc_entry->addend += val;
1295 else
1296 {
1297 /* Add in the separate addend, if any. */
1298 val += reloc_entry->addend;
1299
1300 /* Add VAL to the relocation field. */
1301 status = _bfd_relocate_contents (reloc_entry->howto, abfd, val,
1302 (bfd_byte *) data
1303 + reloc_entry->address);
1304 if (status != bfd_reloc_ok)
1305 return status;
1306 }
1307
1308 if (relocatable)
1309 reloc_entry->address += input_section->output_offset;
1310
1311 return bfd_reloc_ok;
1312 }
1313 \f
1314 /* Swap an entry in a .gptab section. Note that these routines rely
1315 on the equivalence of the two elements of the union. */
1316
1317 static void
1318 bfd_mips_elf32_swap_gptab_in (bfd *abfd, const Elf32_External_gptab *ex,
1319 Elf32_gptab *in)
1320 {
1321 in->gt_entry.gt_g_value = H_GET_32 (abfd, ex->gt_entry.gt_g_value);
1322 in->gt_entry.gt_bytes = H_GET_32 (abfd, ex->gt_entry.gt_bytes);
1323 }
1324
1325 static void
1326 bfd_mips_elf32_swap_gptab_out (bfd *abfd, const Elf32_gptab *in,
1327 Elf32_External_gptab *ex)
1328 {
1329 H_PUT_32 (abfd, in->gt_entry.gt_g_value, ex->gt_entry.gt_g_value);
1330 H_PUT_32 (abfd, in->gt_entry.gt_bytes, ex->gt_entry.gt_bytes);
1331 }
1332
1333 static void
1334 bfd_elf32_swap_compact_rel_out (bfd *abfd, const Elf32_compact_rel *in,
1335 Elf32_External_compact_rel *ex)
1336 {
1337 H_PUT_32 (abfd, in->id1, ex->id1);
1338 H_PUT_32 (abfd, in->num, ex->num);
1339 H_PUT_32 (abfd, in->id2, ex->id2);
1340 H_PUT_32 (abfd, in->offset, ex->offset);
1341 H_PUT_32 (abfd, in->reserved0, ex->reserved0);
1342 H_PUT_32 (abfd, in->reserved1, ex->reserved1);
1343 }
1344
1345 static void
1346 bfd_elf32_swap_crinfo_out (bfd *abfd, const Elf32_crinfo *in,
1347 Elf32_External_crinfo *ex)
1348 {
1349 unsigned long l;
1350
1351 l = (((in->ctype & CRINFO_CTYPE) << CRINFO_CTYPE_SH)
1352 | ((in->rtype & CRINFO_RTYPE) << CRINFO_RTYPE_SH)
1353 | ((in->dist2to & CRINFO_DIST2TO) << CRINFO_DIST2TO_SH)
1354 | ((in->relvaddr & CRINFO_RELVADDR) << CRINFO_RELVADDR_SH));
1355 H_PUT_32 (abfd, l, ex->info);
1356 H_PUT_32 (abfd, in->konst, ex->konst);
1357 H_PUT_32 (abfd, in->vaddr, ex->vaddr);
1358 }
1359 \f
1360 /* A .reginfo section holds a single Elf32_RegInfo structure. These
1361 routines swap this structure in and out. They are used outside of
1362 BFD, so they are globally visible. */
1363
1364 void
1365 bfd_mips_elf32_swap_reginfo_in (bfd *abfd, const Elf32_External_RegInfo *ex,
1366 Elf32_RegInfo *in)
1367 {
1368 in->ri_gprmask = H_GET_32 (abfd, ex->ri_gprmask);
1369 in->ri_cprmask[0] = H_GET_32 (abfd, ex->ri_cprmask[0]);
1370 in->ri_cprmask[1] = H_GET_32 (abfd, ex->ri_cprmask[1]);
1371 in->ri_cprmask[2] = H_GET_32 (abfd, ex->ri_cprmask[2]);
1372 in->ri_cprmask[3] = H_GET_32 (abfd, ex->ri_cprmask[3]);
1373 in->ri_gp_value = H_GET_32 (abfd, ex->ri_gp_value);
1374 }
1375
1376 void
1377 bfd_mips_elf32_swap_reginfo_out (bfd *abfd, const Elf32_RegInfo *in,
1378 Elf32_External_RegInfo *ex)
1379 {
1380 H_PUT_32 (abfd, in->ri_gprmask, ex->ri_gprmask);
1381 H_PUT_32 (abfd, in->ri_cprmask[0], ex->ri_cprmask[0]);
1382 H_PUT_32 (abfd, in->ri_cprmask[1], ex->ri_cprmask[1]);
1383 H_PUT_32 (abfd, in->ri_cprmask[2], ex->ri_cprmask[2]);
1384 H_PUT_32 (abfd, in->ri_cprmask[3], ex->ri_cprmask[3]);
1385 H_PUT_32 (abfd, in->ri_gp_value, ex->ri_gp_value);
1386 }
1387
1388 /* In the 64 bit ABI, the .MIPS.options section holds register
1389 information in an Elf64_Reginfo structure. These routines swap
1390 them in and out. They are globally visible because they are used
1391 outside of BFD. These routines are here so that gas can call them
1392 without worrying about whether the 64 bit ABI has been included. */
1393
1394 void
1395 bfd_mips_elf64_swap_reginfo_in (bfd *abfd, const Elf64_External_RegInfo *ex,
1396 Elf64_Internal_RegInfo *in)
1397 {
1398 in->ri_gprmask = H_GET_32 (abfd, ex->ri_gprmask);
1399 in->ri_pad = H_GET_32 (abfd, ex->ri_pad);
1400 in->ri_cprmask[0] = H_GET_32 (abfd, ex->ri_cprmask[0]);
1401 in->ri_cprmask[1] = H_GET_32 (abfd, ex->ri_cprmask[1]);
1402 in->ri_cprmask[2] = H_GET_32 (abfd, ex->ri_cprmask[2]);
1403 in->ri_cprmask[3] = H_GET_32 (abfd, ex->ri_cprmask[3]);
1404 in->ri_gp_value = H_GET_64 (abfd, ex->ri_gp_value);
1405 }
1406
1407 void
1408 bfd_mips_elf64_swap_reginfo_out (bfd *abfd, const Elf64_Internal_RegInfo *in,
1409 Elf64_External_RegInfo *ex)
1410 {
1411 H_PUT_32 (abfd, in->ri_gprmask, ex->ri_gprmask);
1412 H_PUT_32 (abfd, in->ri_pad, ex->ri_pad);
1413 H_PUT_32 (abfd, in->ri_cprmask[0], ex->ri_cprmask[0]);
1414 H_PUT_32 (abfd, in->ri_cprmask[1], ex->ri_cprmask[1]);
1415 H_PUT_32 (abfd, in->ri_cprmask[2], ex->ri_cprmask[2]);
1416 H_PUT_32 (abfd, in->ri_cprmask[3], ex->ri_cprmask[3]);
1417 H_PUT_64 (abfd, in->ri_gp_value, ex->ri_gp_value);
1418 }
1419
1420 /* Swap in an options header. */
1421
1422 void
1423 bfd_mips_elf_swap_options_in (bfd *abfd, const Elf_External_Options *ex,
1424 Elf_Internal_Options *in)
1425 {
1426 in->kind = H_GET_8 (abfd, ex->kind);
1427 in->size = H_GET_8 (abfd, ex->size);
1428 in->section = H_GET_16 (abfd, ex->section);
1429 in->info = H_GET_32 (abfd, ex->info);
1430 }
1431
1432 /* Swap out an options header. */
1433
1434 void
1435 bfd_mips_elf_swap_options_out (bfd *abfd, const Elf_Internal_Options *in,
1436 Elf_External_Options *ex)
1437 {
1438 H_PUT_8 (abfd, in->kind, ex->kind);
1439 H_PUT_8 (abfd, in->size, ex->size);
1440 H_PUT_16 (abfd, in->section, ex->section);
1441 H_PUT_32 (abfd, in->info, ex->info);
1442 }
1443 \f
1444 /* This function is called via qsort() to sort the dynamic relocation
1445 entries by increasing r_symndx value. */
1446
1447 static int
1448 sort_dynamic_relocs (const void *arg1, const void *arg2)
1449 {
1450 Elf_Internal_Rela int_reloc1;
1451 Elf_Internal_Rela int_reloc2;
1452
1453 bfd_elf32_swap_reloc_in (reldyn_sorting_bfd, arg1, &int_reloc1);
1454 bfd_elf32_swap_reloc_in (reldyn_sorting_bfd, arg2, &int_reloc2);
1455
1456 return ELF32_R_SYM (int_reloc1.r_info) - ELF32_R_SYM (int_reloc2.r_info);
1457 }
1458
1459 /* Like sort_dynamic_relocs, but used for elf64 relocations. */
1460
1461 static int
1462 sort_dynamic_relocs_64 (const void *arg1, const void *arg2)
1463 {
1464 Elf_Internal_Rela int_reloc1[3];
1465 Elf_Internal_Rela int_reloc2[3];
1466
1467 (*get_elf_backend_data (reldyn_sorting_bfd)->s->swap_reloc_in)
1468 (reldyn_sorting_bfd, arg1, int_reloc1);
1469 (*get_elf_backend_data (reldyn_sorting_bfd)->s->swap_reloc_in)
1470 (reldyn_sorting_bfd, arg2, int_reloc2);
1471
1472 return (ELF64_R_SYM (int_reloc1[0].r_info)
1473 - ELF64_R_SYM (int_reloc2[0].r_info));
1474 }
1475
1476
1477 /* This routine is used to write out ECOFF debugging external symbol
1478 information. It is called via mips_elf_link_hash_traverse. The
1479 ECOFF external symbol information must match the ELF external
1480 symbol information. Unfortunately, at this point we don't know
1481 whether a symbol is required by reloc information, so the two
1482 tables may wind up being different. We must sort out the external
1483 symbol information before we can set the final size of the .mdebug
1484 section, and we must set the size of the .mdebug section before we
1485 can relocate any sections, and we can't know which symbols are
1486 required by relocation until we relocate the sections.
1487 Fortunately, it is relatively unlikely that any symbol will be
1488 stripped but required by a reloc. In particular, it can not happen
1489 when generating a final executable. */
1490
1491 static bfd_boolean
1492 mips_elf_output_extsym (struct mips_elf_link_hash_entry *h, void *data)
1493 {
1494 struct extsym_info *einfo = data;
1495 bfd_boolean strip;
1496 asection *sec, *output_section;
1497
1498 if (h->root.root.type == bfd_link_hash_warning)
1499 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
1500
1501 if (h->root.indx == -2)
1502 strip = FALSE;
1503 else if (((h->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_DYNAMIC) != 0
1504 || (h->root.elf_link_hash_flags & ELF_LINK_HASH_REF_DYNAMIC) != 0)
1505 && (h->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR) == 0
1506 && (h->root.elf_link_hash_flags & ELF_LINK_HASH_REF_REGULAR) == 0)
1507 strip = TRUE;
1508 else if (einfo->info->strip == strip_all
1509 || (einfo->info->strip == strip_some
1510 && bfd_hash_lookup (einfo->info->keep_hash,
1511 h->root.root.root.string,
1512 FALSE, FALSE) == NULL))
1513 strip = TRUE;
1514 else
1515 strip = FALSE;
1516
1517 if (strip)
1518 return TRUE;
1519
1520 if (h->esym.ifd == -2)
1521 {
1522 h->esym.jmptbl = 0;
1523 h->esym.cobol_main = 0;
1524 h->esym.weakext = 0;
1525 h->esym.reserved = 0;
1526 h->esym.ifd = ifdNil;
1527 h->esym.asym.value = 0;
1528 h->esym.asym.st = stGlobal;
1529
1530 if (h->root.root.type == bfd_link_hash_undefined
1531 || h->root.root.type == bfd_link_hash_undefweak)
1532 {
1533 const char *name;
1534
1535 /* Use undefined class. Also, set class and type for some
1536 special symbols. */
1537 name = h->root.root.root.string;
1538 if (strcmp (name, mips_elf_dynsym_rtproc_names[0]) == 0
1539 || strcmp (name, mips_elf_dynsym_rtproc_names[1]) == 0)
1540 {
1541 h->esym.asym.sc = scData;
1542 h->esym.asym.st = stLabel;
1543 h->esym.asym.value = 0;
1544 }
1545 else if (strcmp (name, mips_elf_dynsym_rtproc_names[2]) == 0)
1546 {
1547 h->esym.asym.sc = scAbs;
1548 h->esym.asym.st = stLabel;
1549 h->esym.asym.value =
1550 mips_elf_hash_table (einfo->info)->procedure_count;
1551 }
1552 else if (strcmp (name, "_gp_disp") == 0 && ! NEWABI_P (einfo->abfd))
1553 {
1554 h->esym.asym.sc = scAbs;
1555 h->esym.asym.st = stLabel;
1556 h->esym.asym.value = elf_gp (einfo->abfd);
1557 }
1558 else
1559 h->esym.asym.sc = scUndefined;
1560 }
1561 else if (h->root.root.type != bfd_link_hash_defined
1562 && h->root.root.type != bfd_link_hash_defweak)
1563 h->esym.asym.sc = scAbs;
1564 else
1565 {
1566 const char *name;
1567
1568 sec = h->root.root.u.def.section;
1569 output_section = sec->output_section;
1570
1571 /* When making a shared library and symbol h is the one from
1572 the another shared library, OUTPUT_SECTION may be null. */
1573 if (output_section == NULL)
1574 h->esym.asym.sc = scUndefined;
1575 else
1576 {
1577 name = bfd_section_name (output_section->owner, output_section);
1578
1579 if (strcmp (name, ".text") == 0)
1580 h->esym.asym.sc = scText;
1581 else if (strcmp (name, ".data") == 0)
1582 h->esym.asym.sc = scData;
1583 else if (strcmp (name, ".sdata") == 0)
1584 h->esym.asym.sc = scSData;
1585 else if (strcmp (name, ".rodata") == 0
1586 || strcmp (name, ".rdata") == 0)
1587 h->esym.asym.sc = scRData;
1588 else if (strcmp (name, ".bss") == 0)
1589 h->esym.asym.sc = scBss;
1590 else if (strcmp (name, ".sbss") == 0)
1591 h->esym.asym.sc = scSBss;
1592 else if (strcmp (name, ".init") == 0)
1593 h->esym.asym.sc = scInit;
1594 else if (strcmp (name, ".fini") == 0)
1595 h->esym.asym.sc = scFini;
1596 else
1597 h->esym.asym.sc = scAbs;
1598 }
1599 }
1600
1601 h->esym.asym.reserved = 0;
1602 h->esym.asym.index = indexNil;
1603 }
1604
1605 if (h->root.root.type == bfd_link_hash_common)
1606 h->esym.asym.value = h->root.root.u.c.size;
1607 else if (h->root.root.type == bfd_link_hash_defined
1608 || h->root.root.type == bfd_link_hash_defweak)
1609 {
1610 if (h->esym.asym.sc == scCommon)
1611 h->esym.asym.sc = scBss;
1612 else if (h->esym.asym.sc == scSCommon)
1613 h->esym.asym.sc = scSBss;
1614
1615 sec = h->root.root.u.def.section;
1616 output_section = sec->output_section;
1617 if (output_section != NULL)
1618 h->esym.asym.value = (h->root.root.u.def.value
1619 + sec->output_offset
1620 + output_section->vma);
1621 else
1622 h->esym.asym.value = 0;
1623 }
1624 else if ((h->root.elf_link_hash_flags & ELF_LINK_HASH_NEEDS_PLT) != 0)
1625 {
1626 struct mips_elf_link_hash_entry *hd = h;
1627 bfd_boolean no_fn_stub = h->no_fn_stub;
1628
1629 while (hd->root.root.type == bfd_link_hash_indirect)
1630 {
1631 hd = (struct mips_elf_link_hash_entry *)h->root.root.u.i.link;
1632 no_fn_stub = no_fn_stub || hd->no_fn_stub;
1633 }
1634
1635 if (!no_fn_stub)
1636 {
1637 /* Set type and value for a symbol with a function stub. */
1638 h->esym.asym.st = stProc;
1639 sec = hd->root.root.u.def.section;
1640 if (sec == NULL)
1641 h->esym.asym.value = 0;
1642 else
1643 {
1644 output_section = sec->output_section;
1645 if (output_section != NULL)
1646 h->esym.asym.value = (hd->root.plt.offset
1647 + sec->output_offset
1648 + output_section->vma);
1649 else
1650 h->esym.asym.value = 0;
1651 }
1652 #if 0 /* FIXME? */
1653 h->esym.ifd = 0;
1654 #endif
1655 }
1656 }
1657
1658 if (! bfd_ecoff_debug_one_external (einfo->abfd, einfo->debug, einfo->swap,
1659 h->root.root.root.string,
1660 &h->esym))
1661 {
1662 einfo->failed = TRUE;
1663 return FALSE;
1664 }
1665
1666 return TRUE;
1667 }
1668
1669 /* A comparison routine used to sort .gptab entries. */
1670
1671 static int
1672 gptab_compare (const void *p1, const void *p2)
1673 {
1674 const Elf32_gptab *a1 = p1;
1675 const Elf32_gptab *a2 = p2;
1676
1677 return a1->gt_entry.gt_g_value - a2->gt_entry.gt_g_value;
1678 }
1679 \f
1680 /* Functions to manage the got entry hash table. */
1681
1682 /* Use all 64 bits of a bfd_vma for the computation of a 32-bit
1683 hash number. */
1684
1685 static INLINE hashval_t
1686 mips_elf_hash_bfd_vma (bfd_vma addr)
1687 {
1688 #ifdef BFD64
1689 return addr + (addr >> 32);
1690 #else
1691 return addr;
1692 #endif
1693 }
1694
1695 /* got_entries only match if they're identical, except for gotidx, so
1696 use all fields to compute the hash, and compare the appropriate
1697 union members. */
1698
1699 static hashval_t
1700 mips_elf_got_entry_hash (const void *entry_)
1701 {
1702 const struct mips_got_entry *entry = (struct mips_got_entry *)entry_;
1703
1704 return entry->symndx
1705 + (! entry->abfd ? mips_elf_hash_bfd_vma (entry->d.address)
1706 : entry->abfd->id
1707 + (entry->symndx >= 0 ? mips_elf_hash_bfd_vma (entry->d.addend)
1708 : entry->d.h->root.root.root.hash));
1709 }
1710
1711 static int
1712 mips_elf_got_entry_eq (const void *entry1, const void *entry2)
1713 {
1714 const struct mips_got_entry *e1 = (struct mips_got_entry *)entry1;
1715 const struct mips_got_entry *e2 = (struct mips_got_entry *)entry2;
1716
1717 return e1->abfd == e2->abfd && e1->symndx == e2->symndx
1718 && (! e1->abfd ? e1->d.address == e2->d.address
1719 : e1->symndx >= 0 ? e1->d.addend == e2->d.addend
1720 : e1->d.h == e2->d.h);
1721 }
1722
1723 /* multi_got_entries are still a match in the case of global objects,
1724 even if the input bfd in which they're referenced differs, so the
1725 hash computation and compare functions are adjusted
1726 accordingly. */
1727
1728 static hashval_t
1729 mips_elf_multi_got_entry_hash (const void *entry_)
1730 {
1731 const struct mips_got_entry *entry = (struct mips_got_entry *)entry_;
1732
1733 return entry->symndx
1734 + (! entry->abfd
1735 ? mips_elf_hash_bfd_vma (entry->d.address)
1736 : entry->symndx >= 0
1737 ? (entry->abfd->id
1738 + mips_elf_hash_bfd_vma (entry->d.addend))
1739 : entry->d.h->root.root.root.hash);
1740 }
1741
1742 static int
1743 mips_elf_multi_got_entry_eq (const void *entry1, const void *entry2)
1744 {
1745 const struct mips_got_entry *e1 = (struct mips_got_entry *)entry1;
1746 const struct mips_got_entry *e2 = (struct mips_got_entry *)entry2;
1747
1748 return e1->symndx == e2->symndx
1749 && (e1->symndx >= 0 ? e1->abfd == e2->abfd && e1->d.addend == e2->d.addend
1750 : e1->abfd == NULL || e2->abfd == NULL
1751 ? e1->abfd == e2->abfd && e1->d.address == e2->d.address
1752 : e1->d.h == e2->d.h);
1753 }
1754 \f
1755 /* Returns the dynamic relocation section for DYNOBJ. */
1756
1757 static asection *
1758 mips_elf_rel_dyn_section (bfd *dynobj, bfd_boolean create_p)
1759 {
1760 static const char dname[] = ".rel.dyn";
1761 asection *sreloc;
1762
1763 sreloc = bfd_get_section_by_name (dynobj, dname);
1764 if (sreloc == NULL && create_p)
1765 {
1766 sreloc = bfd_make_section (dynobj, dname);
1767 if (sreloc == NULL
1768 || ! bfd_set_section_flags (dynobj, sreloc,
1769 (SEC_ALLOC
1770 | SEC_LOAD
1771 | SEC_HAS_CONTENTS
1772 | SEC_IN_MEMORY
1773 | SEC_LINKER_CREATED
1774 | SEC_READONLY))
1775 || ! bfd_set_section_alignment (dynobj, sreloc,
1776 MIPS_ELF_LOG_FILE_ALIGN (dynobj)))
1777 return NULL;
1778 }
1779 return sreloc;
1780 }
1781
1782 /* Returns the GOT section for ABFD. */
1783
1784 static asection *
1785 mips_elf_got_section (bfd *abfd, bfd_boolean maybe_excluded)
1786 {
1787 asection *sgot = bfd_get_section_by_name (abfd, ".got");
1788 if (sgot == NULL
1789 || (! maybe_excluded && (sgot->flags & SEC_EXCLUDE) != 0))
1790 return NULL;
1791 return sgot;
1792 }
1793
1794 /* Returns the GOT information associated with the link indicated by
1795 INFO. If SGOTP is non-NULL, it is filled in with the GOT
1796 section. */
1797
1798 static struct mips_got_info *
1799 mips_elf_got_info (bfd *abfd, asection **sgotp)
1800 {
1801 asection *sgot;
1802 struct mips_got_info *g;
1803
1804 sgot = mips_elf_got_section (abfd, TRUE);
1805 BFD_ASSERT (sgot != NULL);
1806 BFD_ASSERT (mips_elf_section_data (sgot) != NULL);
1807 g = mips_elf_section_data (sgot)->u.got_info;
1808 BFD_ASSERT (g != NULL);
1809
1810 if (sgotp)
1811 *sgotp = (sgot->flags & SEC_EXCLUDE) == 0 ? sgot : NULL;
1812
1813 return g;
1814 }
1815
1816 /* Returns the GOT offset at which the indicated address can be found.
1817 If there is not yet a GOT entry for this value, create one. Returns
1818 -1 if no satisfactory GOT offset can be found. */
1819
1820 static bfd_vma
1821 mips_elf_local_got_index (bfd *abfd, bfd *ibfd, struct bfd_link_info *info,
1822 bfd_vma value)
1823 {
1824 asection *sgot;
1825 struct mips_got_info *g;
1826 struct mips_got_entry *entry;
1827
1828 g = mips_elf_got_info (elf_hash_table (info)->dynobj, &sgot);
1829
1830 entry = mips_elf_create_local_got_entry (abfd, ibfd, g, sgot, value);
1831 if (entry)
1832 return entry->gotidx;
1833 else
1834 return MINUS_ONE;
1835 }
1836
1837 /* Returns the GOT index for the global symbol indicated by H. */
1838
1839 static bfd_vma
1840 mips_elf_global_got_index (bfd *abfd, bfd *ibfd, struct elf_link_hash_entry *h)
1841 {
1842 bfd_vma index;
1843 asection *sgot;
1844 struct mips_got_info *g, *gg;
1845 long global_got_dynindx = 0;
1846
1847 gg = g = mips_elf_got_info (abfd, &sgot);
1848 if (g->bfd2got && ibfd)
1849 {
1850 struct mips_got_entry e, *p;
1851
1852 BFD_ASSERT (h->dynindx >= 0);
1853
1854 g = mips_elf_got_for_ibfd (g, ibfd);
1855 if (g->next != gg)
1856 {
1857 e.abfd = ibfd;
1858 e.symndx = -1;
1859 e.d.h = (struct mips_elf_link_hash_entry *)h;
1860
1861 p = htab_find (g->got_entries, &e);
1862
1863 BFD_ASSERT (p->gotidx > 0);
1864 return p->gotidx;
1865 }
1866 }
1867
1868 if (gg->global_gotsym != NULL)
1869 global_got_dynindx = gg->global_gotsym->dynindx;
1870
1871 /* Once we determine the global GOT entry with the lowest dynamic
1872 symbol table index, we must put all dynamic symbols with greater
1873 indices into the GOT. That makes it easy to calculate the GOT
1874 offset. */
1875 BFD_ASSERT (h->dynindx >= global_got_dynindx);
1876 index = ((h->dynindx - global_got_dynindx + g->local_gotno)
1877 * MIPS_ELF_GOT_SIZE (abfd));
1878 BFD_ASSERT (index < sgot->_raw_size);
1879
1880 return index;
1881 }
1882
1883 /* Find a GOT entry that is within 32KB of the VALUE. These entries
1884 are supposed to be placed at small offsets in the GOT, i.e.,
1885 within 32KB of GP. Return the index into the GOT for this page,
1886 and store the offset from this entry to the desired address in
1887 OFFSETP, if it is non-NULL. */
1888
1889 static bfd_vma
1890 mips_elf_got_page (bfd *abfd, bfd *ibfd, struct bfd_link_info *info,
1891 bfd_vma value, bfd_vma *offsetp)
1892 {
1893 asection *sgot;
1894 struct mips_got_info *g;
1895 bfd_vma index;
1896 struct mips_got_entry *entry;
1897
1898 g = mips_elf_got_info (elf_hash_table (info)->dynobj, &sgot);
1899
1900 entry = mips_elf_create_local_got_entry (abfd, ibfd, g, sgot,
1901 (value + 0x8000)
1902 & (~(bfd_vma)0xffff));
1903
1904 if (!entry)
1905 return MINUS_ONE;
1906
1907 index = entry->gotidx;
1908
1909 if (offsetp)
1910 *offsetp = value - entry->d.address;
1911
1912 return index;
1913 }
1914
1915 /* Find a GOT entry whose higher-order 16 bits are the same as those
1916 for value. Return the index into the GOT for this entry. */
1917
1918 static bfd_vma
1919 mips_elf_got16_entry (bfd *abfd, bfd *ibfd, struct bfd_link_info *info,
1920 bfd_vma value, bfd_boolean external)
1921 {
1922 asection *sgot;
1923 struct mips_got_info *g;
1924 struct mips_got_entry *entry;
1925
1926 if (! external)
1927 {
1928 /* Although the ABI says that it is "the high-order 16 bits" that we
1929 want, it is really the %high value. The complete value is
1930 calculated with a `addiu' of a LO16 relocation, just as with a
1931 HI16/LO16 pair. */
1932 value = mips_elf_high (value) << 16;
1933 }
1934
1935 g = mips_elf_got_info (elf_hash_table (info)->dynobj, &sgot);
1936
1937 entry = mips_elf_create_local_got_entry (abfd, ibfd, g, sgot, value);
1938 if (entry)
1939 return entry->gotidx;
1940 else
1941 return MINUS_ONE;
1942 }
1943
1944 /* Returns the offset for the entry at the INDEXth position
1945 in the GOT. */
1946
1947 static bfd_vma
1948 mips_elf_got_offset_from_index (bfd *dynobj, bfd *output_bfd,
1949 bfd *input_bfd, bfd_vma index)
1950 {
1951 asection *sgot;
1952 bfd_vma gp;
1953 struct mips_got_info *g;
1954
1955 g = mips_elf_got_info (dynobj, &sgot);
1956 gp = _bfd_get_gp_value (output_bfd)
1957 + mips_elf_adjust_gp (output_bfd, g, input_bfd);
1958
1959 return sgot->output_section->vma + sgot->output_offset + index - gp;
1960 }
1961
1962 /* Create a local GOT entry for VALUE. Return the index of the entry,
1963 or -1 if it could not be created. */
1964
1965 static struct mips_got_entry *
1966 mips_elf_create_local_got_entry (bfd *abfd, bfd *ibfd,
1967 struct mips_got_info *gg,
1968 asection *sgot, bfd_vma value)
1969 {
1970 struct mips_got_entry entry, **loc;
1971 struct mips_got_info *g;
1972
1973 entry.abfd = NULL;
1974 entry.symndx = -1;
1975 entry.d.address = value;
1976
1977 g = mips_elf_got_for_ibfd (gg, ibfd);
1978 if (g == NULL)
1979 {
1980 g = mips_elf_got_for_ibfd (gg, abfd);
1981 BFD_ASSERT (g != NULL);
1982 }
1983
1984 loc = (struct mips_got_entry **) htab_find_slot (g->got_entries, &entry,
1985 INSERT);
1986 if (*loc)
1987 return *loc;
1988
1989 entry.gotidx = MIPS_ELF_GOT_SIZE (abfd) * g->assigned_gotno++;
1990
1991 *loc = (struct mips_got_entry *)bfd_alloc (abfd, sizeof entry);
1992
1993 if (! *loc)
1994 return NULL;
1995
1996 memcpy (*loc, &entry, sizeof entry);
1997
1998 if (g->assigned_gotno >= g->local_gotno)
1999 {
2000 (*loc)->gotidx = -1;
2001 /* We didn't allocate enough space in the GOT. */
2002 (*_bfd_error_handler)
2003 (_("not enough GOT space for local GOT entries"));
2004 bfd_set_error (bfd_error_bad_value);
2005 return NULL;
2006 }
2007
2008 MIPS_ELF_PUT_WORD (abfd, value,
2009 (sgot->contents + entry.gotidx));
2010
2011 return *loc;
2012 }
2013
2014 /* Sort the dynamic symbol table so that symbols that need GOT entries
2015 appear towards the end. This reduces the amount of GOT space
2016 required. MAX_LOCAL is used to set the number of local symbols
2017 known to be in the dynamic symbol table. During
2018 _bfd_mips_elf_size_dynamic_sections, this value is 1. Afterward, the
2019 section symbols are added and the count is higher. */
2020
2021 static bfd_boolean
2022 mips_elf_sort_hash_table (struct bfd_link_info *info, unsigned long max_local)
2023 {
2024 struct mips_elf_hash_sort_data hsd;
2025 struct mips_got_info *g;
2026 bfd *dynobj;
2027
2028 dynobj = elf_hash_table (info)->dynobj;
2029
2030 g = mips_elf_got_info (dynobj, NULL);
2031
2032 hsd.low = NULL;
2033 hsd.max_unref_got_dynindx =
2034 hsd.min_got_dynindx = elf_hash_table (info)->dynsymcount
2035 /* In the multi-got case, assigned_gotno of the master got_info
2036 indicate the number of entries that aren't referenced in the
2037 primary GOT, but that must have entries because there are
2038 dynamic relocations that reference it. Since they aren't
2039 referenced, we move them to the end of the GOT, so that they
2040 don't prevent other entries that are referenced from getting
2041 too large offsets. */
2042 - (g->next ? g->assigned_gotno : 0);
2043 hsd.max_non_got_dynindx = max_local;
2044 mips_elf_link_hash_traverse (((struct mips_elf_link_hash_table *)
2045 elf_hash_table (info)),
2046 mips_elf_sort_hash_table_f,
2047 &hsd);
2048
2049 /* There should have been enough room in the symbol table to
2050 accommodate both the GOT and non-GOT symbols. */
2051 BFD_ASSERT (hsd.max_non_got_dynindx <= hsd.min_got_dynindx);
2052 BFD_ASSERT ((unsigned long)hsd.max_unref_got_dynindx
2053 <= elf_hash_table (info)->dynsymcount);
2054
2055 /* Now we know which dynamic symbol has the lowest dynamic symbol
2056 table index in the GOT. */
2057 g->global_gotsym = hsd.low;
2058
2059 return TRUE;
2060 }
2061
2062 /* If H needs a GOT entry, assign it the highest available dynamic
2063 index. Otherwise, assign it the lowest available dynamic
2064 index. */
2065
2066 static bfd_boolean
2067 mips_elf_sort_hash_table_f (struct mips_elf_link_hash_entry *h, void *data)
2068 {
2069 struct mips_elf_hash_sort_data *hsd = data;
2070
2071 if (h->root.root.type == bfd_link_hash_warning)
2072 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
2073
2074 /* Symbols without dynamic symbol table entries aren't interesting
2075 at all. */
2076 if (h->root.dynindx == -1)
2077 return TRUE;
2078
2079 /* Global symbols that need GOT entries that are not explicitly
2080 referenced are marked with got offset 2. Those that are
2081 referenced get a 1, and those that don't need GOT entries get
2082 -1. */
2083 if (h->root.got.offset == 2)
2084 {
2085 if (hsd->max_unref_got_dynindx == hsd->min_got_dynindx)
2086 hsd->low = (struct elf_link_hash_entry *) h;
2087 h->root.dynindx = hsd->max_unref_got_dynindx++;
2088 }
2089 else if (h->root.got.offset != 1)
2090 h->root.dynindx = hsd->max_non_got_dynindx++;
2091 else
2092 {
2093 h->root.dynindx = --hsd->min_got_dynindx;
2094 hsd->low = (struct elf_link_hash_entry *) h;
2095 }
2096
2097 return TRUE;
2098 }
2099
2100 /* If H is a symbol that needs a global GOT entry, but has a dynamic
2101 symbol table index lower than any we've seen to date, record it for
2102 posterity. */
2103
2104 static bfd_boolean
2105 mips_elf_record_global_got_symbol (struct elf_link_hash_entry *h,
2106 bfd *abfd, struct bfd_link_info *info,
2107 struct mips_got_info *g)
2108 {
2109 struct mips_got_entry entry, **loc;
2110
2111 /* A global symbol in the GOT must also be in the dynamic symbol
2112 table. */
2113 if (h->dynindx == -1)
2114 {
2115 switch (ELF_ST_VISIBILITY (h->other))
2116 {
2117 case STV_INTERNAL:
2118 case STV_HIDDEN:
2119 _bfd_mips_elf_hide_symbol (info, h, TRUE);
2120 break;
2121 }
2122 if (!bfd_elf_link_record_dynamic_symbol (info, h))
2123 return FALSE;
2124 }
2125
2126 entry.abfd = abfd;
2127 entry.symndx = -1;
2128 entry.d.h = (struct mips_elf_link_hash_entry *) h;
2129
2130 loc = (struct mips_got_entry **) htab_find_slot (g->got_entries, &entry,
2131 INSERT);
2132
2133 /* If we've already marked this entry as needing GOT space, we don't
2134 need to do it again. */
2135 if (*loc)
2136 return TRUE;
2137
2138 *loc = (struct mips_got_entry *)bfd_alloc (abfd, sizeof entry);
2139
2140 if (! *loc)
2141 return FALSE;
2142
2143 entry.gotidx = -1;
2144 memcpy (*loc, &entry, sizeof entry);
2145
2146 if (h->got.offset != MINUS_ONE)
2147 return TRUE;
2148
2149 /* By setting this to a value other than -1, we are indicating that
2150 there needs to be a GOT entry for H. Avoid using zero, as the
2151 generic ELF copy_indirect_symbol tests for <= 0. */
2152 h->got.offset = 1;
2153
2154 return TRUE;
2155 }
2156
2157 /* Reserve space in G for a GOT entry containing the value of symbol
2158 SYMNDX in input bfd ABDF, plus ADDEND. */
2159
2160 static bfd_boolean
2161 mips_elf_record_local_got_symbol (bfd *abfd, long symndx, bfd_vma addend,
2162 struct mips_got_info *g)
2163 {
2164 struct mips_got_entry entry, **loc;
2165
2166 entry.abfd = abfd;
2167 entry.symndx = symndx;
2168 entry.d.addend = addend;
2169 loc = (struct mips_got_entry **)
2170 htab_find_slot (g->got_entries, &entry, INSERT);
2171
2172 if (*loc)
2173 return TRUE;
2174
2175 entry.gotidx = g->local_gotno++;
2176
2177 *loc = (struct mips_got_entry *)bfd_alloc (abfd, sizeof entry);
2178
2179 if (! *loc)
2180 return FALSE;
2181
2182 memcpy (*loc, &entry, sizeof entry);
2183
2184 return TRUE;
2185 }
2186 \f
2187 /* Compute the hash value of the bfd in a bfd2got hash entry. */
2188
2189 static hashval_t
2190 mips_elf_bfd2got_entry_hash (const void *entry_)
2191 {
2192 const struct mips_elf_bfd2got_hash *entry
2193 = (struct mips_elf_bfd2got_hash *)entry_;
2194
2195 return entry->bfd->id;
2196 }
2197
2198 /* Check whether two hash entries have the same bfd. */
2199
2200 static int
2201 mips_elf_bfd2got_entry_eq (const void *entry1, const void *entry2)
2202 {
2203 const struct mips_elf_bfd2got_hash *e1
2204 = (const struct mips_elf_bfd2got_hash *)entry1;
2205 const struct mips_elf_bfd2got_hash *e2
2206 = (const struct mips_elf_bfd2got_hash *)entry2;
2207
2208 return e1->bfd == e2->bfd;
2209 }
2210
2211 /* In a multi-got link, determine the GOT to be used for IBDF. G must
2212 be the master GOT data. */
2213
2214 static struct mips_got_info *
2215 mips_elf_got_for_ibfd (struct mips_got_info *g, bfd *ibfd)
2216 {
2217 struct mips_elf_bfd2got_hash e, *p;
2218
2219 if (! g->bfd2got)
2220 return g;
2221
2222 e.bfd = ibfd;
2223 p = htab_find (g->bfd2got, &e);
2224 return p ? p->g : NULL;
2225 }
2226
2227 /* Create one separate got for each bfd that has entries in the global
2228 got, such that we can tell how many local and global entries each
2229 bfd requires. */
2230
2231 static int
2232 mips_elf_make_got_per_bfd (void **entryp, void *p)
2233 {
2234 struct mips_got_entry *entry = (struct mips_got_entry *)*entryp;
2235 struct mips_elf_got_per_bfd_arg *arg = (struct mips_elf_got_per_bfd_arg *)p;
2236 htab_t bfd2got = arg->bfd2got;
2237 struct mips_got_info *g;
2238 struct mips_elf_bfd2got_hash bfdgot_entry, *bfdgot;
2239 void **bfdgotp;
2240
2241 /* Find the got_info for this GOT entry's input bfd. Create one if
2242 none exists. */
2243 bfdgot_entry.bfd = entry->abfd;
2244 bfdgotp = htab_find_slot (bfd2got, &bfdgot_entry, INSERT);
2245 bfdgot = (struct mips_elf_bfd2got_hash *)*bfdgotp;
2246
2247 if (bfdgot != NULL)
2248 g = bfdgot->g;
2249 else
2250 {
2251 bfdgot = (struct mips_elf_bfd2got_hash *)bfd_alloc
2252 (arg->obfd, sizeof (struct mips_elf_bfd2got_hash));
2253
2254 if (bfdgot == NULL)
2255 {
2256 arg->obfd = 0;
2257 return 0;
2258 }
2259
2260 *bfdgotp = bfdgot;
2261
2262 bfdgot->bfd = entry->abfd;
2263 bfdgot->g = g = (struct mips_got_info *)
2264 bfd_alloc (arg->obfd, sizeof (struct mips_got_info));
2265 if (g == NULL)
2266 {
2267 arg->obfd = 0;
2268 return 0;
2269 }
2270
2271 g->global_gotsym = NULL;
2272 g->global_gotno = 0;
2273 g->local_gotno = 0;
2274 g->assigned_gotno = -1;
2275 g->got_entries = htab_try_create (1, mips_elf_multi_got_entry_hash,
2276 mips_elf_multi_got_entry_eq, NULL);
2277 if (g->got_entries == NULL)
2278 {
2279 arg->obfd = 0;
2280 return 0;
2281 }
2282
2283 g->bfd2got = NULL;
2284 g->next = NULL;
2285 }
2286
2287 /* Insert the GOT entry in the bfd's got entry hash table. */
2288 entryp = htab_find_slot (g->got_entries, entry, INSERT);
2289 if (*entryp != NULL)
2290 return 1;
2291
2292 *entryp = entry;
2293
2294 if (entry->symndx >= 0 || entry->d.h->forced_local)
2295 ++g->local_gotno;
2296 else
2297 ++g->global_gotno;
2298
2299 return 1;
2300 }
2301
2302 /* Attempt to merge gots of different input bfds. Try to use as much
2303 as possible of the primary got, since it doesn't require explicit
2304 dynamic relocations, but don't use bfds that would reference global
2305 symbols out of the addressable range. Failing the primary got,
2306 attempt to merge with the current got, or finish the current got
2307 and then make make the new got current. */
2308
2309 static int
2310 mips_elf_merge_gots (void **bfd2got_, void *p)
2311 {
2312 struct mips_elf_bfd2got_hash *bfd2got
2313 = (struct mips_elf_bfd2got_hash *)*bfd2got_;
2314 struct mips_elf_got_per_bfd_arg *arg = (struct mips_elf_got_per_bfd_arg *)p;
2315 unsigned int lcount = bfd2got->g->local_gotno;
2316 unsigned int gcount = bfd2got->g->global_gotno;
2317 unsigned int maxcnt = arg->max_count;
2318
2319 /* If we don't have a primary GOT and this is not too big, use it as
2320 a starting point for the primary GOT. */
2321 if (! arg->primary && lcount + gcount <= maxcnt)
2322 {
2323 arg->primary = bfd2got->g;
2324 arg->primary_count = lcount + gcount;
2325 }
2326 /* If it looks like we can merge this bfd's entries with those of
2327 the primary, merge them. The heuristics is conservative, but we
2328 don't have to squeeze it too hard. */
2329 else if (arg->primary
2330 && (arg->primary_count + lcount + gcount) <= maxcnt)
2331 {
2332 struct mips_got_info *g = bfd2got->g;
2333 int old_lcount = arg->primary->local_gotno;
2334 int old_gcount = arg->primary->global_gotno;
2335
2336 bfd2got->g = arg->primary;
2337
2338 htab_traverse (g->got_entries,
2339 mips_elf_make_got_per_bfd,
2340 arg);
2341 if (arg->obfd == NULL)
2342 return 0;
2343
2344 htab_delete (g->got_entries);
2345 /* We don't have to worry about releasing memory of the actual
2346 got entries, since they're all in the master got_entries hash
2347 table anyway. */
2348
2349 BFD_ASSERT (old_lcount + lcount >= arg->primary->local_gotno);
2350 BFD_ASSERT (old_gcount + gcount >= arg->primary->global_gotno);
2351
2352 arg->primary_count = arg->primary->local_gotno
2353 + arg->primary->global_gotno;
2354 }
2355 /* If we can merge with the last-created got, do it. */
2356 else if (arg->current
2357 && arg->current_count + lcount + gcount <= maxcnt)
2358 {
2359 struct mips_got_info *g = bfd2got->g;
2360 int old_lcount = arg->current->local_gotno;
2361 int old_gcount = arg->current->global_gotno;
2362
2363 bfd2got->g = arg->current;
2364
2365 htab_traverse (g->got_entries,
2366 mips_elf_make_got_per_bfd,
2367 arg);
2368 if (arg->obfd == NULL)
2369 return 0;
2370
2371 htab_delete (g->got_entries);
2372
2373 BFD_ASSERT (old_lcount + lcount >= arg->current->local_gotno);
2374 BFD_ASSERT (old_gcount + gcount >= arg->current->global_gotno);
2375
2376 arg->current_count = arg->current->local_gotno
2377 + arg->current->global_gotno;
2378 }
2379 /* Well, we couldn't merge, so create a new GOT. Don't check if it
2380 fits; if it turns out that it doesn't, we'll get relocation
2381 overflows anyway. */
2382 else
2383 {
2384 bfd2got->g->next = arg->current;
2385 arg->current = bfd2got->g;
2386
2387 arg->current_count = lcount + gcount;
2388 }
2389
2390 return 1;
2391 }
2392
2393 /* If passed a NULL mips_got_info in the argument, set the marker used
2394 to tell whether a global symbol needs a got entry (in the primary
2395 got) to the given VALUE.
2396
2397 If passed a pointer G to a mips_got_info in the argument (it must
2398 not be the primary GOT), compute the offset from the beginning of
2399 the (primary) GOT section to the entry in G corresponding to the
2400 global symbol. G's assigned_gotno must contain the index of the
2401 first available global GOT entry in G. VALUE must contain the size
2402 of a GOT entry in bytes. For each global GOT entry that requires a
2403 dynamic relocation, NEEDED_RELOCS is incremented, and the symbol is
2404 marked as not eligible for lazy resolution through a function
2405 stub. */
2406 static int
2407 mips_elf_set_global_got_offset (void **entryp, void *p)
2408 {
2409 struct mips_got_entry *entry = (struct mips_got_entry *)*entryp;
2410 struct mips_elf_set_global_got_offset_arg *arg
2411 = (struct mips_elf_set_global_got_offset_arg *)p;
2412 struct mips_got_info *g = arg->g;
2413
2414 if (entry->abfd != NULL && entry->symndx == -1
2415 && entry->d.h->root.dynindx != -1)
2416 {
2417 if (g)
2418 {
2419 BFD_ASSERT (g->global_gotsym == NULL);
2420
2421 entry->gotidx = arg->value * (long) g->assigned_gotno++;
2422 if (arg->info->shared
2423 || (elf_hash_table (arg->info)->dynamic_sections_created
2424 && ((entry->d.h->root.elf_link_hash_flags
2425 & ELF_LINK_HASH_DEF_DYNAMIC) != 0)
2426 && ((entry->d.h->root.elf_link_hash_flags
2427 & ELF_LINK_HASH_DEF_REGULAR) == 0)))
2428 ++arg->needed_relocs;
2429 }
2430 else
2431 entry->d.h->root.got.offset = arg->value;
2432 }
2433
2434 return 1;
2435 }
2436
2437 /* Mark any global symbols referenced in the GOT we are iterating over
2438 as inelligible for lazy resolution stubs. */
2439 static int
2440 mips_elf_set_no_stub (void **entryp, void *p ATTRIBUTE_UNUSED)
2441 {
2442 struct mips_got_entry *entry = (struct mips_got_entry *)*entryp;
2443
2444 if (entry->abfd != NULL
2445 && entry->symndx == -1
2446 && entry->d.h->root.dynindx != -1)
2447 entry->d.h->no_fn_stub = TRUE;
2448
2449 return 1;
2450 }
2451
2452 /* Follow indirect and warning hash entries so that each got entry
2453 points to the final symbol definition. P must point to a pointer
2454 to the hash table we're traversing. Since this traversal may
2455 modify the hash table, we set this pointer to NULL to indicate
2456 we've made a potentially-destructive change to the hash table, so
2457 the traversal must be restarted. */
2458 static int
2459 mips_elf_resolve_final_got_entry (void **entryp, void *p)
2460 {
2461 struct mips_got_entry *entry = (struct mips_got_entry *)*entryp;
2462 htab_t got_entries = *(htab_t *)p;
2463
2464 if (entry->abfd != NULL && entry->symndx == -1)
2465 {
2466 struct mips_elf_link_hash_entry *h = entry->d.h;
2467
2468 while (h->root.root.type == bfd_link_hash_indirect
2469 || h->root.root.type == bfd_link_hash_warning)
2470 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
2471
2472 if (entry->d.h == h)
2473 return 1;
2474
2475 entry->d.h = h;
2476
2477 /* If we can't find this entry with the new bfd hash, re-insert
2478 it, and get the traversal restarted. */
2479 if (! htab_find (got_entries, entry))
2480 {
2481 htab_clear_slot (got_entries, entryp);
2482 entryp = htab_find_slot (got_entries, entry, INSERT);
2483 if (! *entryp)
2484 *entryp = entry;
2485 /* Abort the traversal, since the whole table may have
2486 moved, and leave it up to the parent to restart the
2487 process. */
2488 *(htab_t *)p = NULL;
2489 return 0;
2490 }
2491 /* We might want to decrement the global_gotno count, but it's
2492 either too early or too late for that at this point. */
2493 }
2494
2495 return 1;
2496 }
2497
2498 /* Turn indirect got entries in a got_entries table into their final
2499 locations. */
2500 static void
2501 mips_elf_resolve_final_got_entries (struct mips_got_info *g)
2502 {
2503 htab_t got_entries;
2504
2505 do
2506 {
2507 got_entries = g->got_entries;
2508
2509 htab_traverse (got_entries,
2510 mips_elf_resolve_final_got_entry,
2511 &got_entries);
2512 }
2513 while (got_entries == NULL);
2514 }
2515
2516 /* Return the offset of an input bfd IBFD's GOT from the beginning of
2517 the primary GOT. */
2518 static bfd_vma
2519 mips_elf_adjust_gp (bfd *abfd, struct mips_got_info *g, bfd *ibfd)
2520 {
2521 if (g->bfd2got == NULL)
2522 return 0;
2523
2524 g = mips_elf_got_for_ibfd (g, ibfd);
2525 if (! g)
2526 return 0;
2527
2528 BFD_ASSERT (g->next);
2529
2530 g = g->next;
2531
2532 return (g->local_gotno + g->global_gotno) * MIPS_ELF_GOT_SIZE (abfd);
2533 }
2534
2535 /* Turn a single GOT that is too big for 16-bit addressing into
2536 a sequence of GOTs, each one 16-bit addressable. */
2537
2538 static bfd_boolean
2539 mips_elf_multi_got (bfd *abfd, struct bfd_link_info *info,
2540 struct mips_got_info *g, asection *got,
2541 bfd_size_type pages)
2542 {
2543 struct mips_elf_got_per_bfd_arg got_per_bfd_arg;
2544 struct mips_elf_set_global_got_offset_arg set_got_offset_arg;
2545 struct mips_got_info *gg;
2546 unsigned int assign;
2547
2548 g->bfd2got = htab_try_create (1, mips_elf_bfd2got_entry_hash,
2549 mips_elf_bfd2got_entry_eq, NULL);
2550 if (g->bfd2got == NULL)
2551 return FALSE;
2552
2553 got_per_bfd_arg.bfd2got = g->bfd2got;
2554 got_per_bfd_arg.obfd = abfd;
2555 got_per_bfd_arg.info = info;
2556
2557 /* Count how many GOT entries each input bfd requires, creating a
2558 map from bfd to got info while at that. */
2559 mips_elf_resolve_final_got_entries (g);
2560 htab_traverse (g->got_entries, mips_elf_make_got_per_bfd, &got_per_bfd_arg);
2561 if (got_per_bfd_arg.obfd == NULL)
2562 return FALSE;
2563
2564 got_per_bfd_arg.current = NULL;
2565 got_per_bfd_arg.primary = NULL;
2566 /* Taking out PAGES entries is a worst-case estimate. We could
2567 compute the maximum number of pages that each separate input bfd
2568 uses, but it's probably not worth it. */
2569 got_per_bfd_arg.max_count = ((MIPS_ELF_GOT_MAX_SIZE (abfd)
2570 / MIPS_ELF_GOT_SIZE (abfd))
2571 - MIPS_RESERVED_GOTNO - pages);
2572
2573 /* Try to merge the GOTs of input bfds together, as long as they
2574 don't seem to exceed the maximum GOT size, choosing one of them
2575 to be the primary GOT. */
2576 htab_traverse (g->bfd2got, mips_elf_merge_gots, &got_per_bfd_arg);
2577 if (got_per_bfd_arg.obfd == NULL)
2578 return FALSE;
2579
2580 /* If we find any suitable primary GOT, create an empty one. */
2581 if (got_per_bfd_arg.primary == NULL)
2582 {
2583 g->next = (struct mips_got_info *)
2584 bfd_alloc (abfd, sizeof (struct mips_got_info));
2585 if (g->next == NULL)
2586 return FALSE;
2587
2588 g->next->global_gotsym = NULL;
2589 g->next->global_gotno = 0;
2590 g->next->local_gotno = 0;
2591 g->next->assigned_gotno = 0;
2592 g->next->got_entries = htab_try_create (1, mips_elf_multi_got_entry_hash,
2593 mips_elf_multi_got_entry_eq,
2594 NULL);
2595 if (g->next->got_entries == NULL)
2596 return FALSE;
2597 g->next->bfd2got = NULL;
2598 }
2599 else
2600 g->next = got_per_bfd_arg.primary;
2601 g->next->next = got_per_bfd_arg.current;
2602
2603 /* GG is now the master GOT, and G is the primary GOT. */
2604 gg = g;
2605 g = g->next;
2606
2607 /* Map the output bfd to the primary got. That's what we're going
2608 to use for bfds that use GOT16 or GOT_PAGE relocations that we
2609 didn't mark in check_relocs, and we want a quick way to find it.
2610 We can't just use gg->next because we're going to reverse the
2611 list. */
2612 {
2613 struct mips_elf_bfd2got_hash *bfdgot;
2614 void **bfdgotp;
2615
2616 bfdgot = (struct mips_elf_bfd2got_hash *)bfd_alloc
2617 (abfd, sizeof (struct mips_elf_bfd2got_hash));
2618
2619 if (bfdgot == NULL)
2620 return FALSE;
2621
2622 bfdgot->bfd = abfd;
2623 bfdgot->g = g;
2624 bfdgotp = htab_find_slot (gg->bfd2got, bfdgot, INSERT);
2625
2626 BFD_ASSERT (*bfdgotp == NULL);
2627 *bfdgotp = bfdgot;
2628 }
2629
2630 /* The IRIX dynamic linker requires every symbol that is referenced
2631 in a dynamic relocation to be present in the primary GOT, so
2632 arrange for them to appear after those that are actually
2633 referenced.
2634
2635 GNU/Linux could very well do without it, but it would slow down
2636 the dynamic linker, since it would have to resolve every dynamic
2637 symbol referenced in other GOTs more than once, without help from
2638 the cache. Also, knowing that every external symbol has a GOT
2639 helps speed up the resolution of local symbols too, so GNU/Linux
2640 follows IRIX's practice.
2641
2642 The number 2 is used by mips_elf_sort_hash_table_f to count
2643 global GOT symbols that are unreferenced in the primary GOT, with
2644 an initial dynamic index computed from gg->assigned_gotno, where
2645 the number of unreferenced global entries in the primary GOT is
2646 preserved. */
2647 if (1)
2648 {
2649 gg->assigned_gotno = gg->global_gotno - g->global_gotno;
2650 g->global_gotno = gg->global_gotno;
2651 set_got_offset_arg.value = 2;
2652 }
2653 else
2654 {
2655 /* This could be used for dynamic linkers that don't optimize
2656 symbol resolution while applying relocations so as to use
2657 primary GOT entries or assuming the symbol is locally-defined.
2658 With this code, we assign lower dynamic indices to global
2659 symbols that are not referenced in the primary GOT, so that
2660 their entries can be omitted. */
2661 gg->assigned_gotno = 0;
2662 set_got_offset_arg.value = -1;
2663 }
2664
2665 /* Reorder dynamic symbols as described above (which behavior
2666 depends on the setting of VALUE). */
2667 set_got_offset_arg.g = NULL;
2668 htab_traverse (gg->got_entries, mips_elf_set_global_got_offset,
2669 &set_got_offset_arg);
2670 set_got_offset_arg.value = 1;
2671 htab_traverse (g->got_entries, mips_elf_set_global_got_offset,
2672 &set_got_offset_arg);
2673 if (! mips_elf_sort_hash_table (info, 1))
2674 return FALSE;
2675
2676 /* Now go through the GOTs assigning them offset ranges.
2677 [assigned_gotno, local_gotno[ will be set to the range of local
2678 entries in each GOT. We can then compute the end of a GOT by
2679 adding local_gotno to global_gotno. We reverse the list and make
2680 it circular since then we'll be able to quickly compute the
2681 beginning of a GOT, by computing the end of its predecessor. To
2682 avoid special cases for the primary GOT, while still preserving
2683 assertions that are valid for both single- and multi-got links,
2684 we arrange for the main got struct to have the right number of
2685 global entries, but set its local_gotno such that the initial
2686 offset of the primary GOT is zero. Remember that the primary GOT
2687 will become the last item in the circular linked list, so it
2688 points back to the master GOT. */
2689 gg->local_gotno = -g->global_gotno;
2690 gg->global_gotno = g->global_gotno;
2691 assign = 0;
2692 gg->next = gg;
2693
2694 do
2695 {
2696 struct mips_got_info *gn;
2697
2698 assign += MIPS_RESERVED_GOTNO;
2699 g->assigned_gotno = assign;
2700 g->local_gotno += assign + pages;
2701 assign = g->local_gotno + g->global_gotno;
2702
2703 /* Take g out of the direct list, and push it onto the reversed
2704 list that gg points to. */
2705 gn = g->next;
2706 g->next = gg->next;
2707 gg->next = g;
2708 g = gn;
2709
2710 /* Mark global symbols in every non-primary GOT as ineligible for
2711 stubs. */
2712 if (g)
2713 htab_traverse (g->got_entries, mips_elf_set_no_stub, NULL);
2714 }
2715 while (g);
2716
2717 got->_raw_size = (gg->next->local_gotno
2718 + gg->next->global_gotno) * MIPS_ELF_GOT_SIZE (abfd);
2719
2720 return TRUE;
2721 }
2722
2723 \f
2724 /* Returns the first relocation of type r_type found, beginning with
2725 RELOCATION. RELEND is one-past-the-end of the relocation table. */
2726
2727 static const Elf_Internal_Rela *
2728 mips_elf_next_relocation (bfd *abfd ATTRIBUTE_UNUSED, unsigned int r_type,
2729 const Elf_Internal_Rela *relocation,
2730 const Elf_Internal_Rela *relend)
2731 {
2732 /* According to the MIPS ELF ABI, the R_MIPS_LO16 relocation must be
2733 immediately following. However, for the IRIX6 ABI, the next
2734 relocation may be a composed relocation consisting of several
2735 relocations for the same address. In that case, the R_MIPS_LO16
2736 relocation may occur as one of these. We permit a similar
2737 extension in general, as that is useful for GCC. */
2738 while (relocation < relend)
2739 {
2740 if (ELF_R_TYPE (abfd, relocation->r_info) == r_type)
2741 return relocation;
2742
2743 ++relocation;
2744 }
2745
2746 /* We didn't find it. */
2747 bfd_set_error (bfd_error_bad_value);
2748 return NULL;
2749 }
2750
2751 /* Return whether a relocation is against a local symbol. */
2752
2753 static bfd_boolean
2754 mips_elf_local_relocation_p (bfd *input_bfd,
2755 const Elf_Internal_Rela *relocation,
2756 asection **local_sections,
2757 bfd_boolean check_forced)
2758 {
2759 unsigned long r_symndx;
2760 Elf_Internal_Shdr *symtab_hdr;
2761 struct mips_elf_link_hash_entry *h;
2762 size_t extsymoff;
2763
2764 r_symndx = ELF_R_SYM (input_bfd, relocation->r_info);
2765 symtab_hdr = &elf_tdata (input_bfd)->symtab_hdr;
2766 extsymoff = (elf_bad_symtab (input_bfd)) ? 0 : symtab_hdr->sh_info;
2767
2768 if (r_symndx < extsymoff)
2769 return TRUE;
2770 if (elf_bad_symtab (input_bfd) && local_sections[r_symndx] != NULL)
2771 return TRUE;
2772
2773 if (check_forced)
2774 {
2775 /* Look up the hash table to check whether the symbol
2776 was forced local. */
2777 h = (struct mips_elf_link_hash_entry *)
2778 elf_sym_hashes (input_bfd) [r_symndx - extsymoff];
2779 /* Find the real hash-table entry for this symbol. */
2780 while (h->root.root.type == bfd_link_hash_indirect
2781 || h->root.root.type == bfd_link_hash_warning)
2782 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
2783 if ((h->root.elf_link_hash_flags & ELF_LINK_FORCED_LOCAL) != 0)
2784 return TRUE;
2785 }
2786
2787 return FALSE;
2788 }
2789 \f
2790 /* Sign-extend VALUE, which has the indicated number of BITS. */
2791
2792 bfd_vma
2793 _bfd_mips_elf_sign_extend (bfd_vma value, int bits)
2794 {
2795 if (value & ((bfd_vma) 1 << (bits - 1)))
2796 /* VALUE is negative. */
2797 value |= ((bfd_vma) - 1) << bits;
2798
2799 return value;
2800 }
2801
2802 /* Return non-zero if the indicated VALUE has overflowed the maximum
2803 range expressible by a signed number with the indicated number of
2804 BITS. */
2805
2806 static bfd_boolean
2807 mips_elf_overflow_p (bfd_vma value, int bits)
2808 {
2809 bfd_signed_vma svalue = (bfd_signed_vma) value;
2810
2811 if (svalue > (1 << (bits - 1)) - 1)
2812 /* The value is too big. */
2813 return TRUE;
2814 else if (svalue < -(1 << (bits - 1)))
2815 /* The value is too small. */
2816 return TRUE;
2817
2818 /* All is well. */
2819 return FALSE;
2820 }
2821
2822 /* Calculate the %high function. */
2823
2824 static bfd_vma
2825 mips_elf_high (bfd_vma value)
2826 {
2827 return ((value + (bfd_vma) 0x8000) >> 16) & 0xffff;
2828 }
2829
2830 /* Calculate the %higher function. */
2831
2832 static bfd_vma
2833 mips_elf_higher (bfd_vma value ATTRIBUTE_UNUSED)
2834 {
2835 #ifdef BFD64
2836 return ((value + (bfd_vma) 0x80008000) >> 32) & 0xffff;
2837 #else
2838 abort ();
2839 return (bfd_vma) -1;
2840 #endif
2841 }
2842
2843 /* Calculate the %highest function. */
2844
2845 static bfd_vma
2846 mips_elf_highest (bfd_vma value ATTRIBUTE_UNUSED)
2847 {
2848 #ifdef BFD64
2849 return ((value + (((bfd_vma) 0x8000 << 32) | 0x80008000)) >> 48) & 0xffff;
2850 #else
2851 abort ();
2852 return (bfd_vma) -1;
2853 #endif
2854 }
2855 \f
2856 /* Create the .compact_rel section. */
2857
2858 static bfd_boolean
2859 mips_elf_create_compact_rel_section
2860 (bfd *abfd, struct bfd_link_info *info ATTRIBUTE_UNUSED)
2861 {
2862 flagword flags;
2863 register asection *s;
2864
2865 if (bfd_get_section_by_name (abfd, ".compact_rel") == NULL)
2866 {
2867 flags = (SEC_HAS_CONTENTS | SEC_IN_MEMORY | SEC_LINKER_CREATED
2868 | SEC_READONLY);
2869
2870 s = bfd_make_section (abfd, ".compact_rel");
2871 if (s == NULL
2872 || ! bfd_set_section_flags (abfd, s, flags)
2873 || ! bfd_set_section_alignment (abfd, s,
2874 MIPS_ELF_LOG_FILE_ALIGN (abfd)))
2875 return FALSE;
2876
2877 s->_raw_size = sizeof (Elf32_External_compact_rel);
2878 }
2879
2880 return TRUE;
2881 }
2882
2883 /* Create the .got section to hold the global offset table. */
2884
2885 static bfd_boolean
2886 mips_elf_create_got_section (bfd *abfd, struct bfd_link_info *info,
2887 bfd_boolean maybe_exclude)
2888 {
2889 flagword flags;
2890 register asection *s;
2891 struct elf_link_hash_entry *h;
2892 struct bfd_link_hash_entry *bh;
2893 struct mips_got_info *g;
2894 bfd_size_type amt;
2895
2896 /* This function may be called more than once. */
2897 s = mips_elf_got_section (abfd, TRUE);
2898 if (s)
2899 {
2900 if (! maybe_exclude)
2901 s->flags &= ~SEC_EXCLUDE;
2902 return TRUE;
2903 }
2904
2905 flags = (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS | SEC_IN_MEMORY
2906 | SEC_LINKER_CREATED);
2907
2908 if (maybe_exclude)
2909 flags |= SEC_EXCLUDE;
2910
2911 /* We have to use an alignment of 2**4 here because this is hardcoded
2912 in the function stub generation and in the linker script. */
2913 s = bfd_make_section (abfd, ".got");
2914 if (s == NULL
2915 || ! bfd_set_section_flags (abfd, s, flags)
2916 || ! bfd_set_section_alignment (abfd, s, 4))
2917 return FALSE;
2918
2919 /* Define the symbol _GLOBAL_OFFSET_TABLE_. We don't do this in the
2920 linker script because we don't want to define the symbol if we
2921 are not creating a global offset table. */
2922 bh = NULL;
2923 if (! (_bfd_generic_link_add_one_symbol
2924 (info, abfd, "_GLOBAL_OFFSET_TABLE_", BSF_GLOBAL, s,
2925 0, NULL, FALSE, get_elf_backend_data (abfd)->collect, &bh)))
2926 return FALSE;
2927
2928 h = (struct elf_link_hash_entry *) bh;
2929 h->elf_link_hash_flags &= ~ELF_LINK_NON_ELF;
2930 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
2931 h->type = STT_OBJECT;
2932
2933 if (info->shared
2934 && ! bfd_elf_link_record_dynamic_symbol (info, h))
2935 return FALSE;
2936
2937 amt = sizeof (struct mips_got_info);
2938 g = bfd_alloc (abfd, amt);
2939 if (g == NULL)
2940 return FALSE;
2941 g->global_gotsym = NULL;
2942 g->global_gotno = 0;
2943 g->local_gotno = MIPS_RESERVED_GOTNO;
2944 g->assigned_gotno = MIPS_RESERVED_GOTNO;
2945 g->bfd2got = NULL;
2946 g->next = NULL;
2947 g->got_entries = htab_try_create (1, mips_elf_got_entry_hash,
2948 mips_elf_got_entry_eq, NULL);
2949 if (g->got_entries == NULL)
2950 return FALSE;
2951 mips_elf_section_data (s)->u.got_info = g;
2952 mips_elf_section_data (s)->elf.this_hdr.sh_flags
2953 |= SHF_ALLOC | SHF_WRITE | SHF_MIPS_GPREL;
2954
2955 return TRUE;
2956 }
2957 \f
2958 /* Calculate the value produced by the RELOCATION (which comes from
2959 the INPUT_BFD). The ADDEND is the addend to use for this
2960 RELOCATION; RELOCATION->R_ADDEND is ignored.
2961
2962 The result of the relocation calculation is stored in VALUEP.
2963 REQUIRE_JALXP indicates whether or not the opcode used with this
2964 relocation must be JALX.
2965
2966 This function returns bfd_reloc_continue if the caller need take no
2967 further action regarding this relocation, bfd_reloc_notsupported if
2968 something goes dramatically wrong, bfd_reloc_overflow if an
2969 overflow occurs, and bfd_reloc_ok to indicate success. */
2970
2971 static bfd_reloc_status_type
2972 mips_elf_calculate_relocation (bfd *abfd, bfd *input_bfd,
2973 asection *input_section,
2974 struct bfd_link_info *info,
2975 const Elf_Internal_Rela *relocation,
2976 bfd_vma addend, reloc_howto_type *howto,
2977 Elf_Internal_Sym *local_syms,
2978 asection **local_sections, bfd_vma *valuep,
2979 const char **namep, bfd_boolean *require_jalxp,
2980 bfd_boolean save_addend)
2981 {
2982 /* The eventual value we will return. */
2983 bfd_vma value;
2984 /* The address of the symbol against which the relocation is
2985 occurring. */
2986 bfd_vma symbol = 0;
2987 /* The final GP value to be used for the relocatable, executable, or
2988 shared object file being produced. */
2989 bfd_vma gp = MINUS_ONE;
2990 /* The place (section offset or address) of the storage unit being
2991 relocated. */
2992 bfd_vma p;
2993 /* The value of GP used to create the relocatable object. */
2994 bfd_vma gp0 = MINUS_ONE;
2995 /* The offset into the global offset table at which the address of
2996 the relocation entry symbol, adjusted by the addend, resides
2997 during execution. */
2998 bfd_vma g = MINUS_ONE;
2999 /* The section in which the symbol referenced by the relocation is
3000 located. */
3001 asection *sec = NULL;
3002 struct mips_elf_link_hash_entry *h = NULL;
3003 /* TRUE if the symbol referred to by this relocation is a local
3004 symbol. */
3005 bfd_boolean local_p, was_local_p;
3006 /* TRUE if the symbol referred to by this relocation is "_gp_disp". */
3007 bfd_boolean gp_disp_p = FALSE;
3008 Elf_Internal_Shdr *symtab_hdr;
3009 size_t extsymoff;
3010 unsigned long r_symndx;
3011 int r_type;
3012 /* TRUE if overflow occurred during the calculation of the
3013 relocation value. */
3014 bfd_boolean overflowed_p;
3015 /* TRUE if this relocation refers to a MIPS16 function. */
3016 bfd_boolean target_is_16_bit_code_p = FALSE;
3017
3018 /* Parse the relocation. */
3019 r_symndx = ELF_R_SYM (input_bfd, relocation->r_info);
3020 r_type = ELF_R_TYPE (input_bfd, relocation->r_info);
3021 p = (input_section->output_section->vma
3022 + input_section->output_offset
3023 + relocation->r_offset);
3024
3025 /* Assume that there will be no overflow. */
3026 overflowed_p = FALSE;
3027
3028 /* Figure out whether or not the symbol is local, and get the offset
3029 used in the array of hash table entries. */
3030 symtab_hdr = &elf_tdata (input_bfd)->symtab_hdr;
3031 local_p = mips_elf_local_relocation_p (input_bfd, relocation,
3032 local_sections, FALSE);
3033 was_local_p = local_p;
3034 if (! elf_bad_symtab (input_bfd))
3035 extsymoff = symtab_hdr->sh_info;
3036 else
3037 {
3038 /* The symbol table does not follow the rule that local symbols
3039 must come before globals. */
3040 extsymoff = 0;
3041 }
3042
3043 /* Figure out the value of the symbol. */
3044 if (local_p)
3045 {
3046 Elf_Internal_Sym *sym;
3047
3048 sym = local_syms + r_symndx;
3049 sec = local_sections[r_symndx];
3050
3051 symbol = sec->output_section->vma + sec->output_offset;
3052 if (ELF_ST_TYPE (sym->st_info) != STT_SECTION
3053 || (sec->flags & SEC_MERGE))
3054 symbol += sym->st_value;
3055 if ((sec->flags & SEC_MERGE)
3056 && ELF_ST_TYPE (sym->st_info) == STT_SECTION)
3057 {
3058 addend = _bfd_elf_rel_local_sym (abfd, sym, &sec, addend);
3059 addend -= symbol;
3060 addend += sec->output_section->vma + sec->output_offset;
3061 }
3062
3063 /* MIPS16 text labels should be treated as odd. */
3064 if (sym->st_other == STO_MIPS16)
3065 ++symbol;
3066
3067 /* Record the name of this symbol, for our caller. */
3068 *namep = bfd_elf_string_from_elf_section (input_bfd,
3069 symtab_hdr->sh_link,
3070 sym->st_name);
3071 if (*namep == '\0')
3072 *namep = bfd_section_name (input_bfd, sec);
3073
3074 target_is_16_bit_code_p = (sym->st_other == STO_MIPS16);
3075 }
3076 else
3077 {
3078 /* ??? Could we use RELOC_FOR_GLOBAL_SYMBOL here ? */
3079
3080 /* For global symbols we look up the symbol in the hash-table. */
3081 h = ((struct mips_elf_link_hash_entry *)
3082 elf_sym_hashes (input_bfd) [r_symndx - extsymoff]);
3083 /* Find the real hash-table entry for this symbol. */
3084 while (h->root.root.type == bfd_link_hash_indirect
3085 || h->root.root.type == bfd_link_hash_warning)
3086 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
3087
3088 /* Record the name of this symbol, for our caller. */
3089 *namep = h->root.root.root.string;
3090
3091 /* See if this is the special _gp_disp symbol. Note that such a
3092 symbol must always be a global symbol. */
3093 if (strcmp (*namep, "_gp_disp") == 0
3094 && ! NEWABI_P (input_bfd))
3095 {
3096 /* Relocations against _gp_disp are permitted only with
3097 R_MIPS_HI16 and R_MIPS_LO16 relocations. */
3098 if (r_type != R_MIPS_HI16 && r_type != R_MIPS_LO16)
3099 return bfd_reloc_notsupported;
3100
3101 gp_disp_p = TRUE;
3102 }
3103 /* If this symbol is defined, calculate its address. Note that
3104 _gp_disp is a magic symbol, always implicitly defined by the
3105 linker, so it's inappropriate to check to see whether or not
3106 its defined. */
3107 else if ((h->root.root.type == bfd_link_hash_defined
3108 || h->root.root.type == bfd_link_hash_defweak)
3109 && h->root.root.u.def.section)
3110 {
3111 sec = h->root.root.u.def.section;
3112 if (sec->output_section)
3113 symbol = (h->root.root.u.def.value
3114 + sec->output_section->vma
3115 + sec->output_offset);
3116 else
3117 symbol = h->root.root.u.def.value;
3118 }
3119 else if (h->root.root.type == bfd_link_hash_undefweak)
3120 /* We allow relocations against undefined weak symbols, giving
3121 it the value zero, so that you can undefined weak functions
3122 and check to see if they exist by looking at their
3123 addresses. */
3124 symbol = 0;
3125 else if (info->unresolved_syms_in_objects == RM_IGNORE
3126 && ELF_ST_VISIBILITY (h->root.other) == STV_DEFAULT)
3127 symbol = 0;
3128 else if (strcmp (*namep, "_DYNAMIC_LINK") == 0 ||
3129 strcmp (*namep, "_DYNAMIC_LINKING") == 0)
3130 {
3131 /* If this is a dynamic link, we should have created a
3132 _DYNAMIC_LINK symbol or _DYNAMIC_LINKING(for normal mips) symbol
3133 in in _bfd_mips_elf_create_dynamic_sections.
3134 Otherwise, we should define the symbol with a value of 0.
3135 FIXME: It should probably get into the symbol table
3136 somehow as well. */
3137 BFD_ASSERT (! info->shared);
3138 BFD_ASSERT (bfd_get_section_by_name (abfd, ".dynamic") == NULL);
3139 symbol = 0;
3140 }
3141 else
3142 {
3143 if (! ((*info->callbacks->undefined_symbol)
3144 (info, h->root.root.root.string, input_bfd,
3145 input_section, relocation->r_offset,
3146 (info->unresolved_syms_in_objects == RM_GENERATE_ERROR)
3147 || ELF_ST_VISIBILITY (h->root.other))))
3148 return bfd_reloc_undefined;
3149 symbol = 0;
3150 }
3151
3152 target_is_16_bit_code_p = (h->root.other == STO_MIPS16);
3153 }
3154
3155 /* If this is a 32- or 64-bit call to a 16-bit function with a stub, we
3156 need to redirect the call to the stub, unless we're already *in*
3157 a stub. */
3158 if (r_type != R_MIPS16_26 && !info->relocatable
3159 && ((h != NULL && h->fn_stub != NULL)
3160 || (local_p && elf_tdata (input_bfd)->local_stubs != NULL
3161 && elf_tdata (input_bfd)->local_stubs[r_symndx] != NULL))
3162 && !mips_elf_stub_section_p (input_bfd, input_section))
3163 {
3164 /* This is a 32- or 64-bit call to a 16-bit function. We should
3165 have already noticed that we were going to need the
3166 stub. */
3167 if (local_p)
3168 sec = elf_tdata (input_bfd)->local_stubs[r_symndx];
3169 else
3170 {
3171 BFD_ASSERT (h->need_fn_stub);
3172 sec = h->fn_stub;
3173 }
3174
3175 symbol = sec->output_section->vma + sec->output_offset;
3176 }
3177 /* If this is a 16-bit call to a 32- or 64-bit function with a stub, we
3178 need to redirect the call to the stub. */
3179 else if (r_type == R_MIPS16_26 && !info->relocatable
3180 && h != NULL
3181 && (h->call_stub != NULL || h->call_fp_stub != NULL)
3182 && !target_is_16_bit_code_p)
3183 {
3184 /* If both call_stub and call_fp_stub are defined, we can figure
3185 out which one to use by seeing which one appears in the input
3186 file. */
3187 if (h->call_stub != NULL && h->call_fp_stub != NULL)
3188 {
3189 asection *o;
3190
3191 sec = NULL;
3192 for (o = input_bfd->sections; o != NULL; o = o->next)
3193 {
3194 if (strncmp (bfd_get_section_name (input_bfd, o),
3195 CALL_FP_STUB, sizeof CALL_FP_STUB - 1) == 0)
3196 {
3197 sec = h->call_fp_stub;
3198 break;
3199 }
3200 }
3201 if (sec == NULL)
3202 sec = h->call_stub;
3203 }
3204 else if (h->call_stub != NULL)
3205 sec = h->call_stub;
3206 else
3207 sec = h->call_fp_stub;
3208
3209 BFD_ASSERT (sec->_raw_size > 0);
3210 symbol = sec->output_section->vma + sec->output_offset;
3211 }
3212
3213 /* Calls from 16-bit code to 32-bit code and vice versa require the
3214 special jalx instruction. */
3215 *require_jalxp = (!info->relocatable
3216 && (((r_type == R_MIPS16_26) && !target_is_16_bit_code_p)
3217 || ((r_type == R_MIPS_26) && target_is_16_bit_code_p)));
3218
3219 local_p = mips_elf_local_relocation_p (input_bfd, relocation,
3220 local_sections, TRUE);
3221
3222 /* If we haven't already determined the GOT offset, or the GP value,
3223 and we're going to need it, get it now. */
3224 switch (r_type)
3225 {
3226 case R_MIPS_GOT_PAGE:
3227 case R_MIPS_GOT_OFST:
3228 /* We need to decay to GOT_DISP/addend if the symbol doesn't
3229 bind locally. */
3230 local_p = local_p || _bfd_elf_symbol_refs_local_p (&h->root, info, 1);
3231 if (local_p || r_type == R_MIPS_GOT_OFST)
3232 break;
3233 /* Fall through. */
3234
3235 case R_MIPS_CALL16:
3236 case R_MIPS_GOT16:
3237 case R_MIPS_GOT_DISP:
3238 case R_MIPS_GOT_HI16:
3239 case R_MIPS_CALL_HI16:
3240 case R_MIPS_GOT_LO16:
3241 case R_MIPS_CALL_LO16:
3242 /* Find the index into the GOT where this value is located. */
3243 if (!local_p)
3244 {
3245 /* GOT_PAGE may take a non-zero addend, that is ignored in a
3246 GOT_PAGE relocation that decays to GOT_DISP because the
3247 symbol turns out to be global. The addend is then added
3248 as GOT_OFST. */
3249 BFD_ASSERT (addend == 0 || r_type == R_MIPS_GOT_PAGE);
3250 g = mips_elf_global_got_index (elf_hash_table (info)->dynobj,
3251 input_bfd,
3252 (struct elf_link_hash_entry *) h);
3253 if (! elf_hash_table(info)->dynamic_sections_created
3254 || (info->shared
3255 && (info->symbolic || h->root.dynindx == -1)
3256 && (h->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR)))
3257 {
3258 /* This is a static link or a -Bsymbolic link. The
3259 symbol is defined locally, or was forced to be local.
3260 We must initialize this entry in the GOT. */
3261 bfd *tmpbfd = elf_hash_table (info)->dynobj;
3262 asection *sgot = mips_elf_got_section (tmpbfd, FALSE);
3263 MIPS_ELF_PUT_WORD (tmpbfd, symbol, sgot->contents + g);
3264 }
3265 }
3266 else if (r_type == R_MIPS_GOT16 || r_type == R_MIPS_CALL16)
3267 /* There's no need to create a local GOT entry here; the
3268 calculation for a local GOT16 entry does not involve G. */
3269 break;
3270 else
3271 {
3272 g = mips_elf_local_got_index (abfd, input_bfd,
3273 info, symbol + addend);
3274 if (g == MINUS_ONE)
3275 return bfd_reloc_outofrange;
3276 }
3277
3278 /* Convert GOT indices to actual offsets. */
3279 g = mips_elf_got_offset_from_index (elf_hash_table (info)->dynobj,
3280 abfd, input_bfd, g);
3281 break;
3282
3283 case R_MIPS_HI16:
3284 case R_MIPS_LO16:
3285 case R_MIPS16_GPREL:
3286 case R_MIPS_GPREL16:
3287 case R_MIPS_GPREL32:
3288 case R_MIPS_LITERAL:
3289 gp0 = _bfd_get_gp_value (input_bfd);
3290 gp = _bfd_get_gp_value (abfd);
3291 if (elf_hash_table (info)->dynobj)
3292 gp += mips_elf_adjust_gp (abfd,
3293 mips_elf_got_info
3294 (elf_hash_table (info)->dynobj, NULL),
3295 input_bfd);
3296 break;
3297
3298 default:
3299 break;
3300 }
3301
3302 /* Figure out what kind of relocation is being performed. */
3303 switch (r_type)
3304 {
3305 case R_MIPS_NONE:
3306 return bfd_reloc_continue;
3307
3308 case R_MIPS_16:
3309 value = symbol + _bfd_mips_elf_sign_extend (addend, 16);
3310 overflowed_p = mips_elf_overflow_p (value, 16);
3311 break;
3312
3313 case R_MIPS_32:
3314 case R_MIPS_REL32:
3315 case R_MIPS_64:
3316 if ((info->shared
3317 || (elf_hash_table (info)->dynamic_sections_created
3318 && h != NULL
3319 && ((h->root.elf_link_hash_flags
3320 & ELF_LINK_HASH_DEF_DYNAMIC) != 0)
3321 && ((h->root.elf_link_hash_flags
3322 & ELF_LINK_HASH_DEF_REGULAR) == 0)))
3323 && r_symndx != 0
3324 && (input_section->flags & SEC_ALLOC) != 0)
3325 {
3326 /* If we're creating a shared library, or this relocation is
3327 against a symbol in a shared library, then we can't know
3328 where the symbol will end up. So, we create a relocation
3329 record in the output, and leave the job up to the dynamic
3330 linker. */
3331 value = addend;
3332 if (!mips_elf_create_dynamic_relocation (abfd,
3333 info,
3334 relocation,
3335 h,
3336 sec,
3337 symbol,
3338 &value,
3339 input_section))
3340 return bfd_reloc_undefined;
3341 }
3342 else
3343 {
3344 if (r_type != R_MIPS_REL32)
3345 value = symbol + addend;
3346 else
3347 value = addend;
3348 }
3349 value &= howto->dst_mask;
3350 break;
3351
3352 case R_MIPS_PC32:
3353 case R_MIPS_PC64:
3354 case R_MIPS_GNU_REL_LO16:
3355 value = symbol + addend - p;
3356 value &= howto->dst_mask;
3357 break;
3358
3359 case R_MIPS_GNU_REL16_S2:
3360 value = symbol + _bfd_mips_elf_sign_extend (addend, 18) - p;
3361 overflowed_p = mips_elf_overflow_p (value, 18);
3362 value = (value >> 2) & howto->dst_mask;
3363 break;
3364
3365 case R_MIPS_GNU_REL_HI16:
3366 /* Instead of subtracting 'p' here, we should be subtracting the
3367 equivalent value for the LO part of the reloc, since the value
3368 here is relative to that address. Because that's not easy to do,
3369 we adjust 'addend' in _bfd_mips_elf_relocate_section(). See also
3370 the comment there for more information. */
3371 value = mips_elf_high (addend + symbol - p);
3372 value &= howto->dst_mask;
3373 break;
3374
3375 case R_MIPS16_26:
3376 /* The calculation for R_MIPS16_26 is just the same as for an
3377 R_MIPS_26. It's only the storage of the relocated field into
3378 the output file that's different. That's handled in
3379 mips_elf_perform_relocation. So, we just fall through to the
3380 R_MIPS_26 case here. */
3381 case R_MIPS_26:
3382 if (local_p)
3383 value = ((addend | ((p + 4) & 0xf0000000)) + symbol) >> 2;
3384 else
3385 value = (_bfd_mips_elf_sign_extend (addend, 28) + symbol) >> 2;
3386 value &= howto->dst_mask;
3387 break;
3388
3389 case R_MIPS_HI16:
3390 if (!gp_disp_p)
3391 {
3392 value = mips_elf_high (addend + symbol);
3393 value &= howto->dst_mask;
3394 }
3395 else
3396 {
3397 value = mips_elf_high (addend + gp - p);
3398 overflowed_p = mips_elf_overflow_p (value, 16);
3399 }
3400 break;
3401
3402 case R_MIPS_LO16:
3403 if (!gp_disp_p)
3404 value = (symbol + addend) & howto->dst_mask;
3405 else
3406 {
3407 value = addend + gp - p + 4;
3408 /* The MIPS ABI requires checking the R_MIPS_LO16 relocation
3409 for overflow. But, on, say, IRIX5, relocations against
3410 _gp_disp are normally generated from the .cpload
3411 pseudo-op. It generates code that normally looks like
3412 this:
3413
3414 lui $gp,%hi(_gp_disp)
3415 addiu $gp,$gp,%lo(_gp_disp)
3416 addu $gp,$gp,$t9
3417
3418 Here $t9 holds the address of the function being called,
3419 as required by the MIPS ELF ABI. The R_MIPS_LO16
3420 relocation can easily overflow in this situation, but the
3421 R_MIPS_HI16 relocation will handle the overflow.
3422 Therefore, we consider this a bug in the MIPS ABI, and do
3423 not check for overflow here. */
3424 }
3425 break;
3426
3427 case R_MIPS_LITERAL:
3428 /* Because we don't merge literal sections, we can handle this
3429 just like R_MIPS_GPREL16. In the long run, we should merge
3430 shared literals, and then we will need to additional work
3431 here. */
3432
3433 /* Fall through. */
3434
3435 case R_MIPS16_GPREL:
3436 /* The R_MIPS16_GPREL performs the same calculation as
3437 R_MIPS_GPREL16, but stores the relocated bits in a different
3438 order. We don't need to do anything special here; the
3439 differences are handled in mips_elf_perform_relocation. */
3440 case R_MIPS_GPREL16:
3441 /* Only sign-extend the addend if it was extracted from the
3442 instruction. If the addend was separate, leave it alone,
3443 otherwise we may lose significant bits. */
3444 if (howto->partial_inplace)
3445 addend = _bfd_mips_elf_sign_extend (addend, 16);
3446 value = symbol + addend - gp;
3447 /* If the symbol was local, any earlier relocatable links will
3448 have adjusted its addend with the gp offset, so compensate
3449 for that now. Don't do it for symbols forced local in this
3450 link, though, since they won't have had the gp offset applied
3451 to them before. */
3452 if (was_local_p)
3453 value += gp0;
3454 overflowed_p = mips_elf_overflow_p (value, 16);
3455 break;
3456
3457 case R_MIPS_GOT16:
3458 case R_MIPS_CALL16:
3459 if (local_p)
3460 {
3461 bfd_boolean forced;
3462
3463 /* The special case is when the symbol is forced to be local. We
3464 need the full address in the GOT since no R_MIPS_LO16 relocation
3465 follows. */
3466 forced = ! mips_elf_local_relocation_p (input_bfd, relocation,
3467 local_sections, FALSE);
3468 value = mips_elf_got16_entry (abfd, input_bfd, info,
3469 symbol + addend, forced);
3470 if (value == MINUS_ONE)
3471 return bfd_reloc_outofrange;
3472 value
3473 = mips_elf_got_offset_from_index (elf_hash_table (info)->dynobj,
3474 abfd, input_bfd, value);
3475 overflowed_p = mips_elf_overflow_p (value, 16);
3476 break;
3477 }
3478
3479 /* Fall through. */
3480
3481 case R_MIPS_GOT_DISP:
3482 got_disp:
3483 value = g;
3484 overflowed_p = mips_elf_overflow_p (value, 16);
3485 break;
3486
3487 case R_MIPS_GPREL32:
3488 value = (addend + symbol + gp0 - gp);
3489 if (!save_addend)
3490 value &= howto->dst_mask;
3491 break;
3492
3493 case R_MIPS_PC16:
3494 value = _bfd_mips_elf_sign_extend (addend, 16) + symbol - p;
3495 overflowed_p = mips_elf_overflow_p (value, 16);
3496 break;
3497
3498 case R_MIPS_GOT_HI16:
3499 case R_MIPS_CALL_HI16:
3500 /* We're allowed to handle these two relocations identically.
3501 The dynamic linker is allowed to handle the CALL relocations
3502 differently by creating a lazy evaluation stub. */
3503 value = g;
3504 value = mips_elf_high (value);
3505 value &= howto->dst_mask;
3506 break;
3507
3508 case R_MIPS_GOT_LO16:
3509 case R_MIPS_CALL_LO16:
3510 value = g & howto->dst_mask;
3511 break;
3512
3513 case R_MIPS_GOT_PAGE:
3514 /* GOT_PAGE relocations that reference non-local symbols decay
3515 to GOT_DISP. The corresponding GOT_OFST relocation decays to
3516 0. */
3517 if (! local_p)
3518 goto got_disp;
3519 value = mips_elf_got_page (abfd, input_bfd, info, symbol + addend, NULL);
3520 if (value == MINUS_ONE)
3521 return bfd_reloc_outofrange;
3522 value = mips_elf_got_offset_from_index (elf_hash_table (info)->dynobj,
3523 abfd, input_bfd, value);
3524 overflowed_p = mips_elf_overflow_p (value, 16);
3525 break;
3526
3527 case R_MIPS_GOT_OFST:
3528 if (local_p)
3529 mips_elf_got_page (abfd, input_bfd, info, symbol + addend, &value);
3530 else
3531 value = addend;
3532 overflowed_p = mips_elf_overflow_p (value, 16);
3533 break;
3534
3535 case R_MIPS_SUB:
3536 value = symbol - addend;
3537 value &= howto->dst_mask;
3538 break;
3539
3540 case R_MIPS_HIGHER:
3541 value = mips_elf_higher (addend + symbol);
3542 value &= howto->dst_mask;
3543 break;
3544
3545 case R_MIPS_HIGHEST:
3546 value = mips_elf_highest (addend + symbol);
3547 value &= howto->dst_mask;
3548 break;
3549
3550 case R_MIPS_SCN_DISP:
3551 value = symbol + addend - sec->output_offset;
3552 value &= howto->dst_mask;
3553 break;
3554
3555 case R_MIPS_PJUMP:
3556 case R_MIPS_JALR:
3557 /* Both of these may be ignored. R_MIPS_JALR is an optimization
3558 hint; we could improve performance by honoring that hint. */
3559 return bfd_reloc_continue;
3560
3561 case R_MIPS_GNU_VTINHERIT:
3562 case R_MIPS_GNU_VTENTRY:
3563 /* We don't do anything with these at present. */
3564 return bfd_reloc_continue;
3565
3566 default:
3567 /* An unrecognized relocation type. */
3568 return bfd_reloc_notsupported;
3569 }
3570
3571 /* Store the VALUE for our caller. */
3572 *valuep = value;
3573 return overflowed_p ? bfd_reloc_overflow : bfd_reloc_ok;
3574 }
3575
3576 /* Obtain the field relocated by RELOCATION. */
3577
3578 static bfd_vma
3579 mips_elf_obtain_contents (reloc_howto_type *howto,
3580 const Elf_Internal_Rela *relocation,
3581 bfd *input_bfd, bfd_byte *contents)
3582 {
3583 bfd_vma x;
3584 bfd_byte *location = contents + relocation->r_offset;
3585
3586 /* Obtain the bytes. */
3587 x = bfd_get ((8 * bfd_get_reloc_size (howto)), input_bfd, location);
3588
3589 if ((ELF_R_TYPE (input_bfd, relocation->r_info) == R_MIPS16_26
3590 || ELF_R_TYPE (input_bfd, relocation->r_info) == R_MIPS16_GPREL)
3591 && bfd_little_endian (input_bfd))
3592 /* The two 16-bit words will be reversed on a little-endian system.
3593 See mips_elf_perform_relocation for more details. */
3594 x = (((x & 0xffff) << 16) | ((x & 0xffff0000) >> 16));
3595
3596 return x;
3597 }
3598
3599 /* It has been determined that the result of the RELOCATION is the
3600 VALUE. Use HOWTO to place VALUE into the output file at the
3601 appropriate position. The SECTION is the section to which the
3602 relocation applies. If REQUIRE_JALX is TRUE, then the opcode used
3603 for the relocation must be either JAL or JALX, and it is
3604 unconditionally converted to JALX.
3605
3606 Returns FALSE if anything goes wrong. */
3607
3608 static bfd_boolean
3609 mips_elf_perform_relocation (struct bfd_link_info *info,
3610 reloc_howto_type *howto,
3611 const Elf_Internal_Rela *relocation,
3612 bfd_vma value, bfd *input_bfd,
3613 asection *input_section, bfd_byte *contents,
3614 bfd_boolean require_jalx)
3615 {
3616 bfd_vma x;
3617 bfd_byte *location;
3618 int r_type = ELF_R_TYPE (input_bfd, relocation->r_info);
3619
3620 /* Figure out where the relocation is occurring. */
3621 location = contents + relocation->r_offset;
3622
3623 /* Obtain the current value. */
3624 x = mips_elf_obtain_contents (howto, relocation, input_bfd, contents);
3625
3626 /* Clear the field we are setting. */
3627 x &= ~howto->dst_mask;
3628
3629 /* If this is the R_MIPS16_26 relocation, we must store the
3630 value in a funny way. */
3631 if (r_type == R_MIPS16_26)
3632 {
3633 /* R_MIPS16_26 is used for the mips16 jal and jalx instructions.
3634 Most mips16 instructions are 16 bits, but these instructions
3635 are 32 bits.
3636
3637 The format of these instructions is:
3638
3639 +--------------+--------------------------------+
3640 ! JALX ! X! Imm 20:16 ! Imm 25:21 !
3641 +--------------+--------------------------------+
3642 ! Immediate 15:0 !
3643 +-----------------------------------------------+
3644
3645 JALX is the 5-bit value 00011. X is 0 for jal, 1 for jalx.
3646 Note that the immediate value in the first word is swapped.
3647
3648 When producing a relocatable object file, R_MIPS16_26 is
3649 handled mostly like R_MIPS_26. In particular, the addend is
3650 stored as a straight 26-bit value in a 32-bit instruction.
3651 (gas makes life simpler for itself by never adjusting a
3652 R_MIPS16_26 reloc to be against a section, so the addend is
3653 always zero). However, the 32 bit instruction is stored as 2
3654 16-bit values, rather than a single 32-bit value. In a
3655 big-endian file, the result is the same; in a little-endian
3656 file, the two 16-bit halves of the 32 bit value are swapped.
3657 This is so that a disassembler can recognize the jal
3658 instruction.
3659
3660 When doing a final link, R_MIPS16_26 is treated as a 32 bit
3661 instruction stored as two 16-bit values. The addend A is the
3662 contents of the targ26 field. The calculation is the same as
3663 R_MIPS_26. When storing the calculated value, reorder the
3664 immediate value as shown above, and don't forget to store the
3665 value as two 16-bit values.
3666
3667 To put it in MIPS ABI terms, the relocation field is T-targ26-16,
3668 defined as
3669
3670 big-endian:
3671 +--------+----------------------+
3672 | | |
3673 | | targ26-16 |
3674 |31 26|25 0|
3675 +--------+----------------------+
3676
3677 little-endian:
3678 +----------+------+-------------+
3679 | | | |
3680 | sub1 | | sub2 |
3681 |0 9|10 15|16 31|
3682 +----------+--------------------+
3683 where targ26-16 is sub1 followed by sub2 (i.e., the addend field A is
3684 ((sub1 << 16) | sub2)).
3685
3686 When producing a relocatable object file, the calculation is
3687 (((A < 2) | ((P + 4) & 0xf0000000) + S) >> 2)
3688 When producing a fully linked file, the calculation is
3689 let R = (((A < 2) | ((P + 4) & 0xf0000000) + S) >> 2)
3690 ((R & 0x1f0000) << 5) | ((R & 0x3e00000) >> 5) | (R & 0xffff) */
3691
3692 if (!info->relocatable)
3693 /* Shuffle the bits according to the formula above. */
3694 value = (((value & 0x1f0000) << 5)
3695 | ((value & 0x3e00000) >> 5)
3696 | (value & 0xffff));
3697 }
3698 else if (r_type == R_MIPS16_GPREL)
3699 {
3700 /* R_MIPS16_GPREL is used for GP-relative addressing in mips16
3701 mode. A typical instruction will have a format like this:
3702
3703 +--------------+--------------------------------+
3704 ! EXTEND ! Imm 10:5 ! Imm 15:11 !
3705 +--------------+--------------------------------+
3706 ! Major ! rx ! ry ! Imm 4:0 !
3707 +--------------+--------------------------------+
3708
3709 EXTEND is the five bit value 11110. Major is the instruction
3710 opcode.
3711
3712 This is handled exactly like R_MIPS_GPREL16, except that the
3713 addend is retrieved and stored as shown in this diagram; that
3714 is, the Imm fields above replace the V-rel16 field.
3715
3716 All we need to do here is shuffle the bits appropriately. As
3717 above, the two 16-bit halves must be swapped on a
3718 little-endian system. */
3719 value = (((value & 0x7e0) << 16)
3720 | ((value & 0xf800) << 5)
3721 | (value & 0x1f));
3722 }
3723
3724 /* Set the field. */
3725 x |= (value & howto->dst_mask);
3726
3727 /* If required, turn JAL into JALX. */
3728 if (require_jalx)
3729 {
3730 bfd_boolean ok;
3731 bfd_vma opcode = x >> 26;
3732 bfd_vma jalx_opcode;
3733
3734 /* Check to see if the opcode is already JAL or JALX. */
3735 if (r_type == R_MIPS16_26)
3736 {
3737 ok = ((opcode == 0x6) || (opcode == 0x7));
3738 jalx_opcode = 0x7;
3739 }
3740 else
3741 {
3742 ok = ((opcode == 0x3) || (opcode == 0x1d));
3743 jalx_opcode = 0x1d;
3744 }
3745
3746 /* If the opcode is not JAL or JALX, there's a problem. */
3747 if (!ok)
3748 {
3749 (*_bfd_error_handler)
3750 (_("%s: %s+0x%lx: jump to stub routine which is not jal"),
3751 bfd_archive_filename (input_bfd),
3752 input_section->name,
3753 (unsigned long) relocation->r_offset);
3754 bfd_set_error (bfd_error_bad_value);
3755 return FALSE;
3756 }
3757
3758 /* Make this the JALX opcode. */
3759 x = (x & ~(0x3f << 26)) | (jalx_opcode << 26);
3760 }
3761
3762 /* Swap the high- and low-order 16 bits on little-endian systems
3763 when doing a MIPS16 relocation. */
3764 if ((r_type == R_MIPS16_GPREL || r_type == R_MIPS16_26)
3765 && bfd_little_endian (input_bfd))
3766 x = (((x & 0xffff) << 16) | ((x & 0xffff0000) >> 16));
3767
3768 /* Put the value into the output. */
3769 bfd_put (8 * bfd_get_reloc_size (howto), input_bfd, x, location);
3770 return TRUE;
3771 }
3772
3773 /* Returns TRUE if SECTION is a MIPS16 stub section. */
3774
3775 static bfd_boolean
3776 mips_elf_stub_section_p (bfd *abfd ATTRIBUTE_UNUSED, asection *section)
3777 {
3778 const char *name = bfd_get_section_name (abfd, section);
3779
3780 return (strncmp (name, FN_STUB, sizeof FN_STUB - 1) == 0
3781 || strncmp (name, CALL_STUB, sizeof CALL_STUB - 1) == 0
3782 || strncmp (name, CALL_FP_STUB, sizeof CALL_FP_STUB - 1) == 0);
3783 }
3784 \f
3785 /* Add room for N relocations to the .rel.dyn section in ABFD. */
3786
3787 static void
3788 mips_elf_allocate_dynamic_relocations (bfd *abfd, unsigned int n)
3789 {
3790 asection *s;
3791
3792 s = mips_elf_rel_dyn_section (abfd, FALSE);
3793 BFD_ASSERT (s != NULL);
3794
3795 if (s->_raw_size == 0)
3796 {
3797 /* Make room for a null element. */
3798 s->_raw_size += MIPS_ELF_REL_SIZE (abfd);
3799 ++s->reloc_count;
3800 }
3801 s->_raw_size += n * MIPS_ELF_REL_SIZE (abfd);
3802 }
3803
3804 /* Create a rel.dyn relocation for the dynamic linker to resolve. REL
3805 is the original relocation, which is now being transformed into a
3806 dynamic relocation. The ADDENDP is adjusted if necessary; the
3807 caller should store the result in place of the original addend. */
3808
3809 static bfd_boolean
3810 mips_elf_create_dynamic_relocation (bfd *output_bfd,
3811 struct bfd_link_info *info,
3812 const Elf_Internal_Rela *rel,
3813 struct mips_elf_link_hash_entry *h,
3814 asection *sec, bfd_vma symbol,
3815 bfd_vma *addendp, asection *input_section)
3816 {
3817 Elf_Internal_Rela outrel[3];
3818 bfd_boolean skip;
3819 asection *sreloc;
3820 bfd *dynobj;
3821 int r_type;
3822
3823 r_type = ELF_R_TYPE (output_bfd, rel->r_info);
3824 dynobj = elf_hash_table (info)->dynobj;
3825 sreloc = mips_elf_rel_dyn_section (dynobj, FALSE);
3826 BFD_ASSERT (sreloc != NULL);
3827 BFD_ASSERT (sreloc->contents != NULL);
3828 BFD_ASSERT (sreloc->reloc_count * MIPS_ELF_REL_SIZE (output_bfd)
3829 < sreloc->_raw_size);
3830
3831 skip = FALSE;
3832 outrel[0].r_offset =
3833 _bfd_elf_section_offset (output_bfd, info, input_section, rel[0].r_offset);
3834 outrel[1].r_offset =
3835 _bfd_elf_section_offset (output_bfd, info, input_section, rel[1].r_offset);
3836 outrel[2].r_offset =
3837 _bfd_elf_section_offset (output_bfd, info, input_section, rel[2].r_offset);
3838
3839 #if 0
3840 /* We begin by assuming that the offset for the dynamic relocation
3841 is the same as for the original relocation. We'll adjust this
3842 later to reflect the correct output offsets. */
3843 if (input_section->sec_info_type != ELF_INFO_TYPE_STABS)
3844 {
3845 outrel[1].r_offset = rel[1].r_offset;
3846 outrel[2].r_offset = rel[2].r_offset;
3847 }
3848 else
3849 {
3850 /* Except that in a stab section things are more complex.
3851 Because we compress stab information, the offset given in the
3852 relocation may not be the one we want; we must let the stabs
3853 machinery tell us the offset. */
3854 outrel[1].r_offset = outrel[0].r_offset;
3855 outrel[2].r_offset = outrel[0].r_offset;
3856 /* If we didn't need the relocation at all, this value will be
3857 -1. */
3858 if (outrel[0].r_offset == (bfd_vma) -1)
3859 skip = TRUE;
3860 }
3861 #endif
3862
3863 if (outrel[0].r_offset == (bfd_vma) -1)
3864 /* The relocation field has been deleted. */
3865 skip = TRUE;
3866 else if (outrel[0].r_offset == (bfd_vma) -2)
3867 {
3868 /* The relocation field has been converted into a relative value of
3869 some sort. Functions like _bfd_elf_write_section_eh_frame expect
3870 the field to be fully relocated, so add in the symbol's value. */
3871 skip = TRUE;
3872 *addendp += symbol;
3873 }
3874
3875 /* If we've decided to skip this relocation, just output an empty
3876 record. Note that R_MIPS_NONE == 0, so that this call to memset
3877 is a way of setting R_TYPE to R_MIPS_NONE. */
3878 if (skip)
3879 memset (outrel, 0, sizeof (Elf_Internal_Rela) * 3);
3880 else
3881 {
3882 long indx;
3883 bfd_boolean defined_p;
3884
3885 /* We must now calculate the dynamic symbol table index to use
3886 in the relocation. */
3887 if (h != NULL
3888 && (! info->symbolic || (h->root.elf_link_hash_flags
3889 & ELF_LINK_HASH_DEF_REGULAR) == 0)
3890 /* h->root.dynindx may be -1 if this symbol was marked to
3891 become local. */
3892 && h->root.dynindx != -1)
3893 {
3894 indx = h->root.dynindx;
3895 if (SGI_COMPAT (output_bfd))
3896 defined_p = ((h->root.elf_link_hash_flags
3897 & ELF_LINK_HASH_DEF_REGULAR) != 0);
3898 else
3899 /* ??? glibc's ld.so just adds the final GOT entry to the
3900 relocation field. It therefore treats relocs against
3901 defined symbols in the same way as relocs against
3902 undefined symbols. */
3903 defined_p = FALSE;
3904 }
3905 else
3906 {
3907 if (sec != NULL && bfd_is_abs_section (sec))
3908 indx = 0;
3909 else if (sec == NULL || sec->owner == NULL)
3910 {
3911 bfd_set_error (bfd_error_bad_value);
3912 return FALSE;
3913 }
3914 else
3915 {
3916 indx = elf_section_data (sec->output_section)->dynindx;
3917 if (indx == 0)
3918 abort ();
3919 }
3920
3921 /* Instead of generating a relocation using the section
3922 symbol, we may as well make it a fully relative
3923 relocation. We want to avoid generating relocations to
3924 local symbols because we used to generate them
3925 incorrectly, without adding the original symbol value,
3926 which is mandated by the ABI for section symbols. In
3927 order to give dynamic loaders and applications time to
3928 phase out the incorrect use, we refrain from emitting
3929 section-relative relocations. It's not like they're
3930 useful, after all. This should be a bit more efficient
3931 as well. */
3932 /* ??? Although this behavior is compatible with glibc's ld.so,
3933 the ABI says that relocations against STN_UNDEF should have
3934 a symbol value of 0. Irix rld honors this, so relocations
3935 against STN_UNDEF have no effect. */
3936 if (!SGI_COMPAT (output_bfd))
3937 indx = 0;
3938 defined_p = TRUE;
3939 }
3940
3941 /* If the relocation was previously an absolute relocation and
3942 this symbol will not be referred to by the relocation, we must
3943 adjust it by the value we give it in the dynamic symbol table.
3944 Otherwise leave the job up to the dynamic linker. */
3945 if (defined_p && r_type != R_MIPS_REL32)
3946 *addendp += symbol;
3947
3948 /* The relocation is always an REL32 relocation because we don't
3949 know where the shared library will wind up at load-time. */
3950 outrel[0].r_info = ELF_R_INFO (output_bfd, (unsigned long) indx,
3951 R_MIPS_REL32);
3952 /* For strict adherence to the ABI specification, we should
3953 generate a R_MIPS_64 relocation record by itself before the
3954 _REL32/_64 record as well, such that the addend is read in as
3955 a 64-bit value (REL32 is a 32-bit relocation, after all).
3956 However, since none of the existing ELF64 MIPS dynamic
3957 loaders seems to care, we don't waste space with these
3958 artificial relocations. If this turns out to not be true,
3959 mips_elf_allocate_dynamic_relocation() should be tweaked so
3960 as to make room for a pair of dynamic relocations per
3961 invocation if ABI_64_P, and here we should generate an
3962 additional relocation record with R_MIPS_64 by itself for a
3963 NULL symbol before this relocation record. */
3964 outrel[1].r_info = ELF_R_INFO (output_bfd, 0,
3965 ABI_64_P (output_bfd)
3966 ? R_MIPS_64
3967 : R_MIPS_NONE);
3968 outrel[2].r_info = ELF_R_INFO (output_bfd, 0, R_MIPS_NONE);
3969
3970 /* Adjust the output offset of the relocation to reference the
3971 correct location in the output file. */
3972 outrel[0].r_offset += (input_section->output_section->vma
3973 + input_section->output_offset);
3974 outrel[1].r_offset += (input_section->output_section->vma
3975 + input_section->output_offset);
3976 outrel[2].r_offset += (input_section->output_section->vma
3977 + input_section->output_offset);
3978 }
3979
3980 /* Put the relocation back out. We have to use the special
3981 relocation outputter in the 64-bit case since the 64-bit
3982 relocation format is non-standard. */
3983 if (ABI_64_P (output_bfd))
3984 {
3985 (*get_elf_backend_data (output_bfd)->s->swap_reloc_out)
3986 (output_bfd, &outrel[0],
3987 (sreloc->contents
3988 + sreloc->reloc_count * sizeof (Elf64_Mips_External_Rel)));
3989 }
3990 else
3991 bfd_elf32_swap_reloc_out
3992 (output_bfd, &outrel[0],
3993 (sreloc->contents + sreloc->reloc_count * sizeof (Elf32_External_Rel)));
3994
3995 /* We've now added another relocation. */
3996 ++sreloc->reloc_count;
3997
3998 /* Make sure the output section is writable. The dynamic linker
3999 will be writing to it. */
4000 elf_section_data (input_section->output_section)->this_hdr.sh_flags
4001 |= SHF_WRITE;
4002
4003 /* On IRIX5, make an entry of compact relocation info. */
4004 if (! skip && IRIX_COMPAT (output_bfd) == ict_irix5)
4005 {
4006 asection *scpt = bfd_get_section_by_name (dynobj, ".compact_rel");
4007 bfd_byte *cr;
4008
4009 if (scpt)
4010 {
4011 Elf32_crinfo cptrel;
4012
4013 mips_elf_set_cr_format (cptrel, CRF_MIPS_LONG);
4014 cptrel.vaddr = (rel->r_offset
4015 + input_section->output_section->vma
4016 + input_section->output_offset);
4017 if (r_type == R_MIPS_REL32)
4018 mips_elf_set_cr_type (cptrel, CRT_MIPS_REL32);
4019 else
4020 mips_elf_set_cr_type (cptrel, CRT_MIPS_WORD);
4021 mips_elf_set_cr_dist2to (cptrel, 0);
4022 cptrel.konst = *addendp;
4023
4024 cr = (scpt->contents
4025 + sizeof (Elf32_External_compact_rel));
4026 bfd_elf32_swap_crinfo_out (output_bfd, &cptrel,
4027 ((Elf32_External_crinfo *) cr
4028 + scpt->reloc_count));
4029 ++scpt->reloc_count;
4030 }
4031 }
4032
4033 return TRUE;
4034 }
4035 \f
4036 /* Return the MACH for a MIPS e_flags value. */
4037
4038 unsigned long
4039 _bfd_elf_mips_mach (flagword flags)
4040 {
4041 switch (flags & EF_MIPS_MACH)
4042 {
4043 case E_MIPS_MACH_3900:
4044 return bfd_mach_mips3900;
4045
4046 case E_MIPS_MACH_4010:
4047 return bfd_mach_mips4010;
4048
4049 case E_MIPS_MACH_4100:
4050 return bfd_mach_mips4100;
4051
4052 case E_MIPS_MACH_4111:
4053 return bfd_mach_mips4111;
4054
4055 case E_MIPS_MACH_4120:
4056 return bfd_mach_mips4120;
4057
4058 case E_MIPS_MACH_4650:
4059 return bfd_mach_mips4650;
4060
4061 case E_MIPS_MACH_5400:
4062 return bfd_mach_mips5400;
4063
4064 case E_MIPS_MACH_5500:
4065 return bfd_mach_mips5500;
4066
4067 case E_MIPS_MACH_SB1:
4068 return bfd_mach_mips_sb1;
4069
4070 default:
4071 switch (flags & EF_MIPS_ARCH)
4072 {
4073 default:
4074 case E_MIPS_ARCH_1:
4075 return bfd_mach_mips3000;
4076 break;
4077
4078 case E_MIPS_ARCH_2:
4079 return bfd_mach_mips6000;
4080 break;
4081
4082 case E_MIPS_ARCH_3:
4083 return bfd_mach_mips4000;
4084 break;
4085
4086 case E_MIPS_ARCH_4:
4087 return bfd_mach_mips8000;
4088 break;
4089
4090 case E_MIPS_ARCH_5:
4091 return bfd_mach_mips5;
4092 break;
4093
4094 case E_MIPS_ARCH_32:
4095 return bfd_mach_mipsisa32;
4096 break;
4097
4098 case E_MIPS_ARCH_64:
4099 return bfd_mach_mipsisa64;
4100 break;
4101
4102 case E_MIPS_ARCH_32R2:
4103 return bfd_mach_mipsisa32r2;
4104 break;
4105
4106 case E_MIPS_ARCH_64R2:
4107 return bfd_mach_mipsisa64r2;
4108 break;
4109 }
4110 }
4111
4112 return 0;
4113 }
4114
4115 /* Return printable name for ABI. */
4116
4117 static INLINE char *
4118 elf_mips_abi_name (bfd *abfd)
4119 {
4120 flagword flags;
4121
4122 flags = elf_elfheader (abfd)->e_flags;
4123 switch (flags & EF_MIPS_ABI)
4124 {
4125 case 0:
4126 if (ABI_N32_P (abfd))
4127 return "N32";
4128 else if (ABI_64_P (abfd))
4129 return "64";
4130 else
4131 return "none";
4132 case E_MIPS_ABI_O32:
4133 return "O32";
4134 case E_MIPS_ABI_O64:
4135 return "O64";
4136 case E_MIPS_ABI_EABI32:
4137 return "EABI32";
4138 case E_MIPS_ABI_EABI64:
4139 return "EABI64";
4140 default:
4141 return "unknown abi";
4142 }
4143 }
4144 \f
4145 /* MIPS ELF uses two common sections. One is the usual one, and the
4146 other is for small objects. All the small objects are kept
4147 together, and then referenced via the gp pointer, which yields
4148 faster assembler code. This is what we use for the small common
4149 section. This approach is copied from ecoff.c. */
4150 static asection mips_elf_scom_section;
4151 static asymbol mips_elf_scom_symbol;
4152 static asymbol *mips_elf_scom_symbol_ptr;
4153
4154 /* MIPS ELF also uses an acommon section, which represents an
4155 allocated common symbol which may be overridden by a
4156 definition in a shared library. */
4157 static asection mips_elf_acom_section;
4158 static asymbol mips_elf_acom_symbol;
4159 static asymbol *mips_elf_acom_symbol_ptr;
4160
4161 /* Handle the special MIPS section numbers that a symbol may use.
4162 This is used for both the 32-bit and the 64-bit ABI. */
4163
4164 void
4165 _bfd_mips_elf_symbol_processing (bfd *abfd, asymbol *asym)
4166 {
4167 elf_symbol_type *elfsym;
4168
4169 elfsym = (elf_symbol_type *) asym;
4170 switch (elfsym->internal_elf_sym.st_shndx)
4171 {
4172 case SHN_MIPS_ACOMMON:
4173 /* This section is used in a dynamically linked executable file.
4174 It is an allocated common section. The dynamic linker can
4175 either resolve these symbols to something in a shared
4176 library, or it can just leave them here. For our purposes,
4177 we can consider these symbols to be in a new section. */
4178 if (mips_elf_acom_section.name == NULL)
4179 {
4180 /* Initialize the acommon section. */
4181 mips_elf_acom_section.name = ".acommon";
4182 mips_elf_acom_section.flags = SEC_ALLOC;
4183 mips_elf_acom_section.output_section = &mips_elf_acom_section;
4184 mips_elf_acom_section.symbol = &mips_elf_acom_symbol;
4185 mips_elf_acom_section.symbol_ptr_ptr = &mips_elf_acom_symbol_ptr;
4186 mips_elf_acom_symbol.name = ".acommon";
4187 mips_elf_acom_symbol.flags = BSF_SECTION_SYM;
4188 mips_elf_acom_symbol.section = &mips_elf_acom_section;
4189 mips_elf_acom_symbol_ptr = &mips_elf_acom_symbol;
4190 }
4191 asym->section = &mips_elf_acom_section;
4192 break;
4193
4194 case SHN_COMMON:
4195 /* Common symbols less than the GP size are automatically
4196 treated as SHN_MIPS_SCOMMON symbols on IRIX5. */
4197 if (asym->value > elf_gp_size (abfd)
4198 || IRIX_COMPAT (abfd) == ict_irix6)
4199 break;
4200 /* Fall through. */
4201 case SHN_MIPS_SCOMMON:
4202 if (mips_elf_scom_section.name == NULL)
4203 {
4204 /* Initialize the small common section. */
4205 mips_elf_scom_section.name = ".scommon";
4206 mips_elf_scom_section.flags = SEC_IS_COMMON;
4207 mips_elf_scom_section.output_section = &mips_elf_scom_section;
4208 mips_elf_scom_section.symbol = &mips_elf_scom_symbol;
4209 mips_elf_scom_section.symbol_ptr_ptr = &mips_elf_scom_symbol_ptr;
4210 mips_elf_scom_symbol.name = ".scommon";
4211 mips_elf_scom_symbol.flags = BSF_SECTION_SYM;
4212 mips_elf_scom_symbol.section = &mips_elf_scom_section;
4213 mips_elf_scom_symbol_ptr = &mips_elf_scom_symbol;
4214 }
4215 asym->section = &mips_elf_scom_section;
4216 asym->value = elfsym->internal_elf_sym.st_size;
4217 break;
4218
4219 case SHN_MIPS_SUNDEFINED:
4220 asym->section = bfd_und_section_ptr;
4221 break;
4222
4223 #if 0 /* for SGI_COMPAT */
4224 case SHN_MIPS_TEXT:
4225 asym->section = mips_elf_text_section_ptr;
4226 break;
4227
4228 case SHN_MIPS_DATA:
4229 asym->section = mips_elf_data_section_ptr;
4230 break;
4231 #endif
4232 }
4233 }
4234 \f
4235 /* There appears to be a bug in the MIPSpro linker that causes GOT_DISP
4236 relocations against two unnamed section symbols to resolve to the
4237 same address. For example, if we have code like:
4238
4239 lw $4,%got_disp(.data)($gp)
4240 lw $25,%got_disp(.text)($gp)
4241 jalr $25
4242
4243 then the linker will resolve both relocations to .data and the program
4244 will jump there rather than to .text.
4245
4246 We can work around this problem by giving names to local section symbols.
4247 This is also what the MIPSpro tools do. */
4248
4249 bfd_boolean
4250 _bfd_mips_elf_name_local_section_symbols (bfd *abfd)
4251 {
4252 return SGI_COMPAT (abfd);
4253 }
4254 \f
4255 /* Work over a section just before writing it out. This routine is
4256 used by both the 32-bit and the 64-bit ABI. FIXME: We recognize
4257 sections that need the SHF_MIPS_GPREL flag by name; there has to be
4258 a better way. */
4259
4260 bfd_boolean
4261 _bfd_mips_elf_section_processing (bfd *abfd, Elf_Internal_Shdr *hdr)
4262 {
4263 if (hdr->sh_type == SHT_MIPS_REGINFO
4264 && hdr->sh_size > 0)
4265 {
4266 bfd_byte buf[4];
4267
4268 BFD_ASSERT (hdr->sh_size == sizeof (Elf32_External_RegInfo));
4269 BFD_ASSERT (hdr->contents == NULL);
4270
4271 if (bfd_seek (abfd,
4272 hdr->sh_offset + sizeof (Elf32_External_RegInfo) - 4,
4273 SEEK_SET) != 0)
4274 return FALSE;
4275 H_PUT_32 (abfd, elf_gp (abfd), buf);
4276 if (bfd_bwrite (buf, 4, abfd) != 4)
4277 return FALSE;
4278 }
4279
4280 if (hdr->sh_type == SHT_MIPS_OPTIONS
4281 && hdr->bfd_section != NULL
4282 && mips_elf_section_data (hdr->bfd_section) != NULL
4283 && mips_elf_section_data (hdr->bfd_section)->u.tdata != NULL)
4284 {
4285 bfd_byte *contents, *l, *lend;
4286
4287 /* We stored the section contents in the tdata field in the
4288 set_section_contents routine. We save the section contents
4289 so that we don't have to read them again.
4290 At this point we know that elf_gp is set, so we can look
4291 through the section contents to see if there is an
4292 ODK_REGINFO structure. */
4293
4294 contents = mips_elf_section_data (hdr->bfd_section)->u.tdata;
4295 l = contents;
4296 lend = contents + hdr->sh_size;
4297 while (l + sizeof (Elf_External_Options) <= lend)
4298 {
4299 Elf_Internal_Options intopt;
4300
4301 bfd_mips_elf_swap_options_in (abfd, (Elf_External_Options *) l,
4302 &intopt);
4303 if (ABI_64_P (abfd) && intopt.kind == ODK_REGINFO)
4304 {
4305 bfd_byte buf[8];
4306
4307 if (bfd_seek (abfd,
4308 (hdr->sh_offset
4309 + (l - contents)
4310 + sizeof (Elf_External_Options)
4311 + (sizeof (Elf64_External_RegInfo) - 8)),
4312 SEEK_SET) != 0)
4313 return FALSE;
4314 H_PUT_64 (abfd, elf_gp (abfd), buf);
4315 if (bfd_bwrite (buf, 8, abfd) != 8)
4316 return FALSE;
4317 }
4318 else if (intopt.kind == ODK_REGINFO)
4319 {
4320 bfd_byte buf[4];
4321
4322 if (bfd_seek (abfd,
4323 (hdr->sh_offset
4324 + (l - contents)
4325 + sizeof (Elf_External_Options)
4326 + (sizeof (Elf32_External_RegInfo) - 4)),
4327 SEEK_SET) != 0)
4328 return FALSE;
4329 H_PUT_32 (abfd, elf_gp (abfd), buf);
4330 if (bfd_bwrite (buf, 4, abfd) != 4)
4331 return FALSE;
4332 }
4333 l += intopt.size;
4334 }
4335 }
4336
4337 if (hdr->bfd_section != NULL)
4338 {
4339 const char *name = bfd_get_section_name (abfd, hdr->bfd_section);
4340
4341 if (strcmp (name, ".sdata") == 0
4342 || strcmp (name, ".lit8") == 0
4343 || strcmp (name, ".lit4") == 0)
4344 {
4345 hdr->sh_flags |= SHF_ALLOC | SHF_WRITE | SHF_MIPS_GPREL;
4346 hdr->sh_type = SHT_PROGBITS;
4347 }
4348 else if (strcmp (name, ".sbss") == 0)
4349 {
4350 hdr->sh_flags |= SHF_ALLOC | SHF_WRITE | SHF_MIPS_GPREL;
4351 hdr->sh_type = SHT_NOBITS;
4352 }
4353 else if (strcmp (name, ".srdata") == 0)
4354 {
4355 hdr->sh_flags |= SHF_ALLOC | SHF_MIPS_GPREL;
4356 hdr->sh_type = SHT_PROGBITS;
4357 }
4358 else if (strcmp (name, ".compact_rel") == 0)
4359 {
4360 hdr->sh_flags = 0;
4361 hdr->sh_type = SHT_PROGBITS;
4362 }
4363 else if (strcmp (name, ".rtproc") == 0)
4364 {
4365 if (hdr->sh_addralign != 0 && hdr->sh_entsize == 0)
4366 {
4367 unsigned int adjust;
4368
4369 adjust = hdr->sh_size % hdr->sh_addralign;
4370 if (adjust != 0)
4371 hdr->sh_size += hdr->sh_addralign - adjust;
4372 }
4373 }
4374 }
4375
4376 return TRUE;
4377 }
4378
4379 /* Handle a MIPS specific section when reading an object file. This
4380 is called when elfcode.h finds a section with an unknown type.
4381 This routine supports both the 32-bit and 64-bit ELF ABI.
4382
4383 FIXME: We need to handle the SHF_MIPS_GPREL flag, but I'm not sure
4384 how to. */
4385
4386 bfd_boolean
4387 _bfd_mips_elf_section_from_shdr (bfd *abfd, Elf_Internal_Shdr *hdr,
4388 const char *name)
4389 {
4390 flagword flags = 0;
4391
4392 /* There ought to be a place to keep ELF backend specific flags, but
4393 at the moment there isn't one. We just keep track of the
4394 sections by their name, instead. Fortunately, the ABI gives
4395 suggested names for all the MIPS specific sections, so we will
4396 probably get away with this. */
4397 switch (hdr->sh_type)
4398 {
4399 case SHT_MIPS_LIBLIST:
4400 if (strcmp (name, ".liblist") != 0)
4401 return FALSE;
4402 break;
4403 case SHT_MIPS_MSYM:
4404 if (strcmp (name, ".msym") != 0)
4405 return FALSE;
4406 break;
4407 case SHT_MIPS_CONFLICT:
4408 if (strcmp (name, ".conflict") != 0)
4409 return FALSE;
4410 break;
4411 case SHT_MIPS_GPTAB:
4412 if (strncmp (name, ".gptab.", sizeof ".gptab." - 1) != 0)
4413 return FALSE;
4414 break;
4415 case SHT_MIPS_UCODE:
4416 if (strcmp (name, ".ucode") != 0)
4417 return FALSE;
4418 break;
4419 case SHT_MIPS_DEBUG:
4420 if (strcmp (name, ".mdebug") != 0)
4421 return FALSE;
4422 flags = SEC_DEBUGGING;
4423 break;
4424 case SHT_MIPS_REGINFO:
4425 if (strcmp (name, ".reginfo") != 0
4426 || hdr->sh_size != sizeof (Elf32_External_RegInfo))
4427 return FALSE;
4428 flags = (SEC_LINK_ONCE | SEC_LINK_DUPLICATES_SAME_SIZE);
4429 break;
4430 case SHT_MIPS_IFACE:
4431 if (strcmp (name, ".MIPS.interfaces") != 0)
4432 return FALSE;
4433 break;
4434 case SHT_MIPS_CONTENT:
4435 if (strncmp (name, ".MIPS.content", sizeof ".MIPS.content" - 1) != 0)
4436 return FALSE;
4437 break;
4438 case SHT_MIPS_OPTIONS:
4439 if (strcmp (name, MIPS_ELF_OPTIONS_SECTION_NAME (abfd)) != 0)
4440 return FALSE;
4441 break;
4442 case SHT_MIPS_DWARF:
4443 if (strncmp (name, ".debug_", sizeof ".debug_" - 1) != 0)
4444 return FALSE;
4445 break;
4446 case SHT_MIPS_SYMBOL_LIB:
4447 if (strcmp (name, ".MIPS.symlib") != 0)
4448 return FALSE;
4449 break;
4450 case SHT_MIPS_EVENTS:
4451 if (strncmp (name, ".MIPS.events", sizeof ".MIPS.events" - 1) != 0
4452 && strncmp (name, ".MIPS.post_rel",
4453 sizeof ".MIPS.post_rel" - 1) != 0)
4454 return FALSE;
4455 break;
4456 default:
4457 return FALSE;
4458 }
4459
4460 if (! _bfd_elf_make_section_from_shdr (abfd, hdr, name))
4461 return FALSE;
4462
4463 if (flags)
4464 {
4465 if (! bfd_set_section_flags (abfd, hdr->bfd_section,
4466 (bfd_get_section_flags (abfd,
4467 hdr->bfd_section)
4468 | flags)))
4469 return FALSE;
4470 }
4471
4472 /* FIXME: We should record sh_info for a .gptab section. */
4473
4474 /* For a .reginfo section, set the gp value in the tdata information
4475 from the contents of this section. We need the gp value while
4476 processing relocs, so we just get it now. The .reginfo section
4477 is not used in the 64-bit MIPS ELF ABI. */
4478 if (hdr->sh_type == SHT_MIPS_REGINFO)
4479 {
4480 Elf32_External_RegInfo ext;
4481 Elf32_RegInfo s;
4482
4483 if (! bfd_get_section_contents (abfd, hdr->bfd_section,
4484 &ext, 0, sizeof ext))
4485 return FALSE;
4486 bfd_mips_elf32_swap_reginfo_in (abfd, &ext, &s);
4487 elf_gp (abfd) = s.ri_gp_value;
4488 }
4489
4490 /* For a SHT_MIPS_OPTIONS section, look for a ODK_REGINFO entry, and
4491 set the gp value based on what we find. We may see both
4492 SHT_MIPS_REGINFO and SHT_MIPS_OPTIONS/ODK_REGINFO; in that case,
4493 they should agree. */
4494 if (hdr->sh_type == SHT_MIPS_OPTIONS)
4495 {
4496 bfd_byte *contents, *l, *lend;
4497
4498 contents = bfd_malloc (hdr->sh_size);
4499 if (contents == NULL)
4500 return FALSE;
4501 if (! bfd_get_section_contents (abfd, hdr->bfd_section, contents,
4502 0, hdr->sh_size))
4503 {
4504 free (contents);
4505 return FALSE;
4506 }
4507 l = contents;
4508 lend = contents + hdr->sh_size;
4509 while (l + sizeof (Elf_External_Options) <= lend)
4510 {
4511 Elf_Internal_Options intopt;
4512
4513 bfd_mips_elf_swap_options_in (abfd, (Elf_External_Options *) l,
4514 &intopt);
4515 if (ABI_64_P (abfd) && intopt.kind == ODK_REGINFO)
4516 {
4517 Elf64_Internal_RegInfo intreg;
4518
4519 bfd_mips_elf64_swap_reginfo_in
4520 (abfd,
4521 ((Elf64_External_RegInfo *)
4522 (l + sizeof (Elf_External_Options))),
4523 &intreg);
4524 elf_gp (abfd) = intreg.ri_gp_value;
4525 }
4526 else if (intopt.kind == ODK_REGINFO)
4527 {
4528 Elf32_RegInfo intreg;
4529
4530 bfd_mips_elf32_swap_reginfo_in
4531 (abfd,
4532 ((Elf32_External_RegInfo *)
4533 (l + sizeof (Elf_External_Options))),
4534 &intreg);
4535 elf_gp (abfd) = intreg.ri_gp_value;
4536 }
4537 l += intopt.size;
4538 }
4539 free (contents);
4540 }
4541
4542 return TRUE;
4543 }
4544
4545 /* Set the correct type for a MIPS ELF section. We do this by the
4546 section name, which is a hack, but ought to work. This routine is
4547 used by both the 32-bit and the 64-bit ABI. */
4548
4549 bfd_boolean
4550 _bfd_mips_elf_fake_sections (bfd *abfd, Elf_Internal_Shdr *hdr, asection *sec)
4551 {
4552 register const char *name;
4553
4554 name = bfd_get_section_name (abfd, sec);
4555
4556 if (strcmp (name, ".liblist") == 0)
4557 {
4558 hdr->sh_type = SHT_MIPS_LIBLIST;
4559 hdr->sh_info = sec->_raw_size / sizeof (Elf32_Lib);
4560 /* The sh_link field is set in final_write_processing. */
4561 }
4562 else if (strcmp (name, ".conflict") == 0)
4563 hdr->sh_type = SHT_MIPS_CONFLICT;
4564 else if (strncmp (name, ".gptab.", sizeof ".gptab." - 1) == 0)
4565 {
4566 hdr->sh_type = SHT_MIPS_GPTAB;
4567 hdr->sh_entsize = sizeof (Elf32_External_gptab);
4568 /* The sh_info field is set in final_write_processing. */
4569 }
4570 else if (strcmp (name, ".ucode") == 0)
4571 hdr->sh_type = SHT_MIPS_UCODE;
4572 else if (strcmp (name, ".mdebug") == 0)
4573 {
4574 hdr->sh_type = SHT_MIPS_DEBUG;
4575 /* In a shared object on IRIX 5.3, the .mdebug section has an
4576 entsize of 0. FIXME: Does this matter? */
4577 if (SGI_COMPAT (abfd) && (abfd->flags & DYNAMIC) != 0)
4578 hdr->sh_entsize = 0;
4579 else
4580 hdr->sh_entsize = 1;
4581 }
4582 else if (strcmp (name, ".reginfo") == 0)
4583 {
4584 hdr->sh_type = SHT_MIPS_REGINFO;
4585 /* In a shared object on IRIX 5.3, the .reginfo section has an
4586 entsize of 0x18. FIXME: Does this matter? */
4587 if (SGI_COMPAT (abfd))
4588 {
4589 if ((abfd->flags & DYNAMIC) != 0)
4590 hdr->sh_entsize = sizeof (Elf32_External_RegInfo);
4591 else
4592 hdr->sh_entsize = 1;
4593 }
4594 else
4595 hdr->sh_entsize = sizeof (Elf32_External_RegInfo);
4596 }
4597 else if (SGI_COMPAT (abfd)
4598 && (strcmp (name, ".hash") == 0
4599 || strcmp (name, ".dynamic") == 0
4600 || strcmp (name, ".dynstr") == 0))
4601 {
4602 if (SGI_COMPAT (abfd))
4603 hdr->sh_entsize = 0;
4604 #if 0
4605 /* This isn't how the IRIX6 linker behaves. */
4606 hdr->sh_info = SIZEOF_MIPS_DYNSYM_SECNAMES;
4607 #endif
4608 }
4609 else if (strcmp (name, ".got") == 0
4610 || strcmp (name, ".srdata") == 0
4611 || strcmp (name, ".sdata") == 0
4612 || strcmp (name, ".sbss") == 0
4613 || strcmp (name, ".lit4") == 0
4614 || strcmp (name, ".lit8") == 0)
4615 hdr->sh_flags |= SHF_MIPS_GPREL;
4616 else if (strcmp (name, ".MIPS.interfaces") == 0)
4617 {
4618 hdr->sh_type = SHT_MIPS_IFACE;
4619 hdr->sh_flags |= SHF_MIPS_NOSTRIP;
4620 }
4621 else if (strncmp (name, ".MIPS.content", strlen (".MIPS.content")) == 0)
4622 {
4623 hdr->sh_type = SHT_MIPS_CONTENT;
4624 hdr->sh_flags |= SHF_MIPS_NOSTRIP;
4625 /* The sh_info field is set in final_write_processing. */
4626 }
4627 else if (strcmp (name, MIPS_ELF_OPTIONS_SECTION_NAME (abfd)) == 0)
4628 {
4629 hdr->sh_type = SHT_MIPS_OPTIONS;
4630 hdr->sh_entsize = 1;
4631 hdr->sh_flags |= SHF_MIPS_NOSTRIP;
4632 }
4633 else if (strncmp (name, ".debug_", sizeof ".debug_" - 1) == 0)
4634 hdr->sh_type = SHT_MIPS_DWARF;
4635 else if (strcmp (name, ".MIPS.symlib") == 0)
4636 {
4637 hdr->sh_type = SHT_MIPS_SYMBOL_LIB;
4638 /* The sh_link and sh_info fields are set in
4639 final_write_processing. */
4640 }
4641 else if (strncmp (name, ".MIPS.events", sizeof ".MIPS.events" - 1) == 0
4642 || strncmp (name, ".MIPS.post_rel",
4643 sizeof ".MIPS.post_rel" - 1) == 0)
4644 {
4645 hdr->sh_type = SHT_MIPS_EVENTS;
4646 hdr->sh_flags |= SHF_MIPS_NOSTRIP;
4647 /* The sh_link field is set in final_write_processing. */
4648 }
4649 else if (strcmp (name, ".msym") == 0)
4650 {
4651 hdr->sh_type = SHT_MIPS_MSYM;
4652 hdr->sh_flags |= SHF_ALLOC;
4653 hdr->sh_entsize = 8;
4654 }
4655
4656 /* The generic elf_fake_sections will set up REL_HDR using the default
4657 kind of relocations. We used to set up a second header for the
4658 non-default kind of relocations here, but only NewABI would use
4659 these, and the IRIX ld doesn't like resulting empty RELA sections.
4660 Thus we create those header only on demand now. */
4661
4662 return TRUE;
4663 }
4664
4665 /* Given a BFD section, try to locate the corresponding ELF section
4666 index. This is used by both the 32-bit and the 64-bit ABI.
4667 Actually, it's not clear to me that the 64-bit ABI supports these,
4668 but for non-PIC objects we will certainly want support for at least
4669 the .scommon section. */
4670
4671 bfd_boolean
4672 _bfd_mips_elf_section_from_bfd_section (bfd *abfd ATTRIBUTE_UNUSED,
4673 asection *sec, int *retval)
4674 {
4675 if (strcmp (bfd_get_section_name (abfd, sec), ".scommon") == 0)
4676 {
4677 *retval = SHN_MIPS_SCOMMON;
4678 return TRUE;
4679 }
4680 if (strcmp (bfd_get_section_name (abfd, sec), ".acommon") == 0)
4681 {
4682 *retval = SHN_MIPS_ACOMMON;
4683 return TRUE;
4684 }
4685 return FALSE;
4686 }
4687 \f
4688 /* Hook called by the linker routine which adds symbols from an object
4689 file. We must handle the special MIPS section numbers here. */
4690
4691 bfd_boolean
4692 _bfd_mips_elf_add_symbol_hook (bfd *abfd, struct bfd_link_info *info,
4693 Elf_Internal_Sym *sym, const char **namep,
4694 flagword *flagsp ATTRIBUTE_UNUSED,
4695 asection **secp, bfd_vma *valp)
4696 {
4697 if (SGI_COMPAT (abfd)
4698 && (abfd->flags & DYNAMIC) != 0
4699 && strcmp (*namep, "_rld_new_interface") == 0)
4700 {
4701 /* Skip IRIX5 rld entry name. */
4702 *namep = NULL;
4703 return TRUE;
4704 }
4705
4706 switch (sym->st_shndx)
4707 {
4708 case SHN_COMMON:
4709 /* Common symbols less than the GP size are automatically
4710 treated as SHN_MIPS_SCOMMON symbols. */
4711 if (sym->st_size > elf_gp_size (abfd)
4712 || IRIX_COMPAT (abfd) == ict_irix6)
4713 break;
4714 /* Fall through. */
4715 case SHN_MIPS_SCOMMON:
4716 *secp = bfd_make_section_old_way (abfd, ".scommon");
4717 (*secp)->flags |= SEC_IS_COMMON;
4718 *valp = sym->st_size;
4719 break;
4720
4721 case SHN_MIPS_TEXT:
4722 /* This section is used in a shared object. */
4723 if (elf_tdata (abfd)->elf_text_section == NULL)
4724 {
4725 asymbol *elf_text_symbol;
4726 asection *elf_text_section;
4727 bfd_size_type amt = sizeof (asection);
4728
4729 elf_text_section = bfd_zalloc (abfd, amt);
4730 if (elf_text_section == NULL)
4731 return FALSE;
4732
4733 amt = sizeof (asymbol);
4734 elf_text_symbol = bfd_zalloc (abfd, amt);
4735 if (elf_text_symbol == NULL)
4736 return FALSE;
4737
4738 /* Initialize the section. */
4739
4740 elf_tdata (abfd)->elf_text_section = elf_text_section;
4741 elf_tdata (abfd)->elf_text_symbol = elf_text_symbol;
4742
4743 elf_text_section->symbol = elf_text_symbol;
4744 elf_text_section->symbol_ptr_ptr = &elf_tdata (abfd)->elf_text_symbol;
4745
4746 elf_text_section->name = ".text";
4747 elf_text_section->flags = SEC_NO_FLAGS;
4748 elf_text_section->output_section = NULL;
4749 elf_text_section->owner = abfd;
4750 elf_text_symbol->name = ".text";
4751 elf_text_symbol->flags = BSF_SECTION_SYM | BSF_DYNAMIC;
4752 elf_text_symbol->section = elf_text_section;
4753 }
4754 /* This code used to do *secp = bfd_und_section_ptr if
4755 info->shared. I don't know why, and that doesn't make sense,
4756 so I took it out. */
4757 *secp = elf_tdata (abfd)->elf_text_section;
4758 break;
4759
4760 case SHN_MIPS_ACOMMON:
4761 /* Fall through. XXX Can we treat this as allocated data? */
4762 case SHN_MIPS_DATA:
4763 /* This section is used in a shared object. */
4764 if (elf_tdata (abfd)->elf_data_section == NULL)
4765 {
4766 asymbol *elf_data_symbol;
4767 asection *elf_data_section;
4768 bfd_size_type amt = sizeof (asection);
4769
4770 elf_data_section = bfd_zalloc (abfd, amt);
4771 if (elf_data_section == NULL)
4772 return FALSE;
4773
4774 amt = sizeof (asymbol);
4775 elf_data_symbol = bfd_zalloc (abfd, amt);
4776 if (elf_data_symbol == NULL)
4777 return FALSE;
4778
4779 /* Initialize the section. */
4780
4781 elf_tdata (abfd)->elf_data_section = elf_data_section;
4782 elf_tdata (abfd)->elf_data_symbol = elf_data_symbol;
4783
4784 elf_data_section->symbol = elf_data_symbol;
4785 elf_data_section->symbol_ptr_ptr = &elf_tdata (abfd)->elf_data_symbol;
4786
4787 elf_data_section->name = ".data";
4788 elf_data_section->flags = SEC_NO_FLAGS;
4789 elf_data_section->output_section = NULL;
4790 elf_data_section->owner = abfd;
4791 elf_data_symbol->name = ".data";
4792 elf_data_symbol->flags = BSF_SECTION_SYM | BSF_DYNAMIC;
4793 elf_data_symbol->section = elf_data_section;
4794 }
4795 /* This code used to do *secp = bfd_und_section_ptr if
4796 info->shared. I don't know why, and that doesn't make sense,
4797 so I took it out. */
4798 *secp = elf_tdata (abfd)->elf_data_section;
4799 break;
4800
4801 case SHN_MIPS_SUNDEFINED:
4802 *secp = bfd_und_section_ptr;
4803 break;
4804 }
4805
4806 if (SGI_COMPAT (abfd)
4807 && ! info->shared
4808 && info->hash->creator == abfd->xvec
4809 && strcmp (*namep, "__rld_obj_head") == 0)
4810 {
4811 struct elf_link_hash_entry *h;
4812 struct bfd_link_hash_entry *bh;
4813
4814 /* Mark __rld_obj_head as dynamic. */
4815 bh = NULL;
4816 if (! (_bfd_generic_link_add_one_symbol
4817 (info, abfd, *namep, BSF_GLOBAL, *secp, *valp, NULL, FALSE,
4818 get_elf_backend_data (abfd)->collect, &bh)))
4819 return FALSE;
4820
4821 h = (struct elf_link_hash_entry *) bh;
4822 h->elf_link_hash_flags &= ~ELF_LINK_NON_ELF;
4823 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
4824 h->type = STT_OBJECT;
4825
4826 if (! bfd_elf_link_record_dynamic_symbol (info, h))
4827 return FALSE;
4828
4829 mips_elf_hash_table (info)->use_rld_obj_head = TRUE;
4830 }
4831
4832 /* If this is a mips16 text symbol, add 1 to the value to make it
4833 odd. This will cause something like .word SYM to come up with
4834 the right value when it is loaded into the PC. */
4835 if (sym->st_other == STO_MIPS16)
4836 ++*valp;
4837
4838 return TRUE;
4839 }
4840
4841 /* This hook function is called before the linker writes out a global
4842 symbol. We mark symbols as small common if appropriate. This is
4843 also where we undo the increment of the value for a mips16 symbol. */
4844
4845 bfd_boolean
4846 _bfd_mips_elf_link_output_symbol_hook
4847 (struct bfd_link_info *info ATTRIBUTE_UNUSED,
4848 const char *name ATTRIBUTE_UNUSED, Elf_Internal_Sym *sym,
4849 asection *input_sec, struct elf_link_hash_entry *h ATTRIBUTE_UNUSED)
4850 {
4851 /* If we see a common symbol, which implies a relocatable link, then
4852 if a symbol was small common in an input file, mark it as small
4853 common in the output file. */
4854 if (sym->st_shndx == SHN_COMMON
4855 && strcmp (input_sec->name, ".scommon") == 0)
4856 sym->st_shndx = SHN_MIPS_SCOMMON;
4857
4858 if (sym->st_other == STO_MIPS16)
4859 sym->st_value &= ~1;
4860
4861 return TRUE;
4862 }
4863 \f
4864 /* Functions for the dynamic linker. */
4865
4866 /* Create dynamic sections when linking against a dynamic object. */
4867
4868 bfd_boolean
4869 _bfd_mips_elf_create_dynamic_sections (bfd *abfd, struct bfd_link_info *info)
4870 {
4871 struct elf_link_hash_entry *h;
4872 struct bfd_link_hash_entry *bh;
4873 flagword flags;
4874 register asection *s;
4875 const char * const *namep;
4876
4877 flags = (SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS | SEC_IN_MEMORY
4878 | SEC_LINKER_CREATED | SEC_READONLY);
4879
4880 /* Mips ABI requests the .dynamic section to be read only. */
4881 s = bfd_get_section_by_name (abfd, ".dynamic");
4882 if (s != NULL)
4883 {
4884 if (! bfd_set_section_flags (abfd, s, flags))
4885 return FALSE;
4886 }
4887
4888 /* We need to create .got section. */
4889 if (! mips_elf_create_got_section (abfd, info, FALSE))
4890 return FALSE;
4891
4892 if (! mips_elf_rel_dyn_section (elf_hash_table (info)->dynobj, TRUE))
4893 return FALSE;
4894
4895 /* Create .stub section. */
4896 if (bfd_get_section_by_name (abfd,
4897 MIPS_ELF_STUB_SECTION_NAME (abfd)) == NULL)
4898 {
4899 s = bfd_make_section (abfd, MIPS_ELF_STUB_SECTION_NAME (abfd));
4900 if (s == NULL
4901 || ! bfd_set_section_flags (abfd, s, flags | SEC_CODE)
4902 || ! bfd_set_section_alignment (abfd, s,
4903 MIPS_ELF_LOG_FILE_ALIGN (abfd)))
4904 return FALSE;
4905 }
4906
4907 if ((IRIX_COMPAT (abfd) == ict_irix5 || IRIX_COMPAT (abfd) == ict_none)
4908 && !info->shared
4909 && bfd_get_section_by_name (abfd, ".rld_map") == NULL)
4910 {
4911 s = bfd_make_section (abfd, ".rld_map");
4912 if (s == NULL
4913 || ! bfd_set_section_flags (abfd, s, flags &~ (flagword) SEC_READONLY)
4914 || ! bfd_set_section_alignment (abfd, s,
4915 MIPS_ELF_LOG_FILE_ALIGN (abfd)))
4916 return FALSE;
4917 }
4918
4919 /* On IRIX5, we adjust add some additional symbols and change the
4920 alignments of several sections. There is no ABI documentation
4921 indicating that this is necessary on IRIX6, nor any evidence that
4922 the linker takes such action. */
4923 if (IRIX_COMPAT (abfd) == ict_irix5)
4924 {
4925 for (namep = mips_elf_dynsym_rtproc_names; *namep != NULL; namep++)
4926 {
4927 bh = NULL;
4928 if (! (_bfd_generic_link_add_one_symbol
4929 (info, abfd, *namep, BSF_GLOBAL, bfd_und_section_ptr, 0,
4930 NULL, FALSE, get_elf_backend_data (abfd)->collect, &bh)))
4931 return FALSE;
4932
4933 h = (struct elf_link_hash_entry *) bh;
4934 h->elf_link_hash_flags &= ~ELF_LINK_NON_ELF;
4935 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
4936 h->type = STT_SECTION;
4937
4938 if (! bfd_elf_link_record_dynamic_symbol (info, h))
4939 return FALSE;
4940 }
4941
4942 /* We need to create a .compact_rel section. */
4943 if (SGI_COMPAT (abfd))
4944 {
4945 if (!mips_elf_create_compact_rel_section (abfd, info))
4946 return FALSE;
4947 }
4948
4949 /* Change alignments of some sections. */
4950 s = bfd_get_section_by_name (abfd, ".hash");
4951 if (s != NULL)
4952 bfd_set_section_alignment (abfd, s, MIPS_ELF_LOG_FILE_ALIGN (abfd));
4953 s = bfd_get_section_by_name (abfd, ".dynsym");
4954 if (s != NULL)
4955 bfd_set_section_alignment (abfd, s, MIPS_ELF_LOG_FILE_ALIGN (abfd));
4956 s = bfd_get_section_by_name (abfd, ".dynstr");
4957 if (s != NULL)
4958 bfd_set_section_alignment (abfd, s, MIPS_ELF_LOG_FILE_ALIGN (abfd));
4959 s = bfd_get_section_by_name (abfd, ".reginfo");
4960 if (s != NULL)
4961 bfd_set_section_alignment (abfd, s, MIPS_ELF_LOG_FILE_ALIGN (abfd));
4962 s = bfd_get_section_by_name (abfd, ".dynamic");
4963 if (s != NULL)
4964 bfd_set_section_alignment (abfd, s, MIPS_ELF_LOG_FILE_ALIGN (abfd));
4965 }
4966
4967 if (!info->shared)
4968 {
4969 const char *name;
4970
4971 name = SGI_COMPAT (abfd) ? "_DYNAMIC_LINK" : "_DYNAMIC_LINKING";
4972 bh = NULL;
4973 if (!(_bfd_generic_link_add_one_symbol
4974 (info, abfd, name, BSF_GLOBAL, bfd_abs_section_ptr, 0,
4975 NULL, FALSE, get_elf_backend_data (abfd)->collect, &bh)))
4976 return FALSE;
4977
4978 h = (struct elf_link_hash_entry *) bh;
4979 h->elf_link_hash_flags &= ~ELF_LINK_NON_ELF;
4980 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
4981 h->type = STT_SECTION;
4982
4983 if (! bfd_elf_link_record_dynamic_symbol (info, h))
4984 return FALSE;
4985
4986 if (! mips_elf_hash_table (info)->use_rld_obj_head)
4987 {
4988 /* __rld_map is a four byte word located in the .data section
4989 and is filled in by the rtld to contain a pointer to
4990 the _r_debug structure. Its symbol value will be set in
4991 _bfd_mips_elf_finish_dynamic_symbol. */
4992 s = bfd_get_section_by_name (abfd, ".rld_map");
4993 BFD_ASSERT (s != NULL);
4994
4995 name = SGI_COMPAT (abfd) ? "__rld_map" : "__RLD_MAP";
4996 bh = NULL;
4997 if (!(_bfd_generic_link_add_one_symbol
4998 (info, abfd, name, BSF_GLOBAL, s, 0, NULL, FALSE,
4999 get_elf_backend_data (abfd)->collect, &bh)))
5000 return FALSE;
5001
5002 h = (struct elf_link_hash_entry *) bh;
5003 h->elf_link_hash_flags &= ~ELF_LINK_NON_ELF;
5004 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
5005 h->type = STT_OBJECT;
5006
5007 if (! bfd_elf_link_record_dynamic_symbol (info, h))
5008 return FALSE;
5009 }
5010 }
5011
5012 return TRUE;
5013 }
5014 \f
5015 /* Look through the relocs for a section during the first phase, and
5016 allocate space in the global offset table. */
5017
5018 bfd_boolean
5019 _bfd_mips_elf_check_relocs (bfd *abfd, struct bfd_link_info *info,
5020 asection *sec, const Elf_Internal_Rela *relocs)
5021 {
5022 const char *name;
5023 bfd *dynobj;
5024 Elf_Internal_Shdr *symtab_hdr;
5025 struct elf_link_hash_entry **sym_hashes;
5026 struct mips_got_info *g;
5027 size_t extsymoff;
5028 const Elf_Internal_Rela *rel;
5029 const Elf_Internal_Rela *rel_end;
5030 asection *sgot;
5031 asection *sreloc;
5032 const struct elf_backend_data *bed;
5033
5034 if (info->relocatable)
5035 return TRUE;
5036
5037 dynobj = elf_hash_table (info)->dynobj;
5038 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
5039 sym_hashes = elf_sym_hashes (abfd);
5040 extsymoff = (elf_bad_symtab (abfd)) ? 0 : symtab_hdr->sh_info;
5041
5042 /* Check for the mips16 stub sections. */
5043
5044 name = bfd_get_section_name (abfd, sec);
5045 if (strncmp (name, FN_STUB, sizeof FN_STUB - 1) == 0)
5046 {
5047 unsigned long r_symndx;
5048
5049 /* Look at the relocation information to figure out which symbol
5050 this is for. */
5051
5052 r_symndx = ELF_R_SYM (abfd, relocs->r_info);
5053
5054 if (r_symndx < extsymoff
5055 || sym_hashes[r_symndx - extsymoff] == NULL)
5056 {
5057 asection *o;
5058
5059 /* This stub is for a local symbol. This stub will only be
5060 needed if there is some relocation in this BFD, other
5061 than a 16 bit function call, which refers to this symbol. */
5062 for (o = abfd->sections; o != NULL; o = o->next)
5063 {
5064 Elf_Internal_Rela *sec_relocs;
5065 const Elf_Internal_Rela *r, *rend;
5066
5067 /* We can ignore stub sections when looking for relocs. */
5068 if ((o->flags & SEC_RELOC) == 0
5069 || o->reloc_count == 0
5070 || strncmp (bfd_get_section_name (abfd, o), FN_STUB,
5071 sizeof FN_STUB - 1) == 0
5072 || strncmp (bfd_get_section_name (abfd, o), CALL_STUB,
5073 sizeof CALL_STUB - 1) == 0
5074 || strncmp (bfd_get_section_name (abfd, o), CALL_FP_STUB,
5075 sizeof CALL_FP_STUB - 1) == 0)
5076 continue;
5077
5078 sec_relocs
5079 = _bfd_elf_link_read_relocs (abfd, o, NULL, NULL,
5080 info->keep_memory);
5081 if (sec_relocs == NULL)
5082 return FALSE;
5083
5084 rend = sec_relocs + o->reloc_count;
5085 for (r = sec_relocs; r < rend; r++)
5086 if (ELF_R_SYM (abfd, r->r_info) == r_symndx
5087 && ELF_R_TYPE (abfd, r->r_info) != R_MIPS16_26)
5088 break;
5089
5090 if (elf_section_data (o)->relocs != sec_relocs)
5091 free (sec_relocs);
5092
5093 if (r < rend)
5094 break;
5095 }
5096
5097 if (o == NULL)
5098 {
5099 /* There is no non-call reloc for this stub, so we do
5100 not need it. Since this function is called before
5101 the linker maps input sections to output sections, we
5102 can easily discard it by setting the SEC_EXCLUDE
5103 flag. */
5104 sec->flags |= SEC_EXCLUDE;
5105 return TRUE;
5106 }
5107
5108 /* Record this stub in an array of local symbol stubs for
5109 this BFD. */
5110 if (elf_tdata (abfd)->local_stubs == NULL)
5111 {
5112 unsigned long symcount;
5113 asection **n;
5114 bfd_size_type amt;
5115
5116 if (elf_bad_symtab (abfd))
5117 symcount = NUM_SHDR_ENTRIES (symtab_hdr);
5118 else
5119 symcount = symtab_hdr->sh_info;
5120 amt = symcount * sizeof (asection *);
5121 n = bfd_zalloc (abfd, amt);
5122 if (n == NULL)
5123 return FALSE;
5124 elf_tdata (abfd)->local_stubs = n;
5125 }
5126
5127 elf_tdata (abfd)->local_stubs[r_symndx] = sec;
5128
5129 /* We don't need to set mips16_stubs_seen in this case.
5130 That flag is used to see whether we need to look through
5131 the global symbol table for stubs. We don't need to set
5132 it here, because we just have a local stub. */
5133 }
5134 else
5135 {
5136 struct mips_elf_link_hash_entry *h;
5137
5138 h = ((struct mips_elf_link_hash_entry *)
5139 sym_hashes[r_symndx - extsymoff]);
5140
5141 /* H is the symbol this stub is for. */
5142
5143 h->fn_stub = sec;
5144 mips_elf_hash_table (info)->mips16_stubs_seen = TRUE;
5145 }
5146 }
5147 else if (strncmp (name, CALL_STUB, sizeof CALL_STUB - 1) == 0
5148 || strncmp (name, CALL_FP_STUB, sizeof CALL_FP_STUB - 1) == 0)
5149 {
5150 unsigned long r_symndx;
5151 struct mips_elf_link_hash_entry *h;
5152 asection **loc;
5153
5154 /* Look at the relocation information to figure out which symbol
5155 this is for. */
5156
5157 r_symndx = ELF_R_SYM (abfd, relocs->r_info);
5158
5159 if (r_symndx < extsymoff
5160 || sym_hashes[r_symndx - extsymoff] == NULL)
5161 {
5162 /* This stub was actually built for a static symbol defined
5163 in the same file. We assume that all static symbols in
5164 mips16 code are themselves mips16, so we can simply
5165 discard this stub. Since this function is called before
5166 the linker maps input sections to output sections, we can
5167 easily discard it by setting the SEC_EXCLUDE flag. */
5168 sec->flags |= SEC_EXCLUDE;
5169 return TRUE;
5170 }
5171
5172 h = ((struct mips_elf_link_hash_entry *)
5173 sym_hashes[r_symndx - extsymoff]);
5174
5175 /* H is the symbol this stub is for. */
5176
5177 if (strncmp (name, CALL_FP_STUB, sizeof CALL_FP_STUB - 1) == 0)
5178 loc = &h->call_fp_stub;
5179 else
5180 loc = &h->call_stub;
5181
5182 /* If we already have an appropriate stub for this function, we
5183 don't need another one, so we can discard this one. Since
5184 this function is called before the linker maps input sections
5185 to output sections, we can easily discard it by setting the
5186 SEC_EXCLUDE flag. We can also discard this section if we
5187 happen to already know that this is a mips16 function; it is
5188 not necessary to check this here, as it is checked later, but
5189 it is slightly faster to check now. */
5190 if (*loc != NULL || h->root.other == STO_MIPS16)
5191 {
5192 sec->flags |= SEC_EXCLUDE;
5193 return TRUE;
5194 }
5195
5196 *loc = sec;
5197 mips_elf_hash_table (info)->mips16_stubs_seen = TRUE;
5198 }
5199
5200 if (dynobj == NULL)
5201 {
5202 sgot = NULL;
5203 g = NULL;
5204 }
5205 else
5206 {
5207 sgot = mips_elf_got_section (dynobj, FALSE);
5208 if (sgot == NULL)
5209 g = NULL;
5210 else
5211 {
5212 BFD_ASSERT (mips_elf_section_data (sgot) != NULL);
5213 g = mips_elf_section_data (sgot)->u.got_info;
5214 BFD_ASSERT (g != NULL);
5215 }
5216 }
5217
5218 sreloc = NULL;
5219 bed = get_elf_backend_data (abfd);
5220 rel_end = relocs + sec->reloc_count * bed->s->int_rels_per_ext_rel;
5221 for (rel = relocs; rel < rel_end; ++rel)
5222 {
5223 unsigned long r_symndx;
5224 unsigned int r_type;
5225 struct elf_link_hash_entry *h;
5226
5227 r_symndx = ELF_R_SYM (abfd, rel->r_info);
5228 r_type = ELF_R_TYPE (abfd, rel->r_info);
5229
5230 if (r_symndx < extsymoff)
5231 h = NULL;
5232 else if (r_symndx >= extsymoff + NUM_SHDR_ENTRIES (symtab_hdr))
5233 {
5234 (*_bfd_error_handler)
5235 (_("%s: Malformed reloc detected for section %s"),
5236 bfd_archive_filename (abfd), name);
5237 bfd_set_error (bfd_error_bad_value);
5238 return FALSE;
5239 }
5240 else
5241 {
5242 h = sym_hashes[r_symndx - extsymoff];
5243
5244 /* This may be an indirect symbol created because of a version. */
5245 if (h != NULL)
5246 {
5247 while (h->root.type == bfd_link_hash_indirect)
5248 h = (struct elf_link_hash_entry *) h->root.u.i.link;
5249 }
5250 }
5251
5252 /* Some relocs require a global offset table. */
5253 if (dynobj == NULL || sgot == NULL)
5254 {
5255 switch (r_type)
5256 {
5257 case R_MIPS_GOT16:
5258 case R_MIPS_CALL16:
5259 case R_MIPS_CALL_HI16:
5260 case R_MIPS_CALL_LO16:
5261 case R_MIPS_GOT_HI16:
5262 case R_MIPS_GOT_LO16:
5263 case R_MIPS_GOT_PAGE:
5264 case R_MIPS_GOT_OFST:
5265 case R_MIPS_GOT_DISP:
5266 if (dynobj == NULL)
5267 elf_hash_table (info)->dynobj = dynobj = abfd;
5268 if (! mips_elf_create_got_section (dynobj, info, FALSE))
5269 return FALSE;
5270 g = mips_elf_got_info (dynobj, &sgot);
5271 break;
5272
5273 case R_MIPS_32:
5274 case R_MIPS_REL32:
5275 case R_MIPS_64:
5276 if (dynobj == NULL
5277 && (info->shared || h != NULL)
5278 && (sec->flags & SEC_ALLOC) != 0)
5279 elf_hash_table (info)->dynobj = dynobj = abfd;
5280 break;
5281
5282 default:
5283 break;
5284 }
5285 }
5286
5287 if (!h && (r_type == R_MIPS_CALL_LO16
5288 || r_type == R_MIPS_GOT_LO16
5289 || r_type == R_MIPS_GOT_DISP))
5290 {
5291 /* We may need a local GOT entry for this relocation. We
5292 don't count R_MIPS_GOT_PAGE because we can estimate the
5293 maximum number of pages needed by looking at the size of
5294 the segment. Similar comments apply to R_MIPS_GOT16 and
5295 R_MIPS_CALL16. We don't count R_MIPS_GOT_HI16, or
5296 R_MIPS_CALL_HI16 because these are always followed by an
5297 R_MIPS_GOT_LO16 or R_MIPS_CALL_LO16. */
5298 if (! mips_elf_record_local_got_symbol (abfd, r_symndx,
5299 rel->r_addend, g))
5300 return FALSE;
5301 }
5302
5303 switch (r_type)
5304 {
5305 case R_MIPS_CALL16:
5306 if (h == NULL)
5307 {
5308 (*_bfd_error_handler)
5309 (_("%s: CALL16 reloc at 0x%lx not against global symbol"),
5310 bfd_archive_filename (abfd), (unsigned long) rel->r_offset);
5311 bfd_set_error (bfd_error_bad_value);
5312 return FALSE;
5313 }
5314 /* Fall through. */
5315
5316 case R_MIPS_CALL_HI16:
5317 case R_MIPS_CALL_LO16:
5318 if (h != NULL)
5319 {
5320 /* This symbol requires a global offset table entry. */
5321 if (! mips_elf_record_global_got_symbol (h, abfd, info, g))
5322 return FALSE;
5323
5324 /* We need a stub, not a plt entry for the undefined
5325 function. But we record it as if it needs plt. See
5326 _bfd_elf_adjust_dynamic_symbol. */
5327 h->elf_link_hash_flags |= ELF_LINK_HASH_NEEDS_PLT;
5328 h->type = STT_FUNC;
5329 }
5330 break;
5331
5332 case R_MIPS_GOT_PAGE:
5333 /* If this is a global, overridable symbol, GOT_PAGE will
5334 decay to GOT_DISP, so we'll need a GOT entry for it. */
5335 if (h == NULL)
5336 break;
5337 else
5338 {
5339 struct mips_elf_link_hash_entry *hmips =
5340 (struct mips_elf_link_hash_entry *) h;
5341
5342 while (hmips->root.root.type == bfd_link_hash_indirect
5343 || hmips->root.root.type == bfd_link_hash_warning)
5344 hmips = (struct mips_elf_link_hash_entry *)
5345 hmips->root.root.u.i.link;
5346
5347 if ((hmips->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR)
5348 && ! (info->shared && ! info->symbolic
5349 && ! (hmips->root.elf_link_hash_flags
5350 & ELF_LINK_FORCED_LOCAL)))
5351 break;
5352 }
5353 /* Fall through. */
5354
5355 case R_MIPS_GOT16:
5356 case R_MIPS_GOT_HI16:
5357 case R_MIPS_GOT_LO16:
5358 case R_MIPS_GOT_DISP:
5359 /* This symbol requires a global offset table entry. */
5360 if (h && ! mips_elf_record_global_got_symbol (h, abfd, info, g))
5361 return FALSE;
5362 break;
5363
5364 case R_MIPS_32:
5365 case R_MIPS_REL32:
5366 case R_MIPS_64:
5367 if ((info->shared || h != NULL)
5368 && (sec->flags & SEC_ALLOC) != 0)
5369 {
5370 if (sreloc == NULL)
5371 {
5372 sreloc = mips_elf_rel_dyn_section (dynobj, TRUE);
5373 if (sreloc == NULL)
5374 return FALSE;
5375 }
5376 #define MIPS_READONLY_SECTION (SEC_ALLOC | SEC_LOAD | SEC_READONLY)
5377 if (info->shared)
5378 {
5379 /* When creating a shared object, we must copy these
5380 reloc types into the output file as R_MIPS_REL32
5381 relocs. We make room for this reloc in the
5382 .rel.dyn reloc section. */
5383 mips_elf_allocate_dynamic_relocations (dynobj, 1);
5384 if ((sec->flags & MIPS_READONLY_SECTION)
5385 == MIPS_READONLY_SECTION)
5386 /* We tell the dynamic linker that there are
5387 relocations against the text segment. */
5388 info->flags |= DF_TEXTREL;
5389 }
5390 else
5391 {
5392 struct mips_elf_link_hash_entry *hmips;
5393
5394 /* We only need to copy this reloc if the symbol is
5395 defined in a dynamic object. */
5396 hmips = (struct mips_elf_link_hash_entry *) h;
5397 ++hmips->possibly_dynamic_relocs;
5398 if ((sec->flags & MIPS_READONLY_SECTION)
5399 == MIPS_READONLY_SECTION)
5400 /* We need it to tell the dynamic linker if there
5401 are relocations against the text segment. */
5402 hmips->readonly_reloc = TRUE;
5403 }
5404
5405 /* Even though we don't directly need a GOT entry for
5406 this symbol, a symbol must have a dynamic symbol
5407 table index greater that DT_MIPS_GOTSYM if there are
5408 dynamic relocations against it. */
5409 if (h != NULL)
5410 {
5411 if (dynobj == NULL)
5412 elf_hash_table (info)->dynobj = dynobj = abfd;
5413 if (! mips_elf_create_got_section (dynobj, info, TRUE))
5414 return FALSE;
5415 g = mips_elf_got_info (dynobj, &sgot);
5416 if (! mips_elf_record_global_got_symbol (h, abfd, info, g))
5417 return FALSE;
5418 }
5419 }
5420
5421 if (SGI_COMPAT (abfd))
5422 mips_elf_hash_table (info)->compact_rel_size +=
5423 sizeof (Elf32_External_crinfo);
5424 break;
5425
5426 case R_MIPS_26:
5427 case R_MIPS_GPREL16:
5428 case R_MIPS_LITERAL:
5429 case R_MIPS_GPREL32:
5430 if (SGI_COMPAT (abfd))
5431 mips_elf_hash_table (info)->compact_rel_size +=
5432 sizeof (Elf32_External_crinfo);
5433 break;
5434
5435 /* This relocation describes the C++ object vtable hierarchy.
5436 Reconstruct it for later use during GC. */
5437 case R_MIPS_GNU_VTINHERIT:
5438 if (!bfd_elf_gc_record_vtinherit (abfd, sec, h, rel->r_offset))
5439 return FALSE;
5440 break;
5441
5442 /* This relocation describes which C++ vtable entries are actually
5443 used. Record for later use during GC. */
5444 case R_MIPS_GNU_VTENTRY:
5445 if (!bfd_elf_gc_record_vtentry (abfd, sec, h, rel->r_offset))
5446 return FALSE;
5447 break;
5448
5449 default:
5450 break;
5451 }
5452
5453 /* We must not create a stub for a symbol that has relocations
5454 related to taking the function's address. */
5455 switch (r_type)
5456 {
5457 default:
5458 if (h != NULL)
5459 {
5460 struct mips_elf_link_hash_entry *mh;
5461
5462 mh = (struct mips_elf_link_hash_entry *) h;
5463 mh->no_fn_stub = TRUE;
5464 }
5465 break;
5466 case R_MIPS_CALL16:
5467 case R_MIPS_CALL_HI16:
5468 case R_MIPS_CALL_LO16:
5469 case R_MIPS_JALR:
5470 break;
5471 }
5472
5473 /* If this reloc is not a 16 bit call, and it has a global
5474 symbol, then we will need the fn_stub if there is one.
5475 References from a stub section do not count. */
5476 if (h != NULL
5477 && r_type != R_MIPS16_26
5478 && strncmp (bfd_get_section_name (abfd, sec), FN_STUB,
5479 sizeof FN_STUB - 1) != 0
5480 && strncmp (bfd_get_section_name (abfd, sec), CALL_STUB,
5481 sizeof CALL_STUB - 1) != 0
5482 && strncmp (bfd_get_section_name (abfd, sec), CALL_FP_STUB,
5483 sizeof CALL_FP_STUB - 1) != 0)
5484 {
5485 struct mips_elf_link_hash_entry *mh;
5486
5487 mh = (struct mips_elf_link_hash_entry *) h;
5488 mh->need_fn_stub = TRUE;
5489 }
5490 }
5491
5492 return TRUE;
5493 }
5494 \f
5495 bfd_boolean
5496 _bfd_mips_relax_section (bfd *abfd, asection *sec,
5497 struct bfd_link_info *link_info,
5498 bfd_boolean *again)
5499 {
5500 Elf_Internal_Rela *internal_relocs;
5501 Elf_Internal_Rela *irel, *irelend;
5502 Elf_Internal_Shdr *symtab_hdr;
5503 bfd_byte *contents = NULL;
5504 bfd_byte *free_contents = NULL;
5505 size_t extsymoff;
5506 bfd_boolean changed_contents = FALSE;
5507 bfd_vma sec_start = sec->output_section->vma + sec->output_offset;
5508 Elf_Internal_Sym *isymbuf = NULL;
5509
5510 /* We are not currently changing any sizes, so only one pass. */
5511 *again = FALSE;
5512
5513 if (link_info->relocatable)
5514 return TRUE;
5515
5516 internal_relocs = _bfd_elf_link_read_relocs (abfd, sec, NULL, NULL,
5517 link_info->keep_memory);
5518 if (internal_relocs == NULL)
5519 return TRUE;
5520
5521 irelend = internal_relocs + sec->reloc_count
5522 * get_elf_backend_data (abfd)->s->int_rels_per_ext_rel;
5523 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
5524 extsymoff = (elf_bad_symtab (abfd)) ? 0 : symtab_hdr->sh_info;
5525
5526 for (irel = internal_relocs; irel < irelend; irel++)
5527 {
5528 bfd_vma symval;
5529 bfd_signed_vma sym_offset;
5530 unsigned int r_type;
5531 unsigned long r_symndx;
5532 asection *sym_sec;
5533 unsigned long instruction;
5534
5535 /* Turn jalr into bgezal, and jr into beq, if they're marked
5536 with a JALR relocation, that indicate where they jump to.
5537 This saves some pipeline bubbles. */
5538 r_type = ELF_R_TYPE (abfd, irel->r_info);
5539 if (r_type != R_MIPS_JALR)
5540 continue;
5541
5542 r_symndx = ELF_R_SYM (abfd, irel->r_info);
5543 /* Compute the address of the jump target. */
5544 if (r_symndx >= extsymoff)
5545 {
5546 struct mips_elf_link_hash_entry *h
5547 = ((struct mips_elf_link_hash_entry *)
5548 elf_sym_hashes (abfd) [r_symndx - extsymoff]);
5549
5550 while (h->root.root.type == bfd_link_hash_indirect
5551 || h->root.root.type == bfd_link_hash_warning)
5552 h = (struct mips_elf_link_hash_entry *) h->root.root.u.i.link;
5553
5554 /* If a symbol is undefined, or if it may be overridden,
5555 skip it. */
5556 if (! ((h->root.root.type == bfd_link_hash_defined
5557 || h->root.root.type == bfd_link_hash_defweak)
5558 && h->root.root.u.def.section)
5559 || (link_info->shared && ! link_info->symbolic
5560 && ! (h->root.elf_link_hash_flags & ELF_LINK_FORCED_LOCAL)))
5561 continue;
5562
5563 sym_sec = h->root.root.u.def.section;
5564 if (sym_sec->output_section)
5565 symval = (h->root.root.u.def.value
5566 + sym_sec->output_section->vma
5567 + sym_sec->output_offset);
5568 else
5569 symval = h->root.root.u.def.value;
5570 }
5571 else
5572 {
5573 Elf_Internal_Sym *isym;
5574
5575 /* Read this BFD's symbols if we haven't done so already. */
5576 if (isymbuf == NULL && symtab_hdr->sh_info != 0)
5577 {
5578 isymbuf = (Elf_Internal_Sym *) symtab_hdr->contents;
5579 if (isymbuf == NULL)
5580 isymbuf = bfd_elf_get_elf_syms (abfd, symtab_hdr,
5581 symtab_hdr->sh_info, 0,
5582 NULL, NULL, NULL);
5583 if (isymbuf == NULL)
5584 goto relax_return;
5585 }
5586
5587 isym = isymbuf + r_symndx;
5588 if (isym->st_shndx == SHN_UNDEF)
5589 continue;
5590 else if (isym->st_shndx == SHN_ABS)
5591 sym_sec = bfd_abs_section_ptr;
5592 else if (isym->st_shndx == SHN_COMMON)
5593 sym_sec = bfd_com_section_ptr;
5594 else
5595 sym_sec
5596 = bfd_section_from_elf_index (abfd, isym->st_shndx);
5597 symval = isym->st_value
5598 + sym_sec->output_section->vma
5599 + sym_sec->output_offset;
5600 }
5601
5602 /* Compute branch offset, from delay slot of the jump to the
5603 branch target. */
5604 sym_offset = (symval + irel->r_addend)
5605 - (sec_start + irel->r_offset + 4);
5606
5607 /* Branch offset must be properly aligned. */
5608 if ((sym_offset & 3) != 0)
5609 continue;
5610
5611 sym_offset >>= 2;
5612
5613 /* Check that it's in range. */
5614 if (sym_offset < -0x8000 || sym_offset >= 0x8000)
5615 continue;
5616
5617 /* Get the section contents if we haven't done so already. */
5618 if (contents == NULL)
5619 {
5620 /* Get cached copy if it exists. */
5621 if (elf_section_data (sec)->this_hdr.contents != NULL)
5622 contents = elf_section_data (sec)->this_hdr.contents;
5623 else
5624 {
5625 contents = bfd_malloc (sec->_raw_size);
5626 if (contents == NULL)
5627 goto relax_return;
5628
5629 free_contents = contents;
5630 if (! bfd_get_section_contents (abfd, sec, contents,
5631 0, sec->_raw_size))
5632 goto relax_return;
5633 }
5634 }
5635
5636 instruction = bfd_get_32 (abfd, contents + irel->r_offset);
5637
5638 /* If it was jalr <reg>, turn it into bgezal $zero, <target>. */
5639 if ((instruction & 0xfc1fffff) == 0x0000f809)
5640 instruction = 0x04110000;
5641 /* If it was jr <reg>, turn it into b <target>. */
5642 else if ((instruction & 0xfc1fffff) == 0x00000008)
5643 instruction = 0x10000000;
5644 else
5645 continue;
5646
5647 instruction |= (sym_offset & 0xffff);
5648 bfd_put_32 (abfd, instruction, contents + irel->r_offset);
5649 changed_contents = TRUE;
5650 }
5651
5652 if (contents != NULL
5653 && elf_section_data (sec)->this_hdr.contents != contents)
5654 {
5655 if (!changed_contents && !link_info->keep_memory)
5656 free (contents);
5657 else
5658 {
5659 /* Cache the section contents for elf_link_input_bfd. */
5660 elf_section_data (sec)->this_hdr.contents = contents;
5661 }
5662 }
5663 return TRUE;
5664
5665 relax_return:
5666 if (free_contents != NULL)
5667 free (free_contents);
5668 return FALSE;
5669 }
5670 \f
5671 /* Adjust a symbol defined by a dynamic object and referenced by a
5672 regular object. The current definition is in some section of the
5673 dynamic object, but we're not including those sections. We have to
5674 change the definition to something the rest of the link can
5675 understand. */
5676
5677 bfd_boolean
5678 _bfd_mips_elf_adjust_dynamic_symbol (struct bfd_link_info *info,
5679 struct elf_link_hash_entry *h)
5680 {
5681 bfd *dynobj;
5682 struct mips_elf_link_hash_entry *hmips;
5683 asection *s;
5684
5685 dynobj = elf_hash_table (info)->dynobj;
5686
5687 /* Make sure we know what is going on here. */
5688 BFD_ASSERT (dynobj != NULL
5689 && ((h->elf_link_hash_flags & ELF_LINK_HASH_NEEDS_PLT)
5690 || h->weakdef != NULL
5691 || ((h->elf_link_hash_flags
5692 & ELF_LINK_HASH_DEF_DYNAMIC) != 0
5693 && (h->elf_link_hash_flags
5694 & ELF_LINK_HASH_REF_REGULAR) != 0
5695 && (h->elf_link_hash_flags
5696 & ELF_LINK_HASH_DEF_REGULAR) == 0)));
5697
5698 /* If this symbol is defined in a dynamic object, we need to copy
5699 any R_MIPS_32 or R_MIPS_REL32 relocs against it into the output
5700 file. */
5701 hmips = (struct mips_elf_link_hash_entry *) h;
5702 if (! info->relocatable
5703 && hmips->possibly_dynamic_relocs != 0
5704 && (h->root.type == bfd_link_hash_defweak
5705 || (h->elf_link_hash_flags
5706 & ELF_LINK_HASH_DEF_REGULAR) == 0))
5707 {
5708 mips_elf_allocate_dynamic_relocations (dynobj,
5709 hmips->possibly_dynamic_relocs);
5710 if (hmips->readonly_reloc)
5711 /* We tell the dynamic linker that there are relocations
5712 against the text segment. */
5713 info->flags |= DF_TEXTREL;
5714 }
5715
5716 /* For a function, create a stub, if allowed. */
5717 if (! hmips->no_fn_stub
5718 && (h->elf_link_hash_flags & ELF_LINK_HASH_NEEDS_PLT) != 0)
5719 {
5720 if (! elf_hash_table (info)->dynamic_sections_created)
5721 return TRUE;
5722
5723 /* If this symbol is not defined in a regular file, then set
5724 the symbol to the stub location. This is required to make
5725 function pointers compare as equal between the normal
5726 executable and the shared library. */
5727 if ((h->elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR) == 0)
5728 {
5729 /* We need .stub section. */
5730 s = bfd_get_section_by_name (dynobj,
5731 MIPS_ELF_STUB_SECTION_NAME (dynobj));
5732 BFD_ASSERT (s != NULL);
5733
5734 h->root.u.def.section = s;
5735 h->root.u.def.value = s->_raw_size;
5736
5737 /* XXX Write this stub address somewhere. */
5738 h->plt.offset = s->_raw_size;
5739
5740 /* Make room for this stub code. */
5741 s->_raw_size += MIPS_FUNCTION_STUB_SIZE;
5742
5743 /* The last half word of the stub will be filled with the index
5744 of this symbol in .dynsym section. */
5745 return TRUE;
5746 }
5747 }
5748 else if ((h->type == STT_FUNC)
5749 && (h->elf_link_hash_flags & ELF_LINK_HASH_NEEDS_PLT) == 0)
5750 {
5751 /* This will set the entry for this symbol in the GOT to 0, and
5752 the dynamic linker will take care of this. */
5753 h->root.u.def.value = 0;
5754 return TRUE;
5755 }
5756
5757 /* If this is a weak symbol, and there is a real definition, the
5758 processor independent code will have arranged for us to see the
5759 real definition first, and we can just use the same value. */
5760 if (h->weakdef != NULL)
5761 {
5762 BFD_ASSERT (h->weakdef->root.type == bfd_link_hash_defined
5763 || h->weakdef->root.type == bfd_link_hash_defweak);
5764 h->root.u.def.section = h->weakdef->root.u.def.section;
5765 h->root.u.def.value = h->weakdef->root.u.def.value;
5766 return TRUE;
5767 }
5768
5769 /* This is a reference to a symbol defined by a dynamic object which
5770 is not a function. */
5771
5772 return TRUE;
5773 }
5774 \f
5775 /* This function is called after all the input files have been read,
5776 and the input sections have been assigned to output sections. We
5777 check for any mips16 stub sections that we can discard. */
5778
5779 bfd_boolean
5780 _bfd_mips_elf_always_size_sections (bfd *output_bfd,
5781 struct bfd_link_info *info)
5782 {
5783 asection *ri;
5784
5785 bfd *dynobj;
5786 asection *s;
5787 struct mips_got_info *g;
5788 int i;
5789 bfd_size_type loadable_size = 0;
5790 bfd_size_type local_gotno;
5791 bfd *sub;
5792
5793 /* The .reginfo section has a fixed size. */
5794 ri = bfd_get_section_by_name (output_bfd, ".reginfo");
5795 if (ri != NULL)
5796 bfd_set_section_size (output_bfd, ri, sizeof (Elf32_External_RegInfo));
5797
5798 if (! (info->relocatable
5799 || ! mips_elf_hash_table (info)->mips16_stubs_seen))
5800 mips_elf_link_hash_traverse (mips_elf_hash_table (info),
5801 mips_elf_check_mips16_stubs, NULL);
5802
5803 dynobj = elf_hash_table (info)->dynobj;
5804 if (dynobj == NULL)
5805 /* Relocatable links don't have it. */
5806 return TRUE;
5807
5808 g = mips_elf_got_info (dynobj, &s);
5809 if (s == NULL)
5810 return TRUE;
5811
5812 /* Calculate the total loadable size of the output. That
5813 will give us the maximum number of GOT_PAGE entries
5814 required. */
5815 for (sub = info->input_bfds; sub; sub = sub->link_next)
5816 {
5817 asection *subsection;
5818
5819 for (subsection = sub->sections;
5820 subsection;
5821 subsection = subsection->next)
5822 {
5823 if ((subsection->flags & SEC_ALLOC) == 0)
5824 continue;
5825 loadable_size += ((subsection->_raw_size + 0xf)
5826 &~ (bfd_size_type) 0xf);
5827 }
5828 }
5829
5830 /* There has to be a global GOT entry for every symbol with
5831 a dynamic symbol table index of DT_MIPS_GOTSYM or
5832 higher. Therefore, it make sense to put those symbols
5833 that need GOT entries at the end of the symbol table. We
5834 do that here. */
5835 if (! mips_elf_sort_hash_table (info, 1))
5836 return FALSE;
5837
5838 if (g->global_gotsym != NULL)
5839 i = elf_hash_table (info)->dynsymcount - g->global_gotsym->dynindx;
5840 else
5841 /* If there are no global symbols, or none requiring
5842 relocations, then GLOBAL_GOTSYM will be NULL. */
5843 i = 0;
5844
5845 /* In the worst case, we'll get one stub per dynamic symbol, plus
5846 one to account for the dummy entry at the end required by IRIX
5847 rld. */
5848 loadable_size += MIPS_FUNCTION_STUB_SIZE * (i + 1);
5849
5850 /* Assume there are two loadable segments consisting of
5851 contiguous sections. Is 5 enough? */
5852 local_gotno = (loadable_size >> 16) + 5;
5853
5854 g->local_gotno += local_gotno;
5855 s->_raw_size += g->local_gotno * MIPS_ELF_GOT_SIZE (output_bfd);
5856
5857 g->global_gotno = i;
5858 s->_raw_size += i * MIPS_ELF_GOT_SIZE (output_bfd);
5859
5860 if (s->_raw_size > MIPS_ELF_GOT_MAX_SIZE (output_bfd)
5861 && ! mips_elf_multi_got (output_bfd, info, g, s, local_gotno))
5862 return FALSE;
5863
5864 return TRUE;
5865 }
5866
5867 /* Set the sizes of the dynamic sections. */
5868
5869 bfd_boolean
5870 _bfd_mips_elf_size_dynamic_sections (bfd *output_bfd,
5871 struct bfd_link_info *info)
5872 {
5873 bfd *dynobj;
5874 asection *s;
5875 bfd_boolean reltext;
5876
5877 dynobj = elf_hash_table (info)->dynobj;
5878 BFD_ASSERT (dynobj != NULL);
5879
5880 if (elf_hash_table (info)->dynamic_sections_created)
5881 {
5882 /* Set the contents of the .interp section to the interpreter. */
5883 if (info->executable)
5884 {
5885 s = bfd_get_section_by_name (dynobj, ".interp");
5886 BFD_ASSERT (s != NULL);
5887 s->_raw_size
5888 = strlen (ELF_DYNAMIC_INTERPRETER (output_bfd)) + 1;
5889 s->contents
5890 = (bfd_byte *) ELF_DYNAMIC_INTERPRETER (output_bfd);
5891 }
5892 }
5893
5894 /* The check_relocs and adjust_dynamic_symbol entry points have
5895 determined the sizes of the various dynamic sections. Allocate
5896 memory for them. */
5897 reltext = FALSE;
5898 for (s = dynobj->sections; s != NULL; s = s->next)
5899 {
5900 const char *name;
5901 bfd_boolean strip;
5902
5903 /* It's OK to base decisions on the section name, because none
5904 of the dynobj section names depend upon the input files. */
5905 name = bfd_get_section_name (dynobj, s);
5906
5907 if ((s->flags & SEC_LINKER_CREATED) == 0)
5908 continue;
5909
5910 strip = FALSE;
5911
5912 if (strncmp (name, ".rel", 4) == 0)
5913 {
5914 if (s->_raw_size == 0)
5915 {
5916 /* We only strip the section if the output section name
5917 has the same name. Otherwise, there might be several
5918 input sections for this output section. FIXME: This
5919 code is probably not needed these days anyhow, since
5920 the linker now does not create empty output sections. */
5921 if (s->output_section != NULL
5922 && strcmp (name,
5923 bfd_get_section_name (s->output_section->owner,
5924 s->output_section)) == 0)
5925 strip = TRUE;
5926 }
5927 else
5928 {
5929 const char *outname;
5930 asection *target;
5931
5932 /* If this relocation section applies to a read only
5933 section, then we probably need a DT_TEXTREL entry.
5934 If the relocation section is .rel.dyn, we always
5935 assert a DT_TEXTREL entry rather than testing whether
5936 there exists a relocation to a read only section or
5937 not. */
5938 outname = bfd_get_section_name (output_bfd,
5939 s->output_section);
5940 target = bfd_get_section_by_name (output_bfd, outname + 4);
5941 if ((target != NULL
5942 && (target->flags & SEC_READONLY) != 0
5943 && (target->flags & SEC_ALLOC) != 0)
5944 || strcmp (outname, ".rel.dyn") == 0)
5945 reltext = TRUE;
5946
5947 /* We use the reloc_count field as a counter if we need
5948 to copy relocs into the output file. */
5949 if (strcmp (name, ".rel.dyn") != 0)
5950 s->reloc_count = 0;
5951
5952 /* If combreloc is enabled, elf_link_sort_relocs() will
5953 sort relocations, but in a different way than we do,
5954 and before we're done creating relocations. Also, it
5955 will move them around between input sections'
5956 relocation's contents, so our sorting would be
5957 broken, so don't let it run. */
5958 info->combreloc = 0;
5959 }
5960 }
5961 else if (strncmp (name, ".got", 4) == 0)
5962 {
5963 /* _bfd_mips_elf_always_size_sections() has already done
5964 most of the work, but some symbols may have been mapped
5965 to versions that we must now resolve in the got_entries
5966 hash tables. */
5967 struct mips_got_info *gg = mips_elf_got_info (dynobj, NULL);
5968 struct mips_got_info *g = gg;
5969 struct mips_elf_set_global_got_offset_arg set_got_offset_arg;
5970 unsigned int needed_relocs = 0;
5971
5972 if (gg->next)
5973 {
5974 set_got_offset_arg.value = MIPS_ELF_GOT_SIZE (output_bfd);
5975 set_got_offset_arg.info = info;
5976
5977 mips_elf_resolve_final_got_entries (gg);
5978 for (g = gg->next; g && g->next != gg; g = g->next)
5979 {
5980 unsigned int save_assign;
5981
5982 mips_elf_resolve_final_got_entries (g);
5983
5984 /* Assign offsets to global GOT entries. */
5985 save_assign = g->assigned_gotno;
5986 g->assigned_gotno = g->local_gotno;
5987 set_got_offset_arg.g = g;
5988 set_got_offset_arg.needed_relocs = 0;
5989 htab_traverse (g->got_entries,
5990 mips_elf_set_global_got_offset,
5991 &set_got_offset_arg);
5992 needed_relocs += set_got_offset_arg.needed_relocs;
5993 BFD_ASSERT (g->assigned_gotno - g->local_gotno
5994 <= g->global_gotno);
5995
5996 g->assigned_gotno = save_assign;
5997 if (info->shared)
5998 {
5999 needed_relocs += g->local_gotno - g->assigned_gotno;
6000 BFD_ASSERT (g->assigned_gotno == g->next->local_gotno
6001 + g->next->global_gotno
6002 + MIPS_RESERVED_GOTNO);
6003 }
6004 }
6005
6006 if (needed_relocs)
6007 mips_elf_allocate_dynamic_relocations (dynobj, needed_relocs);
6008 }
6009 }
6010 else if (strcmp (name, MIPS_ELF_STUB_SECTION_NAME (output_bfd)) == 0)
6011 {
6012 /* IRIX rld assumes that the function stub isn't at the end
6013 of .text section. So put a dummy. XXX */
6014 s->_raw_size += MIPS_FUNCTION_STUB_SIZE;
6015 }
6016 else if (! info->shared
6017 && ! mips_elf_hash_table (info)->use_rld_obj_head
6018 && strncmp (name, ".rld_map", 8) == 0)
6019 {
6020 /* We add a room for __rld_map. It will be filled in by the
6021 rtld to contain a pointer to the _r_debug structure. */
6022 s->_raw_size += 4;
6023 }
6024 else if (SGI_COMPAT (output_bfd)
6025 && strncmp (name, ".compact_rel", 12) == 0)
6026 s->_raw_size += mips_elf_hash_table (info)->compact_rel_size;
6027 else if (strncmp (name, ".init", 5) != 0)
6028 {
6029 /* It's not one of our sections, so don't allocate space. */
6030 continue;
6031 }
6032
6033 if (strip)
6034 {
6035 _bfd_strip_section_from_output (info, s);
6036 continue;
6037 }
6038
6039 /* Allocate memory for the section contents. */
6040 s->contents = bfd_zalloc (dynobj, s->_raw_size);
6041 if (s->contents == NULL && s->_raw_size != 0)
6042 {
6043 bfd_set_error (bfd_error_no_memory);
6044 return FALSE;
6045 }
6046 }
6047
6048 if (elf_hash_table (info)->dynamic_sections_created)
6049 {
6050 /* Add some entries to the .dynamic section. We fill in the
6051 values later, in _bfd_mips_elf_finish_dynamic_sections, but we
6052 must add the entries now so that we get the correct size for
6053 the .dynamic section. The DT_DEBUG entry is filled in by the
6054 dynamic linker and used by the debugger. */
6055 if (! info->shared)
6056 {
6057 /* SGI object has the equivalence of DT_DEBUG in the
6058 DT_MIPS_RLD_MAP entry. */
6059 if (!MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_RLD_MAP, 0))
6060 return FALSE;
6061 if (!SGI_COMPAT (output_bfd))
6062 {
6063 if (!MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_DEBUG, 0))
6064 return FALSE;
6065 }
6066 }
6067 else
6068 {
6069 /* Shared libraries on traditional mips have DT_DEBUG. */
6070 if (!SGI_COMPAT (output_bfd))
6071 {
6072 if (!MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_DEBUG, 0))
6073 return FALSE;
6074 }
6075 }
6076
6077 if (reltext && SGI_COMPAT (output_bfd))
6078 info->flags |= DF_TEXTREL;
6079
6080 if ((info->flags & DF_TEXTREL) != 0)
6081 {
6082 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_TEXTREL, 0))
6083 return FALSE;
6084 }
6085
6086 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_PLTGOT, 0))
6087 return FALSE;
6088
6089 if (mips_elf_rel_dyn_section (dynobj, FALSE))
6090 {
6091 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_REL, 0))
6092 return FALSE;
6093
6094 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_RELSZ, 0))
6095 return FALSE;
6096
6097 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_RELENT, 0))
6098 return FALSE;
6099 }
6100
6101 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_RLD_VERSION, 0))
6102 return FALSE;
6103
6104 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_FLAGS, 0))
6105 return FALSE;
6106
6107 #if 0
6108 /* Time stamps in executable files are a bad idea. */
6109 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_TIME_STAMP, 0))
6110 return FALSE;
6111 #endif
6112
6113 #if 0 /* FIXME */
6114 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_ICHECKSUM, 0))
6115 return FALSE;
6116 #endif
6117
6118 #if 0 /* FIXME */
6119 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_IVERSION, 0))
6120 return FALSE;
6121 #endif
6122
6123 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_BASE_ADDRESS, 0))
6124 return FALSE;
6125
6126 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_LOCAL_GOTNO, 0))
6127 return FALSE;
6128
6129 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_SYMTABNO, 0))
6130 return FALSE;
6131
6132 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_UNREFEXTNO, 0))
6133 return FALSE;
6134
6135 if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_GOTSYM, 0))
6136 return FALSE;
6137
6138 if (IRIX_COMPAT (dynobj) == ict_irix5
6139 && ! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_HIPAGENO, 0))
6140 return FALSE;
6141
6142 if (IRIX_COMPAT (dynobj) == ict_irix6
6143 && (bfd_get_section_by_name
6144 (dynobj, MIPS_ELF_OPTIONS_SECTION_NAME (dynobj)))
6145 && !MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_MIPS_OPTIONS, 0))
6146 return FALSE;
6147 }
6148
6149 return TRUE;
6150 }
6151 \f
6152 /* Relocate a MIPS ELF section. */
6153
6154 bfd_boolean
6155 _bfd_mips_elf_relocate_section (bfd *output_bfd, struct bfd_link_info *info,
6156 bfd *input_bfd, asection *input_section,
6157 bfd_byte *contents, Elf_Internal_Rela *relocs,
6158 Elf_Internal_Sym *local_syms,
6159 asection **local_sections)
6160 {
6161 Elf_Internal_Rela *rel;
6162 const Elf_Internal_Rela *relend;
6163 bfd_vma addend = 0;
6164 bfd_boolean use_saved_addend_p = FALSE;
6165 const struct elf_backend_data *bed;
6166
6167 bed = get_elf_backend_data (output_bfd);
6168 relend = relocs + input_section->reloc_count * bed->s->int_rels_per_ext_rel;
6169 for (rel = relocs; rel < relend; ++rel)
6170 {
6171 const char *name;
6172 bfd_vma value;
6173 reloc_howto_type *howto;
6174 bfd_boolean require_jalx;
6175 /* TRUE if the relocation is a RELA relocation, rather than a
6176 REL relocation. */
6177 bfd_boolean rela_relocation_p = TRUE;
6178 unsigned int r_type = ELF_R_TYPE (output_bfd, rel->r_info);
6179 const char *msg;
6180
6181 /* Find the relocation howto for this relocation. */
6182 if (r_type == R_MIPS_64 && ! NEWABI_P (input_bfd))
6183 {
6184 /* Some 32-bit code uses R_MIPS_64. In particular, people use
6185 64-bit code, but make sure all their addresses are in the
6186 lowermost or uppermost 32-bit section of the 64-bit address
6187 space. Thus, when they use an R_MIPS_64 they mean what is
6188 usually meant by R_MIPS_32, with the exception that the
6189 stored value is sign-extended to 64 bits. */
6190 howto = MIPS_ELF_RTYPE_TO_HOWTO (input_bfd, R_MIPS_32, FALSE);
6191
6192 /* On big-endian systems, we need to lie about the position
6193 of the reloc. */
6194 if (bfd_big_endian (input_bfd))
6195 rel->r_offset += 4;
6196 }
6197 else
6198 /* NewABI defaults to RELA relocations. */
6199 howto = MIPS_ELF_RTYPE_TO_HOWTO (input_bfd, r_type,
6200 NEWABI_P (input_bfd)
6201 && (MIPS_RELOC_RELA_P
6202 (input_bfd, input_section,
6203 rel - relocs)));
6204
6205 if (!use_saved_addend_p)
6206 {
6207 Elf_Internal_Shdr *rel_hdr;
6208
6209 /* If these relocations were originally of the REL variety,
6210 we must pull the addend out of the field that will be
6211 relocated. Otherwise, we simply use the contents of the
6212 RELA relocation. To determine which flavor or relocation
6213 this is, we depend on the fact that the INPUT_SECTION's
6214 REL_HDR is read before its REL_HDR2. */
6215 rel_hdr = &elf_section_data (input_section)->rel_hdr;
6216 if ((size_t) (rel - relocs)
6217 >= (NUM_SHDR_ENTRIES (rel_hdr) * bed->s->int_rels_per_ext_rel))
6218 rel_hdr = elf_section_data (input_section)->rel_hdr2;
6219 if (rel_hdr->sh_entsize == MIPS_ELF_REL_SIZE (input_bfd))
6220 {
6221 /* Note that this is a REL relocation. */
6222 rela_relocation_p = FALSE;
6223
6224 /* Get the addend, which is stored in the input file. */
6225 addend = mips_elf_obtain_contents (howto, rel, input_bfd,
6226 contents);
6227 addend &= howto->src_mask;
6228
6229 /* For some kinds of relocations, the ADDEND is a
6230 combination of the addend stored in two different
6231 relocations. */
6232 if (r_type == R_MIPS_HI16
6233 || r_type == R_MIPS_GNU_REL_HI16
6234 || (r_type == R_MIPS_GOT16
6235 && mips_elf_local_relocation_p (input_bfd, rel,
6236 local_sections, FALSE)))
6237 {
6238 bfd_vma l;
6239 const Elf_Internal_Rela *lo16_relocation;
6240 reloc_howto_type *lo16_howto;
6241 unsigned int lo;
6242
6243 /* The combined value is the sum of the HI16 addend,
6244 left-shifted by sixteen bits, and the LO16
6245 addend, sign extended. (Usually, the code does
6246 a `lui' of the HI16 value, and then an `addiu' of
6247 the LO16 value.)
6248
6249 Scan ahead to find a matching LO16 relocation. */
6250 if (r_type == R_MIPS_GNU_REL_HI16)
6251 lo = R_MIPS_GNU_REL_LO16;
6252 else
6253 lo = R_MIPS_LO16;
6254 lo16_relocation = mips_elf_next_relocation (input_bfd, lo,
6255 rel, relend);
6256 if (lo16_relocation == NULL)
6257 return FALSE;
6258
6259 /* Obtain the addend kept there. */
6260 lo16_howto = MIPS_ELF_RTYPE_TO_HOWTO (input_bfd, lo, FALSE);
6261 l = mips_elf_obtain_contents (lo16_howto, lo16_relocation,
6262 input_bfd, contents);
6263 l &= lo16_howto->src_mask;
6264 l <<= lo16_howto->rightshift;
6265 l = _bfd_mips_elf_sign_extend (l, 16);
6266
6267 addend <<= 16;
6268
6269 /* Compute the combined addend. */
6270 addend += l;
6271
6272 /* If PC-relative, subtract the difference between the
6273 address of the LO part of the reloc and the address of
6274 the HI part. The relocation is relative to the LO
6275 part, but mips_elf_calculate_relocation() doesn't
6276 know its address or the difference from the HI part, so
6277 we subtract that difference here. See also the
6278 comment in mips_elf_calculate_relocation(). */
6279 if (r_type == R_MIPS_GNU_REL_HI16)
6280 addend -= (lo16_relocation->r_offset - rel->r_offset);
6281 }
6282 else if (r_type == R_MIPS16_GPREL)
6283 {
6284 /* The addend is scrambled in the object file. See
6285 mips_elf_perform_relocation for details on the
6286 format. */
6287 addend = (((addend & 0x1f0000) >> 5)
6288 | ((addend & 0x7e00000) >> 16)
6289 | (addend & 0x1f));
6290 }
6291 else
6292 addend <<= howto->rightshift;
6293 }
6294 else
6295 addend = rel->r_addend;
6296 }
6297
6298 if (info->relocatable)
6299 {
6300 Elf_Internal_Sym *sym;
6301 unsigned long r_symndx;
6302
6303 if (r_type == R_MIPS_64 && ! NEWABI_P (output_bfd)
6304 && bfd_big_endian (input_bfd))
6305 rel->r_offset -= 4;
6306
6307 /* Since we're just relocating, all we need to do is copy
6308 the relocations back out to the object file, unless
6309 they're against a section symbol, in which case we need
6310 to adjust by the section offset, or unless they're GP
6311 relative in which case we need to adjust by the amount
6312 that we're adjusting GP in this relocatable object. */
6313
6314 if (! mips_elf_local_relocation_p (input_bfd, rel, local_sections,
6315 FALSE))
6316 /* There's nothing to do for non-local relocations. */
6317 continue;
6318
6319 if (r_type == R_MIPS16_GPREL
6320 || r_type == R_MIPS_GPREL16
6321 || r_type == R_MIPS_GPREL32
6322 || r_type == R_MIPS_LITERAL)
6323 addend -= (_bfd_get_gp_value (output_bfd)
6324 - _bfd_get_gp_value (input_bfd));
6325
6326 r_symndx = ELF_R_SYM (output_bfd, rel->r_info);
6327 sym = local_syms + r_symndx;
6328 if (ELF_ST_TYPE (sym->st_info) == STT_SECTION)
6329 /* Adjust the addend appropriately. */
6330 addend += local_sections[r_symndx]->output_offset;
6331
6332 if (rela_relocation_p)
6333 /* If this is a RELA relocation, just update the addend. */
6334 rel->r_addend = addend;
6335 else
6336 {
6337 if (r_type == R_MIPS_HI16
6338 || r_type == R_MIPS_GOT16
6339 || r_type == R_MIPS_GNU_REL_HI16)
6340 addend = mips_elf_high (addend);
6341 else if (r_type == R_MIPS_HIGHER)
6342 addend = mips_elf_higher (addend);
6343 else if (r_type == R_MIPS_HIGHEST)
6344 addend = mips_elf_highest (addend);
6345 else
6346 addend >>= howto->rightshift;
6347
6348 /* We use the source mask, rather than the destination
6349 mask because the place to which we are writing will be
6350 source of the addend in the final link. */
6351 addend &= howto->src_mask;
6352
6353 if (r_type == R_MIPS_64 && ! NEWABI_P (output_bfd))
6354 /* See the comment above about using R_MIPS_64 in the 32-bit
6355 ABI. Here, we need to update the addend. It would be
6356 possible to get away with just using the R_MIPS_32 reloc
6357 but for endianness. */
6358 {
6359 bfd_vma sign_bits;
6360 bfd_vma low_bits;
6361 bfd_vma high_bits;
6362
6363 if (addend & ((bfd_vma) 1 << 31))
6364 #ifdef BFD64
6365 sign_bits = ((bfd_vma) 1 << 32) - 1;
6366 #else
6367 sign_bits = -1;
6368 #endif
6369 else
6370 sign_bits = 0;
6371
6372 /* If we don't know that we have a 64-bit type,
6373 do two separate stores. */
6374 if (bfd_big_endian (input_bfd))
6375 {
6376 /* Store the sign-bits (which are most significant)
6377 first. */
6378 low_bits = sign_bits;
6379 high_bits = addend;
6380 }
6381 else
6382 {
6383 low_bits = addend;
6384 high_bits = sign_bits;
6385 }
6386 bfd_put_32 (input_bfd, low_bits,
6387 contents + rel->r_offset);
6388 bfd_put_32 (input_bfd, high_bits,
6389 contents + rel->r_offset + 4);
6390 continue;
6391 }
6392
6393 if (! mips_elf_perform_relocation (info, howto, rel, addend,
6394 input_bfd, input_section,
6395 contents, FALSE))
6396 return FALSE;
6397 }
6398
6399 /* Go on to the next relocation. */
6400 continue;
6401 }
6402
6403 /* In the N32 and 64-bit ABIs there may be multiple consecutive
6404 relocations for the same offset. In that case we are
6405 supposed to treat the output of each relocation as the addend
6406 for the next. */
6407 if (rel + 1 < relend
6408 && rel->r_offset == rel[1].r_offset
6409 && ELF_R_TYPE (input_bfd, rel[1].r_info) != R_MIPS_NONE)
6410 use_saved_addend_p = TRUE;
6411 else
6412 use_saved_addend_p = FALSE;
6413
6414 /* Figure out what value we are supposed to relocate. */
6415 switch (mips_elf_calculate_relocation (output_bfd, input_bfd,
6416 input_section, info, rel,
6417 addend, howto, local_syms,
6418 local_sections, &value,
6419 &name, &require_jalx,
6420 use_saved_addend_p))
6421 {
6422 case bfd_reloc_continue:
6423 /* There's nothing to do. */
6424 continue;
6425
6426 case bfd_reloc_undefined:
6427 /* mips_elf_calculate_relocation already called the
6428 undefined_symbol callback. There's no real point in
6429 trying to perform the relocation at this point, so we
6430 just skip ahead to the next relocation. */
6431 continue;
6432
6433 case bfd_reloc_notsupported:
6434 msg = _("internal error: unsupported relocation error");
6435 info->callbacks->warning
6436 (info, msg, name, input_bfd, input_section, rel->r_offset);
6437 return FALSE;
6438
6439 case bfd_reloc_overflow:
6440 if (use_saved_addend_p)
6441 /* Ignore overflow until we reach the last relocation for
6442 a given location. */
6443 ;
6444 else
6445 {
6446 BFD_ASSERT (name != NULL);
6447 if (! ((*info->callbacks->reloc_overflow)
6448 (info, name, howto->name, 0,
6449 input_bfd, input_section, rel->r_offset)))
6450 return FALSE;
6451 }
6452 break;
6453
6454 case bfd_reloc_ok:
6455 break;
6456
6457 default:
6458 abort ();
6459 break;
6460 }
6461
6462 /* If we've got another relocation for the address, keep going
6463 until we reach the last one. */
6464 if (use_saved_addend_p)
6465 {
6466 addend = value;
6467 continue;
6468 }
6469
6470 if (r_type == R_MIPS_64 && ! NEWABI_P (output_bfd))
6471 /* See the comment above about using R_MIPS_64 in the 32-bit
6472 ABI. Until now, we've been using the HOWTO for R_MIPS_32;
6473 that calculated the right value. Now, however, we
6474 sign-extend the 32-bit result to 64-bits, and store it as a
6475 64-bit value. We are especially generous here in that we
6476 go to extreme lengths to support this usage on systems with
6477 only a 32-bit VMA. */
6478 {
6479 bfd_vma sign_bits;
6480 bfd_vma low_bits;
6481 bfd_vma high_bits;
6482
6483 if (value & ((bfd_vma) 1 << 31))
6484 #ifdef BFD64
6485 sign_bits = ((bfd_vma) 1 << 32) - 1;
6486 #else
6487 sign_bits = -1;
6488 #endif
6489 else
6490 sign_bits = 0;
6491
6492 /* If we don't know that we have a 64-bit type,
6493 do two separate stores. */
6494 if (bfd_big_endian (input_bfd))
6495 {
6496 /* Undo what we did above. */
6497 rel->r_offset -= 4;
6498 /* Store the sign-bits (which are most significant)
6499 first. */
6500 low_bits = sign_bits;
6501 high_bits = value;
6502 }
6503 else
6504 {
6505 low_bits = value;
6506 high_bits = sign_bits;
6507 }
6508 bfd_put_32 (input_bfd, low_bits,
6509 contents + rel->r_offset);
6510 bfd_put_32 (input_bfd, high_bits,
6511 contents + rel->r_offset + 4);
6512 continue;
6513 }
6514
6515 /* Actually perform the relocation. */
6516 if (! mips_elf_perform_relocation (info, howto, rel, value,
6517 input_bfd, input_section,
6518 contents, require_jalx))
6519 return FALSE;
6520 }
6521
6522 return TRUE;
6523 }
6524 \f
6525 /* If NAME is one of the special IRIX6 symbols defined by the linker,
6526 adjust it appropriately now. */
6527
6528 static void
6529 mips_elf_irix6_finish_dynamic_symbol (bfd *abfd ATTRIBUTE_UNUSED,
6530 const char *name, Elf_Internal_Sym *sym)
6531 {
6532 /* The linker script takes care of providing names and values for
6533 these, but we must place them into the right sections. */
6534 static const char* const text_section_symbols[] = {
6535 "_ftext",
6536 "_etext",
6537 "__dso_displacement",
6538 "__elf_header",
6539 "__program_header_table",
6540 NULL
6541 };
6542
6543 static const char* const data_section_symbols[] = {
6544 "_fdata",
6545 "_edata",
6546 "_end",
6547 "_fbss",
6548 NULL
6549 };
6550
6551 const char* const *p;
6552 int i;
6553
6554 for (i = 0; i < 2; ++i)
6555 for (p = (i == 0) ? text_section_symbols : data_section_symbols;
6556 *p;
6557 ++p)
6558 if (strcmp (*p, name) == 0)
6559 {
6560 /* All of these symbols are given type STT_SECTION by the
6561 IRIX6 linker. */
6562 sym->st_info = ELF_ST_INFO (STB_GLOBAL, STT_SECTION);
6563 sym->st_other = STO_PROTECTED;
6564
6565 /* The IRIX linker puts these symbols in special sections. */
6566 if (i == 0)
6567 sym->st_shndx = SHN_MIPS_TEXT;
6568 else
6569 sym->st_shndx = SHN_MIPS_DATA;
6570
6571 break;
6572 }
6573 }
6574
6575 /* Finish up dynamic symbol handling. We set the contents of various
6576 dynamic sections here. */
6577
6578 bfd_boolean
6579 _bfd_mips_elf_finish_dynamic_symbol (bfd *output_bfd,
6580 struct bfd_link_info *info,
6581 struct elf_link_hash_entry *h,
6582 Elf_Internal_Sym *sym)
6583 {
6584 bfd *dynobj;
6585 bfd_vma gval;
6586 asection *sgot;
6587 struct mips_got_info *g, *gg;
6588 const char *name;
6589
6590 dynobj = elf_hash_table (info)->dynobj;
6591 gval = sym->st_value;
6592
6593 if (h->plt.offset != (bfd_vma) -1)
6594 {
6595 asection *s;
6596 bfd_byte stub[MIPS_FUNCTION_STUB_SIZE];
6597
6598 /* This symbol has a stub. Set it up. */
6599
6600 BFD_ASSERT (h->dynindx != -1);
6601
6602 s = bfd_get_section_by_name (dynobj,
6603 MIPS_ELF_STUB_SECTION_NAME (dynobj));
6604 BFD_ASSERT (s != NULL);
6605
6606 /* FIXME: Can h->dynindex be more than 64K? */
6607 if (h->dynindx & 0xffff0000)
6608 return FALSE;
6609
6610 /* Fill the stub. */
6611 bfd_put_32 (output_bfd, STUB_LW (output_bfd), stub);
6612 bfd_put_32 (output_bfd, STUB_MOVE (output_bfd), stub + 4);
6613 bfd_put_32 (output_bfd, STUB_JALR, stub + 8);
6614 bfd_put_32 (output_bfd, STUB_LI16 (output_bfd) + h->dynindx, stub + 12);
6615
6616 BFD_ASSERT (h->plt.offset <= s->_raw_size);
6617 memcpy (s->contents + h->plt.offset, stub, MIPS_FUNCTION_STUB_SIZE);
6618
6619 /* Mark the symbol as undefined. plt.offset != -1 occurs
6620 only for the referenced symbol. */
6621 sym->st_shndx = SHN_UNDEF;
6622
6623 /* The run-time linker uses the st_value field of the symbol
6624 to reset the global offset table entry for this external
6625 to its stub address when unlinking a shared object. */
6626 gval = s->output_section->vma + s->output_offset + h->plt.offset;
6627 sym->st_value = gval;
6628 }
6629
6630 BFD_ASSERT (h->dynindx != -1
6631 || (h->elf_link_hash_flags & ELF_LINK_FORCED_LOCAL) != 0);
6632
6633 sgot = mips_elf_got_section (dynobj, FALSE);
6634 BFD_ASSERT (sgot != NULL);
6635 BFD_ASSERT (mips_elf_section_data (sgot) != NULL);
6636 g = mips_elf_section_data (sgot)->u.got_info;
6637 BFD_ASSERT (g != NULL);
6638
6639 /* Run through the global symbol table, creating GOT entries for all
6640 the symbols that need them. */
6641 if (g->global_gotsym != NULL
6642 && h->dynindx >= g->global_gotsym->dynindx)
6643 {
6644 bfd_vma offset;
6645 bfd_vma value;
6646
6647 value = sym->st_value;
6648 offset = mips_elf_global_got_index (dynobj, output_bfd, h);
6649 MIPS_ELF_PUT_WORD (output_bfd, value, sgot->contents + offset);
6650 }
6651
6652 if (g->next && h->dynindx != -1)
6653 {
6654 struct mips_got_entry e, *p;
6655 bfd_vma entry;
6656 bfd_vma offset;
6657
6658 gg = g;
6659
6660 e.abfd = output_bfd;
6661 e.symndx = -1;
6662 e.d.h = (struct mips_elf_link_hash_entry *)h;
6663
6664 for (g = g->next; g->next != gg; g = g->next)
6665 {
6666 if (g->got_entries
6667 && (p = (struct mips_got_entry *) htab_find (g->got_entries,
6668 &e)))
6669 {
6670 offset = p->gotidx;
6671 if (info->shared
6672 || (elf_hash_table (info)->dynamic_sections_created
6673 && p->d.h != NULL
6674 && ((p->d.h->root.elf_link_hash_flags
6675 & ELF_LINK_HASH_DEF_DYNAMIC) != 0)
6676 && ((p->d.h->root.elf_link_hash_flags
6677 & ELF_LINK_HASH_DEF_REGULAR) == 0)))
6678 {
6679 /* Create an R_MIPS_REL32 relocation for this entry. Due to
6680 the various compatibility problems, it's easier to mock
6681 up an R_MIPS_32 or R_MIPS_64 relocation and leave
6682 mips_elf_create_dynamic_relocation to calculate the
6683 appropriate addend. */
6684 Elf_Internal_Rela rel[3];
6685
6686 memset (rel, 0, sizeof (rel));
6687 if (ABI_64_P (output_bfd))
6688 rel[0].r_info = ELF_R_INFO (output_bfd, 0, R_MIPS_64);
6689 else
6690 rel[0].r_info = ELF_R_INFO (output_bfd, 0, R_MIPS_32);
6691 rel[0].r_offset = rel[1].r_offset = rel[2].r_offset = offset;
6692
6693 entry = 0;
6694 if (! (mips_elf_create_dynamic_relocation
6695 (output_bfd, info, rel,
6696 e.d.h, NULL, sym->st_value, &entry, sgot)))
6697 return FALSE;
6698 }
6699 else
6700 entry = sym->st_value;
6701 MIPS_ELF_PUT_WORD (output_bfd, entry, sgot->contents + offset);
6702 }
6703 }
6704 }
6705
6706 /* Mark _DYNAMIC and _GLOBAL_OFFSET_TABLE_ as absolute. */
6707 name = h->root.root.string;
6708 if (strcmp (name, "_DYNAMIC") == 0
6709 || strcmp (name, "_GLOBAL_OFFSET_TABLE_") == 0)
6710 sym->st_shndx = SHN_ABS;
6711 else if (strcmp (name, "_DYNAMIC_LINK") == 0
6712 || strcmp (name, "_DYNAMIC_LINKING") == 0)
6713 {
6714 sym->st_shndx = SHN_ABS;
6715 sym->st_info = ELF_ST_INFO (STB_GLOBAL, STT_SECTION);
6716 sym->st_value = 1;
6717 }
6718 else if (strcmp (name, "_gp_disp") == 0 && ! NEWABI_P (output_bfd))
6719 {
6720 sym->st_shndx = SHN_ABS;
6721 sym->st_info = ELF_ST_INFO (STB_GLOBAL, STT_SECTION);
6722 sym->st_value = elf_gp (output_bfd);
6723 }
6724 else if (SGI_COMPAT (output_bfd))
6725 {
6726 if (strcmp (name, mips_elf_dynsym_rtproc_names[0]) == 0
6727 || strcmp (name, mips_elf_dynsym_rtproc_names[1]) == 0)
6728 {
6729 sym->st_info = ELF_ST_INFO (STB_GLOBAL, STT_SECTION);
6730 sym->st_other = STO_PROTECTED;
6731 sym->st_value = 0;
6732 sym->st_shndx = SHN_MIPS_DATA;
6733 }
6734 else if (strcmp (name, mips_elf_dynsym_rtproc_names[2]) == 0)
6735 {
6736 sym->st_info = ELF_ST_INFO (STB_GLOBAL, STT_SECTION);
6737 sym->st_other = STO_PROTECTED;
6738 sym->st_value = mips_elf_hash_table (info)->procedure_count;
6739 sym->st_shndx = SHN_ABS;
6740 }
6741 else if (sym->st_shndx != SHN_UNDEF && sym->st_shndx != SHN_ABS)
6742 {
6743 if (h->type == STT_FUNC)
6744 sym->st_shndx = SHN_MIPS_TEXT;
6745 else if (h->type == STT_OBJECT)
6746 sym->st_shndx = SHN_MIPS_DATA;
6747 }
6748 }
6749
6750 /* Handle the IRIX6-specific symbols. */
6751 if (IRIX_COMPAT (output_bfd) == ict_irix6)
6752 mips_elf_irix6_finish_dynamic_symbol (output_bfd, name, sym);
6753
6754 if (! info->shared)
6755 {
6756 if (! mips_elf_hash_table (info)->use_rld_obj_head
6757 && (strcmp (name, "__rld_map") == 0
6758 || strcmp (name, "__RLD_MAP") == 0))
6759 {
6760 asection *s = bfd_get_section_by_name (dynobj, ".rld_map");
6761 BFD_ASSERT (s != NULL);
6762 sym->st_value = s->output_section->vma + s->output_offset;
6763 bfd_put_32 (output_bfd, 0, s->contents);
6764 if (mips_elf_hash_table (info)->rld_value == 0)
6765 mips_elf_hash_table (info)->rld_value = sym->st_value;
6766 }
6767 else if (mips_elf_hash_table (info)->use_rld_obj_head
6768 && strcmp (name, "__rld_obj_head") == 0)
6769 {
6770 /* IRIX6 does not use a .rld_map section. */
6771 if (IRIX_COMPAT (output_bfd) == ict_irix5
6772 || IRIX_COMPAT (output_bfd) == ict_none)
6773 BFD_ASSERT (bfd_get_section_by_name (dynobj, ".rld_map")
6774 != NULL);
6775 mips_elf_hash_table (info)->rld_value = sym->st_value;
6776 }
6777 }
6778
6779 /* If this is a mips16 symbol, force the value to be even. */
6780 if (sym->st_other == STO_MIPS16)
6781 sym->st_value &= ~1;
6782
6783 return TRUE;
6784 }
6785
6786 /* Finish up the dynamic sections. */
6787
6788 bfd_boolean
6789 _bfd_mips_elf_finish_dynamic_sections (bfd *output_bfd,
6790 struct bfd_link_info *info)
6791 {
6792 bfd *dynobj;
6793 asection *sdyn;
6794 asection *sgot;
6795 struct mips_got_info *gg, *g;
6796
6797 dynobj = elf_hash_table (info)->dynobj;
6798
6799 sdyn = bfd_get_section_by_name (dynobj, ".dynamic");
6800
6801 sgot = mips_elf_got_section (dynobj, FALSE);
6802 if (sgot == NULL)
6803 gg = g = NULL;
6804 else
6805 {
6806 BFD_ASSERT (mips_elf_section_data (sgot) != NULL);
6807 gg = mips_elf_section_data (sgot)->u.got_info;
6808 BFD_ASSERT (gg != NULL);
6809 g = mips_elf_got_for_ibfd (gg, output_bfd);
6810 BFD_ASSERT (g != NULL);
6811 }
6812
6813 if (elf_hash_table (info)->dynamic_sections_created)
6814 {
6815 bfd_byte *b;
6816
6817 BFD_ASSERT (sdyn != NULL);
6818 BFD_ASSERT (g != NULL);
6819
6820 for (b = sdyn->contents;
6821 b < sdyn->contents + sdyn->_raw_size;
6822 b += MIPS_ELF_DYN_SIZE (dynobj))
6823 {
6824 Elf_Internal_Dyn dyn;
6825 const char *name;
6826 size_t elemsize;
6827 asection *s;
6828 bfd_boolean swap_out_p;
6829
6830 /* Read in the current dynamic entry. */
6831 (*get_elf_backend_data (dynobj)->s->swap_dyn_in) (dynobj, b, &dyn);
6832
6833 /* Assume that we're going to modify it and write it out. */
6834 swap_out_p = TRUE;
6835
6836 switch (dyn.d_tag)
6837 {
6838 case DT_RELENT:
6839 s = mips_elf_rel_dyn_section (dynobj, FALSE);
6840 BFD_ASSERT (s != NULL);
6841 dyn.d_un.d_val = MIPS_ELF_REL_SIZE (dynobj);
6842 break;
6843
6844 case DT_STRSZ:
6845 /* Rewrite DT_STRSZ. */
6846 dyn.d_un.d_val =
6847 _bfd_elf_strtab_size (elf_hash_table (info)->dynstr);
6848 break;
6849
6850 case DT_PLTGOT:
6851 name = ".got";
6852 s = bfd_get_section_by_name (output_bfd, name);
6853 BFD_ASSERT (s != NULL);
6854 dyn.d_un.d_ptr = s->vma;
6855 break;
6856
6857 case DT_MIPS_RLD_VERSION:
6858 dyn.d_un.d_val = 1; /* XXX */
6859 break;
6860
6861 case DT_MIPS_FLAGS:
6862 dyn.d_un.d_val = RHF_NOTPOT; /* XXX */
6863 break;
6864
6865 case DT_MIPS_TIME_STAMP:
6866 time ((time_t *) &dyn.d_un.d_val);
6867 break;
6868
6869 case DT_MIPS_ICHECKSUM:
6870 /* XXX FIXME: */
6871 swap_out_p = FALSE;
6872 break;
6873
6874 case DT_MIPS_IVERSION:
6875 /* XXX FIXME: */
6876 swap_out_p = FALSE;
6877 break;
6878
6879 case DT_MIPS_BASE_ADDRESS:
6880 s = output_bfd->sections;
6881 BFD_ASSERT (s != NULL);
6882 dyn.d_un.d_ptr = s->vma & ~(bfd_vma) 0xffff;
6883 break;
6884
6885 case DT_MIPS_LOCAL_GOTNO:
6886 dyn.d_un.d_val = g->local_gotno;
6887 break;
6888
6889 case DT_MIPS_UNREFEXTNO:
6890 /* The index into the dynamic symbol table which is the
6891 entry of the first external symbol that is not
6892 referenced within the same object. */
6893 dyn.d_un.d_val = bfd_count_sections (output_bfd) + 1;
6894 break;
6895
6896 case DT_MIPS_GOTSYM:
6897 if (gg->global_gotsym)
6898 {
6899 dyn.d_un.d_val = gg->global_gotsym->dynindx;
6900 break;
6901 }
6902 /* In case if we don't have global got symbols we default
6903 to setting DT_MIPS_GOTSYM to the same value as
6904 DT_MIPS_SYMTABNO, so we just fall through. */
6905
6906 case DT_MIPS_SYMTABNO:
6907 name = ".dynsym";
6908 elemsize = MIPS_ELF_SYM_SIZE (output_bfd);
6909 s = bfd_get_section_by_name (output_bfd, name);
6910 BFD_ASSERT (s != NULL);
6911
6912 if (s->_cooked_size != 0)
6913 dyn.d_un.d_val = s->_cooked_size / elemsize;
6914 else
6915 dyn.d_un.d_val = s->_raw_size / elemsize;
6916 break;
6917
6918 case DT_MIPS_HIPAGENO:
6919 dyn.d_un.d_val = g->local_gotno - MIPS_RESERVED_GOTNO;
6920 break;
6921
6922 case DT_MIPS_RLD_MAP:
6923 dyn.d_un.d_ptr = mips_elf_hash_table (info)->rld_value;
6924 break;
6925
6926 case DT_MIPS_OPTIONS:
6927 s = (bfd_get_section_by_name
6928 (output_bfd, MIPS_ELF_OPTIONS_SECTION_NAME (output_bfd)));
6929 dyn.d_un.d_ptr = s->vma;
6930 break;
6931
6932 case DT_RELSZ:
6933 /* Reduce DT_RELSZ to account for any relocations we
6934 decided not to make. This is for the n64 irix rld,
6935 which doesn't seem to apply any relocations if there
6936 are trailing null entries. */
6937 s = mips_elf_rel_dyn_section (dynobj, FALSE);
6938 dyn.d_un.d_val = (s->reloc_count
6939 * (ABI_64_P (output_bfd)
6940 ? sizeof (Elf64_Mips_External_Rel)
6941 : sizeof (Elf32_External_Rel)));
6942 break;
6943
6944 default:
6945 swap_out_p = FALSE;
6946 break;
6947 }
6948
6949 if (swap_out_p)
6950 (*get_elf_backend_data (dynobj)->s->swap_dyn_out)
6951 (dynobj, &dyn, b);
6952 }
6953 }
6954
6955 /* The first entry of the global offset table will be filled at
6956 runtime. The second entry will be used by some runtime loaders.
6957 This isn't the case of IRIX rld. */
6958 if (sgot != NULL && sgot->_raw_size > 0)
6959 {
6960 MIPS_ELF_PUT_WORD (output_bfd, 0, sgot->contents);
6961 MIPS_ELF_PUT_WORD (output_bfd, 0x80000000,
6962 sgot->contents + MIPS_ELF_GOT_SIZE (output_bfd));
6963 }
6964
6965 if (sgot != NULL)
6966 elf_section_data (sgot->output_section)->this_hdr.sh_entsize
6967 = MIPS_ELF_GOT_SIZE (output_bfd);
6968
6969 /* Generate dynamic relocations for the non-primary gots. */
6970 if (gg != NULL && gg->next)
6971 {
6972 Elf_Internal_Rela rel[3];
6973 bfd_vma addend = 0;
6974
6975 memset (rel, 0, sizeof (rel));
6976 rel[0].r_info = ELF_R_INFO (output_bfd, 0, R_MIPS_REL32);
6977
6978 for (g = gg->next; g->next != gg; g = g->next)
6979 {
6980 bfd_vma index = g->next->local_gotno + g->next->global_gotno;
6981
6982 MIPS_ELF_PUT_WORD (output_bfd, 0, sgot->contents
6983 + index++ * MIPS_ELF_GOT_SIZE (output_bfd));
6984 MIPS_ELF_PUT_WORD (output_bfd, 0x80000000, sgot->contents
6985 + index++ * MIPS_ELF_GOT_SIZE (output_bfd));
6986
6987 if (! info->shared)
6988 continue;
6989
6990 while (index < g->assigned_gotno)
6991 {
6992 rel[0].r_offset = rel[1].r_offset = rel[2].r_offset
6993 = index++ * MIPS_ELF_GOT_SIZE (output_bfd);
6994 if (!(mips_elf_create_dynamic_relocation
6995 (output_bfd, info, rel, NULL,
6996 bfd_abs_section_ptr,
6997 0, &addend, sgot)))
6998 return FALSE;
6999 BFD_ASSERT (addend == 0);
7000 }
7001 }
7002 }
7003
7004 {
7005 asection *s;
7006 Elf32_compact_rel cpt;
7007
7008 if (SGI_COMPAT (output_bfd))
7009 {
7010 /* Write .compact_rel section out. */
7011 s = bfd_get_section_by_name (dynobj, ".compact_rel");
7012 if (s != NULL)
7013 {
7014 cpt.id1 = 1;
7015 cpt.num = s->reloc_count;
7016 cpt.id2 = 2;
7017 cpt.offset = (s->output_section->filepos
7018 + sizeof (Elf32_External_compact_rel));
7019 cpt.reserved0 = 0;
7020 cpt.reserved1 = 0;
7021 bfd_elf32_swap_compact_rel_out (output_bfd, &cpt,
7022 ((Elf32_External_compact_rel *)
7023 s->contents));
7024
7025 /* Clean up a dummy stub function entry in .text. */
7026 s = bfd_get_section_by_name (dynobj,
7027 MIPS_ELF_STUB_SECTION_NAME (dynobj));
7028 if (s != NULL)
7029 {
7030 file_ptr dummy_offset;
7031
7032 BFD_ASSERT (s->_raw_size >= MIPS_FUNCTION_STUB_SIZE);
7033 dummy_offset = s->_raw_size - MIPS_FUNCTION_STUB_SIZE;
7034 memset (s->contents + dummy_offset, 0,
7035 MIPS_FUNCTION_STUB_SIZE);
7036 }
7037 }
7038 }
7039
7040 /* We need to sort the entries of the dynamic relocation section. */
7041
7042 s = mips_elf_rel_dyn_section (dynobj, FALSE);
7043
7044 if (s != NULL
7045 && s->_raw_size > (bfd_vma)2 * MIPS_ELF_REL_SIZE (output_bfd))
7046 {
7047 reldyn_sorting_bfd = output_bfd;
7048
7049 if (ABI_64_P (output_bfd))
7050 qsort ((Elf64_External_Rel *) s->contents + 1, s->reloc_count - 1,
7051 sizeof (Elf64_Mips_External_Rel), sort_dynamic_relocs_64);
7052 else
7053 qsort ((Elf32_External_Rel *) s->contents + 1, s->reloc_count - 1,
7054 sizeof (Elf32_External_Rel), sort_dynamic_relocs);
7055 }
7056 }
7057
7058 return TRUE;
7059 }
7060
7061
7062 /* Set ABFD's EF_MIPS_ARCH and EF_MIPS_MACH flags. */
7063
7064 static void
7065 mips_set_isa_flags (bfd *abfd)
7066 {
7067 flagword val;
7068
7069 switch (bfd_get_mach (abfd))
7070 {
7071 default:
7072 case bfd_mach_mips3000:
7073 val = E_MIPS_ARCH_1;
7074 break;
7075
7076 case bfd_mach_mips3900:
7077 val = E_MIPS_ARCH_1 | E_MIPS_MACH_3900;
7078 break;
7079
7080 case bfd_mach_mips6000:
7081 val = E_MIPS_ARCH_2;
7082 break;
7083
7084 case bfd_mach_mips4000:
7085 case bfd_mach_mips4300:
7086 case bfd_mach_mips4400:
7087 case bfd_mach_mips4600:
7088 val = E_MIPS_ARCH_3;
7089 break;
7090
7091 case bfd_mach_mips4010:
7092 val = E_MIPS_ARCH_3 | E_MIPS_MACH_4010;
7093 break;
7094
7095 case bfd_mach_mips4100:
7096 val = E_MIPS_ARCH_3 | E_MIPS_MACH_4100;
7097 break;
7098
7099 case bfd_mach_mips4111:
7100 val = E_MIPS_ARCH_3 | E_MIPS_MACH_4111;
7101 break;
7102
7103 case bfd_mach_mips4120:
7104 val = E_MIPS_ARCH_3 | E_MIPS_MACH_4120;
7105 break;
7106
7107 case bfd_mach_mips4650:
7108 val = E_MIPS_ARCH_3 | E_MIPS_MACH_4650;
7109 break;
7110
7111 case bfd_mach_mips5400:
7112 val = E_MIPS_ARCH_4 | E_MIPS_MACH_5400;
7113 break;
7114
7115 case bfd_mach_mips5500:
7116 val = E_MIPS_ARCH_4 | E_MIPS_MACH_5500;
7117 break;
7118
7119 case bfd_mach_mips5000:
7120 case bfd_mach_mips7000:
7121 case bfd_mach_mips8000:
7122 case bfd_mach_mips10000:
7123 case bfd_mach_mips12000:
7124 val = E_MIPS_ARCH_4;
7125 break;
7126
7127 case bfd_mach_mips5:
7128 val = E_MIPS_ARCH_5;
7129 break;
7130
7131 case bfd_mach_mips_sb1:
7132 val = E_MIPS_ARCH_64 | E_MIPS_MACH_SB1;
7133 break;
7134
7135 case bfd_mach_mipsisa32:
7136 val = E_MIPS_ARCH_32;
7137 break;
7138
7139 case bfd_mach_mipsisa64:
7140 val = E_MIPS_ARCH_64;
7141 break;
7142
7143 case bfd_mach_mipsisa32r2:
7144 val = E_MIPS_ARCH_32R2;
7145 break;
7146
7147 case bfd_mach_mipsisa64r2:
7148 val = E_MIPS_ARCH_64R2;
7149 break;
7150 }
7151 elf_elfheader (abfd)->e_flags &= ~(EF_MIPS_ARCH | EF_MIPS_MACH);
7152 elf_elfheader (abfd)->e_flags |= val;
7153
7154 }
7155
7156
7157 /* The final processing done just before writing out a MIPS ELF object
7158 file. This gets the MIPS architecture right based on the machine
7159 number. This is used by both the 32-bit and the 64-bit ABI. */
7160
7161 void
7162 _bfd_mips_elf_final_write_processing (bfd *abfd,
7163 bfd_boolean linker ATTRIBUTE_UNUSED)
7164 {
7165 unsigned int i;
7166 Elf_Internal_Shdr **hdrpp;
7167 const char *name;
7168 asection *sec;
7169
7170 /* Keep the existing EF_MIPS_MACH and EF_MIPS_ARCH flags if the former
7171 is nonzero. This is for compatibility with old objects, which used
7172 a combination of a 32-bit EF_MIPS_ARCH and a 64-bit EF_MIPS_MACH. */
7173 if ((elf_elfheader (abfd)->e_flags & EF_MIPS_MACH) == 0)
7174 mips_set_isa_flags (abfd);
7175
7176 /* Set the sh_info field for .gptab sections and other appropriate
7177 info for each special section. */
7178 for (i = 1, hdrpp = elf_elfsections (abfd) + 1;
7179 i < elf_numsections (abfd);
7180 i++, hdrpp++)
7181 {
7182 switch ((*hdrpp)->sh_type)
7183 {
7184 case SHT_MIPS_MSYM:
7185 case SHT_MIPS_LIBLIST:
7186 sec = bfd_get_section_by_name (abfd, ".dynstr");
7187 if (sec != NULL)
7188 (*hdrpp)->sh_link = elf_section_data (sec)->this_idx;
7189 break;
7190
7191 case SHT_MIPS_GPTAB:
7192 BFD_ASSERT ((*hdrpp)->bfd_section != NULL);
7193 name = bfd_get_section_name (abfd, (*hdrpp)->bfd_section);
7194 BFD_ASSERT (name != NULL
7195 && strncmp (name, ".gptab.", sizeof ".gptab." - 1) == 0);
7196 sec = bfd_get_section_by_name (abfd, name + sizeof ".gptab" - 1);
7197 BFD_ASSERT (sec != NULL);
7198 (*hdrpp)->sh_info = elf_section_data (sec)->this_idx;
7199 break;
7200
7201 case SHT_MIPS_CONTENT:
7202 BFD_ASSERT ((*hdrpp)->bfd_section != NULL);
7203 name = bfd_get_section_name (abfd, (*hdrpp)->bfd_section);
7204 BFD_ASSERT (name != NULL
7205 && strncmp (name, ".MIPS.content",
7206 sizeof ".MIPS.content" - 1) == 0);
7207 sec = bfd_get_section_by_name (abfd,
7208 name + sizeof ".MIPS.content" - 1);
7209 BFD_ASSERT (sec != NULL);
7210 (*hdrpp)->sh_link = elf_section_data (sec)->this_idx;
7211 break;
7212
7213 case SHT_MIPS_SYMBOL_LIB:
7214 sec = bfd_get_section_by_name (abfd, ".dynsym");
7215 if (sec != NULL)
7216 (*hdrpp)->sh_link = elf_section_data (sec)->this_idx;
7217 sec = bfd_get_section_by_name (abfd, ".liblist");
7218 if (sec != NULL)
7219 (*hdrpp)->sh_info = elf_section_data (sec)->this_idx;
7220 break;
7221
7222 case SHT_MIPS_EVENTS:
7223 BFD_ASSERT ((*hdrpp)->bfd_section != NULL);
7224 name = bfd_get_section_name (abfd, (*hdrpp)->bfd_section);
7225 BFD_ASSERT (name != NULL);
7226 if (strncmp (name, ".MIPS.events", sizeof ".MIPS.events" - 1) == 0)
7227 sec = bfd_get_section_by_name (abfd,
7228 name + sizeof ".MIPS.events" - 1);
7229 else
7230 {
7231 BFD_ASSERT (strncmp (name, ".MIPS.post_rel",
7232 sizeof ".MIPS.post_rel" - 1) == 0);
7233 sec = bfd_get_section_by_name (abfd,
7234 (name
7235 + sizeof ".MIPS.post_rel" - 1));
7236 }
7237 BFD_ASSERT (sec != NULL);
7238 (*hdrpp)->sh_link = elf_section_data (sec)->this_idx;
7239 break;
7240
7241 }
7242 }
7243 }
7244 \f
7245 /* When creating an IRIX5 executable, we need REGINFO and RTPROC
7246 segments. */
7247
7248 int
7249 _bfd_mips_elf_additional_program_headers (bfd *abfd)
7250 {
7251 asection *s;
7252 int ret = 0;
7253
7254 /* See if we need a PT_MIPS_REGINFO segment. */
7255 s = bfd_get_section_by_name (abfd, ".reginfo");
7256 if (s && (s->flags & SEC_LOAD))
7257 ++ret;
7258
7259 /* See if we need a PT_MIPS_OPTIONS segment. */
7260 if (IRIX_COMPAT (abfd) == ict_irix6
7261 && bfd_get_section_by_name (abfd,
7262 MIPS_ELF_OPTIONS_SECTION_NAME (abfd)))
7263 ++ret;
7264
7265 /* See if we need a PT_MIPS_RTPROC segment. */
7266 if (IRIX_COMPAT (abfd) == ict_irix5
7267 && bfd_get_section_by_name (abfd, ".dynamic")
7268 && bfd_get_section_by_name (abfd, ".mdebug"))
7269 ++ret;
7270
7271 return ret;
7272 }
7273
7274 /* Modify the segment map for an IRIX5 executable. */
7275
7276 bfd_boolean
7277 _bfd_mips_elf_modify_segment_map (bfd *abfd,
7278 struct bfd_link_info *info ATTRIBUTE_UNUSED)
7279 {
7280 asection *s;
7281 struct elf_segment_map *m, **pm;
7282 bfd_size_type amt;
7283
7284 /* If there is a .reginfo section, we need a PT_MIPS_REGINFO
7285 segment. */
7286 s = bfd_get_section_by_name (abfd, ".reginfo");
7287 if (s != NULL && (s->flags & SEC_LOAD) != 0)
7288 {
7289 for (m = elf_tdata (abfd)->segment_map; m != NULL; m = m->next)
7290 if (m->p_type == PT_MIPS_REGINFO)
7291 break;
7292 if (m == NULL)
7293 {
7294 amt = sizeof *m;
7295 m = bfd_zalloc (abfd, amt);
7296 if (m == NULL)
7297 return FALSE;
7298
7299 m->p_type = PT_MIPS_REGINFO;
7300 m->count = 1;
7301 m->sections[0] = s;
7302
7303 /* We want to put it after the PHDR and INTERP segments. */
7304 pm = &elf_tdata (abfd)->segment_map;
7305 while (*pm != NULL
7306 && ((*pm)->p_type == PT_PHDR
7307 || (*pm)->p_type == PT_INTERP))
7308 pm = &(*pm)->next;
7309
7310 m->next = *pm;
7311 *pm = m;
7312 }
7313 }
7314
7315 /* For IRIX 6, we don't have .mdebug sections, nor does anything but
7316 .dynamic end up in PT_DYNAMIC. However, we do have to insert a
7317 PT_MIPS_OPTIONS segment immediately following the program header
7318 table. */
7319 if (NEWABI_P (abfd)
7320 /* On non-IRIX6 new abi, we'll have already created a segment
7321 for this section, so don't create another. I'm not sure this
7322 is not also the case for IRIX 6, but I can't test it right
7323 now. */
7324 && IRIX_COMPAT (abfd) == ict_irix6)
7325 {
7326 for (s = abfd->sections; s; s = s->next)
7327 if (elf_section_data (s)->this_hdr.sh_type == SHT_MIPS_OPTIONS)
7328 break;
7329
7330 if (s)
7331 {
7332 struct elf_segment_map *options_segment;
7333
7334 pm = &elf_tdata (abfd)->segment_map;
7335 while (*pm != NULL
7336 && ((*pm)->p_type == PT_PHDR
7337 || (*pm)->p_type == PT_INTERP))
7338 pm = &(*pm)->next;
7339
7340 amt = sizeof (struct elf_segment_map);
7341 options_segment = bfd_zalloc (abfd, amt);
7342 options_segment->next = *pm;
7343 options_segment->p_type = PT_MIPS_OPTIONS;
7344 options_segment->p_flags = PF_R;
7345 options_segment->p_flags_valid = TRUE;
7346 options_segment->count = 1;
7347 options_segment->sections[0] = s;
7348 *pm = options_segment;
7349 }
7350 }
7351 else
7352 {
7353 if (IRIX_COMPAT (abfd) == ict_irix5)
7354 {
7355 /* If there are .dynamic and .mdebug sections, we make a room
7356 for the RTPROC header. FIXME: Rewrite without section names. */
7357 if (bfd_get_section_by_name (abfd, ".interp") == NULL
7358 && bfd_get_section_by_name (abfd, ".dynamic") != NULL
7359 && bfd_get_section_by_name (abfd, ".mdebug") != NULL)
7360 {
7361 for (m = elf_tdata (abfd)->segment_map; m != NULL; m = m->next)
7362 if (m->p_type == PT_MIPS_RTPROC)
7363 break;
7364 if (m == NULL)
7365 {
7366 amt = sizeof *m;
7367 m = bfd_zalloc (abfd, amt);
7368 if (m == NULL)
7369 return FALSE;
7370
7371 m->p_type = PT_MIPS_RTPROC;
7372
7373 s = bfd_get_section_by_name (abfd, ".rtproc");
7374 if (s == NULL)
7375 {
7376 m->count = 0;
7377 m->p_flags = 0;
7378 m->p_flags_valid = 1;
7379 }
7380 else
7381 {
7382 m->count = 1;
7383 m->sections[0] = s;
7384 }
7385
7386 /* We want to put it after the DYNAMIC segment. */
7387 pm = &elf_tdata (abfd)->segment_map;
7388 while (*pm != NULL && (*pm)->p_type != PT_DYNAMIC)
7389 pm = &(*pm)->next;
7390 if (*pm != NULL)
7391 pm = &(*pm)->next;
7392
7393 m->next = *pm;
7394 *pm = m;
7395 }
7396 }
7397 }
7398 /* On IRIX5, the PT_DYNAMIC segment includes the .dynamic,
7399 .dynstr, .dynsym, and .hash sections, and everything in
7400 between. */
7401 for (pm = &elf_tdata (abfd)->segment_map; *pm != NULL;
7402 pm = &(*pm)->next)
7403 if ((*pm)->p_type == PT_DYNAMIC)
7404 break;
7405 m = *pm;
7406 if (m != NULL && IRIX_COMPAT (abfd) == ict_none)
7407 {
7408 /* For a normal mips executable the permissions for the PT_DYNAMIC
7409 segment are read, write and execute. We do that here since
7410 the code in elf.c sets only the read permission. This matters
7411 sometimes for the dynamic linker. */
7412 if (bfd_get_section_by_name (abfd, ".dynamic") != NULL)
7413 {
7414 m->p_flags = PF_R | PF_W | PF_X;
7415 m->p_flags_valid = 1;
7416 }
7417 }
7418 if (m != NULL
7419 && m->count == 1 && strcmp (m->sections[0]->name, ".dynamic") == 0)
7420 {
7421 static const char *sec_names[] =
7422 {
7423 ".dynamic", ".dynstr", ".dynsym", ".hash"
7424 };
7425 bfd_vma low, high;
7426 unsigned int i, c;
7427 struct elf_segment_map *n;
7428
7429 low = ~(bfd_vma) 0;
7430 high = 0;
7431 for (i = 0; i < sizeof sec_names / sizeof sec_names[0]; i++)
7432 {
7433 s = bfd_get_section_by_name (abfd, sec_names[i]);
7434 if (s != NULL && (s->flags & SEC_LOAD) != 0)
7435 {
7436 bfd_size_type sz;
7437
7438 if (low > s->vma)
7439 low = s->vma;
7440 sz = s->_cooked_size;
7441 if (sz == 0)
7442 sz = s->_raw_size;
7443 if (high < s->vma + sz)
7444 high = s->vma + sz;
7445 }
7446 }
7447
7448 c = 0;
7449 for (s = abfd->sections; s != NULL; s = s->next)
7450 if ((s->flags & SEC_LOAD) != 0
7451 && s->vma >= low
7452 && ((s->vma
7453 + (s->_cooked_size !=
7454 0 ? s->_cooked_size : s->_raw_size)) <= high))
7455 ++c;
7456
7457 amt = sizeof *n + (bfd_size_type) (c - 1) * sizeof (asection *);
7458 n = bfd_zalloc (abfd, amt);
7459 if (n == NULL)
7460 return FALSE;
7461 *n = *m;
7462 n->count = c;
7463
7464 i = 0;
7465 for (s = abfd->sections; s != NULL; s = s->next)
7466 {
7467 if ((s->flags & SEC_LOAD) != 0
7468 && s->vma >= low
7469 && ((s->vma
7470 + (s->_cooked_size != 0 ?
7471 s->_cooked_size : s->_raw_size)) <= high))
7472 {
7473 n->sections[i] = s;
7474 ++i;
7475 }
7476 }
7477
7478 *pm = n;
7479 }
7480 }
7481
7482 return TRUE;
7483 }
7484 \f
7485 /* Return the section that should be marked against GC for a given
7486 relocation. */
7487
7488 asection *
7489 _bfd_mips_elf_gc_mark_hook (asection *sec,
7490 struct bfd_link_info *info ATTRIBUTE_UNUSED,
7491 Elf_Internal_Rela *rel,
7492 struct elf_link_hash_entry *h,
7493 Elf_Internal_Sym *sym)
7494 {
7495 /* ??? Do mips16 stub sections need to be handled special? */
7496
7497 if (h != NULL)
7498 {
7499 switch (ELF_R_TYPE (sec->owner, rel->r_info))
7500 {
7501 case R_MIPS_GNU_VTINHERIT:
7502 case R_MIPS_GNU_VTENTRY:
7503 break;
7504
7505 default:
7506 switch (h->root.type)
7507 {
7508 case bfd_link_hash_defined:
7509 case bfd_link_hash_defweak:
7510 return h->root.u.def.section;
7511
7512 case bfd_link_hash_common:
7513 return h->root.u.c.p->section;
7514
7515 default:
7516 break;
7517 }
7518 }
7519 }
7520 else
7521 return bfd_section_from_elf_index (sec->owner, sym->st_shndx);
7522
7523 return NULL;
7524 }
7525
7526 /* Update the got entry reference counts for the section being removed. */
7527
7528 bfd_boolean
7529 _bfd_mips_elf_gc_sweep_hook (bfd *abfd ATTRIBUTE_UNUSED,
7530 struct bfd_link_info *info ATTRIBUTE_UNUSED,
7531 asection *sec ATTRIBUTE_UNUSED,
7532 const Elf_Internal_Rela *relocs ATTRIBUTE_UNUSED)
7533 {
7534 #if 0
7535 Elf_Internal_Shdr *symtab_hdr;
7536 struct elf_link_hash_entry **sym_hashes;
7537 bfd_signed_vma *local_got_refcounts;
7538 const Elf_Internal_Rela *rel, *relend;
7539 unsigned long r_symndx;
7540 struct elf_link_hash_entry *h;
7541
7542 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
7543 sym_hashes = elf_sym_hashes (abfd);
7544 local_got_refcounts = elf_local_got_refcounts (abfd);
7545
7546 relend = relocs + sec->reloc_count;
7547 for (rel = relocs; rel < relend; rel++)
7548 switch (ELF_R_TYPE (abfd, rel->r_info))
7549 {
7550 case R_MIPS_GOT16:
7551 case R_MIPS_CALL16:
7552 case R_MIPS_CALL_HI16:
7553 case R_MIPS_CALL_LO16:
7554 case R_MIPS_GOT_HI16:
7555 case R_MIPS_GOT_LO16:
7556 case R_MIPS_GOT_DISP:
7557 case R_MIPS_GOT_PAGE:
7558 case R_MIPS_GOT_OFST:
7559 /* ??? It would seem that the existing MIPS code does no sort
7560 of reference counting or whatnot on its GOT and PLT entries,
7561 so it is not possible to garbage collect them at this time. */
7562 break;
7563
7564 default:
7565 break;
7566 }
7567 #endif
7568
7569 return TRUE;
7570 }
7571 \f
7572 /* Copy data from a MIPS ELF indirect symbol to its direct symbol,
7573 hiding the old indirect symbol. Process additional relocation
7574 information. Also called for weakdefs, in which case we just let
7575 _bfd_elf_link_hash_copy_indirect copy the flags for us. */
7576
7577 void
7578 _bfd_mips_elf_copy_indirect_symbol (const struct elf_backend_data *bed,
7579 struct elf_link_hash_entry *dir,
7580 struct elf_link_hash_entry *ind)
7581 {
7582 struct mips_elf_link_hash_entry *dirmips, *indmips;
7583
7584 _bfd_elf_link_hash_copy_indirect (bed, dir, ind);
7585
7586 if (ind->root.type != bfd_link_hash_indirect)
7587 return;
7588
7589 dirmips = (struct mips_elf_link_hash_entry *) dir;
7590 indmips = (struct mips_elf_link_hash_entry *) ind;
7591 dirmips->possibly_dynamic_relocs += indmips->possibly_dynamic_relocs;
7592 if (indmips->readonly_reloc)
7593 dirmips->readonly_reloc = TRUE;
7594 if (indmips->no_fn_stub)
7595 dirmips->no_fn_stub = TRUE;
7596 }
7597
7598 void
7599 _bfd_mips_elf_hide_symbol (struct bfd_link_info *info,
7600 struct elf_link_hash_entry *entry,
7601 bfd_boolean force_local)
7602 {
7603 bfd *dynobj;
7604 asection *got;
7605 struct mips_got_info *g;
7606 struct mips_elf_link_hash_entry *h;
7607
7608 h = (struct mips_elf_link_hash_entry *) entry;
7609 if (h->forced_local)
7610 return;
7611 h->forced_local = force_local;
7612
7613 dynobj = elf_hash_table (info)->dynobj;
7614 if (dynobj != NULL && force_local)
7615 {
7616 got = mips_elf_got_section (dynobj, FALSE);
7617 g = mips_elf_section_data (got)->u.got_info;
7618
7619 if (g->next)
7620 {
7621 struct mips_got_entry e;
7622 struct mips_got_info *gg = g;
7623
7624 /* Since we're turning what used to be a global symbol into a
7625 local one, bump up the number of local entries of each GOT
7626 that had an entry for it. This will automatically decrease
7627 the number of global entries, since global_gotno is actually
7628 the upper limit of global entries. */
7629 e.abfd = dynobj;
7630 e.symndx = -1;
7631 e.d.h = h;
7632
7633 for (g = g->next; g != gg; g = g->next)
7634 if (htab_find (g->got_entries, &e))
7635 {
7636 BFD_ASSERT (g->global_gotno > 0);
7637 g->local_gotno++;
7638 g->global_gotno--;
7639 }
7640
7641 /* If this was a global symbol forced into the primary GOT, we
7642 no longer need an entry for it. We can't release the entry
7643 at this point, but we must at least stop counting it as one
7644 of the symbols that required a forced got entry. */
7645 if (h->root.got.offset == 2)
7646 {
7647 BFD_ASSERT (gg->assigned_gotno > 0);
7648 gg->assigned_gotno--;
7649 }
7650 }
7651 else if (g->global_gotno == 0 && g->global_gotsym == NULL)
7652 /* If we haven't got through GOT allocation yet, just bump up the
7653 number of local entries, as this symbol won't be counted as
7654 global. */
7655 g->local_gotno++;
7656 else if (h->root.got.offset == 1)
7657 {
7658 /* If we're past non-multi-GOT allocation and this symbol had
7659 been marked for a global got entry, give it a local entry
7660 instead. */
7661 BFD_ASSERT (g->global_gotno > 0);
7662 g->local_gotno++;
7663 g->global_gotno--;
7664 }
7665 }
7666
7667 _bfd_elf_link_hash_hide_symbol (info, &h->root, force_local);
7668 }
7669 \f
7670 #define PDR_SIZE 32
7671
7672 bfd_boolean
7673 _bfd_mips_elf_discard_info (bfd *abfd, struct elf_reloc_cookie *cookie,
7674 struct bfd_link_info *info)
7675 {
7676 asection *o;
7677 bfd_boolean ret = FALSE;
7678 unsigned char *tdata;
7679 size_t i, skip;
7680
7681 o = bfd_get_section_by_name (abfd, ".pdr");
7682 if (! o)
7683 return FALSE;
7684 if (o->_raw_size == 0)
7685 return FALSE;
7686 if (o->_raw_size % PDR_SIZE != 0)
7687 return FALSE;
7688 if (o->output_section != NULL
7689 && bfd_is_abs_section (o->output_section))
7690 return FALSE;
7691
7692 tdata = bfd_zmalloc (o->_raw_size / PDR_SIZE);
7693 if (! tdata)
7694 return FALSE;
7695
7696 cookie->rels = _bfd_elf_link_read_relocs (abfd, o, NULL, NULL,
7697 info->keep_memory);
7698 if (!cookie->rels)
7699 {
7700 free (tdata);
7701 return FALSE;
7702 }
7703
7704 cookie->rel = cookie->rels;
7705 cookie->relend = cookie->rels + o->reloc_count;
7706
7707 for (i = 0, skip = 0; i < o->_raw_size / PDR_SIZE; i ++)
7708 {
7709 if (bfd_elf_reloc_symbol_deleted_p (i * PDR_SIZE, cookie))
7710 {
7711 tdata[i] = 1;
7712 skip ++;
7713 }
7714 }
7715
7716 if (skip != 0)
7717 {
7718 mips_elf_section_data (o)->u.tdata = tdata;
7719 o->_cooked_size = o->_raw_size - skip * PDR_SIZE;
7720 ret = TRUE;
7721 }
7722 else
7723 free (tdata);
7724
7725 if (! info->keep_memory)
7726 free (cookie->rels);
7727
7728 return ret;
7729 }
7730
7731 bfd_boolean
7732 _bfd_mips_elf_ignore_discarded_relocs (asection *sec)
7733 {
7734 if (strcmp (sec->name, ".pdr") == 0)
7735 return TRUE;
7736 return FALSE;
7737 }
7738
7739 bfd_boolean
7740 _bfd_mips_elf_write_section (bfd *output_bfd, asection *sec,
7741 bfd_byte *contents)
7742 {
7743 bfd_byte *to, *from, *end;
7744 int i;
7745
7746 if (strcmp (sec->name, ".pdr") != 0)
7747 return FALSE;
7748
7749 if (mips_elf_section_data (sec)->u.tdata == NULL)
7750 return FALSE;
7751
7752 to = contents;
7753 end = contents + sec->_raw_size;
7754 for (from = contents, i = 0;
7755 from < end;
7756 from += PDR_SIZE, i++)
7757 {
7758 if ((mips_elf_section_data (sec)->u.tdata)[i] == 1)
7759 continue;
7760 if (to != from)
7761 memcpy (to, from, PDR_SIZE);
7762 to += PDR_SIZE;
7763 }
7764 bfd_set_section_contents (output_bfd, sec->output_section, contents,
7765 sec->output_offset, sec->_cooked_size);
7766 return TRUE;
7767 }
7768 \f
7769 /* MIPS ELF uses a special find_nearest_line routine in order the
7770 handle the ECOFF debugging information. */
7771
7772 struct mips_elf_find_line
7773 {
7774 struct ecoff_debug_info d;
7775 struct ecoff_find_line i;
7776 };
7777
7778 bfd_boolean
7779 _bfd_mips_elf_find_nearest_line (bfd *abfd, asection *section,
7780 asymbol **symbols, bfd_vma offset,
7781 const char **filename_ptr,
7782 const char **functionname_ptr,
7783 unsigned int *line_ptr)
7784 {
7785 asection *msec;
7786
7787 if (_bfd_dwarf1_find_nearest_line (abfd, section, symbols, offset,
7788 filename_ptr, functionname_ptr,
7789 line_ptr))
7790 return TRUE;
7791
7792 if (_bfd_dwarf2_find_nearest_line (abfd, section, symbols, offset,
7793 filename_ptr, functionname_ptr,
7794 line_ptr, ABI_64_P (abfd) ? 8 : 0,
7795 &elf_tdata (abfd)->dwarf2_find_line_info))
7796 return TRUE;
7797
7798 msec = bfd_get_section_by_name (abfd, ".mdebug");
7799 if (msec != NULL)
7800 {
7801 flagword origflags;
7802 struct mips_elf_find_line *fi;
7803 const struct ecoff_debug_swap * const swap =
7804 get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
7805
7806 /* If we are called during a link, mips_elf_final_link may have
7807 cleared the SEC_HAS_CONTENTS field. We force it back on here
7808 if appropriate (which it normally will be). */
7809 origflags = msec->flags;
7810 if (elf_section_data (msec)->this_hdr.sh_type != SHT_NOBITS)
7811 msec->flags |= SEC_HAS_CONTENTS;
7812
7813 fi = elf_tdata (abfd)->find_line_info;
7814 if (fi == NULL)
7815 {
7816 bfd_size_type external_fdr_size;
7817 char *fraw_src;
7818 char *fraw_end;
7819 struct fdr *fdr_ptr;
7820 bfd_size_type amt = sizeof (struct mips_elf_find_line);
7821
7822 fi = bfd_zalloc (abfd, amt);
7823 if (fi == NULL)
7824 {
7825 msec->flags = origflags;
7826 return FALSE;
7827 }
7828
7829 if (! _bfd_mips_elf_read_ecoff_info (abfd, msec, &fi->d))
7830 {
7831 msec->flags = origflags;
7832 return FALSE;
7833 }
7834
7835 /* Swap in the FDR information. */
7836 amt = fi->d.symbolic_header.ifdMax * sizeof (struct fdr);
7837 fi->d.fdr = bfd_alloc (abfd, amt);
7838 if (fi->d.fdr == NULL)
7839 {
7840 msec->flags = origflags;
7841 return FALSE;
7842 }
7843 external_fdr_size = swap->external_fdr_size;
7844 fdr_ptr = fi->d.fdr;
7845 fraw_src = (char *) fi->d.external_fdr;
7846 fraw_end = (fraw_src
7847 + fi->d.symbolic_header.ifdMax * external_fdr_size);
7848 for (; fraw_src < fraw_end; fraw_src += external_fdr_size, fdr_ptr++)
7849 (*swap->swap_fdr_in) (abfd, fraw_src, fdr_ptr);
7850
7851 elf_tdata (abfd)->find_line_info = fi;
7852
7853 /* Note that we don't bother to ever free this information.
7854 find_nearest_line is either called all the time, as in
7855 objdump -l, so the information should be saved, or it is
7856 rarely called, as in ld error messages, so the memory
7857 wasted is unimportant. Still, it would probably be a
7858 good idea for free_cached_info to throw it away. */
7859 }
7860
7861 if (_bfd_ecoff_locate_line (abfd, section, offset, &fi->d, swap,
7862 &fi->i, filename_ptr, functionname_ptr,
7863 line_ptr))
7864 {
7865 msec->flags = origflags;
7866 return TRUE;
7867 }
7868
7869 msec->flags = origflags;
7870 }
7871
7872 /* Fall back on the generic ELF find_nearest_line routine. */
7873
7874 return _bfd_elf_find_nearest_line (abfd, section, symbols, offset,
7875 filename_ptr, functionname_ptr,
7876 line_ptr);
7877 }
7878 \f
7879 /* When are writing out the .options or .MIPS.options section,
7880 remember the bytes we are writing out, so that we can install the
7881 GP value in the section_processing routine. */
7882
7883 bfd_boolean
7884 _bfd_mips_elf_set_section_contents (bfd *abfd, sec_ptr section,
7885 const void *location,
7886 file_ptr offset, bfd_size_type count)
7887 {
7888 if (strcmp (section->name, MIPS_ELF_OPTIONS_SECTION_NAME (abfd)) == 0)
7889 {
7890 bfd_byte *c;
7891
7892 if (elf_section_data (section) == NULL)
7893 {
7894 bfd_size_type amt = sizeof (struct bfd_elf_section_data);
7895 section->used_by_bfd = bfd_zalloc (abfd, amt);
7896 if (elf_section_data (section) == NULL)
7897 return FALSE;
7898 }
7899 c = mips_elf_section_data (section)->u.tdata;
7900 if (c == NULL)
7901 {
7902 bfd_size_type size;
7903
7904 if (section->_cooked_size != 0)
7905 size = section->_cooked_size;
7906 else
7907 size = section->_raw_size;
7908 c = bfd_zalloc (abfd, size);
7909 if (c == NULL)
7910 return FALSE;
7911 mips_elf_section_data (section)->u.tdata = c;
7912 }
7913
7914 memcpy (c + offset, location, count);
7915 }
7916
7917 return _bfd_elf_set_section_contents (abfd, section, location, offset,
7918 count);
7919 }
7920
7921 /* This is almost identical to bfd_generic_get_... except that some
7922 MIPS relocations need to be handled specially. Sigh. */
7923
7924 bfd_byte *
7925 _bfd_elf_mips_get_relocated_section_contents
7926 (bfd *abfd,
7927 struct bfd_link_info *link_info,
7928 struct bfd_link_order *link_order,
7929 bfd_byte *data,
7930 bfd_boolean relocatable,
7931 asymbol **symbols)
7932 {
7933 /* Get enough memory to hold the stuff */
7934 bfd *input_bfd = link_order->u.indirect.section->owner;
7935 asection *input_section = link_order->u.indirect.section;
7936
7937 long reloc_size = bfd_get_reloc_upper_bound (input_bfd, input_section);
7938 arelent **reloc_vector = NULL;
7939 long reloc_count;
7940
7941 if (reloc_size < 0)
7942 goto error_return;
7943
7944 reloc_vector = bfd_malloc (reloc_size);
7945 if (reloc_vector == NULL && reloc_size != 0)
7946 goto error_return;
7947
7948 /* read in the section */
7949 if (!bfd_get_section_contents (input_bfd, input_section, data, 0,
7950 input_section->_raw_size))
7951 goto error_return;
7952
7953 /* We're not relaxing the section, so just copy the size info */
7954 input_section->_cooked_size = input_section->_raw_size;
7955 input_section->reloc_done = TRUE;
7956
7957 reloc_count = bfd_canonicalize_reloc (input_bfd,
7958 input_section,
7959 reloc_vector,
7960 symbols);
7961 if (reloc_count < 0)
7962 goto error_return;
7963
7964 if (reloc_count > 0)
7965 {
7966 arelent **parent;
7967 /* for mips */
7968 int gp_found;
7969 bfd_vma gp = 0x12345678; /* initialize just to shut gcc up */
7970
7971 {
7972 struct bfd_hash_entry *h;
7973 struct bfd_link_hash_entry *lh;
7974 /* Skip all this stuff if we aren't mixing formats. */
7975 if (abfd && input_bfd
7976 && abfd->xvec == input_bfd->xvec)
7977 lh = 0;
7978 else
7979 {
7980 h = bfd_hash_lookup (&link_info->hash->table, "_gp", FALSE, FALSE);
7981 lh = (struct bfd_link_hash_entry *) h;
7982 }
7983 lookup:
7984 if (lh)
7985 {
7986 switch (lh->type)
7987 {
7988 case bfd_link_hash_undefined:
7989 case bfd_link_hash_undefweak:
7990 case bfd_link_hash_common:
7991 gp_found = 0;
7992 break;
7993 case bfd_link_hash_defined:
7994 case bfd_link_hash_defweak:
7995 gp_found = 1;
7996 gp = lh->u.def.value;
7997 break;
7998 case bfd_link_hash_indirect:
7999 case bfd_link_hash_warning:
8000 lh = lh->u.i.link;
8001 /* @@FIXME ignoring warning for now */
8002 goto lookup;
8003 case bfd_link_hash_new:
8004 default:
8005 abort ();
8006 }
8007 }
8008 else
8009 gp_found = 0;
8010 }
8011 /* end mips */
8012 for (parent = reloc_vector; *parent != NULL; parent++)
8013 {
8014 char *error_message = NULL;
8015 bfd_reloc_status_type r;
8016
8017 /* Specific to MIPS: Deal with relocation types that require
8018 knowing the gp of the output bfd. */
8019 asymbol *sym = *(*parent)->sym_ptr_ptr;
8020 if (bfd_is_abs_section (sym->section) && abfd)
8021 {
8022 /* The special_function wouldn't get called anyway. */
8023 }
8024 else if (!gp_found)
8025 {
8026 /* The gp isn't there; let the special function code
8027 fall over on its own. */
8028 }
8029 else if ((*parent)->howto->special_function
8030 == _bfd_mips_elf32_gprel16_reloc)
8031 {
8032 /* bypass special_function call */
8033 r = _bfd_mips_elf_gprel16_with_gp (input_bfd, sym, *parent,
8034 input_section, relocatable,
8035 data, gp);
8036 goto skip_bfd_perform_relocation;
8037 }
8038 /* end mips specific stuff */
8039
8040 r = bfd_perform_relocation (input_bfd, *parent, data, input_section,
8041 relocatable ? abfd : NULL,
8042 &error_message);
8043 skip_bfd_perform_relocation:
8044
8045 if (relocatable)
8046 {
8047 asection *os = input_section->output_section;
8048
8049 /* A partial link, so keep the relocs */
8050 os->orelocation[os->reloc_count] = *parent;
8051 os->reloc_count++;
8052 }
8053
8054 if (r != bfd_reloc_ok)
8055 {
8056 switch (r)
8057 {
8058 case bfd_reloc_undefined:
8059 if (!((*link_info->callbacks->undefined_symbol)
8060 (link_info, bfd_asymbol_name (*(*parent)->sym_ptr_ptr),
8061 input_bfd, input_section, (*parent)->address,
8062 TRUE)))
8063 goto error_return;
8064 break;
8065 case bfd_reloc_dangerous:
8066 BFD_ASSERT (error_message != NULL);
8067 if (!((*link_info->callbacks->reloc_dangerous)
8068 (link_info, error_message, input_bfd, input_section,
8069 (*parent)->address)))
8070 goto error_return;
8071 break;
8072 case bfd_reloc_overflow:
8073 if (!((*link_info->callbacks->reloc_overflow)
8074 (link_info, bfd_asymbol_name (*(*parent)->sym_ptr_ptr),
8075 (*parent)->howto->name, (*parent)->addend,
8076 input_bfd, input_section, (*parent)->address)))
8077 goto error_return;
8078 break;
8079 case bfd_reloc_outofrange:
8080 default:
8081 abort ();
8082 break;
8083 }
8084
8085 }
8086 }
8087 }
8088 if (reloc_vector != NULL)
8089 free (reloc_vector);
8090 return data;
8091
8092 error_return:
8093 if (reloc_vector != NULL)
8094 free (reloc_vector);
8095 return NULL;
8096 }
8097 \f
8098 /* Create a MIPS ELF linker hash table. */
8099
8100 struct bfd_link_hash_table *
8101 _bfd_mips_elf_link_hash_table_create (bfd *abfd)
8102 {
8103 struct mips_elf_link_hash_table *ret;
8104 bfd_size_type amt = sizeof (struct mips_elf_link_hash_table);
8105
8106 ret = bfd_malloc (amt);
8107 if (ret == NULL)
8108 return NULL;
8109
8110 if (! _bfd_elf_link_hash_table_init (&ret->root, abfd,
8111 mips_elf_link_hash_newfunc))
8112 {
8113 free (ret);
8114 return NULL;
8115 }
8116
8117 #if 0
8118 /* We no longer use this. */
8119 for (i = 0; i < SIZEOF_MIPS_DYNSYM_SECNAMES; i++)
8120 ret->dynsym_sec_strindex[i] = (bfd_size_type) -1;
8121 #endif
8122 ret->procedure_count = 0;
8123 ret->compact_rel_size = 0;
8124 ret->use_rld_obj_head = FALSE;
8125 ret->rld_value = 0;
8126 ret->mips16_stubs_seen = FALSE;
8127
8128 return &ret->root.root;
8129 }
8130 \f
8131 /* We need to use a special link routine to handle the .reginfo and
8132 the .mdebug sections. We need to merge all instances of these
8133 sections together, not write them all out sequentially. */
8134
8135 bfd_boolean
8136 _bfd_mips_elf_final_link (bfd *abfd, struct bfd_link_info *info)
8137 {
8138 asection **secpp;
8139 asection *o;
8140 struct bfd_link_order *p;
8141 asection *reginfo_sec, *mdebug_sec, *gptab_data_sec, *gptab_bss_sec;
8142 asection *rtproc_sec;
8143 Elf32_RegInfo reginfo;
8144 struct ecoff_debug_info debug;
8145 const struct ecoff_debug_swap *swap
8146 = get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
8147 HDRR *symhdr = &debug.symbolic_header;
8148 void *mdebug_handle = NULL;
8149 asection *s;
8150 EXTR esym;
8151 unsigned int i;
8152 bfd_size_type amt;
8153
8154 static const char * const secname[] =
8155 {
8156 ".text", ".init", ".fini", ".data",
8157 ".rodata", ".sdata", ".sbss", ".bss"
8158 };
8159 static const int sc[] =
8160 {
8161 scText, scInit, scFini, scData,
8162 scRData, scSData, scSBss, scBss
8163 };
8164
8165 /* We'd carefully arranged the dynamic symbol indices, and then the
8166 generic size_dynamic_sections renumbered them out from under us.
8167 Rather than trying somehow to prevent the renumbering, just do
8168 the sort again. */
8169 if (elf_hash_table (info)->dynamic_sections_created)
8170 {
8171 bfd *dynobj;
8172 asection *got;
8173 struct mips_got_info *g;
8174
8175 /* When we resort, we must tell mips_elf_sort_hash_table what
8176 the lowest index it may use is. That's the number of section
8177 symbols we're going to add. The generic ELF linker only
8178 adds these symbols when building a shared object. Note that
8179 we count the sections after (possibly) removing the .options
8180 section above. */
8181 if (! mips_elf_sort_hash_table (info, (info->shared
8182 ? bfd_count_sections (abfd) + 1
8183 : 1)))
8184 return FALSE;
8185
8186 /* Make sure we didn't grow the global .got region. */
8187 dynobj = elf_hash_table (info)->dynobj;
8188 got = mips_elf_got_section (dynobj, FALSE);
8189 g = mips_elf_section_data (got)->u.got_info;
8190
8191 if (g->global_gotsym != NULL)
8192 BFD_ASSERT ((elf_hash_table (info)->dynsymcount
8193 - g->global_gotsym->dynindx)
8194 <= g->global_gotno);
8195 }
8196
8197 #if 0
8198 /* We want to set the GP value for ld -r. */
8199 /* On IRIX5, we omit the .options section. On IRIX6, however, we
8200 include it, even though we don't process it quite right. (Some
8201 entries are supposed to be merged.) Empirically, we seem to be
8202 better off including it then not. */
8203 if (IRIX_COMPAT (abfd) == ict_irix5 || IRIX_COMPAT (abfd) == ict_none)
8204 for (secpp = &abfd->sections; *secpp != NULL; secpp = &(*secpp)->next)
8205 {
8206 if (strcmp ((*secpp)->name, MIPS_ELF_OPTIONS_SECTION_NAME (abfd)) == 0)
8207 {
8208 for (p = (*secpp)->link_order_head; p != NULL; p = p->next)
8209 if (p->type == bfd_indirect_link_order)
8210 p->u.indirect.section->flags &= ~SEC_HAS_CONTENTS;
8211 (*secpp)->link_order_head = NULL;
8212 bfd_section_list_remove (abfd, secpp);
8213 --abfd->section_count;
8214
8215 break;
8216 }
8217 }
8218
8219 /* We include .MIPS.options, even though we don't process it quite right.
8220 (Some entries are supposed to be merged.) At IRIX6 empirically we seem
8221 to be better off including it than not. */
8222 for (secpp = &abfd->sections; *secpp != NULL; secpp = &(*secpp)->next)
8223 {
8224 if (strcmp ((*secpp)->name, ".MIPS.options") == 0)
8225 {
8226 for (p = (*secpp)->link_order_head; p != NULL; p = p->next)
8227 if (p->type == bfd_indirect_link_order)
8228 p->u.indirect.section->flags &=~ SEC_HAS_CONTENTS;
8229 (*secpp)->link_order_head = NULL;
8230 bfd_section_list_remove (abfd, secpp);
8231 --abfd->section_count;
8232
8233 break;
8234 }
8235 }
8236 #endif
8237
8238 /* Get a value for the GP register. */
8239 if (elf_gp (abfd) == 0)
8240 {
8241 struct bfd_link_hash_entry *h;
8242
8243 h = bfd_link_hash_lookup (info->hash, "_gp", FALSE, FALSE, TRUE);
8244 if (h != NULL && h->type == bfd_link_hash_defined)
8245 elf_gp (abfd) = (h->u.def.value
8246 + h->u.def.section->output_section->vma
8247 + h->u.def.section->output_offset);
8248 else if (info->relocatable)
8249 {
8250 bfd_vma lo = MINUS_ONE;
8251
8252 /* Find the GP-relative section with the lowest offset. */
8253 for (o = abfd->sections; o != NULL; o = o->next)
8254 if (o->vma < lo
8255 && (elf_section_data (o)->this_hdr.sh_flags & SHF_MIPS_GPREL))
8256 lo = o->vma;
8257
8258 /* And calculate GP relative to that. */
8259 elf_gp (abfd) = lo + ELF_MIPS_GP_OFFSET (abfd);
8260 }
8261 else
8262 {
8263 /* If the relocate_section function needs to do a reloc
8264 involving the GP value, it should make a reloc_dangerous
8265 callback to warn that GP is not defined. */
8266 }
8267 }
8268
8269 /* Go through the sections and collect the .reginfo and .mdebug
8270 information. */
8271 reginfo_sec = NULL;
8272 mdebug_sec = NULL;
8273 gptab_data_sec = NULL;
8274 gptab_bss_sec = NULL;
8275 for (o = abfd->sections; o != NULL; o = o->next)
8276 {
8277 if (strcmp (o->name, ".reginfo") == 0)
8278 {
8279 memset (&reginfo, 0, sizeof reginfo);
8280
8281 /* We have found the .reginfo section in the output file.
8282 Look through all the link_orders comprising it and merge
8283 the information together. */
8284 for (p = o->link_order_head; p != NULL; p = p->next)
8285 {
8286 asection *input_section;
8287 bfd *input_bfd;
8288 Elf32_External_RegInfo ext;
8289 Elf32_RegInfo sub;
8290
8291 if (p->type != bfd_indirect_link_order)
8292 {
8293 if (p->type == bfd_data_link_order)
8294 continue;
8295 abort ();
8296 }
8297
8298 input_section = p->u.indirect.section;
8299 input_bfd = input_section->owner;
8300
8301 /* The linker emulation code has probably clobbered the
8302 size to be zero bytes. */
8303 if (input_section->_raw_size == 0)
8304 input_section->_raw_size = sizeof (Elf32_External_RegInfo);
8305
8306 if (! bfd_get_section_contents (input_bfd, input_section,
8307 &ext, 0, sizeof ext))
8308 return FALSE;
8309
8310 bfd_mips_elf32_swap_reginfo_in (input_bfd, &ext, &sub);
8311
8312 reginfo.ri_gprmask |= sub.ri_gprmask;
8313 reginfo.ri_cprmask[0] |= sub.ri_cprmask[0];
8314 reginfo.ri_cprmask[1] |= sub.ri_cprmask[1];
8315 reginfo.ri_cprmask[2] |= sub.ri_cprmask[2];
8316 reginfo.ri_cprmask[3] |= sub.ri_cprmask[3];
8317
8318 /* ri_gp_value is set by the function
8319 mips_elf32_section_processing when the section is
8320 finally written out. */
8321
8322 /* Hack: reset the SEC_HAS_CONTENTS flag so that
8323 elf_link_input_bfd ignores this section. */
8324 input_section->flags &= ~SEC_HAS_CONTENTS;
8325 }
8326
8327 /* Size has been set in _bfd_mips_elf_always_size_sections. */
8328 BFD_ASSERT(o->_raw_size == sizeof (Elf32_External_RegInfo));
8329
8330 /* Skip this section later on (I don't think this currently
8331 matters, but someday it might). */
8332 o->link_order_head = NULL;
8333
8334 reginfo_sec = o;
8335 }
8336
8337 if (strcmp (o->name, ".mdebug") == 0)
8338 {
8339 struct extsym_info einfo;
8340 bfd_vma last;
8341
8342 /* We have found the .mdebug section in the output file.
8343 Look through all the link_orders comprising it and merge
8344 the information together. */
8345 symhdr->magic = swap->sym_magic;
8346 /* FIXME: What should the version stamp be? */
8347 symhdr->vstamp = 0;
8348 symhdr->ilineMax = 0;
8349 symhdr->cbLine = 0;
8350 symhdr->idnMax = 0;
8351 symhdr->ipdMax = 0;
8352 symhdr->isymMax = 0;
8353 symhdr->ioptMax = 0;
8354 symhdr->iauxMax = 0;
8355 symhdr->issMax = 0;
8356 symhdr->issExtMax = 0;
8357 symhdr->ifdMax = 0;
8358 symhdr->crfd = 0;
8359 symhdr->iextMax = 0;
8360
8361 /* We accumulate the debugging information itself in the
8362 debug_info structure. */
8363 debug.line = NULL;
8364 debug.external_dnr = NULL;
8365 debug.external_pdr = NULL;
8366 debug.external_sym = NULL;
8367 debug.external_opt = NULL;
8368 debug.external_aux = NULL;
8369 debug.ss = NULL;
8370 debug.ssext = debug.ssext_end = NULL;
8371 debug.external_fdr = NULL;
8372 debug.external_rfd = NULL;
8373 debug.external_ext = debug.external_ext_end = NULL;
8374
8375 mdebug_handle = bfd_ecoff_debug_init (abfd, &debug, swap, info);
8376 if (mdebug_handle == NULL)
8377 return FALSE;
8378
8379 esym.jmptbl = 0;
8380 esym.cobol_main = 0;
8381 esym.weakext = 0;
8382 esym.reserved = 0;
8383 esym.ifd = ifdNil;
8384 esym.asym.iss = issNil;
8385 esym.asym.st = stLocal;
8386 esym.asym.reserved = 0;
8387 esym.asym.index = indexNil;
8388 last = 0;
8389 for (i = 0; i < sizeof (secname) / sizeof (secname[0]); i++)
8390 {
8391 esym.asym.sc = sc[i];
8392 s = bfd_get_section_by_name (abfd, secname[i]);
8393 if (s != NULL)
8394 {
8395 esym.asym.value = s->vma;
8396 last = s->vma + s->_raw_size;
8397 }
8398 else
8399 esym.asym.value = last;
8400 if (!bfd_ecoff_debug_one_external (abfd, &debug, swap,
8401 secname[i], &esym))
8402 return FALSE;
8403 }
8404
8405 for (p = o->link_order_head; p != NULL; p = p->next)
8406 {
8407 asection *input_section;
8408 bfd *input_bfd;
8409 const struct ecoff_debug_swap *input_swap;
8410 struct ecoff_debug_info input_debug;
8411 char *eraw_src;
8412 char *eraw_end;
8413
8414 if (p->type != bfd_indirect_link_order)
8415 {
8416 if (p->type == bfd_data_link_order)
8417 continue;
8418 abort ();
8419 }
8420
8421 input_section = p->u.indirect.section;
8422 input_bfd = input_section->owner;
8423
8424 if (bfd_get_flavour (input_bfd) != bfd_target_elf_flavour
8425 || (get_elf_backend_data (input_bfd)
8426 ->elf_backend_ecoff_debug_swap) == NULL)
8427 {
8428 /* I don't know what a non MIPS ELF bfd would be
8429 doing with a .mdebug section, but I don't really
8430 want to deal with it. */
8431 continue;
8432 }
8433
8434 input_swap = (get_elf_backend_data (input_bfd)
8435 ->elf_backend_ecoff_debug_swap);
8436
8437 BFD_ASSERT (p->size == input_section->_raw_size);
8438
8439 /* The ECOFF linking code expects that we have already
8440 read in the debugging information and set up an
8441 ecoff_debug_info structure, so we do that now. */
8442 if (! _bfd_mips_elf_read_ecoff_info (input_bfd, input_section,
8443 &input_debug))
8444 return FALSE;
8445
8446 if (! (bfd_ecoff_debug_accumulate
8447 (mdebug_handle, abfd, &debug, swap, input_bfd,
8448 &input_debug, input_swap, info)))
8449 return FALSE;
8450
8451 /* Loop through the external symbols. For each one with
8452 interesting information, try to find the symbol in
8453 the linker global hash table and save the information
8454 for the output external symbols. */
8455 eraw_src = input_debug.external_ext;
8456 eraw_end = (eraw_src
8457 + (input_debug.symbolic_header.iextMax
8458 * input_swap->external_ext_size));
8459 for (;
8460 eraw_src < eraw_end;
8461 eraw_src += input_swap->external_ext_size)
8462 {
8463 EXTR ext;
8464 const char *name;
8465 struct mips_elf_link_hash_entry *h;
8466
8467 (*input_swap->swap_ext_in) (input_bfd, eraw_src, &ext);
8468 if (ext.asym.sc == scNil
8469 || ext.asym.sc == scUndefined
8470 || ext.asym.sc == scSUndefined)
8471 continue;
8472
8473 name = input_debug.ssext + ext.asym.iss;
8474 h = mips_elf_link_hash_lookup (mips_elf_hash_table (info),
8475 name, FALSE, FALSE, TRUE);
8476 if (h == NULL || h->esym.ifd != -2)
8477 continue;
8478
8479 if (ext.ifd != -1)
8480 {
8481 BFD_ASSERT (ext.ifd
8482 < input_debug.symbolic_header.ifdMax);
8483 ext.ifd = input_debug.ifdmap[ext.ifd];
8484 }
8485
8486 h->esym = ext;
8487 }
8488
8489 /* Free up the information we just read. */
8490 free (input_debug.line);
8491 free (input_debug.external_dnr);
8492 free (input_debug.external_pdr);
8493 free (input_debug.external_sym);
8494 free (input_debug.external_opt);
8495 free (input_debug.external_aux);
8496 free (input_debug.ss);
8497 free (input_debug.ssext);
8498 free (input_debug.external_fdr);
8499 free (input_debug.external_rfd);
8500 free (input_debug.external_ext);
8501
8502 /* Hack: reset the SEC_HAS_CONTENTS flag so that
8503 elf_link_input_bfd ignores this section. */
8504 input_section->flags &= ~SEC_HAS_CONTENTS;
8505 }
8506
8507 if (SGI_COMPAT (abfd) && info->shared)
8508 {
8509 /* Create .rtproc section. */
8510 rtproc_sec = bfd_get_section_by_name (abfd, ".rtproc");
8511 if (rtproc_sec == NULL)
8512 {
8513 flagword flags = (SEC_HAS_CONTENTS | SEC_IN_MEMORY
8514 | SEC_LINKER_CREATED | SEC_READONLY);
8515
8516 rtproc_sec = bfd_make_section (abfd, ".rtproc");
8517 if (rtproc_sec == NULL
8518 || ! bfd_set_section_flags (abfd, rtproc_sec, flags)
8519 || ! bfd_set_section_alignment (abfd, rtproc_sec, 4))
8520 return FALSE;
8521 }
8522
8523 if (! mips_elf_create_procedure_table (mdebug_handle, abfd,
8524 info, rtproc_sec,
8525 &debug))
8526 return FALSE;
8527 }
8528
8529 /* Build the external symbol information. */
8530 einfo.abfd = abfd;
8531 einfo.info = info;
8532 einfo.debug = &debug;
8533 einfo.swap = swap;
8534 einfo.failed = FALSE;
8535 mips_elf_link_hash_traverse (mips_elf_hash_table (info),
8536 mips_elf_output_extsym, &einfo);
8537 if (einfo.failed)
8538 return FALSE;
8539
8540 /* Set the size of the .mdebug section. */
8541 o->_raw_size = bfd_ecoff_debug_size (abfd, &debug, swap);
8542
8543 /* Skip this section later on (I don't think this currently
8544 matters, but someday it might). */
8545 o->link_order_head = NULL;
8546
8547 mdebug_sec = o;
8548 }
8549
8550 if (strncmp (o->name, ".gptab.", sizeof ".gptab." - 1) == 0)
8551 {
8552 const char *subname;
8553 unsigned int c;
8554 Elf32_gptab *tab;
8555 Elf32_External_gptab *ext_tab;
8556 unsigned int j;
8557
8558 /* The .gptab.sdata and .gptab.sbss sections hold
8559 information describing how the small data area would
8560 change depending upon the -G switch. These sections
8561 not used in executables files. */
8562 if (! info->relocatable)
8563 {
8564 for (p = o->link_order_head; p != NULL; p = p->next)
8565 {
8566 asection *input_section;
8567
8568 if (p->type != bfd_indirect_link_order)
8569 {
8570 if (p->type == bfd_data_link_order)
8571 continue;
8572 abort ();
8573 }
8574
8575 input_section = p->u.indirect.section;
8576
8577 /* Hack: reset the SEC_HAS_CONTENTS flag so that
8578 elf_link_input_bfd ignores this section. */
8579 input_section->flags &= ~SEC_HAS_CONTENTS;
8580 }
8581
8582 /* Skip this section later on (I don't think this
8583 currently matters, but someday it might). */
8584 o->link_order_head = NULL;
8585
8586 /* Really remove the section. */
8587 for (secpp = &abfd->sections;
8588 *secpp != o;
8589 secpp = &(*secpp)->next)
8590 ;
8591 bfd_section_list_remove (abfd, secpp);
8592 --abfd->section_count;
8593
8594 continue;
8595 }
8596
8597 /* There is one gptab for initialized data, and one for
8598 uninitialized data. */
8599 if (strcmp (o->name, ".gptab.sdata") == 0)
8600 gptab_data_sec = o;
8601 else if (strcmp (o->name, ".gptab.sbss") == 0)
8602 gptab_bss_sec = o;
8603 else
8604 {
8605 (*_bfd_error_handler)
8606 (_("%s: illegal section name `%s'"),
8607 bfd_get_filename (abfd), o->name);
8608 bfd_set_error (bfd_error_nonrepresentable_section);
8609 return FALSE;
8610 }
8611
8612 /* The linker script always combines .gptab.data and
8613 .gptab.sdata into .gptab.sdata, and likewise for
8614 .gptab.bss and .gptab.sbss. It is possible that there is
8615 no .sdata or .sbss section in the output file, in which
8616 case we must change the name of the output section. */
8617 subname = o->name + sizeof ".gptab" - 1;
8618 if (bfd_get_section_by_name (abfd, subname) == NULL)
8619 {
8620 if (o == gptab_data_sec)
8621 o->name = ".gptab.data";
8622 else
8623 o->name = ".gptab.bss";
8624 subname = o->name + sizeof ".gptab" - 1;
8625 BFD_ASSERT (bfd_get_section_by_name (abfd, subname) != NULL);
8626 }
8627
8628 /* Set up the first entry. */
8629 c = 1;
8630 amt = c * sizeof (Elf32_gptab);
8631 tab = bfd_malloc (amt);
8632 if (tab == NULL)
8633 return FALSE;
8634 tab[0].gt_header.gt_current_g_value = elf_gp_size (abfd);
8635 tab[0].gt_header.gt_unused = 0;
8636
8637 /* Combine the input sections. */
8638 for (p = o->link_order_head; p != NULL; p = p->next)
8639 {
8640 asection *input_section;
8641 bfd *input_bfd;
8642 bfd_size_type size;
8643 unsigned long last;
8644 bfd_size_type gpentry;
8645
8646 if (p->type != bfd_indirect_link_order)
8647 {
8648 if (p->type == bfd_data_link_order)
8649 continue;
8650 abort ();
8651 }
8652
8653 input_section = p->u.indirect.section;
8654 input_bfd = input_section->owner;
8655
8656 /* Combine the gptab entries for this input section one
8657 by one. We know that the input gptab entries are
8658 sorted by ascending -G value. */
8659 size = bfd_section_size (input_bfd, input_section);
8660 last = 0;
8661 for (gpentry = sizeof (Elf32_External_gptab);
8662 gpentry < size;
8663 gpentry += sizeof (Elf32_External_gptab))
8664 {
8665 Elf32_External_gptab ext_gptab;
8666 Elf32_gptab int_gptab;
8667 unsigned long val;
8668 unsigned long add;
8669 bfd_boolean exact;
8670 unsigned int look;
8671
8672 if (! (bfd_get_section_contents
8673 (input_bfd, input_section, &ext_gptab, gpentry,
8674 sizeof (Elf32_External_gptab))))
8675 {
8676 free (tab);
8677 return FALSE;
8678 }
8679
8680 bfd_mips_elf32_swap_gptab_in (input_bfd, &ext_gptab,
8681 &int_gptab);
8682 val = int_gptab.gt_entry.gt_g_value;
8683 add = int_gptab.gt_entry.gt_bytes - last;
8684
8685 exact = FALSE;
8686 for (look = 1; look < c; look++)
8687 {
8688 if (tab[look].gt_entry.gt_g_value >= val)
8689 tab[look].gt_entry.gt_bytes += add;
8690
8691 if (tab[look].gt_entry.gt_g_value == val)
8692 exact = TRUE;
8693 }
8694
8695 if (! exact)
8696 {
8697 Elf32_gptab *new_tab;
8698 unsigned int max;
8699
8700 /* We need a new table entry. */
8701 amt = (bfd_size_type) (c + 1) * sizeof (Elf32_gptab);
8702 new_tab = bfd_realloc (tab, amt);
8703 if (new_tab == NULL)
8704 {
8705 free (tab);
8706 return FALSE;
8707 }
8708 tab = new_tab;
8709 tab[c].gt_entry.gt_g_value = val;
8710 tab[c].gt_entry.gt_bytes = add;
8711
8712 /* Merge in the size for the next smallest -G
8713 value, since that will be implied by this new
8714 value. */
8715 max = 0;
8716 for (look = 1; look < c; look++)
8717 {
8718 if (tab[look].gt_entry.gt_g_value < val
8719 && (max == 0
8720 || (tab[look].gt_entry.gt_g_value
8721 > tab[max].gt_entry.gt_g_value)))
8722 max = look;
8723 }
8724 if (max != 0)
8725 tab[c].gt_entry.gt_bytes +=
8726 tab[max].gt_entry.gt_bytes;
8727
8728 ++c;
8729 }
8730
8731 last = int_gptab.gt_entry.gt_bytes;
8732 }
8733
8734 /* Hack: reset the SEC_HAS_CONTENTS flag so that
8735 elf_link_input_bfd ignores this section. */
8736 input_section->flags &= ~SEC_HAS_CONTENTS;
8737 }
8738
8739 /* The table must be sorted by -G value. */
8740 if (c > 2)
8741 qsort (tab + 1, c - 1, sizeof (tab[0]), gptab_compare);
8742
8743 /* Swap out the table. */
8744 amt = (bfd_size_type) c * sizeof (Elf32_External_gptab);
8745 ext_tab = bfd_alloc (abfd, amt);
8746 if (ext_tab == NULL)
8747 {
8748 free (tab);
8749 return FALSE;
8750 }
8751
8752 for (j = 0; j < c; j++)
8753 bfd_mips_elf32_swap_gptab_out (abfd, tab + j, ext_tab + j);
8754 free (tab);
8755
8756 o->_raw_size = c * sizeof (Elf32_External_gptab);
8757 o->contents = (bfd_byte *) ext_tab;
8758
8759 /* Skip this section later on (I don't think this currently
8760 matters, but someday it might). */
8761 o->link_order_head = NULL;
8762 }
8763 }
8764
8765 /* Invoke the regular ELF backend linker to do all the work. */
8766 if (!bfd_elf_final_link (abfd, info))
8767 return FALSE;
8768
8769 /* Now write out the computed sections. */
8770
8771 if (reginfo_sec != NULL)
8772 {
8773 Elf32_External_RegInfo ext;
8774
8775 bfd_mips_elf32_swap_reginfo_out (abfd, &reginfo, &ext);
8776 if (! bfd_set_section_contents (abfd, reginfo_sec, &ext, 0, sizeof ext))
8777 return FALSE;
8778 }
8779
8780 if (mdebug_sec != NULL)
8781 {
8782 BFD_ASSERT (abfd->output_has_begun);
8783 if (! bfd_ecoff_write_accumulated_debug (mdebug_handle, abfd, &debug,
8784 swap, info,
8785 mdebug_sec->filepos))
8786 return FALSE;
8787
8788 bfd_ecoff_debug_free (mdebug_handle, abfd, &debug, swap, info);
8789 }
8790
8791 if (gptab_data_sec != NULL)
8792 {
8793 if (! bfd_set_section_contents (abfd, gptab_data_sec,
8794 gptab_data_sec->contents,
8795 0, gptab_data_sec->_raw_size))
8796 return FALSE;
8797 }
8798
8799 if (gptab_bss_sec != NULL)
8800 {
8801 if (! bfd_set_section_contents (abfd, gptab_bss_sec,
8802 gptab_bss_sec->contents,
8803 0, gptab_bss_sec->_raw_size))
8804 return FALSE;
8805 }
8806
8807 if (SGI_COMPAT (abfd))
8808 {
8809 rtproc_sec = bfd_get_section_by_name (abfd, ".rtproc");
8810 if (rtproc_sec != NULL)
8811 {
8812 if (! bfd_set_section_contents (abfd, rtproc_sec,
8813 rtproc_sec->contents,
8814 0, rtproc_sec->_raw_size))
8815 return FALSE;
8816 }
8817 }
8818
8819 return TRUE;
8820 }
8821 \f
8822 /* Structure for saying that BFD machine EXTENSION extends BASE. */
8823
8824 struct mips_mach_extension {
8825 unsigned long extension, base;
8826 };
8827
8828
8829 /* An array describing how BFD machines relate to one another. The entries
8830 are ordered topologically with MIPS I extensions listed last. */
8831
8832 static const struct mips_mach_extension mips_mach_extensions[] = {
8833 /* MIPS64 extensions. */
8834 { bfd_mach_mipsisa64r2, bfd_mach_mipsisa64 },
8835 { bfd_mach_mips_sb1, bfd_mach_mipsisa64 },
8836
8837 /* MIPS V extensions. */
8838 { bfd_mach_mipsisa64, bfd_mach_mips5 },
8839
8840 /* R10000 extensions. */
8841 { bfd_mach_mips12000, bfd_mach_mips10000 },
8842
8843 /* R5000 extensions. Note: the vr5500 ISA is an extension of the core
8844 vr5400 ISA, but doesn't include the multimedia stuff. It seems
8845 better to allow vr5400 and vr5500 code to be merged anyway, since
8846 many libraries will just use the core ISA. Perhaps we could add
8847 some sort of ASE flag if this ever proves a problem. */
8848 { bfd_mach_mips5500, bfd_mach_mips5400 },
8849 { bfd_mach_mips5400, bfd_mach_mips5000 },
8850
8851 /* MIPS IV extensions. */
8852 { bfd_mach_mips5, bfd_mach_mips8000 },
8853 { bfd_mach_mips10000, bfd_mach_mips8000 },
8854 { bfd_mach_mips5000, bfd_mach_mips8000 },
8855 { bfd_mach_mips7000, bfd_mach_mips8000 },
8856
8857 /* VR4100 extensions. */
8858 { bfd_mach_mips4120, bfd_mach_mips4100 },
8859 { bfd_mach_mips4111, bfd_mach_mips4100 },
8860
8861 /* MIPS III extensions. */
8862 { bfd_mach_mips8000, bfd_mach_mips4000 },
8863 { bfd_mach_mips4650, bfd_mach_mips4000 },
8864 { bfd_mach_mips4600, bfd_mach_mips4000 },
8865 { bfd_mach_mips4400, bfd_mach_mips4000 },
8866 { bfd_mach_mips4300, bfd_mach_mips4000 },
8867 { bfd_mach_mips4100, bfd_mach_mips4000 },
8868 { bfd_mach_mips4010, bfd_mach_mips4000 },
8869
8870 /* MIPS32 extensions. */
8871 { bfd_mach_mipsisa32r2, bfd_mach_mipsisa32 },
8872
8873 /* MIPS II extensions. */
8874 { bfd_mach_mips4000, bfd_mach_mips6000 },
8875 { bfd_mach_mipsisa32, bfd_mach_mips6000 },
8876
8877 /* MIPS I extensions. */
8878 { bfd_mach_mips6000, bfd_mach_mips3000 },
8879 { bfd_mach_mips3900, bfd_mach_mips3000 }
8880 };
8881
8882
8883 /* Return true if bfd machine EXTENSION is an extension of machine BASE. */
8884
8885 static bfd_boolean
8886 mips_mach_extends_p (unsigned long base, unsigned long extension)
8887 {
8888 size_t i;
8889
8890 for (i = 0; extension != base && i < ARRAY_SIZE (mips_mach_extensions); i++)
8891 if (extension == mips_mach_extensions[i].extension)
8892 extension = mips_mach_extensions[i].base;
8893
8894 return extension == base;
8895 }
8896
8897
8898 /* Return true if the given ELF header flags describe a 32-bit binary. */
8899
8900 static bfd_boolean
8901 mips_32bit_flags_p (flagword flags)
8902 {
8903 return ((flags & EF_MIPS_32BITMODE) != 0
8904 || (flags & EF_MIPS_ABI) == E_MIPS_ABI_O32
8905 || (flags & EF_MIPS_ABI) == E_MIPS_ABI_EABI32
8906 || (flags & EF_MIPS_ARCH) == E_MIPS_ARCH_1
8907 || (flags & EF_MIPS_ARCH) == E_MIPS_ARCH_2
8908 || (flags & EF_MIPS_ARCH) == E_MIPS_ARCH_32
8909 || (flags & EF_MIPS_ARCH) == E_MIPS_ARCH_32R2);
8910 }
8911
8912
8913 /* Merge backend specific data from an object file to the output
8914 object file when linking. */
8915
8916 bfd_boolean
8917 _bfd_mips_elf_merge_private_bfd_data (bfd *ibfd, bfd *obfd)
8918 {
8919 flagword old_flags;
8920 flagword new_flags;
8921 bfd_boolean ok;
8922 bfd_boolean null_input_bfd = TRUE;
8923 asection *sec;
8924
8925 /* Check if we have the same endianess */
8926 if (! _bfd_generic_verify_endian_match (ibfd, obfd))
8927 {
8928 (*_bfd_error_handler)
8929 (_("%s: endianness incompatible with that of the selected emulation"),
8930 bfd_archive_filename (ibfd));
8931 return FALSE;
8932 }
8933
8934 if (bfd_get_flavour (ibfd) != bfd_target_elf_flavour
8935 || bfd_get_flavour (obfd) != bfd_target_elf_flavour)
8936 return TRUE;
8937
8938 if (strcmp (bfd_get_target (ibfd), bfd_get_target (obfd)) != 0)
8939 {
8940 (*_bfd_error_handler)
8941 (_("%s: ABI is incompatible with that of the selected emulation"),
8942 bfd_archive_filename (ibfd));
8943 return FALSE;
8944 }
8945
8946 new_flags = elf_elfheader (ibfd)->e_flags;
8947 elf_elfheader (obfd)->e_flags |= new_flags & EF_MIPS_NOREORDER;
8948 old_flags = elf_elfheader (obfd)->e_flags;
8949
8950 if (! elf_flags_init (obfd))
8951 {
8952 elf_flags_init (obfd) = TRUE;
8953 elf_elfheader (obfd)->e_flags = new_flags;
8954 elf_elfheader (obfd)->e_ident[EI_CLASS]
8955 = elf_elfheader (ibfd)->e_ident[EI_CLASS];
8956
8957 if (bfd_get_arch (obfd) == bfd_get_arch (ibfd)
8958 && bfd_get_arch_info (obfd)->the_default)
8959 {
8960 if (! bfd_set_arch_mach (obfd, bfd_get_arch (ibfd),
8961 bfd_get_mach (ibfd)))
8962 return FALSE;
8963 }
8964
8965 return TRUE;
8966 }
8967
8968 /* Check flag compatibility. */
8969
8970 new_flags &= ~EF_MIPS_NOREORDER;
8971 old_flags &= ~EF_MIPS_NOREORDER;
8972
8973 /* Some IRIX 6 BSD-compatibility objects have this bit set. It
8974 doesn't seem to matter. */
8975 new_flags &= ~EF_MIPS_XGOT;
8976 old_flags &= ~EF_MIPS_XGOT;
8977
8978 /* MIPSpro generates ucode info in n64 objects. Again, we should
8979 just be able to ignore this. */
8980 new_flags &= ~EF_MIPS_UCODE;
8981 old_flags &= ~EF_MIPS_UCODE;
8982
8983 if (new_flags == old_flags)
8984 return TRUE;
8985
8986 /* Check to see if the input BFD actually contains any sections.
8987 If not, its flags may not have been initialised either, but it cannot
8988 actually cause any incompatibility. */
8989 for (sec = ibfd->sections; sec != NULL; sec = sec->next)
8990 {
8991 /* Ignore synthetic sections and empty .text, .data and .bss sections
8992 which are automatically generated by gas. */
8993 if (strcmp (sec->name, ".reginfo")
8994 && strcmp (sec->name, ".mdebug")
8995 && (sec->_raw_size != 0
8996 || (strcmp (sec->name, ".text")
8997 && strcmp (sec->name, ".data")
8998 && strcmp (sec->name, ".bss"))))
8999 {
9000 null_input_bfd = FALSE;
9001 break;
9002 }
9003 }
9004 if (null_input_bfd)
9005 return TRUE;
9006
9007 ok = TRUE;
9008
9009 if (((new_flags & (EF_MIPS_PIC | EF_MIPS_CPIC)) != 0)
9010 != ((old_flags & (EF_MIPS_PIC | EF_MIPS_CPIC)) != 0))
9011 {
9012 (*_bfd_error_handler)
9013 (_("%s: warning: linking PIC files with non-PIC files"),
9014 bfd_archive_filename (ibfd));
9015 ok = TRUE;
9016 }
9017
9018 if (new_flags & (EF_MIPS_PIC | EF_MIPS_CPIC))
9019 elf_elfheader (obfd)->e_flags |= EF_MIPS_CPIC;
9020 if (! (new_flags & EF_MIPS_PIC))
9021 elf_elfheader (obfd)->e_flags &= ~EF_MIPS_PIC;
9022
9023 new_flags &= ~ (EF_MIPS_PIC | EF_MIPS_CPIC);
9024 old_flags &= ~ (EF_MIPS_PIC | EF_MIPS_CPIC);
9025
9026 /* Compare the ISAs. */
9027 if (mips_32bit_flags_p (old_flags) != mips_32bit_flags_p (new_flags))
9028 {
9029 (*_bfd_error_handler)
9030 (_("%s: linking 32-bit code with 64-bit code"),
9031 bfd_archive_filename (ibfd));
9032 ok = FALSE;
9033 }
9034 else if (!mips_mach_extends_p (bfd_get_mach (ibfd), bfd_get_mach (obfd)))
9035 {
9036 /* OBFD's ISA isn't the same as, or an extension of, IBFD's. */
9037 if (mips_mach_extends_p (bfd_get_mach (obfd), bfd_get_mach (ibfd)))
9038 {
9039 /* Copy the architecture info from IBFD to OBFD. Also copy
9040 the 32-bit flag (if set) so that we continue to recognise
9041 OBFD as a 32-bit binary. */
9042 bfd_set_arch_info (obfd, bfd_get_arch_info (ibfd));
9043 elf_elfheader (obfd)->e_flags &= ~(EF_MIPS_ARCH | EF_MIPS_MACH);
9044 elf_elfheader (obfd)->e_flags
9045 |= new_flags & (EF_MIPS_ARCH | EF_MIPS_MACH | EF_MIPS_32BITMODE);
9046
9047 /* Copy across the ABI flags if OBFD doesn't use them
9048 and if that was what caused us to treat IBFD as 32-bit. */
9049 if ((old_flags & EF_MIPS_ABI) == 0
9050 && mips_32bit_flags_p (new_flags)
9051 && !mips_32bit_flags_p (new_flags & ~EF_MIPS_ABI))
9052 elf_elfheader (obfd)->e_flags |= new_flags & EF_MIPS_ABI;
9053 }
9054 else
9055 {
9056 /* The ISAs aren't compatible. */
9057 (*_bfd_error_handler)
9058 (_("%s: linking %s module with previous %s modules"),
9059 bfd_archive_filename (ibfd),
9060 bfd_printable_name (ibfd),
9061 bfd_printable_name (obfd));
9062 ok = FALSE;
9063 }
9064 }
9065
9066 new_flags &= ~(EF_MIPS_ARCH | EF_MIPS_MACH | EF_MIPS_32BITMODE);
9067 old_flags &= ~(EF_MIPS_ARCH | EF_MIPS_MACH | EF_MIPS_32BITMODE);
9068
9069 /* Compare ABIs. The 64-bit ABI does not use EF_MIPS_ABI. But, it
9070 does set EI_CLASS differently from any 32-bit ABI. */
9071 if ((new_flags & EF_MIPS_ABI) != (old_flags & EF_MIPS_ABI)
9072 || (elf_elfheader (ibfd)->e_ident[EI_CLASS]
9073 != elf_elfheader (obfd)->e_ident[EI_CLASS]))
9074 {
9075 /* Only error if both are set (to different values). */
9076 if (((new_flags & EF_MIPS_ABI) && (old_flags & EF_MIPS_ABI))
9077 || (elf_elfheader (ibfd)->e_ident[EI_CLASS]
9078 != elf_elfheader (obfd)->e_ident[EI_CLASS]))
9079 {
9080 (*_bfd_error_handler)
9081 (_("%s: ABI mismatch: linking %s module with previous %s modules"),
9082 bfd_archive_filename (ibfd),
9083 elf_mips_abi_name (ibfd),
9084 elf_mips_abi_name (obfd));
9085 ok = FALSE;
9086 }
9087 new_flags &= ~EF_MIPS_ABI;
9088 old_flags &= ~EF_MIPS_ABI;
9089 }
9090
9091 /* For now, allow arbitrary mixing of ASEs (retain the union). */
9092 if ((new_flags & EF_MIPS_ARCH_ASE) != (old_flags & EF_MIPS_ARCH_ASE))
9093 {
9094 elf_elfheader (obfd)->e_flags |= new_flags & EF_MIPS_ARCH_ASE;
9095
9096 new_flags &= ~ EF_MIPS_ARCH_ASE;
9097 old_flags &= ~ EF_MIPS_ARCH_ASE;
9098 }
9099
9100 /* Warn about any other mismatches */
9101 if (new_flags != old_flags)
9102 {
9103 (*_bfd_error_handler)
9104 (_("%s: uses different e_flags (0x%lx) fields than previous modules (0x%lx)"),
9105 bfd_archive_filename (ibfd), (unsigned long) new_flags,
9106 (unsigned long) old_flags);
9107 ok = FALSE;
9108 }
9109
9110 if (! ok)
9111 {
9112 bfd_set_error (bfd_error_bad_value);
9113 return FALSE;
9114 }
9115
9116 return TRUE;
9117 }
9118
9119 /* Function to keep MIPS specific file flags like as EF_MIPS_PIC. */
9120
9121 bfd_boolean
9122 _bfd_mips_elf_set_private_flags (bfd *abfd, flagword flags)
9123 {
9124 BFD_ASSERT (!elf_flags_init (abfd)
9125 || elf_elfheader (abfd)->e_flags == flags);
9126
9127 elf_elfheader (abfd)->e_flags = flags;
9128 elf_flags_init (abfd) = TRUE;
9129 return TRUE;
9130 }
9131
9132 bfd_boolean
9133 _bfd_mips_elf_print_private_bfd_data (bfd *abfd, void *ptr)
9134 {
9135 FILE *file = ptr;
9136
9137 BFD_ASSERT (abfd != NULL && ptr != NULL);
9138
9139 /* Print normal ELF private data. */
9140 _bfd_elf_print_private_bfd_data (abfd, ptr);
9141
9142 /* xgettext:c-format */
9143 fprintf (file, _("private flags = %lx:"), elf_elfheader (abfd)->e_flags);
9144
9145 if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI) == E_MIPS_ABI_O32)
9146 fprintf (file, _(" [abi=O32]"));
9147 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI) == E_MIPS_ABI_O64)
9148 fprintf (file, _(" [abi=O64]"));
9149 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI) == E_MIPS_ABI_EABI32)
9150 fprintf (file, _(" [abi=EABI32]"));
9151 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI) == E_MIPS_ABI_EABI64)
9152 fprintf (file, _(" [abi=EABI64]"));
9153 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ABI))
9154 fprintf (file, _(" [abi unknown]"));
9155 else if (ABI_N32_P (abfd))
9156 fprintf (file, _(" [abi=N32]"));
9157 else if (ABI_64_P (abfd))
9158 fprintf (file, _(" [abi=64]"));
9159 else
9160 fprintf (file, _(" [no abi set]"));
9161
9162 if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_1)
9163 fprintf (file, _(" [mips1]"));
9164 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_2)
9165 fprintf (file, _(" [mips2]"));
9166 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_3)
9167 fprintf (file, _(" [mips3]"));
9168 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_4)
9169 fprintf (file, _(" [mips4]"));
9170 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_5)
9171 fprintf (file, _(" [mips5]"));
9172 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_32)
9173 fprintf (file, _(" [mips32]"));
9174 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_64)
9175 fprintf (file, _(" [mips64]"));
9176 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_32R2)
9177 fprintf (file, _(" [mips32r2]"));
9178 else if ((elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH) == E_MIPS_ARCH_64R2)
9179 fprintf (file, _(" [mips64r2]"));
9180 else
9181 fprintf (file, _(" [unknown ISA]"));
9182
9183 if (elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH_ASE_MDMX)
9184 fprintf (file, _(" [mdmx]"));
9185
9186 if (elf_elfheader (abfd)->e_flags & EF_MIPS_ARCH_ASE_M16)
9187 fprintf (file, _(" [mips16]"));
9188
9189 if (elf_elfheader (abfd)->e_flags & EF_MIPS_32BITMODE)
9190 fprintf (file, _(" [32bitmode]"));
9191 else
9192 fprintf (file, _(" [not 32bitmode]"));
9193
9194 fputc ('\n', file);
9195
9196 return TRUE;
9197 }
9198
9199 struct bfd_elf_special_section const _bfd_mips_elf_special_sections[]=
9200 {
9201 { ".sdata", 6, -2, SHT_PROGBITS, SHF_ALLOC + SHF_WRITE + SHF_MIPS_GPREL },
9202 { ".sbss", 5, -2, SHT_NOBITS, SHF_ALLOC + SHF_WRITE + SHF_MIPS_GPREL },
9203 { ".lit4", 5, 0, SHT_PROGBITS, SHF_ALLOC + SHF_WRITE + SHF_MIPS_GPREL },
9204 { ".lit8", 5, 0, SHT_PROGBITS, SHF_ALLOC + SHF_WRITE + SHF_MIPS_GPREL },
9205 { ".ucode", 6, 0, SHT_MIPS_UCODE, 0 },
9206 { ".mdebug", 7, 0, SHT_MIPS_DEBUG, 0 },
9207 { NULL, 0, 0, 0, 0 }
9208 };