* elf64-alpha.c (SKIP_HOWTO): New.
[binutils-gdb.git] / bfd / elf64-alpha.c
1 /* Alpha specific support for 64-bit ELF
2 Copyright 1996, 1997, 1998, 1999, 2000, 2001
3 Free Software Foundation, Inc.
4 Contributed by Richard Henderson <rth@tamu.edu>.
5
6 This file is part of BFD, the Binary File Descriptor library.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21
22 /* We need a published ABI spec for this. Until one comes out, don't
23 assume this'll remain unchanged forever. */
24
25 #include "bfd.h"
26 #include "sysdep.h"
27 #include "libbfd.h"
28 #include "elf-bfd.h"
29
30 #include "elf/alpha.h"
31
32 #define ALPHAECOFF
33
34 #define NO_COFF_RELOCS
35 #define NO_COFF_SYMBOLS
36 #define NO_COFF_LINENOS
37
38 /* Get the ECOFF swapping routines. Needed for the debug information. */
39 #include "coff/internal.h"
40 #include "coff/sym.h"
41 #include "coff/symconst.h"
42 #include "coff/ecoff.h"
43 #include "coff/alpha.h"
44 #include "aout/ar.h"
45 #include "libcoff.h"
46 #include "libecoff.h"
47 #define ECOFF_64
48 #include "ecoffswap.h"
49
50 static int alpha_elf_dynamic_symbol_p
51 PARAMS((struct elf_link_hash_entry *, struct bfd_link_info *));
52 static struct bfd_hash_entry * elf64_alpha_link_hash_newfunc
53 PARAMS((struct bfd_hash_entry *, struct bfd_hash_table *, const char *));
54 static struct bfd_link_hash_table * elf64_alpha_bfd_link_hash_table_create
55 PARAMS((bfd *));
56
57 static bfd_reloc_status_type elf64_alpha_reloc_nil
58 PARAMS((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
59 static bfd_reloc_status_type elf64_alpha_reloc_bad
60 PARAMS((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
61 static bfd_reloc_status_type elf64_alpha_do_reloc_gpdisp
62 PARAMS((bfd *, bfd_vma, bfd_byte *, bfd_byte *));
63 static bfd_reloc_status_type elf64_alpha_reloc_gpdisp
64 PARAMS((bfd *, arelent *, asymbol *, PTR, asection *, bfd *, char **));
65
66 static reloc_howto_type * elf64_alpha_bfd_reloc_type_lookup
67 PARAMS((bfd *, bfd_reloc_code_real_type));
68 static void elf64_alpha_info_to_howto
69 PARAMS((bfd *, arelent *, Elf64_Internal_Rela *));
70
71 static boolean elf64_alpha_mkobject
72 PARAMS((bfd *));
73 static boolean elf64_alpha_object_p
74 PARAMS((bfd *));
75 static boolean elf64_alpha_section_from_shdr
76 PARAMS((bfd *, Elf64_Internal_Shdr *, char *));
77 static boolean elf64_alpha_fake_sections
78 PARAMS((bfd *, Elf64_Internal_Shdr *, asection *));
79 static boolean elf64_alpha_create_got_section
80 PARAMS((bfd *, struct bfd_link_info *));
81 static boolean elf64_alpha_create_dynamic_sections
82 PARAMS((bfd *, struct bfd_link_info *));
83
84 static boolean elf64_alpha_read_ecoff_info
85 PARAMS((bfd *, asection *, struct ecoff_debug_info *));
86 static boolean elf64_alpha_is_local_label_name
87 PARAMS((bfd *, const char *));
88 static boolean elf64_alpha_find_nearest_line
89 PARAMS((bfd *, asection *, asymbol **, bfd_vma, const char **,
90 const char **, unsigned int *));
91
92 #if defined(__STDC__) || defined(ALMOST_STDC)
93 struct alpha_elf_link_hash_entry;
94 #endif
95
96 static boolean elf64_alpha_output_extsym
97 PARAMS((struct alpha_elf_link_hash_entry *, PTR));
98
99 static boolean elf64_alpha_can_merge_gots
100 PARAMS((bfd *, bfd *));
101 static void elf64_alpha_merge_gots
102 PARAMS((bfd *, bfd *));
103 static boolean elf64_alpha_calc_got_offsets_for_symbol
104 PARAMS ((struct alpha_elf_link_hash_entry *, PTR));
105 static void elf64_alpha_calc_got_offsets PARAMS ((struct bfd_link_info *));
106 static boolean elf64_alpha_size_got_sections
107 PARAMS ((bfd *, struct bfd_link_info *));
108 static boolean elf64_alpha_always_size_sections
109 PARAMS ((bfd *, struct bfd_link_info *));
110 static boolean elf64_alpha_calc_dynrel_sizes
111 PARAMS ((struct alpha_elf_link_hash_entry *, struct bfd_link_info *));
112 static boolean elf64_alpha_add_symbol_hook
113 PARAMS ((bfd *, struct bfd_link_info *, const Elf_Internal_Sym *,
114 const char **, flagword *, asection **, bfd_vma *));
115 static boolean elf64_alpha_check_relocs
116 PARAMS((bfd *, struct bfd_link_info *, asection *sec,
117 const Elf_Internal_Rela *));
118 static boolean elf64_alpha_adjust_dynamic_symbol
119 PARAMS((struct bfd_link_info *, struct elf_link_hash_entry *));
120 static boolean elf64_alpha_size_dynamic_sections
121 PARAMS((bfd *, struct bfd_link_info *));
122 static boolean elf64_alpha_relocate_section
123 PARAMS((bfd *, struct bfd_link_info *, bfd *, asection *, bfd_byte *,
124 Elf_Internal_Rela *, Elf_Internal_Sym *, asection **));
125 static boolean elf64_alpha_finish_dynamic_symbol
126 PARAMS((bfd *, struct bfd_link_info *, struct elf_link_hash_entry *,
127 Elf_Internal_Sym *));
128 static boolean elf64_alpha_finish_dynamic_sections
129 PARAMS((bfd *, struct bfd_link_info *));
130 static boolean elf64_alpha_final_link
131 PARAMS((bfd *, struct bfd_link_info *));
132 static boolean elf64_alpha_merge_ind_symbols
133 PARAMS((struct alpha_elf_link_hash_entry *, PTR));
134 static Elf_Internal_Rela * elf64_alpha_find_reloc_at_ofs
135 PARAMS ((Elf_Internal_Rela *, Elf_Internal_Rela *, bfd_vma, int));
136 static enum elf_reloc_type_class elf64_alpha_reloc_type_class
137 PARAMS ((int));
138 \f
139 struct alpha_elf_link_hash_entry
140 {
141 struct elf_link_hash_entry root;
142
143 /* External symbol information. */
144 EXTR esym;
145
146 /* Cumulative flags for all the .got entries. */
147 int flags;
148
149 /* Contexts (LITUSE) in which a literal was referenced. */
150 #define ALPHA_ELF_LINK_HASH_LU_ADDR 0x01
151 #define ALPHA_ELF_LINK_HASH_LU_MEM 0x02
152 #define ALPHA_ELF_LINK_HASH_LU_BYTE 0x04
153 #define ALPHA_ELF_LINK_HASH_LU_FUNC 0x08
154
155 /* Used to implement multiple .got subsections. */
156 struct alpha_elf_got_entry
157 {
158 struct alpha_elf_got_entry *next;
159
160 /* which .got subsection? */
161 bfd *gotobj;
162
163 /* the addend in effect for this entry. */
164 bfd_signed_vma addend;
165
166 /* the .got offset for this entry. */
167 int got_offset;
168
169 int flags;
170
171 /* An additional flag. */
172 #define ALPHA_ELF_GOT_ENTRY_RELOCS_DONE 0x10
173
174 int use_count;
175 } *got_entries;
176
177 /* used to count non-got, non-plt relocations for delayed sizing
178 of relocation sections. */
179 struct alpha_elf_reloc_entry
180 {
181 struct alpha_elf_reloc_entry *next;
182
183 /* which .reloc section? */
184 asection *srel;
185
186 /* what kind of relocation? */
187 unsigned int rtype;
188
189 /* is this against read-only section? */
190 unsigned int reltext : 1;
191
192 /* how many did we find? */
193 unsigned long count;
194 } *reloc_entries;
195 };
196
197 /* Alpha ELF linker hash table. */
198
199 struct alpha_elf_link_hash_table
200 {
201 struct elf_link_hash_table root;
202
203 /* The head of a list of .got subsections linked through
204 alpha_elf_tdata(abfd)->got_link_next. */
205 bfd *got_list;
206 };
207
208 /* Look up an entry in a Alpha ELF linker hash table. */
209
210 #define alpha_elf_link_hash_lookup(table, string, create, copy, follow) \
211 ((struct alpha_elf_link_hash_entry *) \
212 elf_link_hash_lookup (&(table)->root, (string), (create), \
213 (copy), (follow)))
214
215 /* Traverse a Alpha ELF linker hash table. */
216
217 #define alpha_elf_link_hash_traverse(table, func, info) \
218 (elf_link_hash_traverse \
219 (&(table)->root, \
220 (boolean (*) PARAMS ((struct elf_link_hash_entry *, PTR))) (func), \
221 (info)))
222
223 /* Get the Alpha ELF linker hash table from a link_info structure. */
224
225 #define alpha_elf_hash_table(p) \
226 ((struct alpha_elf_link_hash_table *) ((p)->hash))
227
228 /* Get the object's symbols as our own entry type. */
229
230 #define alpha_elf_sym_hashes(abfd) \
231 ((struct alpha_elf_link_hash_entry **)elf_sym_hashes(abfd))
232
233 /* Should we do dynamic things to this symbol? */
234
235 static int
236 alpha_elf_dynamic_symbol_p (h, info)
237 struct elf_link_hash_entry *h;
238 struct bfd_link_info *info;
239 {
240 if (h == NULL)
241 return false;
242
243 while (h->root.type == bfd_link_hash_indirect
244 || h->root.type == bfd_link_hash_warning)
245 h = (struct elf_link_hash_entry *) h->root.u.i.link;
246
247 if (h->dynindx == -1)
248 return false;
249
250 if (h->root.type == bfd_link_hash_undefweak
251 || h->root.type == bfd_link_hash_defweak)
252 return true;
253
254 switch (ELF_ST_VISIBILITY (h->other))
255 {
256 case STV_DEFAULT:
257 break;
258 case STV_HIDDEN:
259 case STV_INTERNAL:
260 return false;
261 case STV_PROTECTED:
262 if (h->elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR)
263 return false;
264 break;
265 }
266
267 if ((info->shared && !info->symbolic)
268 || ((h->elf_link_hash_flags
269 & (ELF_LINK_HASH_DEF_DYNAMIC | ELF_LINK_HASH_REF_REGULAR))
270 == (ELF_LINK_HASH_DEF_DYNAMIC | ELF_LINK_HASH_REF_REGULAR)))
271 return true;
272
273 return false;
274 }
275
276 /* Create an entry in a Alpha ELF linker hash table. */
277
278 static struct bfd_hash_entry *
279 elf64_alpha_link_hash_newfunc (entry, table, string)
280 struct bfd_hash_entry *entry;
281 struct bfd_hash_table *table;
282 const char *string;
283 {
284 struct alpha_elf_link_hash_entry *ret =
285 (struct alpha_elf_link_hash_entry *) entry;
286
287 /* Allocate the structure if it has not already been allocated by a
288 subclass. */
289 if (ret == (struct alpha_elf_link_hash_entry *) NULL)
290 ret = ((struct alpha_elf_link_hash_entry *)
291 bfd_hash_allocate (table,
292 sizeof (struct alpha_elf_link_hash_entry)));
293 if (ret == (struct alpha_elf_link_hash_entry *) NULL)
294 return (struct bfd_hash_entry *) ret;
295
296 /* Call the allocation method of the superclass. */
297 ret = ((struct alpha_elf_link_hash_entry *)
298 _bfd_elf_link_hash_newfunc ((struct bfd_hash_entry *) ret,
299 table, string));
300 if (ret != (struct alpha_elf_link_hash_entry *) NULL)
301 {
302 /* Set local fields. */
303 memset (&ret->esym, 0, sizeof (EXTR));
304 /* We use -2 as a marker to indicate that the information has
305 not been set. -1 means there is no associated ifd. */
306 ret->esym.ifd = -2;
307 ret->flags = 0;
308 ret->got_entries = NULL;
309 ret->reloc_entries = NULL;
310 }
311
312 return (struct bfd_hash_entry *) ret;
313 }
314
315 /* Create a Alpha ELF linker hash table. */
316
317 static struct bfd_link_hash_table *
318 elf64_alpha_bfd_link_hash_table_create (abfd)
319 bfd *abfd;
320 {
321 struct alpha_elf_link_hash_table *ret;
322
323 ret = ((struct alpha_elf_link_hash_table *)
324 bfd_zalloc (abfd, sizeof (struct alpha_elf_link_hash_table)));
325 if (ret == (struct alpha_elf_link_hash_table *) NULL)
326 return NULL;
327
328 if (! _bfd_elf_link_hash_table_init (&ret->root, abfd,
329 elf64_alpha_link_hash_newfunc))
330 {
331 bfd_release (abfd, ret);
332 return NULL;
333 }
334
335 return &ret->root.root;
336 }
337 \f
338 /* We have some private fields hanging off of the elf_tdata structure. */
339
340 struct alpha_elf_obj_tdata
341 {
342 struct elf_obj_tdata root;
343
344 /* For every input file, these are the got entries for that object's
345 local symbols. */
346 struct alpha_elf_got_entry ** local_got_entries;
347
348 /* For every input file, this is the object that owns the got that
349 this input file uses. */
350 bfd *gotobj;
351
352 /* For every got, this is a linked list through the objects using this got */
353 bfd *in_got_link_next;
354
355 /* For every got, this is a link to the next got subsegment. */
356 bfd *got_link_next;
357
358 /* For every got, this is the section. */
359 asection *got;
360
361 /* For every got, this is it's total number of *entries*. */
362 int total_got_entries;
363
364 /* For every got, this is the sum of the number of *entries* required
365 to hold all of the member object's local got. */
366 int n_local_got_entries;
367 };
368
369 #define alpha_elf_tdata(abfd) \
370 ((struct alpha_elf_obj_tdata *) (abfd)->tdata.any)
371
372 static boolean
373 elf64_alpha_mkobject (abfd)
374 bfd *abfd;
375 {
376 abfd->tdata.any = bfd_zalloc (abfd, sizeof (struct alpha_elf_obj_tdata));
377 if (abfd->tdata.any == NULL)
378 return false;
379 return true;
380 }
381
382 static boolean
383 elf64_alpha_object_p (abfd)
384 bfd *abfd;
385 {
386 /* Allocate our special target data. */
387 struct alpha_elf_obj_tdata *new_tdata;
388 new_tdata = bfd_zalloc (abfd, sizeof (struct alpha_elf_obj_tdata));
389 if (new_tdata == NULL)
390 return false;
391 new_tdata->root = *abfd->tdata.elf_obj_data;
392 abfd->tdata.any = new_tdata;
393
394 /* Set the right machine number for an Alpha ELF file. */
395 return bfd_default_set_arch_mach (abfd, bfd_arch_alpha, 0);
396 }
397 \f
398 /* In case we're on a 32-bit machine, construct a 64-bit "-1" value
399 from smaller values. Start with zero, widen, *then* decrement. */
400 #define MINUS_ONE (((bfd_vma)0) - 1)
401
402 #define SKIP_HOWTO(N) \
403 HOWTO(N, 0, 0, 0, 0, 0, 0, elf64_alpha_reloc_bad, 0, 0, 0, 0, 0)
404
405 static reloc_howto_type elf64_alpha_howto_table[] =
406 {
407 HOWTO (R_ALPHA_NONE, /* type */
408 0, /* rightshift */
409 0, /* size (0 = byte, 1 = short, 2 = long) */
410 8, /* bitsize */
411 true, /* pc_relative */
412 0, /* bitpos */
413 complain_overflow_dont, /* complain_on_overflow */
414 elf64_alpha_reloc_nil, /* special_function */
415 "NONE", /* name */
416 false, /* partial_inplace */
417 0, /* src_mask */
418 0, /* dst_mask */
419 true), /* pcrel_offset */
420
421 /* A 32 bit reference to a symbol. */
422 HOWTO (R_ALPHA_REFLONG, /* type */
423 0, /* rightshift */
424 2, /* size (0 = byte, 1 = short, 2 = long) */
425 32, /* bitsize */
426 false, /* pc_relative */
427 0, /* bitpos */
428 complain_overflow_bitfield, /* complain_on_overflow */
429 0, /* special_function */
430 "REFLONG", /* name */
431 false, /* partial_inplace */
432 0xffffffff, /* src_mask */
433 0xffffffff, /* dst_mask */
434 false), /* pcrel_offset */
435
436 /* A 64 bit reference to a symbol. */
437 HOWTO (R_ALPHA_REFQUAD, /* type */
438 0, /* rightshift */
439 4, /* size (0 = byte, 1 = short, 2 = long) */
440 64, /* bitsize */
441 false, /* pc_relative */
442 0, /* bitpos */
443 complain_overflow_bitfield, /* complain_on_overflow */
444 0, /* special_function */
445 "REFQUAD", /* name */
446 false, /* partial_inplace */
447 MINUS_ONE, /* src_mask */
448 MINUS_ONE, /* dst_mask */
449 false), /* pcrel_offset */
450
451 /* A 32 bit GP relative offset. This is just like REFLONG except
452 that when the value is used the value of the gp register will be
453 added in. */
454 HOWTO (R_ALPHA_GPREL32, /* type */
455 0, /* rightshift */
456 2, /* size (0 = byte, 1 = short, 2 = long) */
457 32, /* bitsize */
458 false, /* pc_relative */
459 0, /* bitpos */
460 complain_overflow_bitfield, /* complain_on_overflow */
461 0, /* special_function */
462 "GPREL32", /* name */
463 false, /* partial_inplace */
464 0xffffffff, /* src_mask */
465 0xffffffff, /* dst_mask */
466 false), /* pcrel_offset */
467
468 /* Used for an instruction that refers to memory off the GP register. */
469 HOWTO (R_ALPHA_LITERAL, /* type */
470 0, /* rightshift */
471 1, /* size (0 = byte, 1 = short, 2 = long) */
472 16, /* bitsize */
473 false, /* pc_relative */
474 0, /* bitpos */
475 complain_overflow_signed, /* complain_on_overflow */
476 0, /* special_function */
477 "ELF_LITERAL", /* name */
478 false, /* partial_inplace */
479 0xffff, /* src_mask */
480 0xffff, /* dst_mask */
481 false), /* pcrel_offset */
482
483 /* This reloc only appears immediately following an ELF_LITERAL reloc.
484 It identifies a use of the literal. The symbol index is special:
485 1 means the literal address is in the base register of a memory
486 format instruction; 2 means the literal address is in the byte
487 offset register of a byte-manipulation instruction; 3 means the
488 literal address is in the target register of a jsr instruction.
489 This does not actually do any relocation. */
490 HOWTO (R_ALPHA_LITUSE, /* type */
491 0, /* rightshift */
492 1, /* size (0 = byte, 1 = short, 2 = long) */
493 32, /* bitsize */
494 false, /* pc_relative */
495 0, /* bitpos */
496 complain_overflow_dont, /* complain_on_overflow */
497 elf64_alpha_reloc_nil, /* special_function */
498 "LITUSE", /* name */
499 false, /* partial_inplace */
500 0, /* src_mask */
501 0, /* dst_mask */
502 false), /* pcrel_offset */
503
504 /* Load the gp register. This is always used for a ldah instruction
505 which loads the upper 16 bits of the gp register. The symbol
506 index of the GPDISP instruction is an offset in bytes to the lda
507 instruction that loads the lower 16 bits. The value to use for
508 the relocation is the difference between the GP value and the
509 current location; the load will always be done against a register
510 holding the current address.
511
512 NOTE: Unlike ECOFF, partial in-place relocation is not done. If
513 any offset is present in the instructions, it is an offset from
514 the register to the ldah instruction. This lets us avoid any
515 stupid hackery like inventing a gp value to do partial relocation
516 against. Also unlike ECOFF, we do the whole relocation off of
517 the GPDISP rather than a GPDISP_HI16/GPDISP_LO16 pair. An odd,
518 space consuming bit, that, since all the information was present
519 in the GPDISP_HI16 reloc. */
520 HOWTO (R_ALPHA_GPDISP, /* type */
521 16, /* rightshift */
522 2, /* size (0 = byte, 1 = short, 2 = long) */
523 16, /* bitsize */
524 false, /* pc_relative */
525 0, /* bitpos */
526 complain_overflow_dont, /* complain_on_overflow */
527 elf64_alpha_reloc_gpdisp, /* special_function */
528 "GPDISP", /* name */
529 false, /* partial_inplace */
530 0xffff, /* src_mask */
531 0xffff, /* dst_mask */
532 true), /* pcrel_offset */
533
534 /* A 21 bit branch. */
535 HOWTO (R_ALPHA_BRADDR, /* type */
536 2, /* rightshift */
537 2, /* size (0 = byte, 1 = short, 2 = long) */
538 21, /* bitsize */
539 true, /* pc_relative */
540 0, /* bitpos */
541 complain_overflow_signed, /* complain_on_overflow */
542 0, /* special_function */
543 "BRADDR", /* name */
544 false, /* partial_inplace */
545 0x1fffff, /* src_mask */
546 0x1fffff, /* dst_mask */
547 true), /* pcrel_offset */
548
549 /* A hint for a jump to a register. */
550 HOWTO (R_ALPHA_HINT, /* type */
551 2, /* rightshift */
552 1, /* size (0 = byte, 1 = short, 2 = long) */
553 14, /* bitsize */
554 true, /* pc_relative */
555 0, /* bitpos */
556 complain_overflow_dont, /* complain_on_overflow */
557 0, /* special_function */
558 "HINT", /* name */
559 false, /* partial_inplace */
560 0x3fff, /* src_mask */
561 0x3fff, /* dst_mask */
562 true), /* pcrel_offset */
563
564 /* 16 bit PC relative offset. */
565 HOWTO (R_ALPHA_SREL16, /* type */
566 0, /* rightshift */
567 1, /* size (0 = byte, 1 = short, 2 = long) */
568 16, /* bitsize */
569 true, /* pc_relative */
570 0, /* bitpos */
571 complain_overflow_signed, /* complain_on_overflow */
572 0, /* special_function */
573 "SREL16", /* name */
574 false, /* partial_inplace */
575 0xffff, /* src_mask */
576 0xffff, /* dst_mask */
577 true), /* pcrel_offset */
578
579 /* 32 bit PC relative offset. */
580 HOWTO (R_ALPHA_SREL32, /* type */
581 0, /* rightshift */
582 2, /* size (0 = byte, 1 = short, 2 = long) */
583 32, /* bitsize */
584 true, /* pc_relative */
585 0, /* bitpos */
586 complain_overflow_signed, /* complain_on_overflow */
587 0, /* special_function */
588 "SREL32", /* name */
589 false, /* partial_inplace */
590 0xffffffff, /* src_mask */
591 0xffffffff, /* dst_mask */
592 true), /* pcrel_offset */
593
594 /* A 64 bit PC relative offset. */
595 HOWTO (R_ALPHA_SREL64, /* type */
596 0, /* rightshift */
597 4, /* size (0 = byte, 1 = short, 2 = long) */
598 64, /* bitsize */
599 true, /* pc_relative */
600 0, /* bitpos */
601 complain_overflow_signed, /* complain_on_overflow */
602 0, /* special_function */
603 "SREL64", /* name */
604 false, /* partial_inplace */
605 MINUS_ONE, /* src_mask */
606 MINUS_ONE, /* dst_mask */
607 true), /* pcrel_offset */
608
609 /* Skip 12 - 16; deprecated ECOFF relocs. */
610 SKIP_HOWTO (12),
611 SKIP_HOWTO (13),
612 SKIP_HOWTO (14),
613 SKIP_HOWTO (15),
614 SKIP_HOWTO (16),
615
616 /* The high 16 bits of the displacement from GP to the target. */
617 HOWTO (R_ALPHA_GPRELHIGH,
618 0, /* rightshift */
619 1, /* size (0 = byte, 1 = short, 2 = long) */
620 16, /* bitsize */
621 false, /* pc_relative */
622 0, /* bitpos */
623 complain_overflow_signed, /* complain_on_overflow */
624 0, /* special_function */
625 "GPRELHIGH", /* name */
626 false, /* partial_inplace */
627 0xffff, /* src_mask */
628 0xffff, /* dst_mask */
629 false), /* pcrel_offset */
630
631 /* The low 16 bits of the displacement from GP to the target. */
632 HOWTO (R_ALPHA_GPRELLOW,
633 0, /* rightshift */
634 1, /* size (0 = byte, 1 = short, 2 = long) */
635 16, /* bitsize */
636 false, /* pc_relative */
637 0, /* bitpos */
638 complain_overflow_dont, /* complain_on_overflow */
639 0, /* special_function */
640 "GPRELLOW", /* name */
641 false, /* partial_inplace */
642 0xffff, /* src_mask */
643 0xffff, /* dst_mask */
644 false), /* pcrel_offset */
645
646 /* A 16-bit displacement from the GP to the target. */
647 HOWTO (R_ALPHA_GPREL16,
648 0, /* rightshift */
649 1, /* size (0 = byte, 1 = short, 2 = long) */
650 16, /* bitsize */
651 false, /* pc_relative */
652 0, /* bitpos */
653 complain_overflow_signed, /* complain_on_overflow */
654 0, /* special_function */
655 "GPREL16", /* name */
656 false, /* partial_inplace */
657 0xffff, /* src_mask */
658 0xffff, /* dst_mask */
659 false), /* pcrel_offset */
660
661 /* Skip 20 - 23; deprecated ECOFF relocs. */
662 SKIP_HOWTO (20),
663 SKIP_HOWTO (21),
664 SKIP_HOWTO (22),
665 SKIP_HOWTO (23),
666
667 /* Misc ELF relocations. */
668
669 /* A dynamic relocation to copy the target into our .dynbss section. */
670 /* Not generated, as all Alpha objects use PIC, so it is not needed. It
671 is present because every other ELF has one, but should not be used
672 because .dynbss is an ugly thing. */
673 HOWTO (R_ALPHA_COPY,
674 0,
675 0,
676 0,
677 false,
678 0,
679 complain_overflow_dont,
680 bfd_elf_generic_reloc,
681 "COPY",
682 false,
683 0,
684 0,
685 true),
686
687 /* A dynamic relocation for a .got entry. */
688 HOWTO (R_ALPHA_GLOB_DAT,
689 0,
690 0,
691 0,
692 false,
693 0,
694 complain_overflow_dont,
695 bfd_elf_generic_reloc,
696 "GLOB_DAT",
697 false,
698 0,
699 0,
700 true),
701
702 /* A dynamic relocation for a .plt entry. */
703 HOWTO (R_ALPHA_JMP_SLOT,
704 0,
705 0,
706 0,
707 false,
708 0,
709 complain_overflow_dont,
710 bfd_elf_generic_reloc,
711 "JMP_SLOT",
712 false,
713 0,
714 0,
715 true),
716
717 /* A dynamic relocation to add the base of the DSO to a 64-bit field. */
718 HOWTO (R_ALPHA_RELATIVE,
719 0,
720 0,
721 0,
722 false,
723 0,
724 complain_overflow_dont,
725 bfd_elf_generic_reloc,
726 "RELATIVE",
727 false,
728 0,
729 0,
730 true)
731 };
732
733 /* A relocation function which doesn't do anything. */
734
735 static bfd_reloc_status_type
736 elf64_alpha_reloc_nil (abfd, reloc, sym, data, sec, output_bfd, error_message)
737 bfd *abfd ATTRIBUTE_UNUSED;
738 arelent *reloc;
739 asymbol *sym ATTRIBUTE_UNUSED;
740 PTR data ATTRIBUTE_UNUSED;
741 asection *sec;
742 bfd *output_bfd;
743 char **error_message ATTRIBUTE_UNUSED;
744 {
745 if (output_bfd)
746 reloc->address += sec->output_offset;
747 return bfd_reloc_ok;
748 }
749
750 /* A relocation function used for an unsupported reloc. */
751
752 static bfd_reloc_status_type
753 elf64_alpha_reloc_bad (abfd, reloc, sym, data, sec, output_bfd, error_message)
754 bfd *abfd ATTRIBUTE_UNUSED;
755 arelent *reloc;
756 asymbol *sym ATTRIBUTE_UNUSED;
757 PTR data ATTRIBUTE_UNUSED;
758 asection *sec;
759 bfd *output_bfd;
760 char **error_message ATTRIBUTE_UNUSED;
761 {
762 if (output_bfd)
763 reloc->address += sec->output_offset;
764 return bfd_reloc_notsupported;
765 }
766
767 /* Do the work of the GPDISP relocation. */
768
769 static bfd_reloc_status_type
770 elf64_alpha_do_reloc_gpdisp (abfd, gpdisp, p_ldah, p_lda)
771 bfd *abfd;
772 bfd_vma gpdisp;
773 bfd_byte *p_ldah;
774 bfd_byte *p_lda;
775 {
776 bfd_reloc_status_type ret = bfd_reloc_ok;
777 bfd_vma addend;
778 unsigned long i_ldah, i_lda;
779
780 i_ldah = bfd_get_32 (abfd, p_ldah);
781 i_lda = bfd_get_32 (abfd, p_lda);
782
783 /* Complain if the instructions are not correct. */
784 if (((i_ldah >> 26) & 0x3f) != 0x09
785 || ((i_lda >> 26) & 0x3f) != 0x08)
786 ret = bfd_reloc_dangerous;
787
788 /* Extract the user-supplied offset, mirroring the sign extensions
789 that the instructions perform. */
790 addend = ((i_ldah & 0xffff) << 16) | (i_lda & 0xffff);
791 addend = (addend ^ 0x80008000) - 0x80008000;
792
793 gpdisp += addend;
794
795 if ((bfd_signed_vma) gpdisp < -(bfd_signed_vma) 0x80000000
796 || (bfd_signed_vma) gpdisp >= (bfd_signed_vma) 0x7fff8000)
797 ret = bfd_reloc_overflow;
798
799 /* compensate for the sign extension again. */
800 i_ldah = ((i_ldah & 0xffff0000)
801 | (((gpdisp >> 16) + ((gpdisp >> 15) & 1)) & 0xffff));
802 i_lda = (i_lda & 0xffff0000) | (gpdisp & 0xffff);
803
804 bfd_put_32 (abfd, i_ldah, p_ldah);
805 bfd_put_32 (abfd, i_lda, p_lda);
806
807 return ret;
808 }
809
810 /* The special function for the GPDISP reloc. */
811
812 static bfd_reloc_status_type
813 elf64_alpha_reloc_gpdisp (abfd, reloc_entry, sym, data, input_section,
814 output_bfd, err_msg)
815 bfd *abfd;
816 arelent *reloc_entry;
817 asymbol *sym ATTRIBUTE_UNUSED;
818 PTR data;
819 asection *input_section;
820 bfd *output_bfd;
821 char **err_msg;
822 {
823 bfd_reloc_status_type ret;
824 bfd_vma gp, relocation;
825 bfd_byte *p_ldah, *p_lda;
826
827 /* Don't do anything if we're not doing a final link. */
828 if (output_bfd)
829 {
830 reloc_entry->address += input_section->output_offset;
831 return bfd_reloc_ok;
832 }
833
834 if (reloc_entry->address > input_section->_cooked_size ||
835 reloc_entry->address + reloc_entry->addend > input_section->_cooked_size)
836 return bfd_reloc_outofrange;
837
838 /* The gp used in the portion of the output object to which this
839 input object belongs is cached on the input bfd. */
840 gp = _bfd_get_gp_value (abfd);
841
842 relocation = (input_section->output_section->vma
843 + input_section->output_offset
844 + reloc_entry->address);
845
846 p_ldah = (bfd_byte *) data + reloc_entry->address;
847 p_lda = p_ldah + reloc_entry->addend;
848
849 ret = elf64_alpha_do_reloc_gpdisp (abfd, gp - relocation, p_ldah, p_lda);
850
851 /* Complain if the instructions are not correct. */
852 if (ret == bfd_reloc_dangerous)
853 *err_msg = _("GPDISP relocation did not find ldah and lda instructions");
854
855 return ret;
856 }
857
858 /* A mapping from BFD reloc types to Alpha ELF reloc types. */
859
860 struct elf_reloc_map
861 {
862 bfd_reloc_code_real_type bfd_reloc_val;
863 int elf_reloc_val;
864 };
865
866 static const struct elf_reloc_map elf64_alpha_reloc_map[] =
867 {
868 {BFD_RELOC_NONE, R_ALPHA_NONE},
869 {BFD_RELOC_32, R_ALPHA_REFLONG},
870 {BFD_RELOC_64, R_ALPHA_REFQUAD},
871 {BFD_RELOC_CTOR, R_ALPHA_REFQUAD},
872 {BFD_RELOC_GPREL32, R_ALPHA_GPREL32},
873 {BFD_RELOC_ALPHA_ELF_LITERAL, R_ALPHA_LITERAL},
874 {BFD_RELOC_ALPHA_LITUSE, R_ALPHA_LITUSE},
875 {BFD_RELOC_ALPHA_GPDISP, R_ALPHA_GPDISP},
876 {BFD_RELOC_23_PCREL_S2, R_ALPHA_BRADDR},
877 {BFD_RELOC_ALPHA_HINT, R_ALPHA_HINT},
878 {BFD_RELOC_16_PCREL, R_ALPHA_SREL16},
879 {BFD_RELOC_32_PCREL, R_ALPHA_SREL32},
880 {BFD_RELOC_64_PCREL, R_ALPHA_SREL64},
881 {BFD_RELOC_ALPHA_GPREL_HI16, R_ALPHA_GPRELHIGH},
882 {BFD_RELOC_ALPHA_GPREL_LO16, R_ALPHA_GPRELLOW},
883 {BFD_RELOC_GPREL16, R_ALPHA_GPREL16},
884 };
885
886 /* Given a BFD reloc type, return a HOWTO structure. */
887
888 static reloc_howto_type *
889 elf64_alpha_bfd_reloc_type_lookup (abfd, code)
890 bfd *abfd ATTRIBUTE_UNUSED;
891 bfd_reloc_code_real_type code;
892 {
893 const struct elf_reloc_map *i, *e;
894 i = e = elf64_alpha_reloc_map;
895 e += sizeof (elf64_alpha_reloc_map) / sizeof (struct elf_reloc_map);
896 for (; i != e; ++i)
897 {
898 if (i->bfd_reloc_val == code)
899 return &elf64_alpha_howto_table[i->elf_reloc_val];
900 }
901 return 0;
902 }
903
904 /* Given an Alpha ELF reloc type, fill in an arelent structure. */
905
906 static void
907 elf64_alpha_info_to_howto (abfd, cache_ptr, dst)
908 bfd *abfd ATTRIBUTE_UNUSED;
909 arelent *cache_ptr;
910 Elf64_Internal_Rela *dst;
911 {
912 unsigned r_type;
913
914 r_type = ELF64_R_TYPE(dst->r_info);
915 BFD_ASSERT (r_type < (unsigned int) R_ALPHA_max);
916 cache_ptr->howto = &elf64_alpha_howto_table[r_type];
917 }
918 \f
919 /* These functions do relaxation for Alpha ELF.
920
921 Currently I'm only handling what I can do with existing compiler
922 and assembler support, which means no instructions are removed,
923 though some may be nopped. At this time GCC does not emit enough
924 information to do all of the relaxing that is possible. It will
925 take some not small amount of work for that to happen.
926
927 There are a couple of interesting papers that I once read on this
928 subject, that I cannot find references to at the moment, that
929 related to Alpha in particular. They are by David Wall, then of
930 DEC WRL. */
931
932 #define OP_LDA 0x08
933 #define OP_LDAH 0x09
934 #define INSN_JSR 0x68004000
935 #define INSN_JSR_MASK 0xfc00c000
936 #define OP_LDQ 0x29
937 #define OP_BR 0x30
938 #define OP_BSR 0x34
939 #define INSN_UNOP 0x2fe00000
940
941 struct alpha_relax_info
942 {
943 bfd *abfd;
944 asection *sec;
945 bfd_byte *contents;
946 Elf_Internal_Rela *relocs, *relend;
947 struct bfd_link_info *link_info;
948 boolean changed_contents;
949 boolean changed_relocs;
950 bfd_vma gp;
951 bfd *gotobj;
952 asection *tsec;
953 struct alpha_elf_link_hash_entry *h;
954 struct alpha_elf_got_entry *gotent;
955 unsigned char other;
956 };
957
958 static Elf_Internal_Rela * elf64_alpha_relax_with_lituse
959 PARAMS((struct alpha_relax_info *info, bfd_vma symval,
960 Elf_Internal_Rela *irel, Elf_Internal_Rela *irelend));
961
962 static boolean elf64_alpha_relax_without_lituse
963 PARAMS((struct alpha_relax_info *info, bfd_vma symval,
964 Elf_Internal_Rela *irel));
965
966 static bfd_vma elf64_alpha_relax_opt_call
967 PARAMS((struct alpha_relax_info *info, bfd_vma symval));
968
969 static boolean elf64_alpha_relax_section
970 PARAMS((bfd *abfd, asection *sec, struct bfd_link_info *link_info,
971 boolean *again));
972
973 static Elf_Internal_Rela *
974 elf64_alpha_find_reloc_at_ofs (rel, relend, offset, type)
975 Elf_Internal_Rela *rel, *relend;
976 bfd_vma offset;
977 int type;
978 {
979 while (rel < relend)
980 {
981 if (rel->r_offset == offset
982 && ELF64_R_TYPE (rel->r_info) == (unsigned int) type)
983 return rel;
984 ++rel;
985 }
986 return NULL;
987 }
988
989 static Elf_Internal_Rela *
990 elf64_alpha_relax_with_lituse (info, symval, irel, irelend)
991 struct alpha_relax_info *info;
992 bfd_vma symval;
993 Elf_Internal_Rela *irel, *irelend;
994 {
995 Elf_Internal_Rela *urel;
996 int flags, count, i;
997 bfd_signed_vma disp;
998 boolean fits16;
999 boolean fits32;
1000 boolean lit_reused = false;
1001 boolean all_optimized = true;
1002 unsigned int lit_insn;
1003
1004 lit_insn = bfd_get_32 (info->abfd, info->contents + irel->r_offset);
1005 if (lit_insn >> 26 != OP_LDQ)
1006 {
1007 ((*_bfd_error_handler)
1008 ("%s: %s+0x%lx: warning: LITERAL relocation against unexpected insn",
1009 bfd_get_filename (info->abfd), info->sec->name,
1010 (unsigned long)irel->r_offset));
1011 return irel;
1012 }
1013
1014 /* Summarize how this particular LITERAL is used. */
1015 for (urel = irel+1, flags = count = 0; urel < irelend; ++urel, ++count)
1016 {
1017 if (ELF64_R_TYPE (urel->r_info) != R_ALPHA_LITUSE)
1018 break;
1019 if (urel->r_addend >= 0 && urel->r_addend <= 3)
1020 flags |= 1 << urel->r_addend;
1021 }
1022
1023 /* A little preparation for the loop... */
1024 disp = symval - info->gp;
1025
1026 for (urel = irel+1, i = 0; i < count; ++i, ++urel)
1027 {
1028 unsigned int insn;
1029 int insn_disp;
1030 bfd_signed_vma xdisp;
1031
1032 insn = bfd_get_32 (info->abfd, info->contents + urel->r_offset);
1033
1034 switch (urel->r_addend)
1035 {
1036 default: /* 0 = ADDRESS FORMAT */
1037 /* This type is really just a placeholder to note that all
1038 uses cannot be optimized, but to still allow some. */
1039 all_optimized = false;
1040 break;
1041
1042 case 1: /* MEM FORMAT */
1043 /* We can always optimize 16-bit displacements. */
1044
1045 /* Extract the displacement from the instruction, sign-extending
1046 it if necessary, then test whether it is within 16 or 32 bits
1047 displacement from GP. */
1048 insn_disp = insn & 0x0000ffff;
1049 if (insn_disp & 0x00008000)
1050 insn_disp |= 0xffff0000; /* Negative: sign-extend. */
1051
1052 xdisp = disp + insn_disp;
1053 fits16 = (xdisp >= - (bfd_signed_vma) 0x00008000 && xdisp < 0x00008000);
1054 fits32 = (xdisp >= - (bfd_signed_vma) 0x80000000 && xdisp < 0x7fff8000);
1055
1056 if (fits16)
1057 {
1058 /* Take the op code and dest from this insn, take the base
1059 register from the literal insn. Leave the offset alone. */
1060 insn = (insn & 0xffe0ffff) | (lit_insn & 0x001f0000);
1061 urel->r_info = ELF64_R_INFO (ELF64_R_SYM (irel->r_info),
1062 R_ALPHA_GPREL16);
1063 urel->r_addend = irel->r_addend;
1064 info->changed_relocs = true;
1065
1066 bfd_put_32 (info->abfd, insn, info->contents + urel->r_offset);
1067 info->changed_contents = true;
1068 }
1069
1070 /* If all mem+byte, we can optimize 32-bit mem displacements. */
1071 else if (fits32 && !(flags & ~6))
1072 {
1073 /* FIXME: sanity check that lit insn Ra is mem insn Rb. */
1074
1075 irel->r_info = ELF64_R_INFO (ELF64_R_SYM (irel->r_info),
1076 R_ALPHA_GPRELHIGH);
1077 lit_insn = (OP_LDAH << 26) | (lit_insn & 0x03ff0000);
1078 bfd_put_32 (info->abfd, lit_insn,
1079 info->contents + irel->r_offset);
1080 lit_reused = true;
1081 info->changed_contents = true;
1082
1083 urel->r_info = ELF64_R_INFO (ELF64_R_SYM (irel->r_info),
1084 R_ALPHA_GPRELLOW);
1085 urel->r_addend = irel->r_addend;
1086 info->changed_relocs = true;
1087 }
1088 else
1089 all_optimized = false;
1090 break;
1091
1092 case 2: /* BYTE OFFSET FORMAT */
1093 /* We can always optimize byte instructions. */
1094
1095 /* FIXME: sanity check the insn for byte op. Check that the
1096 literal dest reg is indeed Rb in the byte insn. */
1097
1098 insn = (insn & ~0x001ff000) | ((symval & 7) << 13) | 0x1000;
1099
1100 urel->r_info = ELF64_R_INFO (0, R_ALPHA_NONE);
1101 urel->r_addend = 0;
1102 info->changed_relocs = true;
1103
1104 bfd_put_32 (info->abfd, insn, info->contents + urel->r_offset);
1105 info->changed_contents = true;
1106 break;
1107
1108 case 3: /* CALL FORMAT */
1109 {
1110 /* If not zero, place to jump without needing pv. */
1111 bfd_vma optdest = elf64_alpha_relax_opt_call (info, symval);
1112 bfd_vma org = (info->sec->output_section->vma
1113 + info->sec->output_offset
1114 + urel->r_offset + 4);
1115 bfd_signed_vma odisp;
1116
1117 odisp = (optdest ? optdest : symval) - org;
1118 if (odisp >= -0x400000 && odisp < 0x400000)
1119 {
1120 Elf_Internal_Rela *xrel;
1121
1122 /* Preserve branch prediction call stack when possible. */
1123 if ((insn & INSN_JSR_MASK) == INSN_JSR)
1124 insn = (OP_BSR << 26) | (insn & 0x03e00000);
1125 else
1126 insn = (OP_BR << 26) | (insn & 0x03e00000);
1127
1128 urel->r_info = ELF64_R_INFO (ELF64_R_SYM (irel->r_info),
1129 R_ALPHA_BRADDR);
1130 urel->r_addend = irel->r_addend;
1131
1132 if (optdest)
1133 urel->r_addend += optdest - symval;
1134 else
1135 all_optimized = false;
1136
1137 bfd_put_32 (info->abfd, insn, info->contents + urel->r_offset);
1138
1139 /* Kill any HINT reloc that might exist for this insn. */
1140 xrel = (elf64_alpha_find_reloc_at_ofs
1141 (info->relocs, info->relend, urel->r_offset,
1142 R_ALPHA_HINT));
1143 if (xrel)
1144 xrel->r_info = ELF64_R_INFO (0, R_ALPHA_NONE);
1145
1146 info->changed_contents = true;
1147 info->changed_relocs = true;
1148 }
1149 else
1150 all_optimized = false;
1151
1152 /* ??? If target gp == current gp we can eliminate the gp reload.
1153 This does depend on every place a gp could be reloaded will
1154 be, which currently happens for all code produced by gcc, but
1155 not necessarily by hand-coded assembly, or if sibling calls
1156 are enabled in gcc.
1157
1158 Perhaps conditionalize this on a flag being set in the target
1159 object file's header, and have gcc set it? */
1160 }
1161 break;
1162 }
1163 }
1164
1165 /* If all cases were optimized, we can reduce the use count on this
1166 got entry by one, possibly eliminating it. */
1167 if (all_optimized)
1168 {
1169 info->gotent->use_count -= 1;
1170 alpha_elf_tdata (info->gotent->gotobj)->total_got_entries -= 1;
1171 if (!info->h)
1172 alpha_elf_tdata (info->gotent->gotobj)->n_local_got_entries -= 1;
1173
1174 /* If the literal instruction is no longer needed (it may have been
1175 reused. We can eliminate it.
1176 ??? For now, I don't want to deal with compacting the section,
1177 so just nop it out. */
1178 if (!lit_reused)
1179 {
1180 irel->r_info = ELF64_R_INFO (0, R_ALPHA_NONE);
1181 info->changed_relocs = true;
1182
1183 bfd_put_32 (info->abfd, INSN_UNOP, info->contents + irel->r_offset);
1184 info->changed_contents = true;
1185 }
1186 }
1187
1188 return irel + count;
1189 }
1190
1191 static bfd_vma
1192 elf64_alpha_relax_opt_call (info, symval)
1193 struct alpha_relax_info *info;
1194 bfd_vma symval;
1195 {
1196 /* If the function has the same gp, and we can identify that the
1197 function does not use its function pointer, we can eliminate the
1198 address load. */
1199
1200 /* If the symbol is marked NOPV, we are being told the function never
1201 needs its procedure value. */
1202 if ((info->other & STO_ALPHA_STD_GPLOAD) == STO_ALPHA_NOPV)
1203 return symval;
1204
1205 /* If the symbol is marked STD_GP, we are being told the function does
1206 a normal ldgp in the first two words. */
1207 else if ((info->other & STO_ALPHA_STD_GPLOAD) == STO_ALPHA_STD_GPLOAD)
1208 ;
1209
1210 /* Otherwise, we may be able to identify a GP load in the first two
1211 words, which we can then skip. */
1212 else
1213 {
1214 Elf_Internal_Rela *tsec_relocs, *tsec_relend, *tsec_free, *gpdisp;
1215 bfd_vma ofs;
1216
1217 /* Load the relocations from the section that the target symbol is in. */
1218 if (info->sec == info->tsec)
1219 {
1220 tsec_relocs = info->relocs;
1221 tsec_relend = info->relend;
1222 tsec_free = NULL;
1223 }
1224 else
1225 {
1226 tsec_relocs = (_bfd_elf64_link_read_relocs
1227 (info->abfd, info->tsec, (PTR) NULL,
1228 (Elf_Internal_Rela *) NULL,
1229 info->link_info->keep_memory));
1230 if (tsec_relocs == NULL)
1231 return 0;
1232 tsec_relend = tsec_relocs + info->tsec->reloc_count;
1233 tsec_free = (info->link_info->keep_memory ? NULL : tsec_relocs);
1234 }
1235
1236 /* Recover the symbol's offset within the section. */
1237 ofs = (symval - info->tsec->output_section->vma
1238 - info->tsec->output_offset);
1239
1240 /* Look for a GPDISP reloc. */
1241 gpdisp = (elf64_alpha_find_reloc_at_ofs
1242 (tsec_relocs, tsec_relend, ofs, R_ALPHA_GPDISP));
1243
1244 if (!gpdisp || gpdisp->r_addend != 4)
1245 {
1246 if (tsec_free)
1247 free (tsec_free);
1248 return 0;
1249 }
1250 if (tsec_free)
1251 free (tsec_free);
1252 }
1253
1254 /* We've now determined that we can skip an initial gp load. Verify
1255 that the call and the target use the same gp. */
1256 if (info->link_info->hash->creator != info->tsec->owner->xvec
1257 || info->gotobj != alpha_elf_tdata (info->tsec->owner)->gotobj)
1258 return 0;
1259
1260 return symval + 8;
1261 }
1262
1263 static boolean
1264 elf64_alpha_relax_without_lituse (info, symval, irel)
1265 struct alpha_relax_info *info;
1266 bfd_vma symval;
1267 Elf_Internal_Rela *irel;
1268 {
1269 unsigned int insn;
1270 bfd_signed_vma disp;
1271
1272 /* Get the instruction. */
1273 insn = bfd_get_32 (info->abfd, info->contents + irel->r_offset);
1274
1275 if (insn >> 26 != OP_LDQ)
1276 {
1277 ((*_bfd_error_handler)
1278 ("%s: %s+0x%lx: warning: LITERAL relocation against unexpected insn",
1279 bfd_get_filename (info->abfd), info->sec->name,
1280 (unsigned long) irel->r_offset));
1281 return true;
1282 }
1283
1284 /* So we aren't told much. Do what we can with the address load and
1285 fake the rest. All of the optimizations here require that the
1286 offset from the GP fit in 16 bits. */
1287
1288 disp = symval - info->gp;
1289 if (disp < -0x8000 || disp >= 0x8000)
1290 return true;
1291
1292 /* On the LITERAL instruction itself, consider exchanging
1293 `ldq R,X(gp)' for `lda R,Y(gp)'. */
1294
1295 insn = (OP_LDA << 26) | (insn & 0x03ff0000);
1296 bfd_put_32 (info->abfd, insn, info->contents + irel->r_offset);
1297 info->changed_contents = true;
1298
1299 irel->r_info = ELF64_R_INFO (ELF64_R_SYM (irel->r_info), R_ALPHA_GPREL16);
1300 info->changed_relocs = true;
1301
1302 /* Reduce the use count on this got entry by one, possibly
1303 eliminating it. */
1304 info->gotent->use_count -= 1;
1305 alpha_elf_tdata (info->gotent->gotobj)->total_got_entries -= 1;
1306 if (!info->h)
1307 alpha_elf_tdata (info->gotent->gotobj)->n_local_got_entries -= 1;
1308
1309 /* ??? Search forward through this basic block looking for insns
1310 that use the target register. Stop after an insn modifying the
1311 register is seen, or after a branch or call.
1312
1313 Any such memory load insn may be substituted by a load directly
1314 off the GP. This allows the memory load insn to be issued before
1315 the calculated GP register would otherwise be ready.
1316
1317 Any such jsr insn can be replaced by a bsr if it is in range.
1318
1319 This would mean that we'd have to _add_ relocations, the pain of
1320 which gives one pause. */
1321
1322 return true;
1323 }
1324
1325 static boolean
1326 elf64_alpha_relax_section (abfd, sec, link_info, again)
1327 bfd *abfd;
1328 asection *sec;
1329 struct bfd_link_info *link_info;
1330 boolean *again;
1331 {
1332 Elf_Internal_Shdr *symtab_hdr;
1333 Elf_Internal_Rela *internal_relocs;
1334 Elf_Internal_Rela *free_relocs = NULL;
1335 Elf_Internal_Rela *irel, *irelend;
1336 bfd_byte *free_contents = NULL;
1337 Elf64_External_Sym *extsyms = NULL;
1338 Elf64_External_Sym *free_extsyms = NULL;
1339 struct alpha_elf_got_entry **local_got_entries;
1340 struct alpha_relax_info info;
1341
1342 /* We are not currently changing any sizes, so only one pass. */
1343 *again = false;
1344
1345 if (link_info->relocateable
1346 || (sec->flags & SEC_RELOC) == 0
1347 || sec->reloc_count == 0)
1348 return true;
1349
1350 /* If this is the first time we have been called for this section,
1351 initialize the cooked size. */
1352 if (sec->_cooked_size == 0)
1353 sec->_cooked_size = sec->_raw_size;
1354
1355 symtab_hdr = &elf_tdata (abfd)->symtab_hdr;
1356 local_got_entries = alpha_elf_tdata(abfd)->local_got_entries;
1357
1358 /* Load the relocations for this section. */
1359 internal_relocs = (_bfd_elf64_link_read_relocs
1360 (abfd, sec, (PTR) NULL, (Elf_Internal_Rela *) NULL,
1361 link_info->keep_memory));
1362 if (internal_relocs == NULL)
1363 goto error_return;
1364 if (! link_info->keep_memory)
1365 free_relocs = internal_relocs;
1366
1367 memset(&info, 0, sizeof (info));
1368 info.abfd = abfd;
1369 info.sec = sec;
1370 info.link_info = link_info;
1371 info.relocs = internal_relocs;
1372 info.relend = irelend = internal_relocs + sec->reloc_count;
1373
1374 /* Find the GP for this object. */
1375 info.gotobj = alpha_elf_tdata (abfd)->gotobj;
1376 if (info.gotobj)
1377 {
1378 asection *sgot = alpha_elf_tdata (info.gotobj)->got;
1379 info.gp = _bfd_get_gp_value (info.gotobj);
1380 if (info.gp == 0)
1381 {
1382 info.gp = (sgot->output_section->vma
1383 + sgot->output_offset
1384 + 0x8000);
1385 _bfd_set_gp_value (info.gotobj, info.gp);
1386 }
1387 }
1388
1389 for (irel = internal_relocs; irel < irelend; irel++)
1390 {
1391 bfd_vma symval;
1392 Elf_Internal_Sym isym;
1393 struct alpha_elf_got_entry *gotent;
1394
1395 if (ELF64_R_TYPE (irel->r_info) != (int) R_ALPHA_LITERAL)
1396 continue;
1397
1398 /* Get the section contents. */
1399 if (info.contents == NULL)
1400 {
1401 if (elf_section_data (sec)->this_hdr.contents != NULL)
1402 info.contents = elf_section_data (sec)->this_hdr.contents;
1403 else
1404 {
1405 info.contents = (bfd_byte *) bfd_malloc (sec->_raw_size);
1406 if (info.contents == NULL)
1407 goto error_return;
1408 free_contents = info.contents;
1409
1410 if (! bfd_get_section_contents (abfd, sec, info.contents,
1411 (file_ptr) 0, sec->_raw_size))
1412 goto error_return;
1413 }
1414 }
1415
1416 /* Read this BFD's symbols if we haven't done so already. */
1417 if (extsyms == NULL)
1418 {
1419 if (symtab_hdr->contents != NULL)
1420 extsyms = (Elf64_External_Sym *) symtab_hdr->contents;
1421 else
1422 {
1423 extsyms = ((Elf64_External_Sym *)
1424 bfd_malloc (symtab_hdr->sh_size));
1425 if (extsyms == NULL)
1426 goto error_return;
1427 free_extsyms = extsyms;
1428 if (bfd_seek (abfd, symtab_hdr->sh_offset, SEEK_SET) != 0
1429 || (bfd_read (extsyms, 1, symtab_hdr->sh_size, abfd)
1430 != symtab_hdr->sh_size))
1431 goto error_return;
1432 }
1433 }
1434
1435 /* Get the value of the symbol referred to by the reloc. */
1436 if (ELF64_R_SYM (irel->r_info) < symtab_hdr->sh_info)
1437 {
1438 /* A local symbol. */
1439 bfd_elf64_swap_symbol_in (abfd,
1440 extsyms + ELF64_R_SYM (irel->r_info),
1441 &isym);
1442 if (isym.st_shndx == SHN_UNDEF)
1443 info.tsec = bfd_und_section_ptr;
1444 else if (isym.st_shndx > 0 && isym.st_shndx < SHN_LORESERVE)
1445 info.tsec = bfd_section_from_elf_index (abfd, isym.st_shndx);
1446 else if (isym.st_shndx == SHN_ABS)
1447 info.tsec = bfd_abs_section_ptr;
1448 else if (isym.st_shndx == SHN_COMMON)
1449 info.tsec = bfd_com_section_ptr;
1450 else
1451 continue; /* who knows. */
1452
1453 info.h = NULL;
1454 info.other = isym.st_other;
1455 gotent = local_got_entries[ELF64_R_SYM(irel->r_info)];
1456 symval = isym.st_value;
1457 }
1458 else
1459 {
1460 unsigned long indx;
1461 struct alpha_elf_link_hash_entry *h;
1462
1463 indx = ELF64_R_SYM (irel->r_info) - symtab_hdr->sh_info;
1464 h = alpha_elf_sym_hashes (abfd)[indx];
1465 BFD_ASSERT (h != NULL);
1466
1467 while (h->root.root.type == bfd_link_hash_indirect
1468 || h->root.root.type == bfd_link_hash_warning)
1469 h = (struct alpha_elf_link_hash_entry *)h->root.root.u.i.link;
1470
1471 /* We can't do anthing with undefined or dynamic symbols. */
1472 if (h->root.root.type == bfd_link_hash_undefined
1473 || h->root.root.type == bfd_link_hash_undefweak
1474 || alpha_elf_dynamic_symbol_p (&h->root, link_info))
1475 continue;
1476
1477 info.h = h;
1478 info.tsec = h->root.root.u.def.section;
1479 info.other = h->root.other;
1480 gotent = h->got_entries;
1481 symval = h->root.root.u.def.value;
1482 }
1483
1484 /* Search for the got entry to be used by this relocation. */
1485 while (gotent->gotobj != info.gotobj || gotent->addend != irel->r_addend)
1486 gotent = gotent->next;
1487 info.gotent = gotent;
1488
1489 symval += info.tsec->output_section->vma + info.tsec->output_offset;
1490 symval += irel->r_addend;
1491
1492 BFD_ASSERT(info.gotent != NULL);
1493
1494 /* If there exist LITUSE relocations immediately following, this
1495 opens up all sorts of interesting optimizations, because we
1496 now know every location that this address load is used. */
1497
1498 if (irel+1 < irelend && ELF64_R_TYPE (irel[1].r_info) == R_ALPHA_LITUSE)
1499 {
1500 irel = elf64_alpha_relax_with_lituse (&info, symval, irel, irelend);
1501 if (irel == NULL)
1502 goto error_return;
1503 }
1504 else
1505 {
1506 if (!elf64_alpha_relax_without_lituse (&info, symval, irel))
1507 goto error_return;
1508 }
1509 }
1510
1511 if (!elf64_alpha_size_got_sections (abfd, link_info))
1512 return false;
1513
1514 if (info.changed_relocs)
1515 {
1516 elf_section_data (sec)->relocs = internal_relocs;
1517 }
1518 else if (free_relocs != NULL)
1519 {
1520 free (free_relocs);
1521 }
1522
1523 if (info.changed_contents)
1524 {
1525 elf_section_data (sec)->this_hdr.contents = info.contents;
1526 }
1527 else if (free_contents != NULL)
1528 {
1529 if (! link_info->keep_memory)
1530 free (free_contents);
1531 else
1532 {
1533 /* Cache the section contents for elf_link_input_bfd. */
1534 elf_section_data (sec)->this_hdr.contents = info.contents;
1535 }
1536 }
1537
1538 if (free_extsyms != NULL)
1539 {
1540 if (! link_info->keep_memory)
1541 free (free_extsyms);
1542 else
1543 {
1544 /* Cache the symbols for elf_link_input_bfd. */
1545 symtab_hdr->contents = extsyms;
1546 }
1547 }
1548
1549 *again = info.changed_contents || info.changed_relocs;
1550
1551 return true;
1552
1553 error_return:
1554 if (free_relocs != NULL)
1555 free (free_relocs);
1556 if (free_contents != NULL)
1557 free (free_contents);
1558 if (free_extsyms != NULL)
1559 free (free_extsyms);
1560 return false;
1561 }
1562 \f
1563 /* PLT/GOT Stuff */
1564 #define PLT_HEADER_SIZE 32
1565 #define PLT_HEADER_WORD1 0xc3600000 /* br $27,.+4 */
1566 #define PLT_HEADER_WORD2 0xa77b000c /* ldq $27,12($27) */
1567 #define PLT_HEADER_WORD3 0x47ff041f /* nop */
1568 #define PLT_HEADER_WORD4 0x6b7b0000 /* jmp $27,($27) */
1569
1570 #define PLT_ENTRY_SIZE 12
1571 #define PLT_ENTRY_WORD1 0xc3800000 /* br $28, plt0 */
1572 #define PLT_ENTRY_WORD2 0
1573 #define PLT_ENTRY_WORD3 0
1574
1575 #define MAX_GOT_ENTRIES (64*1024 / 8)
1576
1577 #define ELF_DYNAMIC_INTERPRETER "/usr/lib/ld.so"
1578 \f
1579 /* Handle an Alpha specific section when reading an object file. This
1580 is called when elfcode.h finds a section with an unknown type.
1581 FIXME: We need to handle the SHF_ALPHA_GPREL flag, but I'm not sure
1582 how to. */
1583
1584 static boolean
1585 elf64_alpha_section_from_shdr (abfd, hdr, name)
1586 bfd *abfd;
1587 Elf64_Internal_Shdr *hdr;
1588 char *name;
1589 {
1590 asection *newsect;
1591
1592 /* There ought to be a place to keep ELF backend specific flags, but
1593 at the moment there isn't one. We just keep track of the
1594 sections by their name, instead. Fortunately, the ABI gives
1595 suggested names for all the MIPS specific sections, so we will
1596 probably get away with this. */
1597 switch (hdr->sh_type)
1598 {
1599 case SHT_ALPHA_DEBUG:
1600 if (strcmp (name, ".mdebug") != 0)
1601 return false;
1602 break;
1603 #ifdef ERIC_neverdef
1604 case SHT_ALPHA_REGINFO:
1605 if (strcmp (name, ".reginfo") != 0
1606 || hdr->sh_size != sizeof (Elf64_External_RegInfo))
1607 return false;
1608 break;
1609 #endif
1610 default:
1611 return false;
1612 }
1613
1614 if (! _bfd_elf_make_section_from_shdr (abfd, hdr, name))
1615 return false;
1616 newsect = hdr->bfd_section;
1617
1618 if (hdr->sh_type == SHT_ALPHA_DEBUG)
1619 {
1620 if (! bfd_set_section_flags (abfd, newsect,
1621 (bfd_get_section_flags (abfd, newsect)
1622 | SEC_DEBUGGING)))
1623 return false;
1624 }
1625
1626 #ifdef ERIC_neverdef
1627 /* For a .reginfo section, set the gp value in the tdata information
1628 from the contents of this section. We need the gp value while
1629 processing relocs, so we just get it now. */
1630 if (hdr->sh_type == SHT_ALPHA_REGINFO)
1631 {
1632 Elf64_External_RegInfo ext;
1633 Elf64_RegInfo s;
1634
1635 if (! bfd_get_section_contents (abfd, newsect, (PTR) &ext,
1636 (file_ptr) 0, sizeof ext))
1637 return false;
1638 bfd_alpha_elf64_swap_reginfo_in (abfd, &ext, &s);
1639 elf_gp (abfd) = s.ri_gp_value;
1640 }
1641 #endif
1642
1643 return true;
1644 }
1645
1646 /* Set the correct type for an Alpha ELF section. We do this by the
1647 section name, which is a hack, but ought to work. */
1648
1649 static boolean
1650 elf64_alpha_fake_sections (abfd, hdr, sec)
1651 bfd *abfd;
1652 Elf64_Internal_Shdr *hdr;
1653 asection *sec;
1654 {
1655 register const char *name;
1656
1657 name = bfd_get_section_name (abfd, sec);
1658
1659 if (strcmp (name, ".mdebug") == 0)
1660 {
1661 hdr->sh_type = SHT_ALPHA_DEBUG;
1662 /* In a shared object on Irix 5.3, the .mdebug section has an
1663 entsize of 0. FIXME: Does this matter? */
1664 if ((abfd->flags & DYNAMIC) != 0 )
1665 hdr->sh_entsize = 0;
1666 else
1667 hdr->sh_entsize = 1;
1668 }
1669 #ifdef ERIC_neverdef
1670 else if (strcmp (name, ".reginfo") == 0)
1671 {
1672 hdr->sh_type = SHT_ALPHA_REGINFO;
1673 /* In a shared object on Irix 5.3, the .reginfo section has an
1674 entsize of 0x18. FIXME: Does this matter? */
1675 if ((abfd->flags & DYNAMIC) != 0)
1676 hdr->sh_entsize = sizeof (Elf64_External_RegInfo);
1677 else
1678 hdr->sh_entsize = 1;
1679
1680 /* Force the section size to the correct value, even if the
1681 linker thinks it is larger. The link routine below will only
1682 write out this much data for .reginfo. */
1683 hdr->sh_size = sec->_raw_size = sizeof (Elf64_External_RegInfo);
1684 }
1685 else if (strcmp (name, ".hash") == 0
1686 || strcmp (name, ".dynamic") == 0
1687 || strcmp (name, ".dynstr") == 0)
1688 {
1689 hdr->sh_entsize = 0;
1690 hdr->sh_info = SIZEOF_ALPHA_DYNSYM_SECNAMES;
1691 }
1692 #endif
1693 else if (strcmp (name, ".sdata") == 0
1694 || strcmp (name, ".sbss") == 0
1695 || strcmp (name, ".lit4") == 0
1696 || strcmp (name, ".lit8") == 0)
1697 hdr->sh_flags |= SHF_ALPHA_GPREL;
1698
1699 return true;
1700 }
1701
1702 /* Hook called by the linker routine which adds symbols from an object
1703 file. We use it to put .comm items in .sbss, and not .bss. */
1704
1705 static boolean
1706 elf64_alpha_add_symbol_hook (abfd, info, sym, namep, flagsp, secp, valp)
1707 bfd *abfd;
1708 struct bfd_link_info *info;
1709 const Elf_Internal_Sym *sym;
1710 const char **namep ATTRIBUTE_UNUSED;
1711 flagword *flagsp ATTRIBUTE_UNUSED;
1712 asection **secp;
1713 bfd_vma *valp;
1714 {
1715 if (sym->st_shndx == SHN_COMMON
1716 && !info->relocateable
1717 && sym->st_size <= elf_gp_size (abfd))
1718 {
1719 /* Common symbols less than or equal to -G nn bytes are
1720 automatically put into .sbss. */
1721
1722 asection *scomm = bfd_get_section_by_name (abfd, ".scommon");
1723
1724 if (scomm == NULL)
1725 {
1726 scomm = bfd_make_section (abfd, ".scommon");
1727 if (scomm == NULL
1728 || !bfd_set_section_flags (abfd, scomm, (SEC_ALLOC
1729 | SEC_IS_COMMON
1730 | SEC_LINKER_CREATED)))
1731 return false;
1732 }
1733
1734 *secp = scomm;
1735 *valp = sym->st_size;
1736 }
1737
1738 return true;
1739 }
1740
1741 /* Create the .got section. */
1742
1743 static boolean
1744 elf64_alpha_create_got_section(abfd, info)
1745 bfd *abfd;
1746 struct bfd_link_info *info ATTRIBUTE_UNUSED;
1747 {
1748 asection *s;
1749
1750 if (bfd_get_section_by_name (abfd, ".got"))
1751 return true;
1752
1753 s = bfd_make_section (abfd, ".got");
1754 if (s == NULL
1755 || !bfd_set_section_flags (abfd, s, (SEC_ALLOC | SEC_LOAD
1756 | SEC_HAS_CONTENTS
1757 | SEC_IN_MEMORY
1758 | SEC_LINKER_CREATED))
1759 || !bfd_set_section_alignment (abfd, s, 3))
1760 return false;
1761
1762 alpha_elf_tdata (abfd)->got = s;
1763
1764 return true;
1765 }
1766
1767 /* Create all the dynamic sections. */
1768
1769 static boolean
1770 elf64_alpha_create_dynamic_sections (abfd, info)
1771 bfd *abfd;
1772 struct bfd_link_info *info;
1773 {
1774 asection *s;
1775 struct elf_link_hash_entry *h;
1776
1777 /* We need to create .plt, .rela.plt, .got, and .rela.got sections. */
1778
1779 s = bfd_make_section (abfd, ".plt");
1780 if (s == NULL
1781 || ! bfd_set_section_flags (abfd, s, (SEC_ALLOC | SEC_LOAD
1782 | SEC_HAS_CONTENTS
1783 | SEC_IN_MEMORY
1784 | SEC_LINKER_CREATED
1785 | SEC_CODE))
1786 || ! bfd_set_section_alignment (abfd, s, 3))
1787 return false;
1788
1789 /* Define the symbol _PROCEDURE_LINKAGE_TABLE_ at the start of the
1790 .plt section. */
1791 h = NULL;
1792 if (! (_bfd_generic_link_add_one_symbol
1793 (info, abfd, "_PROCEDURE_LINKAGE_TABLE_", BSF_GLOBAL, s,
1794 (bfd_vma) 0, (const char *) NULL, false,
1795 get_elf_backend_data (abfd)->collect,
1796 (struct bfd_link_hash_entry **) &h)))
1797 return false;
1798 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
1799 h->type = STT_OBJECT;
1800
1801 if (info->shared
1802 && ! _bfd_elf_link_record_dynamic_symbol (info, h))
1803 return false;
1804
1805 s = bfd_make_section (abfd, ".rela.plt");
1806 if (s == NULL
1807 || !bfd_set_section_flags (abfd, s, (SEC_ALLOC | SEC_LOAD
1808 | SEC_HAS_CONTENTS
1809 | SEC_IN_MEMORY
1810 | SEC_LINKER_CREATED
1811 | SEC_READONLY))
1812 || ! bfd_set_section_alignment (abfd, s, 3))
1813 return false;
1814
1815 /* We may or may not have created a .got section for this object, but
1816 we definitely havn't done the rest of the work. */
1817
1818 if (!elf64_alpha_create_got_section (abfd, info))
1819 return false;
1820
1821 s = bfd_make_section(abfd, ".rela.got");
1822 if (s == NULL
1823 || !bfd_set_section_flags (abfd, s, (SEC_ALLOC | SEC_LOAD
1824 | SEC_HAS_CONTENTS
1825 | SEC_IN_MEMORY
1826 | SEC_LINKER_CREATED
1827 | SEC_READONLY))
1828 || !bfd_set_section_alignment (abfd, s, 3))
1829 return false;
1830
1831 /* Define the symbol _GLOBAL_OFFSET_TABLE_ at the start of the
1832 dynobj's .got section. We don't do this in the linker script
1833 because we don't want to define the symbol if we are not creating
1834 a global offset table. */
1835 h = NULL;
1836 if (!(_bfd_generic_link_add_one_symbol
1837 (info, abfd, "_GLOBAL_OFFSET_TABLE_", BSF_GLOBAL,
1838 alpha_elf_tdata(abfd)->got, (bfd_vma) 0, (const char *) NULL,
1839 false, get_elf_backend_data (abfd)->collect,
1840 (struct bfd_link_hash_entry **) &h)))
1841 return false;
1842 h->elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
1843 h->type = STT_OBJECT;
1844
1845 if (info->shared
1846 && ! _bfd_elf_link_record_dynamic_symbol (info, h))
1847 return false;
1848
1849 elf_hash_table (info)->hgot = h;
1850
1851 return true;
1852 }
1853 \f
1854 /* Read ECOFF debugging information from a .mdebug section into a
1855 ecoff_debug_info structure. */
1856
1857 static boolean
1858 elf64_alpha_read_ecoff_info (abfd, section, debug)
1859 bfd *abfd;
1860 asection *section;
1861 struct ecoff_debug_info *debug;
1862 {
1863 HDRR *symhdr;
1864 const struct ecoff_debug_swap *swap;
1865 char *ext_hdr = NULL;
1866
1867 swap = get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
1868 memset (debug, 0, sizeof (*debug));
1869
1870 ext_hdr = (char *) bfd_malloc ((size_t) swap->external_hdr_size);
1871 if (ext_hdr == NULL && swap->external_hdr_size != 0)
1872 goto error_return;
1873
1874 if (bfd_get_section_contents (abfd, section, ext_hdr, (file_ptr) 0,
1875 swap->external_hdr_size)
1876 == false)
1877 goto error_return;
1878
1879 symhdr = &debug->symbolic_header;
1880 (*swap->swap_hdr_in) (abfd, ext_hdr, symhdr);
1881
1882 /* The symbolic header contains absolute file offsets and sizes to
1883 read. */
1884 #define READ(ptr, offset, count, size, type) \
1885 if (symhdr->count == 0) \
1886 debug->ptr = NULL; \
1887 else \
1888 { \
1889 debug->ptr = (type) bfd_malloc ((size_t) (size * symhdr->count)); \
1890 if (debug->ptr == NULL) \
1891 goto error_return; \
1892 if (bfd_seek (abfd, (file_ptr) symhdr->offset, SEEK_SET) != 0 \
1893 || (bfd_read (debug->ptr, size, symhdr->count, \
1894 abfd) != size * symhdr->count)) \
1895 goto error_return; \
1896 }
1897
1898 READ (line, cbLineOffset, cbLine, sizeof (unsigned char), unsigned char *);
1899 READ (external_dnr, cbDnOffset, idnMax, swap->external_dnr_size, PTR);
1900 READ (external_pdr, cbPdOffset, ipdMax, swap->external_pdr_size, PTR);
1901 READ (external_sym, cbSymOffset, isymMax, swap->external_sym_size, PTR);
1902 READ (external_opt, cbOptOffset, ioptMax, swap->external_opt_size, PTR);
1903 READ (external_aux, cbAuxOffset, iauxMax, sizeof (union aux_ext),
1904 union aux_ext *);
1905 READ (ss, cbSsOffset, issMax, sizeof (char), char *);
1906 READ (ssext, cbSsExtOffset, issExtMax, sizeof (char), char *);
1907 READ (external_fdr, cbFdOffset, ifdMax, swap->external_fdr_size, PTR);
1908 READ (external_rfd, cbRfdOffset, crfd, swap->external_rfd_size, PTR);
1909 READ (external_ext, cbExtOffset, iextMax, swap->external_ext_size, PTR);
1910 #undef READ
1911
1912 debug->fdr = NULL;
1913 debug->adjust = NULL;
1914
1915 return true;
1916
1917 error_return:
1918 if (ext_hdr != NULL)
1919 free (ext_hdr);
1920 if (debug->line != NULL)
1921 free (debug->line);
1922 if (debug->external_dnr != NULL)
1923 free (debug->external_dnr);
1924 if (debug->external_pdr != NULL)
1925 free (debug->external_pdr);
1926 if (debug->external_sym != NULL)
1927 free (debug->external_sym);
1928 if (debug->external_opt != NULL)
1929 free (debug->external_opt);
1930 if (debug->external_aux != NULL)
1931 free (debug->external_aux);
1932 if (debug->ss != NULL)
1933 free (debug->ss);
1934 if (debug->ssext != NULL)
1935 free (debug->ssext);
1936 if (debug->external_fdr != NULL)
1937 free (debug->external_fdr);
1938 if (debug->external_rfd != NULL)
1939 free (debug->external_rfd);
1940 if (debug->external_ext != NULL)
1941 free (debug->external_ext);
1942 return false;
1943 }
1944
1945 /* Alpha ELF local labels start with '$'. */
1946
1947 static boolean
1948 elf64_alpha_is_local_label_name (abfd, name)
1949 bfd *abfd ATTRIBUTE_UNUSED;
1950 const char *name;
1951 {
1952 return name[0] == '$';
1953 }
1954
1955 /* Alpha ELF follows MIPS ELF in using a special find_nearest_line
1956 routine in order to handle the ECOFF debugging information. We
1957 still call this mips_elf_find_line because of the slot
1958 find_line_info in elf_obj_tdata is declared that way. */
1959
1960 struct mips_elf_find_line
1961 {
1962 struct ecoff_debug_info d;
1963 struct ecoff_find_line i;
1964 };
1965
1966 static boolean
1967 elf64_alpha_find_nearest_line (abfd, section, symbols, offset, filename_ptr,
1968 functionname_ptr, line_ptr)
1969 bfd *abfd;
1970 asection *section;
1971 asymbol **symbols;
1972 bfd_vma offset;
1973 const char **filename_ptr;
1974 const char **functionname_ptr;
1975 unsigned int *line_ptr;
1976 {
1977 asection *msec;
1978
1979 if (_bfd_dwarf2_find_nearest_line (abfd, section, symbols, offset,
1980 filename_ptr, functionname_ptr,
1981 line_ptr, 0,
1982 &elf_tdata (abfd)->dwarf2_find_line_info))
1983 return true;
1984
1985 msec = bfd_get_section_by_name (abfd, ".mdebug");
1986 if (msec != NULL)
1987 {
1988 flagword origflags;
1989 struct mips_elf_find_line *fi;
1990 const struct ecoff_debug_swap * const swap =
1991 get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
1992
1993 /* If we are called during a link, alpha_elf_final_link may have
1994 cleared the SEC_HAS_CONTENTS field. We force it back on here
1995 if appropriate (which it normally will be). */
1996 origflags = msec->flags;
1997 if (elf_section_data (msec)->this_hdr.sh_type != SHT_NOBITS)
1998 msec->flags |= SEC_HAS_CONTENTS;
1999
2000 fi = elf_tdata (abfd)->find_line_info;
2001 if (fi == NULL)
2002 {
2003 bfd_size_type external_fdr_size;
2004 char *fraw_src;
2005 char *fraw_end;
2006 struct fdr *fdr_ptr;
2007
2008 fi = ((struct mips_elf_find_line *)
2009 bfd_zalloc (abfd, sizeof (struct mips_elf_find_line)));
2010 if (fi == NULL)
2011 {
2012 msec->flags = origflags;
2013 return false;
2014 }
2015
2016 if (!elf64_alpha_read_ecoff_info (abfd, msec, &fi->d))
2017 {
2018 msec->flags = origflags;
2019 return false;
2020 }
2021
2022 /* Swap in the FDR information. */
2023 fi->d.fdr = ((struct fdr *)
2024 bfd_alloc (abfd,
2025 (fi->d.symbolic_header.ifdMax *
2026 sizeof (struct fdr))));
2027 if (fi->d.fdr == NULL)
2028 {
2029 msec->flags = origflags;
2030 return false;
2031 }
2032 external_fdr_size = swap->external_fdr_size;
2033 fdr_ptr = fi->d.fdr;
2034 fraw_src = (char *) fi->d.external_fdr;
2035 fraw_end = (fraw_src
2036 + fi->d.symbolic_header.ifdMax * external_fdr_size);
2037 for (; fraw_src < fraw_end; fraw_src += external_fdr_size, fdr_ptr++)
2038 (*swap->swap_fdr_in) (abfd, (PTR) fraw_src, fdr_ptr);
2039
2040 elf_tdata (abfd)->find_line_info = fi;
2041
2042 /* Note that we don't bother to ever free this information.
2043 find_nearest_line is either called all the time, as in
2044 objdump -l, so the information should be saved, or it is
2045 rarely called, as in ld error messages, so the memory
2046 wasted is unimportant. Still, it would probably be a
2047 good idea for free_cached_info to throw it away. */
2048 }
2049
2050 if (_bfd_ecoff_locate_line (abfd, section, offset, &fi->d, swap,
2051 &fi->i, filename_ptr, functionname_ptr,
2052 line_ptr))
2053 {
2054 msec->flags = origflags;
2055 return true;
2056 }
2057
2058 msec->flags = origflags;
2059 }
2060
2061 /* Fall back on the generic ELF find_nearest_line routine. */
2062
2063 return _bfd_elf_find_nearest_line (abfd, section, symbols, offset,
2064 filename_ptr, functionname_ptr,
2065 line_ptr);
2066 }
2067 \f
2068 /* Structure used to pass information to alpha_elf_output_extsym. */
2069
2070 struct extsym_info
2071 {
2072 bfd *abfd;
2073 struct bfd_link_info *info;
2074 struct ecoff_debug_info *debug;
2075 const struct ecoff_debug_swap *swap;
2076 boolean failed;
2077 };
2078
2079 static boolean
2080 elf64_alpha_output_extsym (h, data)
2081 struct alpha_elf_link_hash_entry *h;
2082 PTR data;
2083 {
2084 struct extsym_info *einfo = (struct extsym_info *) data;
2085 boolean strip;
2086 asection *sec, *output_section;
2087
2088 if (h->root.indx == -2)
2089 strip = false;
2090 else if (((h->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_DYNAMIC) != 0
2091 || (h->root.elf_link_hash_flags & ELF_LINK_HASH_REF_DYNAMIC) != 0)
2092 && (h->root.elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR) == 0
2093 && (h->root.elf_link_hash_flags & ELF_LINK_HASH_REF_REGULAR) == 0)
2094 strip = true;
2095 else if (einfo->info->strip == strip_all
2096 || (einfo->info->strip == strip_some
2097 && bfd_hash_lookup (einfo->info->keep_hash,
2098 h->root.root.root.string,
2099 false, false) == NULL))
2100 strip = true;
2101 else
2102 strip = false;
2103
2104 if (strip)
2105 return true;
2106
2107 if (h->esym.ifd == -2)
2108 {
2109 h->esym.jmptbl = 0;
2110 h->esym.cobol_main = 0;
2111 h->esym.weakext = 0;
2112 h->esym.reserved = 0;
2113 h->esym.ifd = ifdNil;
2114 h->esym.asym.value = 0;
2115 h->esym.asym.st = stGlobal;
2116
2117 if (h->root.root.type != bfd_link_hash_defined
2118 && h->root.root.type != bfd_link_hash_defweak)
2119 h->esym.asym.sc = scAbs;
2120 else
2121 {
2122 const char *name;
2123
2124 sec = h->root.root.u.def.section;
2125 output_section = sec->output_section;
2126
2127 /* When making a shared library and symbol h is the one from
2128 the another shared library, OUTPUT_SECTION may be null. */
2129 if (output_section == NULL)
2130 h->esym.asym.sc = scUndefined;
2131 else
2132 {
2133 name = bfd_section_name (output_section->owner, output_section);
2134
2135 if (strcmp (name, ".text") == 0)
2136 h->esym.asym.sc = scText;
2137 else if (strcmp (name, ".data") == 0)
2138 h->esym.asym.sc = scData;
2139 else if (strcmp (name, ".sdata") == 0)
2140 h->esym.asym.sc = scSData;
2141 else if (strcmp (name, ".rodata") == 0
2142 || strcmp (name, ".rdata") == 0)
2143 h->esym.asym.sc = scRData;
2144 else if (strcmp (name, ".bss") == 0)
2145 h->esym.asym.sc = scBss;
2146 else if (strcmp (name, ".sbss") == 0)
2147 h->esym.asym.sc = scSBss;
2148 else if (strcmp (name, ".init") == 0)
2149 h->esym.asym.sc = scInit;
2150 else if (strcmp (name, ".fini") == 0)
2151 h->esym.asym.sc = scFini;
2152 else
2153 h->esym.asym.sc = scAbs;
2154 }
2155 }
2156
2157 h->esym.asym.reserved = 0;
2158 h->esym.asym.index = indexNil;
2159 }
2160
2161 if (h->root.root.type == bfd_link_hash_common)
2162 h->esym.asym.value = h->root.root.u.c.size;
2163 else if (h->root.root.type == bfd_link_hash_defined
2164 || h->root.root.type == bfd_link_hash_defweak)
2165 {
2166 if (h->esym.asym.sc == scCommon)
2167 h->esym.asym.sc = scBss;
2168 else if (h->esym.asym.sc == scSCommon)
2169 h->esym.asym.sc = scSBss;
2170
2171 sec = h->root.root.u.def.section;
2172 output_section = sec->output_section;
2173 if (output_section != NULL)
2174 h->esym.asym.value = (h->root.root.u.def.value
2175 + sec->output_offset
2176 + output_section->vma);
2177 else
2178 h->esym.asym.value = 0;
2179 }
2180 else if ((h->root.elf_link_hash_flags & ELF_LINK_HASH_NEEDS_PLT) != 0)
2181 {
2182 /* Set type and value for a symbol with a function stub. */
2183 h->esym.asym.st = stProc;
2184 sec = bfd_get_section_by_name (einfo->abfd, ".plt");
2185 if (sec == NULL)
2186 h->esym.asym.value = 0;
2187 else
2188 {
2189 output_section = sec->output_section;
2190 if (output_section != NULL)
2191 h->esym.asym.value = (h->root.plt.offset
2192 + sec->output_offset
2193 + output_section->vma);
2194 else
2195 h->esym.asym.value = 0;
2196 }
2197 #if 0 /* FIXME? */
2198 h->esym.ifd = 0;
2199 #endif
2200 }
2201
2202 if (! bfd_ecoff_debug_one_external (einfo->abfd, einfo->debug, einfo->swap,
2203 h->root.root.root.string,
2204 &h->esym))
2205 {
2206 einfo->failed = true;
2207 return false;
2208 }
2209
2210 return true;
2211 }
2212
2213 /* FIXME: Create a runtime procedure table from the .mdebug section.
2214
2215 static boolean
2216 mips_elf_create_procedure_table (handle, abfd, info, s, debug)
2217 PTR handle;
2218 bfd *abfd;
2219 struct bfd_link_info *info;
2220 asection *s;
2221 struct ecoff_debug_info *debug;
2222 */
2223 \f
2224 /* Handle dynamic relocations when doing an Alpha ELF link. */
2225
2226 static boolean
2227 elf64_alpha_check_relocs (abfd, info, sec, relocs)
2228 bfd *abfd;
2229 struct bfd_link_info *info;
2230 asection *sec;
2231 const Elf_Internal_Rela *relocs;
2232 {
2233 bfd *dynobj;
2234 asection *sreloc;
2235 const char *rel_sec_name;
2236 Elf_Internal_Shdr *symtab_hdr;
2237 struct alpha_elf_link_hash_entry **sym_hashes;
2238 struct alpha_elf_got_entry **local_got_entries;
2239 const Elf_Internal_Rela *rel, *relend;
2240 int got_created;
2241
2242 if (info->relocateable)
2243 return true;
2244
2245 dynobj = elf_hash_table(info)->dynobj;
2246 if (dynobj == NULL)
2247 elf_hash_table(info)->dynobj = dynobj = abfd;
2248
2249 sreloc = NULL;
2250 rel_sec_name = NULL;
2251 symtab_hdr = &elf_tdata(abfd)->symtab_hdr;
2252 sym_hashes = alpha_elf_sym_hashes(abfd);
2253 local_got_entries = alpha_elf_tdata(abfd)->local_got_entries;
2254 got_created = 0;
2255
2256 relend = relocs + sec->reloc_count;
2257 for (rel = relocs; rel < relend; ++rel)
2258 {
2259 unsigned long r_symndx, r_type;
2260 struct alpha_elf_link_hash_entry *h;
2261
2262 r_symndx = ELF64_R_SYM (rel->r_info);
2263 if (r_symndx < symtab_hdr->sh_info)
2264 h = NULL;
2265 else
2266 {
2267 h = sym_hashes[r_symndx - symtab_hdr->sh_info];
2268
2269 while (h->root.root.type == bfd_link_hash_indirect
2270 || h->root.root.type == bfd_link_hash_warning)
2271 h = (struct alpha_elf_link_hash_entry *)h->root.root.u.i.link;
2272
2273 h->root.elf_link_hash_flags |= ELF_LINK_HASH_REF_REGULAR;
2274 }
2275 r_type = ELF64_R_TYPE (rel->r_info);
2276
2277 switch (r_type)
2278 {
2279 case R_ALPHA_LITERAL:
2280 {
2281 struct alpha_elf_got_entry *gotent;
2282 int flags = 0;
2283
2284 if (h)
2285 {
2286 /* Search for and possibly create a got entry. */
2287 for (gotent = h->got_entries; gotent ; gotent = gotent->next)
2288 if (gotent->gotobj == abfd &&
2289 gotent->addend == rel->r_addend)
2290 break;
2291
2292 if (!gotent)
2293 {
2294 gotent = ((struct alpha_elf_got_entry *)
2295 bfd_alloc (abfd,
2296 sizeof (struct alpha_elf_got_entry)));
2297 if (!gotent)
2298 return false;
2299
2300 gotent->gotobj = abfd;
2301 gotent->addend = rel->r_addend;
2302 gotent->got_offset = -1;
2303 gotent->flags = 0;
2304 gotent->use_count = 1;
2305
2306 gotent->next = h->got_entries;
2307 h->got_entries = gotent;
2308
2309 alpha_elf_tdata (abfd)->total_got_entries++;
2310 }
2311 else
2312 gotent->use_count += 1;
2313 }
2314 else
2315 {
2316 /* This is a local .got entry -- record for merge. */
2317 if (!local_got_entries)
2318 {
2319 size_t size;
2320 size = (symtab_hdr->sh_info
2321 * sizeof (struct alpha_elf_got_entry *));
2322
2323 local_got_entries = ((struct alpha_elf_got_entry **)
2324 bfd_alloc (abfd, size));
2325 if (!local_got_entries)
2326 return false;
2327
2328 memset (local_got_entries, 0, size);
2329 alpha_elf_tdata (abfd)->local_got_entries =
2330 local_got_entries;
2331 }
2332
2333 for (gotent = local_got_entries[ELF64_R_SYM(rel->r_info)];
2334 gotent != NULL && gotent->addend != rel->r_addend;
2335 gotent = gotent->next)
2336 continue;
2337 if (!gotent)
2338 {
2339 gotent = ((struct alpha_elf_got_entry *)
2340 bfd_alloc (abfd,
2341 sizeof (struct alpha_elf_got_entry)));
2342 if (!gotent)
2343 return false;
2344
2345 gotent->gotobj = abfd;
2346 gotent->addend = rel->r_addend;
2347 gotent->got_offset = -1;
2348 gotent->flags = 0;
2349 gotent->use_count = 1;
2350
2351 gotent->next = local_got_entries[ELF64_R_SYM(rel->r_info)];
2352 local_got_entries[ELF64_R_SYM(rel->r_info)] = gotent;
2353
2354 alpha_elf_tdata(abfd)->total_got_entries++;
2355 alpha_elf_tdata(abfd)->n_local_got_entries++;
2356 }
2357 else
2358 gotent->use_count += 1;
2359 }
2360
2361 /* Remember how this literal is used from its LITUSEs.
2362 This will be important when it comes to decide if we can
2363 create a .plt entry for a function symbol. */
2364 if (rel+1 < relend
2365 && ELF64_R_TYPE (rel[1].r_info) == R_ALPHA_LITUSE)
2366 {
2367 do
2368 {
2369 ++rel;
2370 if (rel->r_addend >= 1 && rel->r_addend <= 3)
2371 flags |= 1 << rel->r_addend;
2372 }
2373 while (rel+1 < relend &&
2374 ELF64_R_TYPE (rel[1].r_info) == R_ALPHA_LITUSE);
2375 }
2376 else
2377 {
2378 /* No LITUSEs -- presumably the address is not being
2379 loaded for nothing. */
2380 flags = ALPHA_ELF_LINK_HASH_LU_ADDR;
2381 }
2382
2383 gotent->flags |= flags;
2384 if (h)
2385 {
2386 /* Make a guess as to whether a .plt entry will be needed. */
2387 if ((h->flags |= flags) == ALPHA_ELF_LINK_HASH_LU_FUNC)
2388 h->root.elf_link_hash_flags |= ELF_LINK_HASH_NEEDS_PLT;
2389 else
2390 h->root.elf_link_hash_flags &= ~ELF_LINK_HASH_NEEDS_PLT;
2391 }
2392 }
2393 /* FALLTHRU */
2394
2395 case R_ALPHA_GPDISP:
2396 case R_ALPHA_GPREL16:
2397 case R_ALPHA_GPREL32:
2398 case R_ALPHA_GPRELHIGH:
2399 case R_ALPHA_GPRELLOW:
2400 /* We don't actually use the .got here, but the sections must
2401 be created before the linker maps input sections to output
2402 sections. */
2403 if (!got_created)
2404 {
2405 if (!elf64_alpha_create_got_section (abfd, info))
2406 return false;
2407
2408 /* Make sure the object's gotobj is set to itself so
2409 that we default to every object with its own .got.
2410 We'll merge .gots later once we've collected each
2411 object's info. */
2412 alpha_elf_tdata(abfd)->gotobj = abfd;
2413
2414 got_created = 1;
2415 }
2416 break;
2417
2418 case R_ALPHA_SREL16:
2419 case R_ALPHA_SREL32:
2420 case R_ALPHA_SREL64:
2421 if (h == NULL)
2422 break;
2423 /* FALLTHRU */
2424
2425 case R_ALPHA_REFLONG:
2426 case R_ALPHA_REFQUAD:
2427 if (rel_sec_name == NULL)
2428 {
2429 rel_sec_name = (bfd_elf_string_from_elf_section
2430 (abfd, elf_elfheader(abfd)->e_shstrndx,
2431 elf_section_data(sec)->rel_hdr.sh_name));
2432 if (rel_sec_name == NULL)
2433 return false;
2434
2435 BFD_ASSERT (strncmp (rel_sec_name, ".rela", 5) == 0
2436 && strcmp (bfd_get_section_name (abfd, sec),
2437 rel_sec_name+5) == 0);
2438 }
2439
2440 /* We need to create the section here now whether we eventually
2441 use it or not so that it gets mapped to an output section by
2442 the linker. If not used, we'll kill it in
2443 size_dynamic_sections. */
2444 if (sreloc == NULL)
2445 {
2446 sreloc = bfd_get_section_by_name (dynobj, rel_sec_name);
2447 if (sreloc == NULL)
2448 {
2449 sreloc = bfd_make_section (dynobj, rel_sec_name);
2450 if (sreloc == NULL
2451 || !bfd_set_section_flags (dynobj, sreloc,
2452 (((sec->flags
2453 & SEC_ALLOC)
2454 ? (SEC_ALLOC
2455 | SEC_LOAD) : 0)
2456 | SEC_HAS_CONTENTS
2457 | SEC_IN_MEMORY
2458 | SEC_LINKER_CREATED
2459 | SEC_READONLY))
2460 || !bfd_set_section_alignment (dynobj, sreloc, 3))
2461 return false;
2462 }
2463 }
2464
2465 if (h)
2466 {
2467 /* Since we havn't seen all of the input symbols yet, we
2468 don't know whether we'll actually need a dynamic relocation
2469 entry for this reloc. So make a record of it. Once we
2470 find out if this thing needs dynamic relocation we'll
2471 expand the relocation sections by the appropriate amount. */
2472
2473 struct alpha_elf_reloc_entry *rent;
2474
2475 for (rent = h->reloc_entries; rent; rent = rent->next)
2476 if (rent->rtype == r_type && rent->srel == sreloc)
2477 break;
2478
2479 if (!rent)
2480 {
2481 rent = ((struct alpha_elf_reloc_entry *)
2482 bfd_alloc (abfd,
2483 sizeof (struct alpha_elf_reloc_entry)));
2484 if (!rent)
2485 return false;
2486
2487 rent->srel = sreloc;
2488 rent->rtype = r_type;
2489 rent->count = 1;
2490 rent->reltext = (sec->flags & SEC_READONLY) != 0;
2491
2492 rent->next = h->reloc_entries;
2493 h->reloc_entries = rent;
2494 }
2495 else
2496 rent->count++;
2497 }
2498 else if (info->shared && (sec->flags & SEC_ALLOC))
2499 {
2500 /* If this is a shared library, and the section is to be
2501 loaded into memory, we need a RELATIVE reloc. */
2502 sreloc->_raw_size += sizeof (Elf64_External_Rela);
2503 if (sec->flags & SEC_READONLY)
2504 info->flags |= DF_TEXTREL;
2505 }
2506 break;
2507 }
2508 }
2509
2510 return true;
2511 }
2512
2513 /* Adjust a symbol defined by a dynamic object and referenced by a
2514 regular object. The current definition is in some section of the
2515 dynamic object, but we're not including those sections. We have to
2516 change the definition to something the rest of the link can
2517 understand. */
2518
2519 static boolean
2520 elf64_alpha_adjust_dynamic_symbol (info, h)
2521 struct bfd_link_info *info;
2522 struct elf_link_hash_entry *h;
2523 {
2524 bfd *dynobj;
2525 asection *s;
2526 struct alpha_elf_link_hash_entry *ah;
2527
2528 dynobj = elf_hash_table(info)->dynobj;
2529 ah = (struct alpha_elf_link_hash_entry *)h;
2530
2531 /* Now that we've seen all of the input symbols, finalize our decision
2532 about whether this symbol should get a .plt entry. */
2533
2534 if (h->root.type != bfd_link_hash_undefweak
2535 && alpha_elf_dynamic_symbol_p (h, info)
2536 && ((h->type == STT_FUNC
2537 && !(ah->flags & ALPHA_ELF_LINK_HASH_LU_ADDR))
2538 || (h->type == STT_NOTYPE
2539 && ah->flags == ALPHA_ELF_LINK_HASH_LU_FUNC))
2540 /* Don't prevent otherwise valid programs from linking by attempting
2541 to create a new .got entry somewhere. A Correct Solution would be
2542 to add a new .got section to a new object file and let it be merged
2543 somewhere later. But for now don't bother. */
2544 && ah->got_entries)
2545 {
2546 h->elf_link_hash_flags |= ELF_LINK_HASH_NEEDS_PLT;
2547
2548 s = bfd_get_section_by_name(dynobj, ".plt");
2549 if (!s && !elf64_alpha_create_dynamic_sections (dynobj, info))
2550 return false;
2551
2552 /* The first bit of the .plt is reserved. */
2553 if (s->_raw_size == 0)
2554 s->_raw_size = PLT_HEADER_SIZE;
2555
2556 h->plt.offset = s->_raw_size;
2557 s->_raw_size += PLT_ENTRY_SIZE;
2558
2559 /* If this symbol is not defined in a regular file, and we are not
2560 generating a shared library, then set the symbol to the location
2561 in the .plt. This is required to make function pointers compare
2562 equal between the normal executable and the shared library. */
2563 if (! info->shared
2564 && h->root.type != bfd_link_hash_defweak)
2565 {
2566 h->root.u.def.section = s;
2567 h->root.u.def.value = h->plt.offset;
2568 }
2569
2570 /* We also need a JMP_SLOT entry in the .rela.plt section. */
2571 s = bfd_get_section_by_name (dynobj, ".rela.plt");
2572 BFD_ASSERT (s != NULL);
2573 s->_raw_size += sizeof (Elf64_External_Rela);
2574
2575 return true;
2576 }
2577 else
2578 h->elf_link_hash_flags &= ~ELF_LINK_HASH_NEEDS_PLT;
2579
2580 /* If this is a weak symbol, and there is a real definition, the
2581 processor independent code will have arranged for us to see the
2582 real definition first, and we can just use the same value. */
2583 if (h->weakdef != NULL)
2584 {
2585 BFD_ASSERT (h->weakdef->root.type == bfd_link_hash_defined
2586 || h->weakdef->root.type == bfd_link_hash_defweak);
2587 h->root.u.def.section = h->weakdef->root.u.def.section;
2588 h->root.u.def.value = h->weakdef->root.u.def.value;
2589 return true;
2590 }
2591
2592 /* This is a reference to a symbol defined by a dynamic object which
2593 is not a function. The Alpha, since it uses .got entries for all
2594 symbols even in regular objects, does not need the hackery of a
2595 .dynbss section and COPY dynamic relocations. */
2596
2597 return true;
2598 }
2599
2600 /* Symbol versioning can create new symbols, and make our old symbols
2601 indirect to the new ones. Consolidate the got and reloc information
2602 in these situations. */
2603
2604 static boolean
2605 elf64_alpha_merge_ind_symbols (hi, dummy)
2606 struct alpha_elf_link_hash_entry *hi;
2607 PTR dummy ATTRIBUTE_UNUSED;
2608 {
2609 struct alpha_elf_link_hash_entry *hs;
2610
2611 if (hi->root.root.type != bfd_link_hash_indirect)
2612 return true;
2613 hs = hi;
2614 do {
2615 hs = (struct alpha_elf_link_hash_entry *)hs->root.root.u.i.link;
2616 } while (hs->root.root.type == bfd_link_hash_indirect);
2617
2618 /* Merge the flags. Whee. */
2619
2620 hs->flags |= hi->flags;
2621
2622 /* Merge the .got entries. Cannibalize the old symbol's list in
2623 doing so, since we don't need it anymore. */
2624
2625 if (hs->got_entries == NULL)
2626 hs->got_entries = hi->got_entries;
2627 else
2628 {
2629 struct alpha_elf_got_entry *gi, *gs, *gin, *gsh;
2630
2631 gsh = hs->got_entries;
2632 for (gi = hi->got_entries; gi ; gi = gin)
2633 {
2634 gin = gi->next;
2635 for (gs = gsh; gs ; gs = gs->next)
2636 if (gi->gotobj == gs->gotobj && gi->addend == gs->addend)
2637 goto got_found;
2638 gi->next = hs->got_entries;
2639 hs->got_entries = gi;
2640 got_found:;
2641 }
2642 }
2643 hi->got_entries = NULL;
2644
2645 /* And similar for the reloc entries. */
2646
2647 if (hs->reloc_entries == NULL)
2648 hs->reloc_entries = hi->reloc_entries;
2649 else
2650 {
2651 struct alpha_elf_reloc_entry *ri, *rs, *rin, *rsh;
2652
2653 rsh = hs->reloc_entries;
2654 for (ri = hi->reloc_entries; ri ; ri = rin)
2655 {
2656 rin = ri->next;
2657 for (rs = rsh; rs ; rs = rs->next)
2658 if (ri->rtype == rs->rtype)
2659 {
2660 rs->count += ri->count;
2661 goto found_reloc;
2662 }
2663 ri->next = hs->reloc_entries;
2664 hs->reloc_entries = ri;
2665 found_reloc:;
2666 }
2667 }
2668 hi->reloc_entries = NULL;
2669
2670 return true;
2671 }
2672
2673 /* Is it possible to merge two object file's .got tables? */
2674
2675 static boolean
2676 elf64_alpha_can_merge_gots (a, b)
2677 bfd *a, *b;
2678 {
2679 int total = alpha_elf_tdata (a)->total_got_entries;
2680 bfd *bsub;
2681
2682 /* Trivial quick fallout test. */
2683 if (total + alpha_elf_tdata (b)->total_got_entries <= MAX_GOT_ENTRIES)
2684 return true;
2685
2686 /* By their nature, local .got entries cannot be merged. */
2687 if ((total += alpha_elf_tdata (b)->n_local_got_entries) > MAX_GOT_ENTRIES)
2688 return false;
2689
2690 /* Failing the common trivial comparison, we must effectively
2691 perform the merge. Not actually performing the merge means that
2692 we don't have to store undo information in case we fail. */
2693 for (bsub = b; bsub ; bsub = alpha_elf_tdata (bsub)->in_got_link_next)
2694 {
2695 struct alpha_elf_link_hash_entry **hashes = alpha_elf_sym_hashes (bsub);
2696 Elf_Internal_Shdr *symtab_hdr = &elf_tdata (bsub)->symtab_hdr;
2697 int i, n;
2698
2699 n = NUM_SHDR_ENTRIES (symtab_hdr) - symtab_hdr->sh_info;
2700 for (i = 0; i < n; ++i)
2701 {
2702 struct alpha_elf_got_entry *ae, *be;
2703 struct alpha_elf_link_hash_entry *h;
2704
2705 h = hashes[i];
2706 while (h->root.root.type == bfd_link_hash_indirect
2707 || h->root.root.type == bfd_link_hash_warning)
2708 h = (struct alpha_elf_link_hash_entry *)h->root.root.u.i.link;
2709
2710 for (be = h->got_entries; be ; be = be->next)
2711 {
2712 if (be->use_count == 0)
2713 continue;
2714 if (be->gotobj != b)
2715 continue;
2716
2717 for (ae = h->got_entries; ae ; ae = ae->next)
2718 if (ae->gotobj == a && ae->addend == be->addend)
2719 goto global_found;
2720
2721 if (++total > MAX_GOT_ENTRIES)
2722 return false;
2723 global_found:;
2724 }
2725 }
2726 }
2727
2728 return true;
2729 }
2730
2731 /* Actually merge two .got tables. */
2732
2733 static void
2734 elf64_alpha_merge_gots (a, b)
2735 bfd *a, *b;
2736 {
2737 int total = alpha_elf_tdata (a)->total_got_entries;
2738 bfd *bsub;
2739
2740 /* Remember local expansion. */
2741 {
2742 int e = alpha_elf_tdata (b)->n_local_got_entries;
2743 total += e;
2744 alpha_elf_tdata (a)->n_local_got_entries += e;
2745 }
2746
2747 for (bsub = b; bsub ; bsub = alpha_elf_tdata (bsub)->in_got_link_next)
2748 {
2749 struct alpha_elf_got_entry **local_got_entries;
2750 struct alpha_elf_link_hash_entry **hashes;
2751 Elf_Internal_Shdr *symtab_hdr;
2752 int i, n;
2753
2754 /* Let the local .got entries know they are part of a new subsegment. */
2755 local_got_entries = alpha_elf_tdata (bsub)->local_got_entries;
2756 if (local_got_entries)
2757 {
2758 n = elf_tdata (bsub)->symtab_hdr.sh_info;
2759 for (i = 0; i < n; ++i)
2760 {
2761 struct alpha_elf_got_entry *ent;
2762 for (ent = local_got_entries[i]; ent; ent = ent->next)
2763 ent->gotobj = a;
2764 }
2765 }
2766
2767 /* Merge the global .got entries. */
2768 hashes = alpha_elf_sym_hashes (bsub);
2769 symtab_hdr = &elf_tdata (bsub)->symtab_hdr;
2770
2771 n = NUM_SHDR_ENTRIES (symtab_hdr) - symtab_hdr->sh_info;
2772 for (i = 0; i < n; ++i)
2773 {
2774 struct alpha_elf_got_entry *ae, *be, **pbe, **start;
2775 struct alpha_elf_link_hash_entry *h;
2776
2777 h = hashes[i];
2778 while (h->root.root.type == bfd_link_hash_indirect
2779 || h->root.root.type == bfd_link_hash_warning)
2780 h = (struct alpha_elf_link_hash_entry *)h->root.root.u.i.link;
2781
2782 start = &h->got_entries;
2783 for (pbe = start, be = *start; be ; pbe = &be->next, be = be->next)
2784 {
2785 if (be->use_count == 0)
2786 {
2787 *pbe = be->next;
2788 continue;
2789 }
2790 if (be->gotobj != b)
2791 continue;
2792
2793 for (ae = *start; ae ; ae = ae->next)
2794 if (ae->gotobj == a && ae->addend == be->addend)
2795 {
2796 ae->flags |= be->flags;
2797 ae->use_count += be->use_count;
2798 *pbe = be->next;
2799 goto global_found;
2800 }
2801 be->gotobj = a;
2802 total += 1;
2803
2804 global_found:;
2805 }
2806 }
2807
2808 alpha_elf_tdata (bsub)->gotobj = a;
2809 }
2810 alpha_elf_tdata (a)->total_got_entries = total;
2811
2812 /* Merge the two in_got chains. */
2813 {
2814 bfd *next;
2815
2816 bsub = a;
2817 while ((next = alpha_elf_tdata (bsub)->in_got_link_next) != NULL)
2818 bsub = next;
2819
2820 alpha_elf_tdata (bsub)->in_got_link_next = b;
2821 }
2822 }
2823
2824 /* Calculate the offsets for the got entries. */
2825
2826 static boolean
2827 elf64_alpha_calc_got_offsets_for_symbol (h, arg)
2828 struct alpha_elf_link_hash_entry *h;
2829 PTR arg ATTRIBUTE_UNUSED;
2830 {
2831 struct alpha_elf_got_entry *gotent;
2832
2833 for (gotent = h->got_entries; gotent; gotent = gotent->next)
2834 if (gotent->use_count > 0)
2835 {
2836 bfd_size_type *plge
2837 = &alpha_elf_tdata (gotent->gotobj)->got->_raw_size;
2838
2839 gotent->got_offset = *plge;
2840 *plge += 8;
2841 }
2842
2843 return true;
2844 }
2845
2846 static void
2847 elf64_alpha_calc_got_offsets (info)
2848 struct bfd_link_info *info;
2849 {
2850 bfd *i, *got_list = alpha_elf_hash_table(info)->got_list;
2851
2852 /* First, zero out the .got sizes, as we may be recalculating the
2853 .got after optimizing it. */
2854 for (i = got_list; i ; i = alpha_elf_tdata(i)->got_link_next)
2855 alpha_elf_tdata(i)->got->_raw_size = 0;
2856
2857 /* Next, fill in the offsets for all the global entries. */
2858 alpha_elf_link_hash_traverse (alpha_elf_hash_table (info),
2859 elf64_alpha_calc_got_offsets_for_symbol,
2860 NULL);
2861
2862 /* Finally, fill in the offsets for the local entries. */
2863 for (i = got_list; i ; i = alpha_elf_tdata(i)->got_link_next)
2864 {
2865 bfd_size_type got_offset = alpha_elf_tdata(i)->got->_raw_size;
2866 bfd *j;
2867
2868 for (j = i; j ; j = alpha_elf_tdata(j)->in_got_link_next)
2869 {
2870 struct alpha_elf_got_entry **local_got_entries, *gotent;
2871 int k, n;
2872
2873 local_got_entries = alpha_elf_tdata(j)->local_got_entries;
2874 if (!local_got_entries)
2875 continue;
2876
2877 for (k = 0, n = elf_tdata(j)->symtab_hdr.sh_info; k < n; ++k)
2878 for (gotent = local_got_entries[k]; gotent; gotent = gotent->next)
2879 if (gotent->use_count > 0)
2880 {
2881 gotent->got_offset = got_offset;
2882 got_offset += 8;
2883 }
2884 }
2885
2886 alpha_elf_tdata(i)->got->_raw_size = got_offset;
2887 alpha_elf_tdata(i)->got->_cooked_size = got_offset;
2888 }
2889 }
2890
2891 /* Constructs the gots. */
2892
2893 static boolean
2894 elf64_alpha_size_got_sections (output_bfd, info)
2895 bfd *output_bfd ATTRIBUTE_UNUSED;
2896 struct bfd_link_info *info;
2897 {
2898 bfd *i, *got_list, *cur_got_obj = NULL;
2899 int something_changed = 0;
2900
2901 got_list = alpha_elf_hash_table (info)->got_list;
2902
2903 /* On the first time through, pretend we have an existing got list
2904 consisting of all of the input files. */
2905 if (got_list == NULL)
2906 {
2907 for (i = info->input_bfds; i ; i = i->link_next)
2908 {
2909 bfd *this_got = alpha_elf_tdata (i)->gotobj;
2910 if (this_got == NULL)
2911 continue;
2912
2913 /* We are assuming no merging has yet ocurred. */
2914 BFD_ASSERT (this_got == i);
2915
2916 if (alpha_elf_tdata (this_got)->total_got_entries > MAX_GOT_ENTRIES)
2917 {
2918 /* Yikes! A single object file has too many entries. */
2919 (*_bfd_error_handler)
2920 (_("%s: .got subsegment exceeds 64K (size %d)"),
2921 bfd_get_filename (i),
2922 alpha_elf_tdata (this_got)->total_got_entries * 8);
2923 return false;
2924 }
2925
2926 if (got_list == NULL)
2927 got_list = this_got;
2928 else
2929 alpha_elf_tdata(cur_got_obj)->got_link_next = this_got;
2930 cur_got_obj = this_got;
2931 }
2932
2933 /* Strange degenerate case of no got references. */
2934 if (got_list == NULL)
2935 return true;
2936
2937 alpha_elf_hash_table (info)->got_list = got_list;
2938
2939 /* Force got offsets to be recalculated. */
2940 something_changed = 1;
2941 }
2942
2943 cur_got_obj = got_list;
2944 i = alpha_elf_tdata(cur_got_obj)->got_link_next;
2945 while (i != NULL)
2946 {
2947 if (elf64_alpha_can_merge_gots (cur_got_obj, i))
2948 {
2949 elf64_alpha_merge_gots (cur_got_obj, i);
2950 i = alpha_elf_tdata(i)->got_link_next;
2951 alpha_elf_tdata(cur_got_obj)->got_link_next = i;
2952 something_changed = 1;
2953 }
2954 else
2955 {
2956 cur_got_obj = i;
2957 i = alpha_elf_tdata(i)->got_link_next;
2958 }
2959 }
2960
2961 /* Once the gots have been merged, fill in the got offsets for
2962 everything therein. */
2963 if (1 || something_changed)
2964 elf64_alpha_calc_got_offsets (info);
2965
2966 return true;
2967 }
2968
2969 static boolean
2970 elf64_alpha_always_size_sections (output_bfd, info)
2971 bfd *output_bfd;
2972 struct bfd_link_info *info;
2973 {
2974 bfd *i;
2975
2976 if (info->relocateable)
2977 return true;
2978
2979 /* First, take care of the indirect symbols created by versioning. */
2980 alpha_elf_link_hash_traverse (alpha_elf_hash_table (info),
2981 elf64_alpha_merge_ind_symbols,
2982 NULL);
2983
2984 if (!elf64_alpha_size_got_sections (output_bfd, info))
2985 return false;
2986
2987 /* Allocate space for all of the .got subsections. */
2988 i = alpha_elf_hash_table (info)->got_list;
2989 for ( ; i ; i = alpha_elf_tdata(i)->got_link_next)
2990 {
2991 asection *s = alpha_elf_tdata(i)->got;
2992 if (s->_raw_size > 0)
2993 {
2994 s->contents = (bfd_byte *) bfd_zalloc (i, s->_raw_size);
2995 if (s->contents == NULL)
2996 return false;
2997 }
2998 }
2999
3000 return true;
3001 }
3002
3003 /* Work out the sizes of the dynamic relocation entries. */
3004
3005 static boolean
3006 elf64_alpha_calc_dynrel_sizes (h, info)
3007 struct alpha_elf_link_hash_entry *h;
3008 struct bfd_link_info *info;
3009 {
3010 /* If the symbol was defined as a common symbol in a regular object
3011 file, and there was no definition in any dynamic object, then the
3012 linker will have allocated space for the symbol in a common
3013 section but the ELF_LINK_HASH_DEF_REGULAR flag will not have been
3014 set. This is done for dynamic symbols in
3015 elf_adjust_dynamic_symbol but this is not done for non-dynamic
3016 symbols, somehow. */
3017 if (((h->root.elf_link_hash_flags
3018 & (ELF_LINK_HASH_DEF_REGULAR
3019 | ELF_LINK_HASH_REF_REGULAR
3020 | ELF_LINK_HASH_DEF_DYNAMIC))
3021 == ELF_LINK_HASH_REF_REGULAR)
3022 && (h->root.root.type == bfd_link_hash_defined
3023 || h->root.root.type == bfd_link_hash_defweak)
3024 && !(h->root.root.u.def.section->owner->flags & DYNAMIC))
3025 {
3026 h->root.elf_link_hash_flags |= ELF_LINK_HASH_DEF_REGULAR;
3027 }
3028
3029 /* If the symbol is dynamic, we'll need all the relocations in their
3030 natural form. If this is a shared object, and it has been forced
3031 local, we'll need the same number of RELATIVE relocations. */
3032
3033 if (alpha_elf_dynamic_symbol_p (&h->root, info) || info->shared)
3034 {
3035 struct alpha_elf_reloc_entry *relent;
3036 bfd *dynobj;
3037 struct alpha_elf_got_entry *gotent;
3038 bfd_size_type count;
3039 asection *srel;
3040
3041 for (relent = h->reloc_entries; relent; relent = relent->next)
3042 if (relent->rtype == R_ALPHA_REFLONG
3043 || relent->rtype == R_ALPHA_REFQUAD)
3044 {
3045 relent->srel->_raw_size +=
3046 sizeof (Elf64_External_Rela) * relent->count;
3047 if (relent->reltext)
3048 info->flags |= DT_TEXTREL;
3049 }
3050
3051 dynobj = elf_hash_table(info)->dynobj;
3052 count = 0;
3053
3054 for (gotent = h->got_entries; gotent ; gotent = gotent->next)
3055 count++;
3056
3057 /* If we are using a .plt entry, subtract one, as the first
3058 reference uses a .rela.plt entry instead. */
3059 if (h->root.plt.offset != MINUS_ONE)
3060 count--;
3061
3062 if (count > 0)
3063 {
3064 srel = bfd_get_section_by_name (dynobj, ".rela.got");
3065 BFD_ASSERT (srel != NULL);
3066 srel->_raw_size += sizeof (Elf64_External_Rela) * count;
3067 }
3068 }
3069
3070 return true;
3071 }
3072
3073 /* Set the sizes of the dynamic sections. */
3074
3075 static boolean
3076 elf64_alpha_size_dynamic_sections (output_bfd, info)
3077 bfd *output_bfd ATTRIBUTE_UNUSED;
3078 struct bfd_link_info *info;
3079 {
3080 bfd *dynobj;
3081 asection *s;
3082 boolean relplt;
3083
3084 dynobj = elf_hash_table(info)->dynobj;
3085 BFD_ASSERT(dynobj != NULL);
3086
3087 if (elf_hash_table (info)->dynamic_sections_created)
3088 {
3089 /* Set the contents of the .interp section to the interpreter. */
3090 if (!info->shared)
3091 {
3092 s = bfd_get_section_by_name (dynobj, ".interp");
3093 BFD_ASSERT (s != NULL);
3094 s->_raw_size = sizeof ELF_DYNAMIC_INTERPRETER;
3095 s->contents = (unsigned char *) ELF_DYNAMIC_INTERPRETER;
3096 }
3097
3098 /* Now that we've seen all of the input files, we can decide which
3099 symbols need dynamic relocation entries and which don't. We've
3100 collected information in check_relocs that we can now apply to
3101 size the dynamic relocation sections. */
3102 alpha_elf_link_hash_traverse (alpha_elf_hash_table (info),
3103 elf64_alpha_calc_dynrel_sizes,
3104 info);
3105
3106 /* When building shared libraries, each local .got entry needs a
3107 RELATIVE reloc. */
3108 if (info->shared)
3109 {
3110 bfd *i;
3111 asection *srel;
3112 bfd_size_type count;
3113
3114 srel = bfd_get_section_by_name (dynobj, ".rela.got");
3115 BFD_ASSERT (srel != NULL);
3116
3117 for (i = alpha_elf_hash_table(info)->got_list, count = 0;
3118 i != NULL;
3119 i = alpha_elf_tdata(i)->got_link_next)
3120 count += alpha_elf_tdata(i)->n_local_got_entries;
3121
3122 srel->_raw_size += count * sizeof (Elf64_External_Rela);
3123 }
3124 }
3125 /* else we're not dynamic and by definition we don't need such things. */
3126
3127 /* The check_relocs and adjust_dynamic_symbol entry points have
3128 determined the sizes of the various dynamic sections. Allocate
3129 memory for them. */
3130 relplt = false;
3131 for (s = dynobj->sections; s != NULL; s = s->next)
3132 {
3133 const char *name;
3134 boolean strip;
3135
3136 if (!(s->flags & SEC_LINKER_CREATED))
3137 continue;
3138
3139 /* It's OK to base decisions on the section name, because none
3140 of the dynobj section names depend upon the input files. */
3141 name = bfd_get_section_name (dynobj, s);
3142
3143 /* If we don't need this section, strip it from the output file.
3144 This is to handle .rela.bss and .rela.plt. We must create it
3145 in create_dynamic_sections, because it must be created before
3146 the linker maps input sections to output sections. The
3147 linker does that before adjust_dynamic_symbol is called, and
3148 it is that function which decides whether anything needs to
3149 go into these sections. */
3150
3151 strip = false;
3152
3153 if (strncmp (name, ".rela", 5) == 0)
3154 {
3155 strip = (s->_raw_size == 0);
3156
3157 if (!strip)
3158 {
3159 if (strcmp(name, ".rela.plt") == 0)
3160 relplt = true;
3161
3162 /* We use the reloc_count field as a counter if we need
3163 to copy relocs into the output file. */
3164 s->reloc_count = 0;
3165 }
3166 }
3167 else if (strcmp (name, ".plt") != 0)
3168 {
3169 /* It's not one of our dynamic sections, so don't allocate space. */
3170 continue;
3171 }
3172
3173 if (strip)
3174 _bfd_strip_section_from_output (info, s);
3175 else
3176 {
3177 /* Allocate memory for the section contents. */
3178 s->contents = (bfd_byte *) bfd_zalloc(dynobj, s->_raw_size);
3179 if (s->contents == NULL && s->_raw_size != 0)
3180 return false;
3181 }
3182 }
3183
3184 if (elf_hash_table (info)->dynamic_sections_created)
3185 {
3186 /* Add some entries to the .dynamic section. We fill in the
3187 values later, in elf64_alpha_finish_dynamic_sections, but we
3188 must add the entries now so that we get the correct size for
3189 the .dynamic section. The DT_DEBUG entry is filled in by the
3190 dynamic linker and used by the debugger. */
3191 if (!info->shared)
3192 {
3193 if (!bfd_elf64_add_dynamic_entry (info, DT_DEBUG, 0))
3194 return false;
3195 }
3196
3197 if (! bfd_elf64_add_dynamic_entry (info, DT_PLTGOT, 0))
3198 return false;
3199
3200 if (relplt)
3201 {
3202 if (! bfd_elf64_add_dynamic_entry (info, DT_PLTRELSZ, 0)
3203 || ! bfd_elf64_add_dynamic_entry (info, DT_PLTREL, DT_RELA)
3204 || ! bfd_elf64_add_dynamic_entry (info, DT_JMPREL, 0))
3205 return false;
3206 }
3207
3208 if (! bfd_elf64_add_dynamic_entry (info, DT_RELA, 0)
3209 || ! bfd_elf64_add_dynamic_entry (info, DT_RELASZ, 0)
3210 || ! bfd_elf64_add_dynamic_entry (info, DT_RELAENT,
3211 sizeof (Elf64_External_Rela)))
3212 return false;
3213
3214 if (info->flags & DF_TEXTREL)
3215 {
3216 if (! bfd_elf64_add_dynamic_entry (info, DT_TEXTREL, 0))
3217 return false;
3218 }
3219 }
3220
3221 return true;
3222 }
3223
3224 /* Relocate an Alpha ELF section. */
3225
3226 static boolean
3227 elf64_alpha_relocate_section (output_bfd, info, input_bfd, input_section,
3228 contents, relocs, local_syms, local_sections)
3229 bfd *output_bfd;
3230 struct bfd_link_info *info;
3231 bfd *input_bfd;
3232 asection *input_section;
3233 bfd_byte *contents;
3234 Elf_Internal_Rela *relocs;
3235 Elf_Internal_Sym *local_syms;
3236 asection **local_sections;
3237 {
3238 Elf_Internal_Shdr *symtab_hdr;
3239 Elf_Internal_Rela *rel;
3240 Elf_Internal_Rela *relend;
3241 asection *sec, *sgot, *srel, *srelgot;
3242 bfd *dynobj, *gotobj;
3243 bfd_vma gp;
3244
3245 srelgot = srel = NULL;
3246 symtab_hdr = &elf_tdata (input_bfd)->symtab_hdr;
3247 dynobj = elf_hash_table (info)->dynobj;
3248 if (dynobj)
3249 {
3250 srelgot = bfd_get_section_by_name (dynobj, ".rela.got");
3251 }
3252
3253 /* Find the gp value for this input bfd. */
3254 sgot = NULL;
3255 gp = 0;
3256 gotobj = alpha_elf_tdata (input_bfd)->gotobj;
3257 if (gotobj)
3258 {
3259 sgot = alpha_elf_tdata (gotobj)->got;
3260 gp = _bfd_get_gp_value (gotobj);
3261 if (gp == 0)
3262 {
3263 gp = (sgot->output_section->vma
3264 + sgot->output_offset
3265 + 0x8000);
3266 _bfd_set_gp_value (gotobj, gp);
3267 }
3268 }
3269
3270 rel = relocs;
3271 relend = relocs + input_section->reloc_count;
3272 for (; rel < relend; rel++)
3273 {
3274 int r_type;
3275 reloc_howto_type *howto;
3276 unsigned long r_symndx;
3277 struct alpha_elf_link_hash_entry *h;
3278 Elf_Internal_Sym *sym;
3279 bfd_vma relocation;
3280 bfd_signed_vma addend;
3281 bfd_reloc_status_type r;
3282
3283 r_type = ELF64_R_TYPE(rel->r_info);
3284 if (r_type < 0 || r_type >= (int) R_ALPHA_max)
3285 {
3286 bfd_set_error (bfd_error_bad_value);
3287 return false;
3288 }
3289 howto = elf64_alpha_howto_table + r_type;
3290
3291 r_symndx = ELF64_R_SYM(rel->r_info);
3292
3293 if (info->relocateable)
3294 {
3295 /* This is a relocateable link. We don't have to change
3296 anything, unless the reloc is against a section symbol,
3297 in which case we have to adjust according to where the
3298 section symbol winds up in the output section. */
3299
3300 /* The symbol associated with GPDISP and LITUSE is
3301 immaterial. Only the addend is significant. */
3302 if (r_type == R_ALPHA_GPDISP || r_type == R_ALPHA_LITUSE)
3303 continue;
3304
3305 if (r_symndx < symtab_hdr->sh_info)
3306 {
3307 sym = local_syms + r_symndx;
3308 if (ELF_ST_TYPE(sym->st_info) == STT_SECTION)
3309 {
3310 sec = local_sections[r_symndx];
3311 rel->r_addend += sec->output_offset + sym->st_value;
3312 }
3313 }
3314
3315 continue;
3316 }
3317
3318 /* This is a final link. */
3319
3320 h = NULL;
3321 sym = NULL;
3322 sec = NULL;
3323
3324 if (r_symndx < symtab_hdr->sh_info)
3325 {
3326 sym = local_syms + r_symndx;
3327 sec = local_sections[r_symndx];
3328 relocation = (sec->output_section->vma
3329 + sec->output_offset
3330 + sym->st_value);
3331 }
3332 else
3333 {
3334 h = alpha_elf_sym_hashes (input_bfd)[r_symndx - symtab_hdr->sh_info];
3335
3336 while (h->root.root.type == bfd_link_hash_indirect
3337 || h->root.root.type == bfd_link_hash_warning)
3338 h = (struct alpha_elf_link_hash_entry *)h->root.root.u.i.link;
3339
3340 if (h->root.root.type == bfd_link_hash_defined
3341 || h->root.root.type == bfd_link_hash_defweak)
3342 {
3343 sec = h->root.root.u.def.section;
3344
3345 #if rth_notdef
3346 if ((r_type == R_ALPHA_LITERAL
3347 && elf_hash_table(info)->dynamic_sections_created
3348 && (!info->shared
3349 || !info->symbolic
3350 || !(h->root.elf_link_hash_flags
3351 & ELF_LINK_HASH_DEF_REGULAR)))
3352 || (info->shared
3353 && (!info->symbolic
3354 || !(h->root.elf_link_hash_flags
3355 & ELF_LINK_HASH_DEF_REGULAR))
3356 && (input_section->flags & SEC_ALLOC)
3357 && (r_type == R_ALPHA_REFLONG
3358 || r_type == R_ALPHA_REFQUAD
3359 || r_type == R_ALPHA_LITERAL)))
3360 {
3361 /* In these cases, we don't need the relocation value.
3362 We check specially because in some obscure cases
3363 sec->output_section will be NULL. */
3364 relocation = 0;
3365 }
3366 #else
3367 /* FIXME: Are not these obscure cases simply bugs? Let's
3368 get something working and come back to this. */
3369 if (sec->output_section == NULL)
3370 relocation = 0;
3371 #endif /* rth_notdef */
3372 else
3373 {
3374 relocation = (h->root.root.u.def.value
3375 + sec->output_section->vma
3376 + sec->output_offset);
3377 }
3378 }
3379 else if (h->root.root.type == bfd_link_hash_undefweak)
3380 relocation = 0;
3381 else if (info->shared && !info->symbolic
3382 && !info->no_undefined
3383 && ELF_ST_VISIBILITY (h->root.other) == STV_DEFAULT)
3384 relocation = 0;
3385 else
3386 {
3387 if (!((*info->callbacks->undefined_symbol)
3388 (info, h->root.root.root.string, input_bfd,
3389 input_section, rel->r_offset,
3390 (!info->shared || info->no_undefined
3391 || ELF_ST_VISIBILITY (h->root.other)))))
3392 return false;
3393 relocation = 0;
3394 }
3395 }
3396 addend = rel->r_addend;
3397
3398 switch (r_type)
3399 {
3400 case R_ALPHA_GPDISP:
3401 {
3402 bfd_byte *p_ldah, *p_lda;
3403
3404 BFD_ASSERT(gp != 0);
3405
3406 relocation = (input_section->output_section->vma
3407 + input_section->output_offset
3408 + rel->r_offset);
3409
3410 p_ldah = contents + rel->r_offset - input_section->vma;
3411 p_lda = p_ldah + rel->r_addend;
3412
3413 r = elf64_alpha_do_reloc_gpdisp (input_bfd, gp - relocation,
3414 p_ldah, p_lda);
3415 }
3416 break;
3417
3418 case R_ALPHA_LITERAL:
3419 {
3420 struct alpha_elf_got_entry *gotent;
3421 boolean dynamic_symbol;
3422
3423 BFD_ASSERT(sgot != NULL);
3424 BFD_ASSERT(gp != 0);
3425
3426 if (h != NULL)
3427 {
3428 gotent = h->got_entries;
3429 dynamic_symbol = alpha_elf_dynamic_symbol_p (&h->root, info);
3430 }
3431 else
3432 {
3433 gotent = (alpha_elf_tdata(input_bfd)->
3434 local_got_entries[r_symndx]);
3435 dynamic_symbol = false;
3436 }
3437
3438 BFD_ASSERT(gotent != NULL);
3439
3440 while (gotent->gotobj != gotobj || gotent->addend != addend)
3441 gotent = gotent->next;
3442
3443 BFD_ASSERT(gotent->use_count >= 1);
3444
3445 /* Initialize the .got entry's value. */
3446 if (!(gotent->flags & ALPHA_ELF_GOT_ENTRY_RELOCS_DONE))
3447 {
3448 bfd_put_64 (output_bfd, relocation+addend,
3449 sgot->contents + gotent->got_offset);
3450
3451 /* If the symbol has been forced local, output a
3452 RELATIVE reloc, otherwise it will be handled in
3453 finish_dynamic_symbol. */
3454 if (info->shared && !dynamic_symbol)
3455 {
3456 Elf_Internal_Rela outrel;
3457
3458 BFD_ASSERT(srelgot != NULL);
3459
3460 outrel.r_offset = (sgot->output_section->vma
3461 + sgot->output_offset
3462 + gotent->got_offset);
3463 outrel.r_info = ELF64_R_INFO(0, R_ALPHA_RELATIVE);
3464 outrel.r_addend = relocation+addend;
3465
3466 bfd_elf64_swap_reloca_out (output_bfd, &outrel,
3467 ((Elf64_External_Rela *)
3468 srelgot->contents)
3469 + srelgot->reloc_count++);
3470 BFD_ASSERT (sizeof (Elf64_External_Rela)
3471 * srelgot->reloc_count
3472 <= srelgot->_cooked_size);
3473 }
3474
3475 gotent->flags |= ALPHA_ELF_GOT_ENTRY_RELOCS_DONE;
3476 }
3477
3478 /* Figure the gprel relocation. */
3479 addend = 0;
3480 relocation = (sgot->output_section->vma
3481 + sgot->output_offset
3482 + gotent->got_offset);
3483 relocation -= gp;
3484 }
3485 /* overflow handled by _bfd_final_link_relocate */
3486 goto default_reloc;
3487
3488 case R_ALPHA_GPREL16:
3489 case R_ALPHA_GPREL32:
3490 case R_ALPHA_GPRELLOW:
3491 BFD_ASSERT(gp != 0);
3492 relocation -= gp;
3493 goto default_reloc;
3494
3495 case R_ALPHA_GPRELHIGH:
3496 BFD_ASSERT(gp != 0);
3497 relocation -= gp;
3498 relocation += addend;
3499 addend = 0;
3500 relocation = (((bfd_signed_vma) relocation >> 16)
3501 + ((relocation >> 15) & 1));
3502 goto default_reloc;
3503
3504 case R_ALPHA_BRADDR:
3505 case R_ALPHA_HINT:
3506 /* The regular PC-relative stuff measures from the start of
3507 the instruction rather than the end. */
3508 addend -= 4;
3509 goto default_reloc;
3510
3511 case R_ALPHA_REFLONG:
3512 case R_ALPHA_REFQUAD:
3513 {
3514 Elf_Internal_Rela outrel;
3515 boolean skip;
3516
3517 /* Careful here to remember RELATIVE relocations for global
3518 variables for symbolic shared objects. */
3519
3520 if (h && alpha_elf_dynamic_symbol_p (&h->root, info))
3521 {
3522 BFD_ASSERT(h->root.dynindx != -1);
3523 outrel.r_info = ELF64_R_INFO(h->root.dynindx, r_type);
3524 outrel.r_addend = addend;
3525 addend = 0, relocation = 0;
3526 }
3527 else if (info->shared && (input_section->flags & SEC_ALLOC))
3528 {
3529 outrel.r_info = ELF64_R_INFO(0, R_ALPHA_RELATIVE);
3530 outrel.r_addend = relocation + addend;
3531 }
3532 else
3533 goto default_reloc;
3534
3535 if (!srel)
3536 {
3537 const char *name;
3538
3539 name = (bfd_elf_string_from_elf_section
3540 (input_bfd, elf_elfheader(input_bfd)->e_shstrndx,
3541 elf_section_data(input_section)->rel_hdr.sh_name));
3542 BFD_ASSERT(name != NULL);
3543
3544 srel = bfd_get_section_by_name (dynobj, name);
3545 BFD_ASSERT(srel != NULL);
3546 }
3547
3548 skip = false;
3549
3550 if (elf_section_data (input_section)->stab_info == NULL)
3551 outrel.r_offset = rel->r_offset;
3552 else
3553 {
3554 bfd_vma off;
3555
3556 off = (_bfd_stab_section_offset
3557 (output_bfd, &elf_hash_table (info)->stab_info,
3558 input_section,
3559 &elf_section_data (input_section)->stab_info,
3560 rel->r_offset));
3561 if (off == (bfd_vma) -1)
3562 skip = true;
3563 outrel.r_offset = off;
3564 }
3565
3566 if (! skip)
3567 outrel.r_offset += (input_section->output_section->vma
3568 + input_section->output_offset);
3569 else
3570 memset (&outrel, 0, sizeof outrel);
3571
3572 bfd_elf64_swap_reloca_out (output_bfd, &outrel,
3573 ((Elf64_External_Rela *)
3574 srel->contents)
3575 + srel->reloc_count++);
3576 BFD_ASSERT (sizeof (Elf64_External_Rela) * srel->reloc_count
3577 <= srel->_cooked_size);
3578 }
3579 goto default_reloc;
3580
3581 default:
3582 default_reloc:
3583 r = _bfd_final_link_relocate (howto, input_bfd, input_section,
3584 contents, rel->r_offset, relocation,
3585 addend);
3586 break;
3587 }
3588
3589 switch (r)
3590 {
3591 case bfd_reloc_ok:
3592 break;
3593
3594 case bfd_reloc_overflow:
3595 {
3596 const char *name;
3597
3598 if (h != NULL)
3599 name = h->root.root.root.string;
3600 else
3601 {
3602 name = (bfd_elf_string_from_elf_section
3603 (input_bfd, symtab_hdr->sh_link, sym->st_name));
3604 if (name == NULL)
3605 return false;
3606 if (*name == '\0')
3607 name = bfd_section_name (input_bfd, sec);
3608 }
3609 if (! ((*info->callbacks->reloc_overflow)
3610 (info, name, howto->name, (bfd_vma) 0,
3611 input_bfd, input_section, rel->r_offset)))
3612 return false;
3613 }
3614 break;
3615
3616 default:
3617 case bfd_reloc_outofrange:
3618 abort ();
3619 }
3620 }
3621
3622 return true;
3623 }
3624
3625 /* Finish up dynamic symbol handling. We set the contents of various
3626 dynamic sections here. */
3627
3628 static boolean
3629 elf64_alpha_finish_dynamic_symbol (output_bfd, info, h, sym)
3630 bfd *output_bfd;
3631 struct bfd_link_info *info;
3632 struct elf_link_hash_entry *h;
3633 Elf_Internal_Sym *sym;
3634 {
3635 bfd *dynobj = elf_hash_table(info)->dynobj;
3636
3637 if (h->plt.offset != MINUS_ONE)
3638 {
3639 /* Fill in the .plt entry for this symbol. */
3640 asection *splt, *sgot, *srel;
3641 Elf_Internal_Rela outrel;
3642 bfd_vma got_addr, plt_addr;
3643 bfd_vma plt_index;
3644 struct alpha_elf_got_entry *gotent;
3645
3646 BFD_ASSERT (h->dynindx != -1);
3647
3648 /* The first .got entry will be updated by the .plt with the
3649 address of the target function. */
3650 gotent = ((struct alpha_elf_link_hash_entry *) h)->got_entries;
3651 BFD_ASSERT (gotent && gotent->addend == 0);
3652
3653 splt = bfd_get_section_by_name (dynobj, ".plt");
3654 BFD_ASSERT (splt != NULL);
3655 srel = bfd_get_section_by_name (dynobj, ".rela.plt");
3656 BFD_ASSERT (srel != NULL);
3657 sgot = alpha_elf_tdata (gotent->gotobj)->got;
3658 BFD_ASSERT (sgot != NULL);
3659
3660 got_addr = (sgot->output_section->vma
3661 + sgot->output_offset
3662 + gotent->got_offset);
3663 plt_addr = (splt->output_section->vma
3664 + splt->output_offset
3665 + h->plt.offset);
3666
3667 plt_index = (h->plt.offset - PLT_HEADER_SIZE) / PLT_ENTRY_SIZE;
3668
3669 /* Fill in the entry in the procedure linkage table. */
3670 {
3671 unsigned insn1, insn2, insn3;
3672
3673 insn1 = PLT_ENTRY_WORD1 | ((-(h->plt.offset + 4) >> 2) & 0x1fffff);
3674 insn2 = PLT_ENTRY_WORD2;
3675 insn3 = PLT_ENTRY_WORD3;
3676
3677 bfd_put_32 (output_bfd, insn1, splt->contents + h->plt.offset);
3678 bfd_put_32 (output_bfd, insn2, splt->contents + h->plt.offset + 4);
3679 bfd_put_32 (output_bfd, insn3, splt->contents + h->plt.offset + 8);
3680 }
3681
3682 /* Fill in the entry in the .rela.plt section. */
3683 outrel.r_offset = got_addr;
3684 outrel.r_info = ELF64_R_INFO(h->dynindx, R_ALPHA_JMP_SLOT);
3685 outrel.r_addend = 0;
3686
3687 bfd_elf64_swap_reloca_out (output_bfd, &outrel,
3688 ((Elf64_External_Rela *)srel->contents
3689 + plt_index));
3690
3691 if (!(h->elf_link_hash_flags & ELF_LINK_HASH_DEF_REGULAR))
3692 {
3693 /* Mark the symbol as undefined, rather than as defined in the
3694 .plt section. Leave the value alone. */
3695 sym->st_shndx = SHN_UNDEF;
3696 }
3697
3698 /* Fill in the entries in the .got. */
3699 bfd_put_64 (output_bfd, plt_addr, sgot->contents + gotent->got_offset);
3700
3701 /* Subsequent .got entries will continue to bounce through the .plt. */
3702 if (gotent->next)
3703 {
3704 srel = bfd_get_section_by_name (dynobj, ".rela.got");
3705 BFD_ASSERT (! info->shared || srel != NULL);
3706
3707 gotent = gotent->next;
3708 do
3709 {
3710 sgot = alpha_elf_tdata(gotent->gotobj)->got;
3711 BFD_ASSERT(sgot != NULL);
3712 BFD_ASSERT(gotent->addend == 0);
3713
3714 bfd_put_64 (output_bfd, plt_addr,
3715 sgot->contents + gotent->got_offset);
3716
3717 if (info->shared)
3718 {
3719 outrel.r_offset = (sgot->output_section->vma
3720 + sgot->output_offset
3721 + gotent->got_offset);
3722 outrel.r_info = ELF64_R_INFO(0, R_ALPHA_RELATIVE);
3723 outrel.r_addend = plt_addr;
3724
3725 bfd_elf64_swap_reloca_out (output_bfd, &outrel,
3726 ((Elf64_External_Rela *)
3727 srel->contents)
3728 + srel->reloc_count++);
3729 BFD_ASSERT (sizeof (Elf64_External_Rela) * srel->reloc_count
3730 <= srel->_cooked_size);
3731 }
3732
3733 gotent = gotent->next;
3734 }
3735 while (gotent != NULL);
3736 }
3737 }
3738 else if (alpha_elf_dynamic_symbol_p (h, info))
3739 {
3740 /* Fill in the dynamic relocations for this symbol's .got entries. */
3741 asection *srel;
3742 Elf_Internal_Rela outrel;
3743 struct alpha_elf_got_entry *gotent;
3744
3745 srel = bfd_get_section_by_name (dynobj, ".rela.got");
3746 BFD_ASSERT (srel != NULL);
3747
3748 outrel.r_info = ELF64_R_INFO (h->dynindx, R_ALPHA_GLOB_DAT);
3749 for (gotent = ((struct alpha_elf_link_hash_entry *) h)->got_entries;
3750 gotent != NULL;
3751 gotent = gotent->next)
3752 {
3753 asection *sgot = alpha_elf_tdata (gotent->gotobj)->got;
3754 outrel.r_offset = (sgot->output_section->vma
3755 + sgot->output_offset
3756 + gotent->got_offset);
3757 outrel.r_addend = gotent->addend;
3758
3759 bfd_elf64_swap_reloca_out (output_bfd, &outrel,
3760 ((Elf64_External_Rela *)srel->contents
3761 + srel->reloc_count++));
3762 BFD_ASSERT (sizeof (Elf64_External_Rela) * srel->reloc_count
3763 <= srel->_cooked_size);
3764 }
3765 }
3766
3767 /* Mark some specially defined symbols as absolute. */
3768 if (strcmp (h->root.root.string, "_DYNAMIC") == 0
3769 || strcmp (h->root.root.string, "_GLOBAL_OFFSET_TABLE_") == 0
3770 || strcmp (h->root.root.string, "_PROCEDURE_LINKAGE_TABLE_") == 0)
3771 sym->st_shndx = SHN_ABS;
3772
3773 return true;
3774 }
3775
3776 /* Finish up the dynamic sections. */
3777
3778 static boolean
3779 elf64_alpha_finish_dynamic_sections (output_bfd, info)
3780 bfd *output_bfd;
3781 struct bfd_link_info *info;
3782 {
3783 bfd *dynobj;
3784 asection *sdyn;
3785
3786 dynobj = elf_hash_table (info)->dynobj;
3787 sdyn = bfd_get_section_by_name (dynobj, ".dynamic");
3788
3789 if (elf_hash_table (info)->dynamic_sections_created)
3790 {
3791 asection *splt;
3792 Elf64_External_Dyn *dyncon, *dynconend;
3793
3794 splt = bfd_get_section_by_name (dynobj, ".plt");
3795 BFD_ASSERT (splt != NULL && sdyn != NULL);
3796
3797 dyncon = (Elf64_External_Dyn *) sdyn->contents;
3798 dynconend = (Elf64_External_Dyn *) (sdyn->contents + sdyn->_raw_size);
3799 for (; dyncon < dynconend; dyncon++)
3800 {
3801 Elf_Internal_Dyn dyn;
3802 const char *name;
3803 asection *s;
3804
3805 bfd_elf64_swap_dyn_in (dynobj, dyncon, &dyn);
3806
3807 switch (dyn.d_tag)
3808 {
3809 case DT_PLTGOT:
3810 name = ".plt";
3811 goto get_vma;
3812 case DT_PLTRELSZ:
3813 name = ".rela.plt";
3814 goto get_size;
3815 case DT_JMPREL:
3816 name = ".rela.plt";
3817 goto get_vma;
3818
3819 case DT_RELASZ:
3820 /* My interpretation of the TIS v1.1 ELF document indicates
3821 that RELASZ should not include JMPREL. This is not what
3822 the rest of the BFD does. It is, however, what the
3823 glibc ld.so wants. Do this fixup here until we found
3824 out who is right. */
3825 s = bfd_get_section_by_name (output_bfd, ".rela.plt");
3826 if (s)
3827 {
3828 dyn.d_un.d_val -=
3829 (s->_cooked_size ? s->_cooked_size : s->_raw_size);
3830 }
3831 break;
3832
3833 get_vma:
3834 s = bfd_get_section_by_name (output_bfd, name);
3835 dyn.d_un.d_ptr = (s ? s->vma : 0);
3836 break;
3837
3838 get_size:
3839 s = bfd_get_section_by_name (output_bfd, name);
3840 dyn.d_un.d_val =
3841 (s->_cooked_size ? s->_cooked_size : s->_raw_size);
3842 break;
3843 }
3844
3845 bfd_elf64_swap_dyn_out (output_bfd, &dyn, dyncon);
3846 }
3847
3848 /* Initialize the PLT0 entry */
3849 if (splt->_raw_size > 0)
3850 {
3851 bfd_put_32 (output_bfd, PLT_HEADER_WORD1, splt->contents);
3852 bfd_put_32 (output_bfd, PLT_HEADER_WORD2, splt->contents + 4);
3853 bfd_put_32 (output_bfd, PLT_HEADER_WORD3, splt->contents + 8);
3854 bfd_put_32 (output_bfd, PLT_HEADER_WORD4, splt->contents + 12);
3855
3856 /* The next two words will be filled in by ld.so */
3857 bfd_put_64 (output_bfd, 0, splt->contents + 16);
3858 bfd_put_64 (output_bfd, 0, splt->contents + 24);
3859
3860 elf_section_data (splt->output_section)->this_hdr.sh_entsize =
3861 PLT_HEADER_SIZE;
3862 }
3863 }
3864
3865 return true;
3866 }
3867
3868 /* We need to use a special link routine to handle the .reginfo and
3869 the .mdebug sections. We need to merge all instances of these
3870 sections together, not write them all out sequentially. */
3871
3872 static boolean
3873 elf64_alpha_final_link (abfd, info)
3874 bfd *abfd;
3875 struct bfd_link_info *info;
3876 {
3877 asection *o;
3878 struct bfd_link_order *p;
3879 asection *reginfo_sec, *mdebug_sec, *gptab_data_sec, *gptab_bss_sec;
3880 struct ecoff_debug_info debug;
3881 const struct ecoff_debug_swap *swap
3882 = get_elf_backend_data (abfd)->elf_backend_ecoff_debug_swap;
3883 HDRR *symhdr = &debug.symbolic_header;
3884 PTR mdebug_handle = NULL;
3885
3886 #if 0
3887 if (++ngots == 2)
3888 {
3889 (*info->callbacks->warning)
3890 (info, _("using multiple gp values"), (char *) NULL,
3891 output_bfd, (asection *) NULL, (bfd_vma) 0);
3892 }
3893 #endif
3894
3895 /* Go through the sections and collect the .reginfo and .mdebug
3896 information. */
3897 reginfo_sec = NULL;
3898 mdebug_sec = NULL;
3899 gptab_data_sec = NULL;
3900 gptab_bss_sec = NULL;
3901 for (o = abfd->sections; o != (asection *) NULL; o = o->next)
3902 {
3903 #ifdef ERIC_neverdef
3904 if (strcmp (o->name, ".reginfo") == 0)
3905 {
3906 memset (&reginfo, 0, sizeof reginfo);
3907
3908 /* We have found the .reginfo section in the output file.
3909 Look through all the link_orders comprising it and merge
3910 the information together. */
3911 for (p = o->link_order_head;
3912 p != (struct bfd_link_order *) NULL;
3913 p = p->next)
3914 {
3915 asection *input_section;
3916 bfd *input_bfd;
3917 Elf64_External_RegInfo ext;
3918 Elf64_RegInfo sub;
3919
3920 if (p->type != bfd_indirect_link_order)
3921 {
3922 if (p->type == bfd_fill_link_order)
3923 continue;
3924 abort ();
3925 }
3926
3927 input_section = p->u.indirect.section;
3928 input_bfd = input_section->owner;
3929
3930 /* The linker emulation code has probably clobbered the
3931 size to be zero bytes. */
3932 if (input_section->_raw_size == 0)
3933 input_section->_raw_size = sizeof (Elf64_External_RegInfo);
3934
3935 if (! bfd_get_section_contents (input_bfd, input_section,
3936 (PTR) &ext,
3937 (file_ptr) 0,
3938 sizeof ext))
3939 return false;
3940
3941 bfd_alpha_elf64_swap_reginfo_in (input_bfd, &ext, &sub);
3942
3943 reginfo.ri_gprmask |= sub.ri_gprmask;
3944 reginfo.ri_cprmask[0] |= sub.ri_cprmask[0];
3945 reginfo.ri_cprmask[1] |= sub.ri_cprmask[1];
3946 reginfo.ri_cprmask[2] |= sub.ri_cprmask[2];
3947 reginfo.ri_cprmask[3] |= sub.ri_cprmask[3];
3948
3949 /* ri_gp_value is set by the function
3950 alpha_elf_section_processing when the section is
3951 finally written out. */
3952
3953 /* Hack: reset the SEC_HAS_CONTENTS flag so that
3954 elf_link_input_bfd ignores this section. */
3955 input_section->flags &=~ SEC_HAS_CONTENTS;
3956 }
3957
3958 /* Force the section size to the value we want. */
3959 o->_raw_size = sizeof (Elf64_External_RegInfo);
3960
3961 /* Skip this section later on (I don't think this currently
3962 matters, but someday it might). */
3963 o->link_order_head = (struct bfd_link_order *) NULL;
3964
3965 reginfo_sec = o;
3966 }
3967 #endif
3968
3969 if (strcmp (o->name, ".mdebug") == 0)
3970 {
3971 struct extsym_info einfo;
3972
3973 /* We have found the .mdebug section in the output file.
3974 Look through all the link_orders comprising it and merge
3975 the information together. */
3976 symhdr->magic = swap->sym_magic;
3977 /* FIXME: What should the version stamp be? */
3978 symhdr->vstamp = 0;
3979 symhdr->ilineMax = 0;
3980 symhdr->cbLine = 0;
3981 symhdr->idnMax = 0;
3982 symhdr->ipdMax = 0;
3983 symhdr->isymMax = 0;
3984 symhdr->ioptMax = 0;
3985 symhdr->iauxMax = 0;
3986 symhdr->issMax = 0;
3987 symhdr->issExtMax = 0;
3988 symhdr->ifdMax = 0;
3989 symhdr->crfd = 0;
3990 symhdr->iextMax = 0;
3991
3992 /* We accumulate the debugging information itself in the
3993 debug_info structure. */
3994 debug.line = NULL;
3995 debug.external_dnr = NULL;
3996 debug.external_pdr = NULL;
3997 debug.external_sym = NULL;
3998 debug.external_opt = NULL;
3999 debug.external_aux = NULL;
4000 debug.ss = NULL;
4001 debug.ssext = debug.ssext_end = NULL;
4002 debug.external_fdr = NULL;
4003 debug.external_rfd = NULL;
4004 debug.external_ext = debug.external_ext_end = NULL;
4005
4006 mdebug_handle = bfd_ecoff_debug_init (abfd, &debug, swap, info);
4007 if (mdebug_handle == (PTR) NULL)
4008 return false;
4009
4010 if (1)
4011 {
4012 asection *s;
4013 EXTR esym;
4014 bfd_vma last = 0;
4015 unsigned int i;
4016 static const char * const name[] =
4017 {
4018 ".text", ".init", ".fini", ".data",
4019 ".rodata", ".sdata", ".sbss", ".bss"
4020 };
4021 static const int sc[] = { scText, scInit, scFini, scData,
4022 scRData, scSData, scSBss, scBss };
4023
4024 esym.jmptbl = 0;
4025 esym.cobol_main = 0;
4026 esym.weakext = 0;
4027 esym.reserved = 0;
4028 esym.ifd = ifdNil;
4029 esym.asym.iss = issNil;
4030 esym.asym.st = stLocal;
4031 esym.asym.reserved = 0;
4032 esym.asym.index = indexNil;
4033 for (i = 0; i < 8; i++)
4034 {
4035 esym.asym.sc = sc[i];
4036 s = bfd_get_section_by_name (abfd, name[i]);
4037 if (s != NULL)
4038 {
4039 esym.asym.value = s->vma;
4040 last = s->vma + s->_raw_size;
4041 }
4042 else
4043 esym.asym.value = last;
4044
4045 if (! bfd_ecoff_debug_one_external (abfd, &debug, swap,
4046 name[i], &esym))
4047 return false;
4048 }
4049 }
4050
4051 for (p = o->link_order_head;
4052 p != (struct bfd_link_order *) NULL;
4053 p = p->next)
4054 {
4055 asection *input_section;
4056 bfd *input_bfd;
4057 const struct ecoff_debug_swap *input_swap;
4058 struct ecoff_debug_info input_debug;
4059 char *eraw_src;
4060 char *eraw_end;
4061
4062 if (p->type != bfd_indirect_link_order)
4063 {
4064 if (p->type == bfd_fill_link_order)
4065 continue;
4066 abort ();
4067 }
4068
4069 input_section = p->u.indirect.section;
4070 input_bfd = input_section->owner;
4071
4072 if (bfd_get_flavour (input_bfd) != bfd_target_elf_flavour
4073 || (get_elf_backend_data (input_bfd)
4074 ->elf_backend_ecoff_debug_swap) == NULL)
4075 {
4076 /* I don't know what a non ALPHA ELF bfd would be
4077 doing with a .mdebug section, but I don't really
4078 want to deal with it. */
4079 continue;
4080 }
4081
4082 input_swap = (get_elf_backend_data (input_bfd)
4083 ->elf_backend_ecoff_debug_swap);
4084
4085 BFD_ASSERT (p->size == input_section->_raw_size);
4086
4087 /* The ECOFF linking code expects that we have already
4088 read in the debugging information and set up an
4089 ecoff_debug_info structure, so we do that now. */
4090 if (!elf64_alpha_read_ecoff_info (input_bfd, input_section,
4091 &input_debug))
4092 return false;
4093
4094 if (! (bfd_ecoff_debug_accumulate
4095 (mdebug_handle, abfd, &debug, swap, input_bfd,
4096 &input_debug, input_swap, info)))
4097 return false;
4098
4099 /* Loop through the external symbols. For each one with
4100 interesting information, try to find the symbol in
4101 the linker global hash table and save the information
4102 for the output external symbols. */
4103 eraw_src = input_debug.external_ext;
4104 eraw_end = (eraw_src
4105 + (input_debug.symbolic_header.iextMax
4106 * input_swap->external_ext_size));
4107 for (;
4108 eraw_src < eraw_end;
4109 eraw_src += input_swap->external_ext_size)
4110 {
4111 EXTR ext;
4112 const char *name;
4113 struct alpha_elf_link_hash_entry *h;
4114
4115 (*input_swap->swap_ext_in) (input_bfd, (PTR) eraw_src, &ext);
4116 if (ext.asym.sc == scNil
4117 || ext.asym.sc == scUndefined
4118 || ext.asym.sc == scSUndefined)
4119 continue;
4120
4121 name = input_debug.ssext + ext.asym.iss;
4122 h = alpha_elf_link_hash_lookup (alpha_elf_hash_table (info),
4123 name, false, false, true);
4124 if (h == NULL || h->esym.ifd != -2)
4125 continue;
4126
4127 if (ext.ifd != -1)
4128 {
4129 BFD_ASSERT (ext.ifd
4130 < input_debug.symbolic_header.ifdMax);
4131 ext.ifd = input_debug.ifdmap[ext.ifd];
4132 }
4133
4134 h->esym = ext;
4135 }
4136
4137 /* Free up the information we just read. */
4138 free (input_debug.line);
4139 free (input_debug.external_dnr);
4140 free (input_debug.external_pdr);
4141 free (input_debug.external_sym);
4142 free (input_debug.external_opt);
4143 free (input_debug.external_aux);
4144 free (input_debug.ss);
4145 free (input_debug.ssext);
4146 free (input_debug.external_fdr);
4147 free (input_debug.external_rfd);
4148 free (input_debug.external_ext);
4149
4150 /* Hack: reset the SEC_HAS_CONTENTS flag so that
4151 elf_link_input_bfd ignores this section. */
4152 input_section->flags &=~ SEC_HAS_CONTENTS;
4153 }
4154
4155 #ifdef ERIC_neverdef
4156 if (info->shared)
4157 {
4158 /* Create .rtproc section. */
4159 rtproc_sec = bfd_get_section_by_name (abfd, ".rtproc");
4160 if (rtproc_sec == NULL)
4161 {
4162 flagword flags = (SEC_HAS_CONTENTS
4163 | SEC_IN_MEMORY
4164 | SEC_LINKER_CREATED
4165 | SEC_READONLY);
4166
4167 rtproc_sec = bfd_make_section (abfd, ".rtproc");
4168 if (rtproc_sec == NULL
4169 || ! bfd_set_section_flags (abfd, rtproc_sec, flags)
4170 || ! bfd_set_section_alignment (abfd, rtproc_sec, 12))
4171 return false;
4172 }
4173
4174 if (! alpha_elf_create_procedure_table (mdebug_handle, abfd,
4175 info, rtproc_sec, &debug))
4176 return false;
4177 }
4178 #endif
4179
4180 /* Build the external symbol information. */
4181 einfo.abfd = abfd;
4182 einfo.info = info;
4183 einfo.debug = &debug;
4184 einfo.swap = swap;
4185 einfo.failed = false;
4186 elf_link_hash_traverse (elf_hash_table (info),
4187 elf64_alpha_output_extsym,
4188 (PTR) &einfo);
4189 if (einfo.failed)
4190 return false;
4191
4192 /* Set the size of the .mdebug section. */
4193 o->_raw_size = bfd_ecoff_debug_size (abfd, &debug, swap);
4194
4195 /* Skip this section later on (I don't think this currently
4196 matters, but someday it might). */
4197 o->link_order_head = (struct bfd_link_order *) NULL;
4198
4199 mdebug_sec = o;
4200 }
4201
4202 #ifdef ERIC_neverdef
4203 if (strncmp (o->name, ".gptab.", sizeof ".gptab." - 1) == 0)
4204 {
4205 const char *subname;
4206 unsigned int c;
4207 Elf64_gptab *tab;
4208 Elf64_External_gptab *ext_tab;
4209 unsigned int i;
4210
4211 /* The .gptab.sdata and .gptab.sbss sections hold
4212 information describing how the small data area would
4213 change depending upon the -G switch. These sections
4214 not used in executables files. */
4215 if (! info->relocateable)
4216 {
4217 asection **secpp;
4218
4219 for (p = o->link_order_head;
4220 p != (struct bfd_link_order *) NULL;
4221 p = p->next)
4222 {
4223 asection *input_section;
4224
4225 if (p->type != bfd_indirect_link_order)
4226 {
4227 if (p->type == bfd_fill_link_order)
4228 continue;
4229 abort ();
4230 }
4231
4232 input_section = p->u.indirect.section;
4233
4234 /* Hack: reset the SEC_HAS_CONTENTS flag so that
4235 elf_link_input_bfd ignores this section. */
4236 input_section->flags &=~ SEC_HAS_CONTENTS;
4237 }
4238
4239 /* Skip this section later on (I don't think this
4240 currently matters, but someday it might). */
4241 o->link_order_head = (struct bfd_link_order *) NULL;
4242
4243 /* Really remove the section. */
4244 for (secpp = &abfd->sections;
4245 *secpp != o;
4246 secpp = &(*secpp)->next)
4247 ;
4248 *secpp = (*secpp)->next;
4249 --abfd->section_count;
4250
4251 continue;
4252 }
4253
4254 /* There is one gptab for initialized data, and one for
4255 uninitialized data. */
4256 if (strcmp (o->name, ".gptab.sdata") == 0)
4257 gptab_data_sec = o;
4258 else if (strcmp (o->name, ".gptab.sbss") == 0)
4259 gptab_bss_sec = o;
4260 else
4261 {
4262 (*_bfd_error_handler)
4263 (_("%s: illegal section name `%s'"),
4264 bfd_get_filename (abfd), o->name);
4265 bfd_set_error (bfd_error_nonrepresentable_section);
4266 return false;
4267 }
4268
4269 /* The linker script always combines .gptab.data and
4270 .gptab.sdata into .gptab.sdata, and likewise for
4271 .gptab.bss and .gptab.sbss. It is possible that there is
4272 no .sdata or .sbss section in the output file, in which
4273 case we must change the name of the output section. */
4274 subname = o->name + sizeof ".gptab" - 1;
4275 if (bfd_get_section_by_name (abfd, subname) == NULL)
4276 {
4277 if (o == gptab_data_sec)
4278 o->name = ".gptab.data";
4279 else
4280 o->name = ".gptab.bss";
4281 subname = o->name + sizeof ".gptab" - 1;
4282 BFD_ASSERT (bfd_get_section_by_name (abfd, subname) != NULL);
4283 }
4284
4285 /* Set up the first entry. */
4286 c = 1;
4287 tab = (Elf64_gptab *) bfd_malloc (c * sizeof (Elf64_gptab));
4288 if (tab == NULL)
4289 return false;
4290 tab[0].gt_header.gt_current_g_value = elf_gp_size (abfd);
4291 tab[0].gt_header.gt_unused = 0;
4292
4293 /* Combine the input sections. */
4294 for (p = o->link_order_head;
4295 p != (struct bfd_link_order *) NULL;
4296 p = p->next)
4297 {
4298 asection *input_section;
4299 bfd *input_bfd;
4300 bfd_size_type size;
4301 unsigned long last;
4302 bfd_size_type gpentry;
4303
4304 if (p->type != bfd_indirect_link_order)
4305 {
4306 if (p->type == bfd_fill_link_order)
4307 continue;
4308 abort ();
4309 }
4310
4311 input_section = p->u.indirect.section;
4312 input_bfd = input_section->owner;
4313
4314 /* Combine the gptab entries for this input section one
4315 by one. We know that the input gptab entries are
4316 sorted by ascending -G value. */
4317 size = bfd_section_size (input_bfd, input_section);
4318 last = 0;
4319 for (gpentry = sizeof (Elf64_External_gptab);
4320 gpentry < size;
4321 gpentry += sizeof (Elf64_External_gptab))
4322 {
4323 Elf64_External_gptab ext_gptab;
4324 Elf64_gptab int_gptab;
4325 unsigned long val;
4326 unsigned long add;
4327 boolean exact;
4328 unsigned int look;
4329
4330 if (! (bfd_get_section_contents
4331 (input_bfd, input_section, (PTR) &ext_gptab,
4332 gpentry, sizeof (Elf64_External_gptab))))
4333 {
4334 free (tab);
4335 return false;
4336 }
4337
4338 bfd_alpha_elf64_swap_gptab_in (input_bfd, &ext_gptab,
4339 &int_gptab);
4340 val = int_gptab.gt_entry.gt_g_value;
4341 add = int_gptab.gt_entry.gt_bytes - last;
4342
4343 exact = false;
4344 for (look = 1; look < c; look++)
4345 {
4346 if (tab[look].gt_entry.gt_g_value >= val)
4347 tab[look].gt_entry.gt_bytes += add;
4348
4349 if (tab[look].gt_entry.gt_g_value == val)
4350 exact = true;
4351 }
4352
4353 if (! exact)
4354 {
4355 Elf64_gptab *new_tab;
4356 unsigned int max;
4357
4358 /* We need a new table entry. */
4359 new_tab = ((Elf64_gptab *)
4360 bfd_realloc ((PTR) tab,
4361 (c + 1) * sizeof (Elf64_gptab)));
4362 if (new_tab == NULL)
4363 {
4364 free (tab);
4365 return false;
4366 }
4367 tab = new_tab;
4368 tab[c].gt_entry.gt_g_value = val;
4369 tab[c].gt_entry.gt_bytes = add;
4370
4371 /* Merge in the size for the next smallest -G
4372 value, since that will be implied by this new
4373 value. */
4374 max = 0;
4375 for (look = 1; look < c; look++)
4376 {
4377 if (tab[look].gt_entry.gt_g_value < val
4378 && (max == 0
4379 || (tab[look].gt_entry.gt_g_value
4380 > tab[max].gt_entry.gt_g_value)))
4381 max = look;
4382 }
4383 if (max != 0)
4384 tab[c].gt_entry.gt_bytes +=
4385 tab[max].gt_entry.gt_bytes;
4386
4387 ++c;
4388 }
4389
4390 last = int_gptab.gt_entry.gt_bytes;
4391 }
4392
4393 /* Hack: reset the SEC_HAS_CONTENTS flag so that
4394 elf_link_input_bfd ignores this section. */
4395 input_section->flags &=~ SEC_HAS_CONTENTS;
4396 }
4397
4398 /* The table must be sorted by -G value. */
4399 if (c > 2)
4400 qsort (tab + 1, c - 1, sizeof (tab[0]), gptab_compare);
4401
4402 /* Swap out the table. */
4403 ext_tab = ((Elf64_External_gptab *)
4404 bfd_alloc (abfd, c * sizeof (Elf64_External_gptab)));
4405 if (ext_tab == NULL)
4406 {
4407 free (tab);
4408 return false;
4409 }
4410
4411 for (i = 0; i < c; i++)
4412 bfd_alpha_elf64_swap_gptab_out (abfd, tab + i, ext_tab + i);
4413 free (tab);
4414
4415 o->_raw_size = c * sizeof (Elf64_External_gptab);
4416 o->contents = (bfd_byte *) ext_tab;
4417
4418 /* Skip this section later on (I don't think this currently
4419 matters, but someday it might). */
4420 o->link_order_head = (struct bfd_link_order *) NULL;
4421 }
4422 #endif
4423
4424 }
4425
4426 /* Invoke the regular ELF backend linker to do all the work. */
4427 if (! bfd_elf64_bfd_final_link (abfd, info))
4428 return false;
4429
4430 /* Now write out the computed sections. */
4431
4432 /* The .got subsections... */
4433 {
4434 bfd *i, *dynobj = elf_hash_table(info)->dynobj;
4435 for (i = alpha_elf_hash_table(info)->got_list;
4436 i != NULL;
4437 i = alpha_elf_tdata(i)->got_link_next)
4438 {
4439 asection *sgot;
4440
4441 /* elf_bfd_final_link already did everything in dynobj. */
4442 if (i == dynobj)
4443 continue;
4444
4445 sgot = alpha_elf_tdata(i)->got;
4446 if (! bfd_set_section_contents (abfd, sgot->output_section,
4447 sgot->contents, sgot->output_offset,
4448 sgot->_raw_size))
4449 return false;
4450 }
4451 }
4452
4453 #ifdef ERIC_neverdef
4454 if (reginfo_sec != (asection *) NULL)
4455 {
4456 Elf64_External_RegInfo ext;
4457
4458 bfd_alpha_elf64_swap_reginfo_out (abfd, &reginfo, &ext);
4459 if (! bfd_set_section_contents (abfd, reginfo_sec, (PTR) &ext,
4460 (file_ptr) 0, sizeof ext))
4461 return false;
4462 }
4463 #endif
4464
4465 if (mdebug_sec != (asection *) NULL)
4466 {
4467 BFD_ASSERT (abfd->output_has_begun);
4468 if (! bfd_ecoff_write_accumulated_debug (mdebug_handle, abfd, &debug,
4469 swap, info,
4470 mdebug_sec->filepos))
4471 return false;
4472
4473 bfd_ecoff_debug_free (mdebug_handle, abfd, &debug, swap, info);
4474 }
4475
4476 if (gptab_data_sec != (asection *) NULL)
4477 {
4478 if (! bfd_set_section_contents (abfd, gptab_data_sec,
4479 gptab_data_sec->contents,
4480 (file_ptr) 0,
4481 gptab_data_sec->_raw_size))
4482 return false;
4483 }
4484
4485 if (gptab_bss_sec != (asection *) NULL)
4486 {
4487 if (! bfd_set_section_contents (abfd, gptab_bss_sec,
4488 gptab_bss_sec->contents,
4489 (file_ptr) 0,
4490 gptab_bss_sec->_raw_size))
4491 return false;
4492 }
4493
4494 return true;
4495 }
4496
4497 static enum elf_reloc_type_class
4498 elf64_alpha_reloc_type_class (type)
4499 int type;
4500 {
4501 switch (type)
4502 {
4503 case R_ALPHA_RELATIVE:
4504 return reloc_class_relative;
4505 case R_ALPHA_JMP_SLOT:
4506 return reloc_class_plt;
4507 case R_ALPHA_COPY:
4508 return reloc_class_copy;
4509 default:
4510 return reloc_class_normal;
4511 }
4512 }
4513 \f
4514 /* ECOFF swapping routines. These are used when dealing with the
4515 .mdebug section, which is in the ECOFF debugging format. Copied
4516 from elf32-mips.c. */
4517 static const struct ecoff_debug_swap
4518 elf64_alpha_ecoff_debug_swap =
4519 {
4520 /* Symbol table magic number. */
4521 magicSym2,
4522 /* Alignment of debugging information. E.g., 4. */
4523 8,
4524 /* Sizes of external symbolic information. */
4525 sizeof (struct hdr_ext),
4526 sizeof (struct dnr_ext),
4527 sizeof (struct pdr_ext),
4528 sizeof (struct sym_ext),
4529 sizeof (struct opt_ext),
4530 sizeof (struct fdr_ext),
4531 sizeof (struct rfd_ext),
4532 sizeof (struct ext_ext),
4533 /* Functions to swap in external symbolic data. */
4534 ecoff_swap_hdr_in,
4535 ecoff_swap_dnr_in,
4536 ecoff_swap_pdr_in,
4537 ecoff_swap_sym_in,
4538 ecoff_swap_opt_in,
4539 ecoff_swap_fdr_in,
4540 ecoff_swap_rfd_in,
4541 ecoff_swap_ext_in,
4542 _bfd_ecoff_swap_tir_in,
4543 _bfd_ecoff_swap_rndx_in,
4544 /* Functions to swap out external symbolic data. */
4545 ecoff_swap_hdr_out,
4546 ecoff_swap_dnr_out,
4547 ecoff_swap_pdr_out,
4548 ecoff_swap_sym_out,
4549 ecoff_swap_opt_out,
4550 ecoff_swap_fdr_out,
4551 ecoff_swap_rfd_out,
4552 ecoff_swap_ext_out,
4553 _bfd_ecoff_swap_tir_out,
4554 _bfd_ecoff_swap_rndx_out,
4555 /* Function to read in symbolic data. */
4556 elf64_alpha_read_ecoff_info
4557 };
4558 \f
4559 /* Use a non-standard hash bucket size of 8. */
4560
4561 const struct elf_size_info alpha_elf_size_info =
4562 {
4563 sizeof (Elf64_External_Ehdr),
4564 sizeof (Elf64_External_Phdr),
4565 sizeof (Elf64_External_Shdr),
4566 sizeof (Elf64_External_Rel),
4567 sizeof (Elf64_External_Rela),
4568 sizeof (Elf64_External_Sym),
4569 sizeof (Elf64_External_Dyn),
4570 sizeof (Elf_External_Note),
4571 8,
4572 1,
4573 64, 8,
4574 ELFCLASS64, EV_CURRENT,
4575 bfd_elf64_write_out_phdrs,
4576 bfd_elf64_write_shdrs_and_ehdr,
4577 bfd_elf64_write_relocs,
4578 bfd_elf64_swap_symbol_out,
4579 bfd_elf64_slurp_reloc_table,
4580 bfd_elf64_slurp_symbol_table,
4581 bfd_elf64_swap_dyn_in,
4582 bfd_elf64_swap_dyn_out,
4583 NULL,
4584 NULL,
4585 NULL,
4586 NULL
4587 };
4588
4589 #define TARGET_LITTLE_SYM bfd_elf64_alpha_vec
4590 #define TARGET_LITTLE_NAME "elf64-alpha"
4591 #define ELF_ARCH bfd_arch_alpha
4592 #define ELF_MACHINE_CODE EM_ALPHA
4593 #define ELF_MAXPAGESIZE 0x10000
4594
4595 #define bfd_elf64_bfd_link_hash_table_create \
4596 elf64_alpha_bfd_link_hash_table_create
4597
4598 #define bfd_elf64_bfd_reloc_type_lookup \
4599 elf64_alpha_bfd_reloc_type_lookup
4600 #define elf_info_to_howto \
4601 elf64_alpha_info_to_howto
4602
4603 #define bfd_elf64_mkobject \
4604 elf64_alpha_mkobject
4605 #define elf_backend_object_p \
4606 elf64_alpha_object_p
4607
4608 #define elf_backend_section_from_shdr \
4609 elf64_alpha_section_from_shdr
4610 #define elf_backend_fake_sections \
4611 elf64_alpha_fake_sections
4612
4613 #define bfd_elf64_bfd_is_local_label_name \
4614 elf64_alpha_is_local_label_name
4615 #define bfd_elf64_find_nearest_line \
4616 elf64_alpha_find_nearest_line
4617 #define bfd_elf64_bfd_relax_section \
4618 elf64_alpha_relax_section
4619
4620 #define elf_backend_add_symbol_hook \
4621 elf64_alpha_add_symbol_hook
4622 #define elf_backend_check_relocs \
4623 elf64_alpha_check_relocs
4624 #define elf_backend_create_dynamic_sections \
4625 elf64_alpha_create_dynamic_sections
4626 #define elf_backend_adjust_dynamic_symbol \
4627 elf64_alpha_adjust_dynamic_symbol
4628 #define elf_backend_always_size_sections \
4629 elf64_alpha_always_size_sections
4630 #define elf_backend_size_dynamic_sections \
4631 elf64_alpha_size_dynamic_sections
4632 #define elf_backend_relocate_section \
4633 elf64_alpha_relocate_section
4634 #define elf_backend_finish_dynamic_symbol \
4635 elf64_alpha_finish_dynamic_symbol
4636 #define elf_backend_finish_dynamic_sections \
4637 elf64_alpha_finish_dynamic_sections
4638 #define bfd_elf64_bfd_final_link \
4639 elf64_alpha_final_link
4640 #define elf_backend_reloc_type_class \
4641 elf64_alpha_reloc_type_class
4642
4643 #define elf_backend_ecoff_debug_swap \
4644 &elf64_alpha_ecoff_debug_swap
4645
4646 #define elf_backend_size_info \
4647 alpha_elf_size_info
4648
4649 /* A few constants that determine how the .plt section is set up. */
4650 #define elf_backend_want_got_plt 0
4651 #define elf_backend_plt_readonly 0
4652 #define elf_backend_want_plt_sym 1
4653 #define elf_backend_got_header_size 0
4654 #define elf_backend_plt_header_size PLT_HEADER_SIZE
4655
4656 #include "elf64-target.h"