1 /* IA-64 support for OpenVMS
2 Copyright (C) 1998-2015 Free Software Foundation, Inc.
4 This file is part of BFD, the Binary File Descriptor library.
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19 MA 02110-1301, USA. */
25 #include "opcode/ia64.h"
29 #include "elfxx-ia64.h"
33 /* THE RULES for all the stuff the linker creates --
35 GOT Entries created in response to LTOFF or LTOFF_FPTR
36 relocations. Dynamic relocs created for dynamic
37 symbols in an application; REL relocs for locals
40 FPTR The canonical function descriptor. Created for local
41 symbols in applications. Descriptors for dynamic symbols
42 and local symbols in shared libraries are created by
43 ld.so. Thus there are no dynamic relocs against these
44 objects. The FPTR relocs for such _are_ passed through
45 to the dynamic relocation tables.
47 FULL_PLT Created for a PCREL21B relocation against a dynamic symbol.
48 Requires the creation of a PLTOFF entry. This does not
49 require any dynamic relocations.
51 PLTOFF Created by PLTOFF relocations. For local symbols, this
52 is an alternate function descriptor, and in shared libraries
53 requires two REL relocations. Note that this cannot be
54 transformed into an FPTR relocation, since it must be in
55 range of the GP. For dynamic symbols, this is a function
58 typedef struct bfd_hash_entry
*(*new_hash_entry_func
)
59 (struct bfd_hash_entry
*, struct bfd_hash_table
*, const char *);
61 /* In dynamically (linker-) created sections, we generally need to keep track
62 of the place a symbol or expression got allocated to. This is done via hash
63 tables that store entries of the following type. */
65 struct elf64_ia64_dyn_sym_info
67 /* The addend for which this entry is relevant. */
72 bfd_vma pltoff_offset
;
76 /* The symbol table entry, if any, that this was derived from. */
77 struct elf_link_hash_entry
*h
;
79 /* Used to count non-got, non-plt relocations for delayed sizing
80 of relocation sections. */
81 struct elf64_ia64_dyn_reloc_entry
83 struct elf64_ia64_dyn_reloc_entry
*next
;
89 /* TRUE when the section contents have been updated. */
90 unsigned got_done
: 1;
91 unsigned fptr_done
: 1;
92 unsigned pltoff_done
: 1;
94 /* TRUE for the different kinds of linker data we want created. */
95 unsigned want_got
: 1;
96 unsigned want_gotx
: 1;
97 unsigned want_fptr
: 1;
98 unsigned want_ltoff_fptr
: 1;
99 unsigned want_plt
: 1; /* A MIN_PLT entry. */
100 unsigned want_plt2
: 1; /* A FULL_PLT. */
101 unsigned want_pltoff
: 1;
104 struct elf64_ia64_local_hash_entry
108 /* The number of elements in elf64_ia64_dyn_sym_info array. */
110 /* The number of sorted elements in elf64_ia64_dyn_sym_info array. */
111 unsigned int sorted_count
;
112 /* The size of elf64_ia64_dyn_sym_info array. */
114 /* The array of elf64_ia64_dyn_sym_info. */
115 struct elf64_ia64_dyn_sym_info
*info
;
117 /* TRUE if this hash entry's addends was translated for
118 SHF_MERGE optimization. */
119 unsigned sec_merge_done
: 1;
122 struct elf64_ia64_link_hash_entry
124 struct elf_link_hash_entry root
;
126 /* Set if this symbol is defined in a shared library.
127 We can't use root.u.def.section->owner as the symbol is an absolute
131 /* The number of elements in elf64_ia64_dyn_sym_info array. */
133 /* The number of sorted elements in elf64_ia64_dyn_sym_info array. */
134 unsigned int sorted_count
;
135 /* The size of elf64_ia64_dyn_sym_info array. */
137 /* The array of elf64_ia64_dyn_sym_info. */
138 struct elf64_ia64_dyn_sym_info
*info
;
141 struct elf64_ia64_link_hash_table
143 /* The main hash table. */
144 struct elf_link_hash_table root
;
146 asection
*fptr_sec
; /* Function descriptor table (or NULL). */
147 asection
*rel_fptr_sec
; /* Dynamic relocation section for same. */
148 asection
*pltoff_sec
; /* Private descriptors for plt (or NULL). */
149 asection
*fixups_sec
; /* Fixups section. */
150 asection
*transfer_sec
; /* Transfer vector section. */
151 asection
*note_sec
; /* .note section. */
153 /* There are maybe R_IA64_GPREL22 relocations, including those
154 optimized from R_IA64_LTOFF22X, against non-SHF_IA_64_SHORT
155 sections. We need to record those sections so that we can choose
156 a proper GP to cover all R_IA64_GPREL22 relocations. */
157 asection
*max_short_sec
; /* Maximum short output section. */
158 bfd_vma max_short_offset
; /* Maximum short offset. */
159 asection
*min_short_sec
; /* Minimum short output section. */
160 bfd_vma min_short_offset
; /* Minimum short offset. */
162 htab_t loc_hash_table
;
163 void *loc_hash_memory
;
166 struct elf64_ia64_allocate_data
168 struct bfd_link_info
*info
;
172 #define elf64_ia64_hash_table(p) \
173 (elf_hash_table_id ((struct elf_link_hash_table *) ((p)->hash)) \
174 == IA64_ELF_DATA ? ((struct elf64_ia64_link_hash_table *) ((p)->hash)) : NULL)
176 struct elf64_ia64_vms_obj_tdata
178 struct elf_obj_tdata root
;
180 /* Ident for shared library. */
183 /* Used only during link: offset in the .fixups section for this bfd. */
186 /* Max number of shared libraries. */
187 unsigned int needed_count
;
190 #define elf_ia64_vms_tdata(abfd) \
191 ((struct elf64_ia64_vms_obj_tdata *)((abfd)->tdata.any))
192 #define elf_ia64_vms_ident(abfd) (elf_ia64_vms_tdata(abfd)->ident)
194 struct elf64_vms_transfer
196 unsigned char size
[4];
197 unsigned char spare
[4];
198 unsigned char tfradr1
[8];
199 unsigned char tfradr2
[8];
200 unsigned char tfradr3
[8];
201 unsigned char tfradr4
[8];
202 unsigned char tfradr5
[8];
204 /* Local function descriptor for tfr3. */
205 unsigned char tfr3_func
[8];
206 unsigned char tfr3_gp
[8];
211 Elf64_External_Ehdr ehdr
;
212 unsigned char vms_needed_count
[8];
213 } Elf64_External_VMS_Ehdr
;
215 static struct elf64_ia64_dyn_sym_info
* get_dyn_sym_info
216 (struct elf64_ia64_link_hash_table
*,
217 struct elf_link_hash_entry
*,
218 bfd
*, const Elf_Internal_Rela
*, bfd_boolean
);
219 static bfd_boolean elf64_ia64_dynamic_symbol_p
220 (struct elf_link_hash_entry
*);
221 static bfd_boolean elf64_ia64_choose_gp
222 (bfd
*, struct bfd_link_info
*, bfd_boolean
);
223 static void elf64_ia64_dyn_sym_traverse
224 (struct elf64_ia64_link_hash_table
*,
225 bfd_boolean (*) (struct elf64_ia64_dyn_sym_info
*, void *),
227 static bfd_boolean allocate_global_data_got
228 (struct elf64_ia64_dyn_sym_info
*, void *);
229 static bfd_boolean allocate_global_fptr_got
230 (struct elf64_ia64_dyn_sym_info
*, void *);
231 static bfd_boolean allocate_local_got
232 (struct elf64_ia64_dyn_sym_info
*, void *);
233 static bfd_boolean allocate_dynrel_entries
234 (struct elf64_ia64_dyn_sym_info
*, void *);
235 static asection
*get_pltoff
236 (bfd
*, struct elf64_ia64_link_hash_table
*);
237 static asection
*get_got
238 (bfd
*, struct elf64_ia64_link_hash_table
*);
241 /* Given a ELF reloc, return the matching HOWTO structure. */
244 elf64_ia64_info_to_howto (bfd
*abfd ATTRIBUTE_UNUSED
,
246 Elf_Internal_Rela
*elf_reloc
)
249 = ia64_elf_lookup_howto ((unsigned int) ELF64_R_TYPE (elf_reloc
->r_info
));
253 #define PLT_FULL_ENTRY_SIZE (2 * 16)
255 static const bfd_byte plt_full_entry
[PLT_FULL_ENTRY_SIZE
] =
257 0x0b, 0x78, 0x00, 0x02, 0x00, 0x24, /* [MMI] addl r15=0,r1;; */
258 0x00, 0x41, 0x3c, 0x70, 0x29, 0xc0, /* ld8.acq r16=[r15],8*/
259 0x01, 0x08, 0x00, 0x84, /* mov r14=r1;; */
260 0x11, 0x08, 0x00, 0x1e, 0x18, 0x10, /* [MIB] ld8 r1=[r15] */
261 0x60, 0x80, 0x04, 0x80, 0x03, 0x00, /* mov b6=r16 */
262 0x60, 0x00, 0x80, 0x00 /* br.few b6;; */
265 static const bfd_byte oor_brl
[16] =
267 0x05, 0x00, 0x00, 0x00, 0x01, 0x00, /* [MLX] nop.m 0 */
268 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, /* brl.sptk.few tgt;;*/
269 0x00, 0x00, 0x00, 0xc0
273 /* These functions do relaxation for IA-64 ELF. */
275 /* Rename some of the generic section flags to better document how they
277 #define skip_relax_pass_0 sec_flg0
278 #define skip_relax_pass_1 sec_flg1
281 elf64_ia64_update_short_info (asection
*sec
, bfd_vma offset
,
282 struct elf64_ia64_link_hash_table
*ia64_info
)
284 /* Skip ABS and SHF_IA_64_SHORT sections. */
285 if (sec
== bfd_abs_section_ptr
286 || (sec
->flags
& SEC_SMALL_DATA
) != 0)
289 if (!ia64_info
->min_short_sec
)
291 ia64_info
->max_short_sec
= sec
;
292 ia64_info
->max_short_offset
= offset
;
293 ia64_info
->min_short_sec
= sec
;
294 ia64_info
->min_short_offset
= offset
;
296 else if (sec
== ia64_info
->max_short_sec
297 && offset
> ia64_info
->max_short_offset
)
298 ia64_info
->max_short_offset
= offset
;
299 else if (sec
== ia64_info
->min_short_sec
300 && offset
< ia64_info
->min_short_offset
)
301 ia64_info
->min_short_offset
= offset
;
302 else if (sec
->output_section
->vma
303 > ia64_info
->max_short_sec
->vma
)
305 ia64_info
->max_short_sec
= sec
;
306 ia64_info
->max_short_offset
= offset
;
308 else if (sec
->output_section
->vma
309 < ia64_info
->min_short_sec
->vma
)
311 ia64_info
->min_short_sec
= sec
;
312 ia64_info
->min_short_offset
= offset
;
316 /* Use a two passes algorithm. In the first pass, branches are relaxed
317 (which may increase the size of the section). In the second pass,
318 the other relaxations are done.
322 elf64_ia64_relax_section (bfd
*abfd
, asection
*sec
,
323 struct bfd_link_info
*link_info
,
328 struct one_fixup
*next
;
334 Elf_Internal_Shdr
*symtab_hdr
;
335 Elf_Internal_Rela
*internal_relocs
;
336 Elf_Internal_Rela
*irel
, *irelend
;
338 Elf_Internal_Sym
*isymbuf
= NULL
;
339 struct elf64_ia64_link_hash_table
*ia64_info
;
340 struct one_fixup
*fixups
= NULL
;
341 bfd_boolean changed_contents
= FALSE
;
342 bfd_boolean changed_relocs
= FALSE
;
343 bfd_boolean skip_relax_pass_0
= TRUE
;
344 bfd_boolean skip_relax_pass_1
= TRUE
;
347 /* Assume we're not going to change any sizes, and we'll only need
351 if (bfd_link_relocatable (link_info
))
352 (*link_info
->callbacks
->einfo
)
353 (_("%P%F: --relax and -r may not be used together\n"));
355 /* Don't even try to relax for non-ELF outputs. */
356 if (!is_elf_hash_table (link_info
->hash
))
359 /* Nothing to do if there are no relocations or there is no need for
361 if ((sec
->flags
& SEC_RELOC
) == 0
362 || sec
->reloc_count
== 0
363 || (link_info
->relax_pass
== 0 && sec
->skip_relax_pass_0
)
364 || (link_info
->relax_pass
== 1 && sec
->skip_relax_pass_1
))
367 ia64_info
= elf64_ia64_hash_table (link_info
);
368 if (ia64_info
== NULL
)
371 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
373 /* Load the relocations for this section. */
374 internal_relocs
= (_bfd_elf_link_read_relocs
375 (abfd
, sec
, NULL
, (Elf_Internal_Rela
*) NULL
,
376 link_info
->keep_memory
));
377 if (internal_relocs
== NULL
)
380 irelend
= internal_relocs
+ sec
->reloc_count
;
382 /* Get the section contents. */
383 if (elf_section_data (sec
)->this_hdr
.contents
!= NULL
)
384 contents
= elf_section_data (sec
)->this_hdr
.contents
;
387 if (!bfd_malloc_and_get_section (abfd
, sec
, &contents
))
391 for (irel
= internal_relocs
; irel
< irelend
; irel
++)
393 unsigned long r_type
= ELF64_R_TYPE (irel
->r_info
);
394 bfd_vma symaddr
, reladdr
, trampoff
, toff
, roff
;
398 bfd_boolean is_branch
;
399 struct elf64_ia64_dyn_sym_info
*dyn_i
;
403 case R_IA64_PCREL21B
:
404 case R_IA64_PCREL21BI
:
405 case R_IA64_PCREL21M
:
406 case R_IA64_PCREL21F
:
407 /* In pass 1, all br relaxations are done. We can skip it. */
408 if (link_info
->relax_pass
== 1)
410 skip_relax_pass_0
= FALSE
;
414 case R_IA64_PCREL60B
:
415 /* We can't optimize brl to br in pass 0 since br relaxations
416 will increase the code size. Defer it to pass 1. */
417 if (link_info
->relax_pass
== 0)
419 skip_relax_pass_1
= FALSE
;
426 /* Update max_short_sec/min_short_sec. */
428 case R_IA64_LTOFF22X
:
430 /* We can't relax ldx/mov in pass 0 since br relaxations will
431 increase the code size. Defer it to pass 1. */
432 if (link_info
->relax_pass
== 0)
434 skip_relax_pass_1
= FALSE
;
444 /* Get the value of the symbol referred to by the reloc. */
445 if (ELF64_R_SYM (irel
->r_info
) < symtab_hdr
->sh_info
)
447 /* A local symbol. */
448 Elf_Internal_Sym
*isym
;
450 /* Read this BFD's local symbols. */
453 isymbuf
= (Elf_Internal_Sym
*) symtab_hdr
->contents
;
455 isymbuf
= bfd_elf_get_elf_syms (abfd
, symtab_hdr
,
456 symtab_hdr
->sh_info
, 0,
462 isym
= isymbuf
+ ELF64_R_SYM (irel
->r_info
);
463 if (isym
->st_shndx
== SHN_UNDEF
)
464 continue; /* We can't do anything with undefined symbols. */
465 else if (isym
->st_shndx
== SHN_ABS
)
466 tsec
= bfd_abs_section_ptr
;
467 else if (isym
->st_shndx
== SHN_COMMON
)
468 tsec
= bfd_com_section_ptr
;
469 else if (isym
->st_shndx
== SHN_IA_64_ANSI_COMMON
)
470 tsec
= bfd_com_section_ptr
;
472 tsec
= bfd_section_from_elf_index (abfd
, isym
->st_shndx
);
474 toff
= isym
->st_value
;
475 dyn_i
= get_dyn_sym_info (ia64_info
, NULL
, abfd
, irel
, FALSE
);
480 struct elf_link_hash_entry
*h
;
482 indx
= ELF64_R_SYM (irel
->r_info
) - symtab_hdr
->sh_info
;
483 h
= elf_sym_hashes (abfd
)[indx
];
484 BFD_ASSERT (h
!= NULL
);
486 while (h
->root
.type
== bfd_link_hash_indirect
487 || h
->root
.type
== bfd_link_hash_warning
)
488 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
490 dyn_i
= get_dyn_sym_info (ia64_info
, h
, abfd
, irel
, FALSE
);
492 /* For branches to dynamic symbols, we're interested instead
493 in a branch to the PLT entry. */
494 if (is_branch
&& dyn_i
&& dyn_i
->want_plt2
)
496 /* Internal branches shouldn't be sent to the PLT.
497 Leave this for now and we'll give an error later. */
498 if (r_type
!= R_IA64_PCREL21B
)
501 tsec
= ia64_info
->root
.splt
;
502 toff
= dyn_i
->plt2_offset
;
503 BFD_ASSERT (irel
->r_addend
== 0);
506 /* Can't do anything else with dynamic symbols. */
507 else if (elf64_ia64_dynamic_symbol_p (h
))
512 /* We can't do anything with undefined symbols. */
513 if (h
->root
.type
== bfd_link_hash_undefined
514 || h
->root
.type
== bfd_link_hash_undefweak
)
517 tsec
= h
->root
.u
.def
.section
;
518 toff
= h
->root
.u
.def
.value
;
522 toff
+= irel
->r_addend
;
524 symaddr
= tsec
->output_section
->vma
+ tsec
->output_offset
+ toff
;
526 roff
= irel
->r_offset
;
530 bfd_signed_vma offset
;
532 reladdr
= (sec
->output_section
->vma
534 + roff
) & (bfd_vma
) -4;
536 /* The .plt section is aligned at 32byte and the .text section
537 is aligned at 64byte. The .text section is right after the
538 .plt section. After the first relaxation pass, linker may
539 increase the gap between the .plt and .text sections up
540 to 32byte. We assume linker will always insert 32byte
541 between the .plt and .text sections after the first
543 if (tsec
== ia64_info
->root
.splt
)
544 offset
= -0x1000000 + 32;
548 /* If the branch is in range, no need to do anything. */
549 if ((bfd_signed_vma
) (symaddr
- reladdr
) >= offset
550 && (bfd_signed_vma
) (symaddr
- reladdr
) <= 0x0FFFFF0)
552 /* If the 60-bit branch is in 21-bit range, optimize it. */
553 if (r_type
== R_IA64_PCREL60B
)
555 ia64_elf_relax_brl (contents
, roff
);
557 irel
->r_info
= ELF64_R_INFO (ELF64_R_SYM (irel
->r_info
),
560 /* If the original relocation offset points to slot
561 1, change it to slot 2. */
562 if ((irel
->r_offset
& 3) == 1)
568 else if (r_type
== R_IA64_PCREL60B
)
570 else if (ia64_elf_relax_br (contents
, roff
))
572 irel
->r_info
= ELF64_R_INFO (ELF64_R_SYM (irel
->r_info
),
575 /* Make the relocation offset point to slot 1. */
576 irel
->r_offset
= (irel
->r_offset
& ~((bfd_vma
) 0x3)) + 1;
580 /* We can't put a trampoline in a .init/.fini section. Issue
582 if (strcmp (sec
->output_section
->name
, ".init") == 0
583 || strcmp (sec
->output_section
->name
, ".fini") == 0)
585 (*_bfd_error_handler
)
586 (_("%B: Can't relax br at 0x%lx in section `%A'. Please use brl or indirect branch."),
587 sec
->owner
, sec
, (unsigned long) roff
);
588 bfd_set_error (bfd_error_bad_value
);
592 /* If the branch and target are in the same section, you've
593 got one honking big section and we can't help you unless
594 you are branching backwards. You'll get an error message
596 if (tsec
== sec
&& toff
> roff
)
599 /* Look for an existing fixup to this address. */
600 for (f
= fixups
; f
; f
= f
->next
)
601 if (f
->tsec
== tsec
&& f
->toff
== toff
)
606 /* Two alternatives: If it's a branch to a PLT entry, we can
607 make a copy of the FULL_PLT entry. Otherwise, we'll have
608 to use a `brl' insn to get where we're going. */
612 if (tsec
== ia64_info
->root
.splt
)
613 size
= sizeof (plt_full_entry
);
615 size
= sizeof (oor_brl
);
617 /* Resize the current section to make room for the new branch. */
618 trampoff
= (sec
->size
+ 15) & (bfd_vma
) -16;
620 /* If trampoline is out of range, there is nothing we
622 offset
= trampoff
- (roff
& (bfd_vma
) -4);
623 if (offset
< -0x1000000 || offset
> 0x0FFFFF0)
626 amt
= trampoff
+ size
;
627 contents
= (bfd_byte
*) bfd_realloc (contents
, amt
);
628 if (contents
== NULL
)
632 if (tsec
== ia64_info
->root
.splt
)
634 memcpy (contents
+ trampoff
, plt_full_entry
, size
);
636 /* Hijack the old relocation for use as the PLTOFF reloc. */
637 irel
->r_info
= ELF64_R_INFO (ELF64_R_SYM (irel
->r_info
),
639 irel
->r_offset
= trampoff
;
643 memcpy (contents
+ trampoff
, oor_brl
, size
);
644 irel
->r_info
= ELF64_R_INFO (ELF64_R_SYM (irel
->r_info
),
646 irel
->r_offset
= trampoff
+ 2;
649 /* Record the fixup so we don't do it again this section. */
650 f
= (struct one_fixup
*)
651 bfd_malloc ((bfd_size_type
) sizeof (*f
));
655 f
->trampoff
= trampoff
;
660 /* If trampoline is out of range, there is nothing we
662 offset
= f
->trampoff
- (roff
& (bfd_vma
) -4);
663 if (offset
< -0x1000000 || offset
> 0x0FFFFF0)
666 /* Nop out the reloc, since we're finalizing things here. */
667 irel
->r_info
= ELF64_R_INFO (0, R_IA64_NONE
);
670 /* Fix up the existing branch to hit the trampoline. */
671 if (ia64_elf_install_value (contents
+ roff
, offset
, r_type
)
675 changed_contents
= TRUE
;
676 changed_relocs
= TRUE
;
683 bfd
*obfd
= sec
->output_section
->owner
;
684 gp
= _bfd_get_gp_value (obfd
);
687 if (!elf64_ia64_choose_gp (obfd
, link_info
, FALSE
))
689 gp
= _bfd_get_gp_value (obfd
);
693 /* If the data is out of range, do nothing. */
694 if ((bfd_signed_vma
) (symaddr
- gp
) >= 0x200000
695 ||(bfd_signed_vma
) (symaddr
- gp
) < -0x200000)
698 if (r_type
== R_IA64_GPREL22
)
699 elf64_ia64_update_short_info (tsec
->output_section
,
700 tsec
->output_offset
+ toff
,
702 else if (r_type
== R_IA64_LTOFF22X
)
704 /* Can't deal yet correctly with ABS symbols. */
705 if (bfd_is_abs_section (tsec
))
708 irel
->r_info
= ELF64_R_INFO (ELF64_R_SYM (irel
->r_info
),
710 changed_relocs
= TRUE
;
712 elf64_ia64_update_short_info (tsec
->output_section
,
713 tsec
->output_offset
+ toff
,
718 ia64_elf_relax_ldxmov (contents
, roff
);
719 irel
->r_info
= ELF64_R_INFO (0, R_IA64_NONE
);
720 changed_contents
= TRUE
;
721 changed_relocs
= TRUE
;
726 /* ??? If we created fixups, this may push the code segment large
727 enough that the data segment moves, which will change the GP.
728 Reset the GP so that we re-calculate next round. We need to
729 do this at the _beginning_ of the next round; now will not do. */
731 /* Clean up and go home. */
734 struct one_fixup
*f
= fixups
;
735 fixups
= fixups
->next
;
740 && symtab_hdr
->contents
!= (unsigned char *) isymbuf
)
742 if (! link_info
->keep_memory
)
746 /* Cache the symbols for elf_link_input_bfd. */
747 symtab_hdr
->contents
= (unsigned char *) isymbuf
;
752 && elf_section_data (sec
)->this_hdr
.contents
!= contents
)
754 if (!changed_contents
&& !link_info
->keep_memory
)
758 /* Cache the section contents for elf_link_input_bfd. */
759 elf_section_data (sec
)->this_hdr
.contents
= contents
;
763 if (elf_section_data (sec
)->relocs
!= internal_relocs
)
766 free (internal_relocs
);
768 elf_section_data (sec
)->relocs
= internal_relocs
;
771 if (link_info
->relax_pass
== 0)
773 /* Pass 0 is only needed to relax br. */
774 sec
->skip_relax_pass_0
= skip_relax_pass_0
;
775 sec
->skip_relax_pass_1
= skip_relax_pass_1
;
778 *again
= changed_contents
|| changed_relocs
;
782 if (isymbuf
!= NULL
&& (unsigned char *) isymbuf
!= symtab_hdr
->contents
)
785 && elf_section_data (sec
)->this_hdr
.contents
!= contents
)
787 if (internal_relocs
!= NULL
788 && elf_section_data (sec
)->relocs
!= internal_relocs
)
789 free (internal_relocs
);
792 #undef skip_relax_pass_0
793 #undef skip_relax_pass_1
795 /* Return TRUE if NAME is an unwind table section name. */
797 static inline bfd_boolean
798 is_unwind_section_name (bfd
*abfd ATTRIBUTE_UNUSED
, const char *name
)
800 return ((CONST_STRNEQ (name
, ELF_STRING_ia64_unwind
)
801 && ! CONST_STRNEQ (name
, ELF_STRING_ia64_unwind_info
))
802 || CONST_STRNEQ (name
, ELF_STRING_ia64_unwind_once
));
806 /* Convert IA-64 specific section flags to bfd internal section flags. */
808 /* ??? There is no bfd internal flag equivalent to the SHF_IA_64_NORECOV
812 elf64_ia64_section_flags (flagword
*flags
,
813 const Elf_Internal_Shdr
*hdr
)
815 if (hdr
->sh_flags
& SHF_IA_64_SHORT
)
816 *flags
|= SEC_SMALL_DATA
;
821 /* Set the correct type for an IA-64 ELF section. We do this by the
822 section name, which is a hack, but ought to work. */
825 elf64_ia64_fake_sections (bfd
*abfd
, Elf_Internal_Shdr
*hdr
,
830 name
= bfd_get_section_name (abfd
, sec
);
832 if (is_unwind_section_name (abfd
, name
))
834 /* We don't have the sections numbered at this point, so sh_info
835 is set later, in elf64_ia64_final_write_processing. */
836 hdr
->sh_type
= SHT_IA_64_UNWIND
;
837 hdr
->sh_flags
|= SHF_LINK_ORDER
;
839 else if (strcmp (name
, ELF_STRING_ia64_archext
) == 0)
840 hdr
->sh_type
= SHT_IA_64_EXT
;
842 if (sec
->flags
& SEC_SMALL_DATA
)
843 hdr
->sh_flags
|= SHF_IA_64_SHORT
;
848 /* Hook called by the linker routine which adds symbols from an object
849 file. We use it to put .comm items in .sbss, and not .bss. */
852 elf64_ia64_add_symbol_hook (bfd
*abfd
,
853 struct bfd_link_info
*info
,
854 Elf_Internal_Sym
*sym
,
855 const char **namep ATTRIBUTE_UNUSED
,
856 flagword
*flagsp ATTRIBUTE_UNUSED
,
860 if (sym
->st_shndx
== SHN_COMMON
861 && !bfd_link_relocatable (info
)
862 && sym
->st_size
<= elf_gp_size (abfd
))
864 /* Common symbols less than or equal to -G nn bytes are
865 automatically put into .sbss. */
867 asection
*scomm
= bfd_get_section_by_name (abfd
, ".scommon");
871 scomm
= bfd_make_section_with_flags (abfd
, ".scommon",
874 | SEC_LINKER_CREATED
));
880 *valp
= sym
->st_size
;
886 /* According to the Tahoe assembler spec, all labels starting with a
890 elf64_ia64_is_local_label_name (bfd
*abfd ATTRIBUTE_UNUSED
,
893 return name
[0] == '.';
896 /* Should we do dynamic things to this symbol? */
899 elf64_ia64_dynamic_symbol_p (struct elf_link_hash_entry
*h
)
901 return h
!= NULL
&& h
->def_dynamic
;
904 static struct bfd_hash_entry
*
905 elf64_ia64_new_elf_hash_entry (struct bfd_hash_entry
*entry
,
906 struct bfd_hash_table
*table
,
909 struct elf64_ia64_link_hash_entry
*ret
;
910 ret
= (struct elf64_ia64_link_hash_entry
*) entry
;
912 /* Allocate the structure if it has not already been allocated by a
915 ret
= bfd_hash_allocate (table
, sizeof (*ret
));
920 /* Call the allocation method of the superclass. */
921 ret
= ((struct elf64_ia64_link_hash_entry
*)
922 _bfd_elf_link_hash_newfunc ((struct bfd_hash_entry
*) ret
,
927 ret
->sorted_count
= 0;
929 return (struct bfd_hash_entry
*) ret
;
933 elf64_ia64_hash_hide_symbol (struct bfd_link_info
*info
,
934 struct elf_link_hash_entry
*xh
,
935 bfd_boolean force_local
)
937 struct elf64_ia64_link_hash_entry
*h
;
938 struct elf64_ia64_dyn_sym_info
*dyn_i
;
941 h
= (struct elf64_ia64_link_hash_entry
*)xh
;
943 _bfd_elf_link_hash_hide_symbol (info
, &h
->root
, force_local
);
945 for (count
= h
->count
, dyn_i
= h
->info
;
949 dyn_i
->want_plt2
= 0;
954 /* Compute a hash of a local hash entry. */
957 elf64_ia64_local_htab_hash (const void *ptr
)
959 struct elf64_ia64_local_hash_entry
*entry
960 = (struct elf64_ia64_local_hash_entry
*) ptr
;
962 return ELF_LOCAL_SYMBOL_HASH (entry
->id
, entry
->r_sym
);
965 /* Compare local hash entries. */
968 elf64_ia64_local_htab_eq (const void *ptr1
, const void *ptr2
)
970 struct elf64_ia64_local_hash_entry
*entry1
971 = (struct elf64_ia64_local_hash_entry
*) ptr1
;
972 struct elf64_ia64_local_hash_entry
*entry2
973 = (struct elf64_ia64_local_hash_entry
*) ptr2
;
975 return entry1
->id
== entry2
->id
&& entry1
->r_sym
== entry2
->r_sym
;
978 /* Free the global elf64_ia64_dyn_sym_info array. */
981 elf64_ia64_global_dyn_info_free (void **xentry
,
982 void * unused ATTRIBUTE_UNUSED
)
984 struct elf64_ia64_link_hash_entry
*entry
985 = (struct elf64_ia64_link_hash_entry
*) xentry
;
987 if (entry
->root
.root
.type
== bfd_link_hash_warning
)
988 entry
= (struct elf64_ia64_link_hash_entry
*) entry
->root
.root
.u
.i
.link
;
995 entry
->sorted_count
= 0;
1002 /* Free the local elf64_ia64_dyn_sym_info array. */
1005 elf64_ia64_local_dyn_info_free (void **slot
,
1006 void * unused ATTRIBUTE_UNUSED
)
1008 struct elf64_ia64_local_hash_entry
*entry
1009 = (struct elf64_ia64_local_hash_entry
*) *slot
;
1016 entry
->sorted_count
= 0;
1023 /* Destroy IA-64 linker hash table. */
1026 elf64_ia64_link_hash_table_free (bfd
*obfd
)
1028 struct elf64_ia64_link_hash_table
*ia64_info
1029 = (struct elf64_ia64_link_hash_table
*) obfd
->link
.hash
;
1030 if (ia64_info
->loc_hash_table
)
1032 htab_traverse (ia64_info
->loc_hash_table
,
1033 elf64_ia64_local_dyn_info_free
, NULL
);
1034 htab_delete (ia64_info
->loc_hash_table
);
1036 if (ia64_info
->loc_hash_memory
)
1037 objalloc_free ((struct objalloc
*) ia64_info
->loc_hash_memory
);
1038 elf_link_hash_traverse (&ia64_info
->root
,
1039 elf64_ia64_global_dyn_info_free
, NULL
);
1040 _bfd_elf_link_hash_table_free (obfd
);
1043 /* Create the derived linker hash table. The IA-64 ELF port uses this
1044 derived hash table to keep information specific to the IA-64 ElF
1045 linker (without using static variables). */
1047 static struct bfd_link_hash_table
*
1048 elf64_ia64_hash_table_create (bfd
*abfd
)
1050 struct elf64_ia64_link_hash_table
*ret
;
1052 ret
= bfd_zmalloc ((bfd_size_type
) sizeof (*ret
));
1056 if (!_bfd_elf_link_hash_table_init (&ret
->root
, abfd
,
1057 elf64_ia64_new_elf_hash_entry
,
1058 sizeof (struct elf64_ia64_link_hash_entry
),
1065 ret
->loc_hash_table
= htab_try_create (1024, elf64_ia64_local_htab_hash
,
1066 elf64_ia64_local_htab_eq
, NULL
);
1067 ret
->loc_hash_memory
= objalloc_create ();
1068 if (!ret
->loc_hash_table
|| !ret
->loc_hash_memory
)
1070 elf64_ia64_link_hash_table_free (abfd
);
1073 ret
->root
.root
.hash_table_free
= elf64_ia64_link_hash_table_free
;
1075 return &ret
->root
.root
;
1078 /* Traverse both local and global hash tables. */
1080 struct elf64_ia64_dyn_sym_traverse_data
1082 bfd_boolean (*func
) (struct elf64_ia64_dyn_sym_info
*, void *);
1087 elf64_ia64_global_dyn_sym_thunk (struct bfd_hash_entry
*xentry
,
1090 struct elf64_ia64_link_hash_entry
*entry
1091 = (struct elf64_ia64_link_hash_entry
*) xentry
;
1092 struct elf64_ia64_dyn_sym_traverse_data
*data
1093 = (struct elf64_ia64_dyn_sym_traverse_data
*) xdata
;
1094 struct elf64_ia64_dyn_sym_info
*dyn_i
;
1097 if (entry
->root
.root
.type
== bfd_link_hash_warning
)
1098 entry
= (struct elf64_ia64_link_hash_entry
*) entry
->root
.root
.u
.i
.link
;
1100 for (count
= entry
->count
, dyn_i
= entry
->info
;
1103 if (! (*data
->func
) (dyn_i
, data
->data
))
1109 elf64_ia64_local_dyn_sym_thunk (void **slot
, void * xdata
)
1111 struct elf64_ia64_local_hash_entry
*entry
1112 = (struct elf64_ia64_local_hash_entry
*) *slot
;
1113 struct elf64_ia64_dyn_sym_traverse_data
*data
1114 = (struct elf64_ia64_dyn_sym_traverse_data
*) xdata
;
1115 struct elf64_ia64_dyn_sym_info
*dyn_i
;
1118 for (count
= entry
->count
, dyn_i
= entry
->info
;
1121 if (! (*data
->func
) (dyn_i
, data
->data
))
1127 elf64_ia64_dyn_sym_traverse (struct elf64_ia64_link_hash_table
*ia64_info
,
1128 bfd_boolean (*func
) (struct elf64_ia64_dyn_sym_info
*, void *),
1131 struct elf64_ia64_dyn_sym_traverse_data xdata
;
1136 elf_link_hash_traverse (&ia64_info
->root
,
1137 elf64_ia64_global_dyn_sym_thunk
, &xdata
);
1138 htab_traverse (ia64_info
->loc_hash_table
,
1139 elf64_ia64_local_dyn_sym_thunk
, &xdata
);
1142 #define NOTE_NAME "IPF/VMS"
1145 create_ia64_vms_notes (bfd
*abfd
, struct bfd_link_info
*info
,
1146 unsigned int time_hi
, unsigned int time_lo
)
1149 Elf_Internal_Note notes
[NBR_NOTES
];
1151 int module_name_len
;
1152 unsigned char cur_time
[8];
1153 Elf64_External_VMS_ORIG_DYN_Note
*orig_dyn
;
1154 unsigned int orig_dyn_size
;
1155 unsigned int note_size
;
1157 unsigned char *noteptr
;
1158 unsigned char *note_contents
;
1159 struct elf64_ia64_link_hash_table
*ia64_info
;
1161 ia64_info
= elf64_ia64_hash_table (info
);
1163 module_name
= vms_get_module_name (bfd_get_filename (abfd
), TRUE
);
1164 module_name_len
= strlen (module_name
) + 1;
1166 bfd_putl32 (time_lo
, cur_time
+ 0);
1167 bfd_putl32 (time_hi
, cur_time
+ 4);
1169 /* Note 0: IMGNAM. */
1170 notes
[0].type
= NT_VMS_IMGNAM
;
1171 notes
[0].descdata
= module_name
;
1172 notes
[0].descsz
= module_name_len
;
1174 /* Note 1: GSTNAM. */
1175 notes
[1].type
= NT_VMS_GSTNAM
;
1176 notes
[1].descdata
= module_name
;
1177 notes
[1].descsz
= module_name_len
;
1179 /* Note 2: IMGID. */
1180 #define IMG_ID "V1.0"
1181 notes
[2].type
= NT_VMS_IMGID
;
1182 notes
[2].descdata
= IMG_ID
;
1183 notes
[2].descsz
= sizeof (IMG_ID
);
1185 /* Note 3: Linktime. */
1186 notes
[3].type
= NT_VMS_LINKTIME
;
1187 notes
[3].descdata
= (char *)cur_time
;
1188 notes
[3].descsz
= sizeof (cur_time
);
1190 /* Note 4: Linker id. */
1191 notes
[4].type
= NT_VMS_LINKID
;
1192 notes
[4].descdata
= "GNU ld " BFD_VERSION_STRING
;
1193 notes
[4].descsz
= strlen (notes
[4].descdata
) + 1;
1195 /* Note 5: Original dyn. */
1196 orig_dyn_size
= (sizeof (*orig_dyn
) + sizeof (IMG_ID
) - 1 + 7) & ~7;
1197 orig_dyn
= bfd_zalloc (abfd
, orig_dyn_size
);
1198 if (orig_dyn
== NULL
)
1200 bfd_putl32 (1, orig_dyn
->major_id
);
1201 bfd_putl32 (3, orig_dyn
->minor_id
);
1202 memcpy (orig_dyn
->manipulation_date
, cur_time
, sizeof (cur_time
));
1203 bfd_putl64 (VMS_LF_IMGSTA
| VMS_LF_MAIN
, orig_dyn
->link_flags
);
1204 bfd_putl32 (EF_IA_64_ABI64
, orig_dyn
->elf_flags
);
1205 memcpy (orig_dyn
->imgid
, IMG_ID
, sizeof (IMG_ID
));
1206 notes
[5].type
= NT_VMS_ORIG_DYN
;
1207 notes
[5].descdata
= (char *)orig_dyn
;
1208 notes
[5].descsz
= orig_dyn_size
;
1210 /* Note 3: Patchtime. */
1211 notes
[6].type
= NT_VMS_PATCHTIME
;
1212 notes
[6].descdata
= (char *)cur_time
;
1213 notes
[6].descsz
= sizeof (cur_time
);
1215 /* Compute notes size. */
1217 for (i
= 0; i
< NBR_NOTES
; i
++)
1218 note_size
+= sizeof (Elf64_External_VMS_Note
) - 1
1219 + ((sizeof (NOTE_NAME
) - 1 + 7) & ~7)
1220 + ((notes
[i
].descsz
+ 7) & ~7);
1222 /* Malloc a temporary buffer large enough for most notes */
1223 note_contents
= (unsigned char *) bfd_zalloc (abfd
, note_size
);
1224 if (note_contents
== NULL
)
1226 noteptr
= note_contents
;
1229 for (i
= 0; i
< NBR_NOTES
; i
++)
1231 Elf64_External_VMS_Note
*enote
= (Elf64_External_VMS_Note
*) noteptr
;
1233 bfd_putl64 (sizeof (NOTE_NAME
) - 1, enote
->namesz
);
1234 bfd_putl64 (notes
[i
].descsz
, enote
->descsz
);
1235 bfd_putl64 (notes
[i
].type
, enote
->type
);
1237 noteptr
= (unsigned char *)enote
->name
;
1238 memcpy (noteptr
, NOTE_NAME
, sizeof (NOTE_NAME
) - 1);
1239 noteptr
+= (sizeof (NOTE_NAME
) - 1 + 7) & ~7;
1240 memcpy (noteptr
, notes
[i
].descdata
, notes
[i
].descsz
);
1241 noteptr
+= (notes
[i
].descsz
+ 7) & ~7;
1244 ia64_info
->note_sec
->contents
= note_contents
;
1245 ia64_info
->note_sec
->size
= note_size
;
1253 elf64_ia64_create_dynamic_sections (bfd
*abfd
,
1254 struct bfd_link_info
*info
)
1256 struct elf64_ia64_link_hash_table
*ia64_info
;
1259 const struct elf_backend_data
*bed
;
1261 ia64_info
= elf64_ia64_hash_table (info
);
1262 if (ia64_info
== NULL
)
1265 if (elf_hash_table (info
)->dynamic_sections_created
)
1268 abfd
= elf_hash_table (info
)->dynobj
;
1269 bed
= get_elf_backend_data (abfd
);
1271 flags
= bed
->dynamic_sec_flags
;
1273 s
= bfd_make_section_anyway_with_flags (abfd
, ".dynamic",
1274 flags
| SEC_READONLY
);
1276 || ! bfd_set_section_alignment (abfd
, s
, bed
->s
->log_file_align
))
1279 s
= bfd_make_section_anyway_with_flags (abfd
, ".plt", flags
| SEC_READONLY
);
1281 || ! bfd_set_section_alignment (abfd
, s
, bed
->plt_alignment
))
1283 ia64_info
->root
.splt
= s
;
1285 if (!get_got (abfd
, ia64_info
))
1288 if (!get_pltoff (abfd
, ia64_info
))
1291 s
= bfd_make_section_anyway_with_flags (abfd
, ".vmsdynstr",
1295 | SEC_LINKER_CREATED
));
1297 || !bfd_set_section_alignment (abfd
, s
, 0))
1300 /* Create a fixup section. */
1301 s
= bfd_make_section_anyway_with_flags (abfd
, ".fixups",
1305 | SEC_LINKER_CREATED
));
1307 || !bfd_set_section_alignment (abfd
, s
, 3))
1309 ia64_info
->fixups_sec
= s
;
1311 /* Create the transfer fixup section. */
1312 s
= bfd_make_section_anyway_with_flags (abfd
, ".transfer",
1316 | SEC_LINKER_CREATED
));
1318 || !bfd_set_section_alignment (abfd
, s
, 3))
1320 s
->size
= sizeof (struct elf64_vms_transfer
);
1321 ia64_info
->transfer_sec
= s
;
1323 /* Create note section. */
1324 s
= bfd_make_section_anyway_with_flags (abfd
, ".vms.note",
1330 || !bfd_set_section_alignment (abfd
, s
, 3))
1332 ia64_info
->note_sec
= s
;
1334 elf_hash_table (info
)->dynamic_sections_created
= TRUE
;
1338 /* Find and/or create a hash entry for local symbol. */
1339 static struct elf64_ia64_local_hash_entry
*
1340 get_local_sym_hash (struct elf64_ia64_link_hash_table
*ia64_info
,
1341 bfd
*abfd
, const Elf_Internal_Rela
*rel
,
1344 struct elf64_ia64_local_hash_entry e
, *ret
;
1345 asection
*sec
= abfd
->sections
;
1346 hashval_t h
= ELF_LOCAL_SYMBOL_HASH (sec
->id
,
1347 ELF64_R_SYM (rel
->r_info
));
1351 e
.r_sym
= ELF64_R_SYM (rel
->r_info
);
1352 slot
= htab_find_slot_with_hash (ia64_info
->loc_hash_table
, &e
, h
,
1353 create
? INSERT
: NO_INSERT
);
1359 return (struct elf64_ia64_local_hash_entry
*) *slot
;
1361 ret
= (struct elf64_ia64_local_hash_entry
*)
1362 objalloc_alloc ((struct objalloc
*) ia64_info
->loc_hash_memory
,
1363 sizeof (struct elf64_ia64_local_hash_entry
));
1366 memset (ret
, 0, sizeof (*ret
));
1368 ret
->r_sym
= ELF64_R_SYM (rel
->r_info
);
1374 /* Used to sort elf64_ia64_dyn_sym_info array. */
1377 addend_compare (const void *xp
, const void *yp
)
1379 const struct elf64_ia64_dyn_sym_info
*x
1380 = (const struct elf64_ia64_dyn_sym_info
*) xp
;
1381 const struct elf64_ia64_dyn_sym_info
*y
1382 = (const struct elf64_ia64_dyn_sym_info
*) yp
;
1384 return x
->addend
< y
->addend
? -1 : x
->addend
> y
->addend
? 1 : 0;
1387 /* Sort elf64_ia64_dyn_sym_info array and remove duplicates. */
1390 sort_dyn_sym_info (struct elf64_ia64_dyn_sym_info
*info
,
1393 bfd_vma curr
, prev
, got_offset
;
1394 unsigned int i
, kept
, dupes
, diff
, dest
, src
, len
;
1396 qsort (info
, count
, sizeof (*info
), addend_compare
);
1398 /* Find the first duplicate. */
1399 prev
= info
[0].addend
;
1400 got_offset
= info
[0].got_offset
;
1401 for (i
= 1; i
< count
; i
++)
1403 curr
= info
[i
].addend
;
1406 /* For duplicates, make sure that GOT_OFFSET is valid. */
1407 if (got_offset
== (bfd_vma
) -1)
1408 got_offset
= info
[i
].got_offset
;
1411 got_offset
= info
[i
].got_offset
;
1415 /* We may move a block of elements to here. */
1418 /* Remove duplicates. */
1423 /* For duplicates, make sure that the kept one has a valid
1426 if (got_offset
!= (bfd_vma
) -1)
1427 info
[kept
].got_offset
= got_offset
;
1429 curr
= info
[i
].addend
;
1430 got_offset
= info
[i
].got_offset
;
1432 /* Move a block of elements whose first one is different from
1436 for (src
= i
+ 1; src
< count
; src
++)
1438 if (info
[src
].addend
!= curr
)
1440 /* For duplicates, make sure that GOT_OFFSET is
1442 if (got_offset
== (bfd_vma
) -1)
1443 got_offset
= info
[src
].got_offset
;
1446 /* Make sure that the kept one has a valid got_offset. */
1447 if (got_offset
!= (bfd_vma
) -1)
1448 info
[kept
].got_offset
= got_offset
;
1456 /* Find the next duplicate. SRC will be kept. */
1457 prev
= info
[src
].addend
;
1458 got_offset
= info
[src
].got_offset
;
1459 for (dupes
= src
+ 1; dupes
< count
; dupes
++)
1461 curr
= info
[dupes
].addend
;
1464 /* Make sure that got_offset is valid. */
1465 if (got_offset
== (bfd_vma
) -1)
1466 got_offset
= info
[dupes
].got_offset
;
1468 /* For duplicates, make sure that the kept one has
1469 a valid got_offset. */
1470 if (got_offset
!= (bfd_vma
) -1)
1471 info
[dupes
- 1].got_offset
= got_offset
;
1474 got_offset
= info
[dupes
].got_offset
;
1478 /* How much to move. */
1482 if (len
== 1 && dupes
< count
)
1484 /* If we only move 1 element, we combine it with the next
1485 one. There must be at least a duplicate. Find the
1486 next different one. */
1487 for (diff
= dupes
+ 1, src
++; diff
< count
; diff
++, src
++)
1489 if (info
[diff
].addend
!= curr
)
1491 /* Make sure that got_offset is valid. */
1492 if (got_offset
== (bfd_vma
) -1)
1493 got_offset
= info
[diff
].got_offset
;
1496 /* Makre sure that the last duplicated one has an valid
1498 BFD_ASSERT (curr
== prev
);
1499 if (got_offset
!= (bfd_vma
) -1)
1500 info
[diff
- 1].got_offset
= got_offset
;
1504 /* Find the next duplicate. Track the current valid
1506 prev
= info
[diff
].addend
;
1507 got_offset
= info
[diff
].got_offset
;
1508 for (dupes
= diff
+ 1; dupes
< count
; dupes
++)
1510 curr
= info
[dupes
].addend
;
1513 /* For duplicates, make sure that GOT_OFFSET
1515 if (got_offset
== (bfd_vma
) -1)
1516 got_offset
= info
[dupes
].got_offset
;
1519 got_offset
= info
[dupes
].got_offset
;
1524 len
= diff
- src
+ 1;
1529 memmove (&info
[dest
], &info
[src
], len
* sizeof (*info
));
1538 /* When we get here, either there is no duplicate at all or
1539 the only duplicate is the last element. */
1542 /* If the last element is a duplicate, make sure that the
1543 kept one has a valid got_offset. We also update count. */
1544 if (got_offset
!= (bfd_vma
) -1)
1545 info
[dest
- 1].got_offset
= got_offset
;
1553 /* Find and/or create a descriptor for dynamic symbol info. This will
1554 vary based on global or local symbol, and the addend to the reloc.
1556 We don't sort when inserting. Also, we sort and eliminate
1557 duplicates if there is an unsorted section. Typically, this will
1558 only happen once, because we do all insertions before lookups. We
1559 then use bsearch to do a lookup. This also allows lookups to be
1560 fast. So we have fast insertion (O(log N) due to duplicate check),
1561 fast lookup (O(log N)) and one sort (O(N log N) expected time).
1562 Previously, all lookups were O(N) because of the use of the linked
1563 list and also all insertions were O(N) because of the check for
1564 duplicates. There are some complications here because the array
1565 size grows occasionally, which may add an O(N) factor, but this
1566 should be rare. Also, we free the excess array allocation, which
1567 requires a copy which is O(N), but this only happens once. */
1569 static struct elf64_ia64_dyn_sym_info
*
1570 get_dyn_sym_info (struct elf64_ia64_link_hash_table
*ia64_info
,
1571 struct elf_link_hash_entry
*h
, bfd
*abfd
,
1572 const Elf_Internal_Rela
*rel
, bfd_boolean create
)
1574 struct elf64_ia64_dyn_sym_info
**info_p
, *info
, *dyn_i
, key
;
1575 unsigned int *count_p
, *sorted_count_p
, *size_p
;
1576 unsigned int count
, sorted_count
, size
;
1577 bfd_vma addend
= rel
? rel
->r_addend
: 0;
1582 struct elf64_ia64_link_hash_entry
*global_h
;
1584 global_h
= (struct elf64_ia64_link_hash_entry
*) h
;
1585 info_p
= &global_h
->info
;
1586 count_p
= &global_h
->count
;
1587 sorted_count_p
= &global_h
->sorted_count
;
1588 size_p
= &global_h
->size
;
1592 struct elf64_ia64_local_hash_entry
*loc_h
;
1594 loc_h
= get_local_sym_hash (ia64_info
, abfd
, rel
, create
);
1597 BFD_ASSERT (!create
);
1601 info_p
= &loc_h
->info
;
1602 count_p
= &loc_h
->count
;
1603 sorted_count_p
= &loc_h
->sorted_count
;
1604 size_p
= &loc_h
->size
;
1608 sorted_count
= *sorted_count_p
;
1613 /* When we create the array, we don't check for duplicates,
1614 except in the previously sorted section if one exists, and
1615 against the last inserted entry. This allows insertions to
1621 /* Try bsearch first on the sorted section. */
1622 key
.addend
= addend
;
1623 dyn_i
= bsearch (&key
, info
, sorted_count
,
1624 sizeof (*info
), addend_compare
);
1632 /* Do a quick check for the last inserted entry. */
1633 dyn_i
= info
+ count
- 1;
1634 if (dyn_i
->addend
== addend
)
1642 /* It is the very first element. We create the array of size
1645 amt
= size
* sizeof (*info
);
1646 info
= bfd_malloc (amt
);
1648 else if (size
<= count
)
1650 /* We double the array size every time when we reach the
1653 amt
= size
* sizeof (*info
);
1654 info
= bfd_realloc (info
, amt
);
1665 /* Append the new one to the array. */
1666 dyn_i
= info
+ count
;
1667 memset (dyn_i
, 0, sizeof (*dyn_i
));
1668 dyn_i
->got_offset
= (bfd_vma
) -1;
1669 dyn_i
->addend
= addend
;
1671 /* We increment count only since the new ones are unsorted and
1672 may have duplicate. */
1677 /* It is a lookup without insertion. Sort array if part of the
1678 array isn't sorted. */
1679 if (count
!= sorted_count
)
1681 count
= sort_dyn_sym_info (info
, count
);
1683 *sorted_count_p
= count
;
1686 /* Free unused memory. */
1689 amt
= count
* sizeof (*info
);
1690 info
= bfd_malloc (amt
);
1693 memcpy (info
, *info_p
, amt
);
1700 key
.addend
= addend
;
1701 dyn_i
= bsearch (&key
, info
, count
,
1702 sizeof (*info
), addend_compare
);
1709 get_got (bfd
*abfd
, struct elf64_ia64_link_hash_table
*ia64_info
)
1714 got
= ia64_info
->root
.sgot
;
1719 dynobj
= ia64_info
->root
.dynobj
;
1721 ia64_info
->root
.dynobj
= dynobj
= abfd
;
1723 /* The .got section is always aligned at 8 bytes. */
1724 flags
= get_elf_backend_data (dynobj
)->dynamic_sec_flags
;
1725 got
= bfd_make_section_anyway_with_flags (dynobj
, ".got",
1726 flags
| SEC_SMALL_DATA
);
1728 || !bfd_set_section_alignment (dynobj
, got
, 3))
1730 ia64_info
->root
.sgot
= got
;
1736 /* Create function descriptor section (.opd). This section is called .opd
1737 because it contains "official procedure descriptors". The "official"
1738 refers to the fact that these descriptors are used when taking the address
1739 of a procedure, thus ensuring a unique address for each procedure. */
1742 get_fptr (bfd
*abfd
, struct bfd_link_info
*info
,
1743 struct elf64_ia64_link_hash_table
*ia64_info
)
1748 fptr
= ia64_info
->fptr_sec
;
1751 dynobj
= ia64_info
->root
.dynobj
;
1753 ia64_info
->root
.dynobj
= dynobj
= abfd
;
1755 fptr
= bfd_make_section_anyway_with_flags (dynobj
, ".opd",
1760 | (bfd_link_pie (info
) ? 0
1762 | SEC_LINKER_CREATED
));
1764 || !bfd_set_section_alignment (dynobj
, fptr
, 4))
1770 ia64_info
->fptr_sec
= fptr
;
1772 if (bfd_link_pie (info
))
1775 fptr_rel
= bfd_make_section_anyway_with_flags (dynobj
, ".rela.opd",
1776 (SEC_ALLOC
| SEC_LOAD
1779 | SEC_LINKER_CREATED
1781 if (fptr_rel
== NULL
1782 || !bfd_set_section_alignment (dynobj
, fptr_rel
, 3))
1788 ia64_info
->rel_fptr_sec
= fptr_rel
;
1796 get_pltoff (bfd
*abfd
, struct elf64_ia64_link_hash_table
*ia64_info
)
1801 pltoff
= ia64_info
->pltoff_sec
;
1804 dynobj
= ia64_info
->root
.dynobj
;
1806 ia64_info
->root
.dynobj
= dynobj
= abfd
;
1808 pltoff
= bfd_make_section_anyway_with_flags (dynobj
,
1809 ELF_STRING_ia64_pltoff
,
1815 | SEC_LINKER_CREATED
));
1817 || !bfd_set_section_alignment (dynobj
, pltoff
, 4))
1823 ia64_info
->pltoff_sec
= pltoff
;
1830 get_reloc_section (bfd
*abfd
,
1831 struct elf64_ia64_link_hash_table
*ia64_info
,
1832 asection
*sec
, bfd_boolean create
)
1834 const char *srel_name
;
1838 srel_name
= (bfd_elf_string_from_elf_section
1839 (abfd
, elf_elfheader(abfd
)->e_shstrndx
,
1840 _bfd_elf_single_rel_hdr (sec
)->sh_name
));
1841 if (srel_name
== NULL
)
1844 BFD_ASSERT ((CONST_STRNEQ (srel_name
, ".rela")
1845 && strcmp (bfd_get_section_name (abfd
, sec
),
1847 || (CONST_STRNEQ (srel_name
, ".rel")
1848 && strcmp (bfd_get_section_name (abfd
, sec
),
1849 srel_name
+4) == 0));
1851 dynobj
= ia64_info
->root
.dynobj
;
1853 ia64_info
->root
.dynobj
= dynobj
= abfd
;
1855 srel
= bfd_get_linker_section (dynobj
, srel_name
);
1856 if (srel
== NULL
&& create
)
1858 srel
= bfd_make_section_anyway_with_flags (dynobj
, srel_name
,
1859 (SEC_ALLOC
| SEC_LOAD
1862 | SEC_LINKER_CREATED
1865 || !bfd_set_section_alignment (dynobj
, srel
, 3))
1873 count_dyn_reloc (bfd
*abfd
, struct elf64_ia64_dyn_sym_info
*dyn_i
,
1874 asection
*srel
, int type
)
1876 struct elf64_ia64_dyn_reloc_entry
*rent
;
1878 for (rent
= dyn_i
->reloc_entries
; rent
; rent
= rent
->next
)
1879 if (rent
->srel
== srel
&& rent
->type
== type
)
1884 rent
= ((struct elf64_ia64_dyn_reloc_entry
*)
1885 bfd_alloc (abfd
, (bfd_size_type
) sizeof (*rent
)));
1889 rent
->next
= dyn_i
->reloc_entries
;
1893 dyn_i
->reloc_entries
= rent
;
1901 elf64_ia64_check_relocs (bfd
*abfd
, struct bfd_link_info
*info
,
1903 const Elf_Internal_Rela
*relocs
)
1905 struct elf64_ia64_link_hash_table
*ia64_info
;
1906 const Elf_Internal_Rela
*relend
;
1907 Elf_Internal_Shdr
*symtab_hdr
;
1908 const Elf_Internal_Rela
*rel
;
1909 asection
*got
, *fptr
, *srel
, *pltoff
;
1918 NEED_LTOFF_FPTR
= 128
1921 struct elf_link_hash_entry
*h
;
1922 unsigned long r_symndx
;
1923 bfd_boolean maybe_dynamic
;
1925 if (bfd_link_relocatable (info
))
1928 symtab_hdr
= &elf_tdata (abfd
)->symtab_hdr
;
1929 ia64_info
= elf64_ia64_hash_table (info
);
1930 if (ia64_info
== NULL
)
1933 got
= fptr
= srel
= pltoff
= NULL
;
1935 relend
= relocs
+ sec
->reloc_count
;
1937 /* We scan relocations first to create dynamic relocation arrays. We
1938 modified get_dyn_sym_info to allow fast insertion and support fast
1939 lookup in the next loop. */
1940 for (rel
= relocs
; rel
< relend
; ++rel
)
1942 r_symndx
= ELF64_R_SYM (rel
->r_info
);
1943 if (r_symndx
>= symtab_hdr
->sh_info
)
1945 long indx
= r_symndx
- symtab_hdr
->sh_info
;
1946 h
= elf_sym_hashes (abfd
)[indx
];
1947 while (h
->root
.type
== bfd_link_hash_indirect
1948 || h
->root
.type
== bfd_link_hash_warning
)
1949 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
1954 /* We can only get preliminary data on whether a symbol is
1955 locally or externally defined, as not all of the input files
1956 have yet been processed. Do something with what we know, as
1957 this may help reduce memory usage and processing time later. */
1958 maybe_dynamic
= (h
&& ((!bfd_link_executable (info
)
1959 && (!SYMBOLIC_BIND (info
, h
)
1960 || info
->unresolved_syms_in_shared_libs
== RM_IGNORE
))
1962 || h
->root
.type
== bfd_link_hash_defweak
));
1965 switch (ELF64_R_TYPE (rel
->r_info
))
1967 case R_IA64_TPREL64MSB
:
1968 case R_IA64_TPREL64LSB
:
1969 case R_IA64_LTOFF_TPREL22
:
1970 case R_IA64_DTPREL32MSB
:
1971 case R_IA64_DTPREL32LSB
:
1972 case R_IA64_DTPREL64MSB
:
1973 case R_IA64_DTPREL64LSB
:
1974 case R_IA64_LTOFF_DTPREL22
:
1975 case R_IA64_DTPMOD64MSB
:
1976 case R_IA64_DTPMOD64LSB
:
1977 case R_IA64_LTOFF_DTPMOD22
:
1981 case R_IA64_IPLTMSB
:
1982 case R_IA64_IPLTLSB
:
1985 case R_IA64_LTOFF_FPTR22
:
1986 case R_IA64_LTOFF_FPTR64I
:
1987 case R_IA64_LTOFF_FPTR32MSB
:
1988 case R_IA64_LTOFF_FPTR32LSB
:
1989 case R_IA64_LTOFF_FPTR64MSB
:
1990 case R_IA64_LTOFF_FPTR64LSB
:
1991 need_entry
= NEED_FPTR
| NEED_GOT
| NEED_LTOFF_FPTR
;
1994 case R_IA64_FPTR64I
:
1995 case R_IA64_FPTR32MSB
:
1996 case R_IA64_FPTR32LSB
:
1997 case R_IA64_FPTR64MSB
:
1998 case R_IA64_FPTR64LSB
:
1999 if (bfd_link_pic (info
) || h
)
2000 need_entry
= NEED_FPTR
| NEED_DYNREL
;
2002 need_entry
= NEED_FPTR
;
2005 case R_IA64_LTOFF22
:
2006 case R_IA64_LTOFF64I
:
2007 need_entry
= NEED_GOT
;
2010 case R_IA64_LTOFF22X
:
2011 need_entry
= NEED_GOTX
;
2014 case R_IA64_PLTOFF22
:
2015 case R_IA64_PLTOFF64I
:
2016 case R_IA64_PLTOFF64MSB
:
2017 case R_IA64_PLTOFF64LSB
:
2018 need_entry
= NEED_PLTOFF
;
2022 need_entry
|= NEED_MIN_PLT
;
2026 (*info
->callbacks
->warning
)
2027 (info
, _("@pltoff reloc against local symbol"), 0,
2028 abfd
, 0, (bfd_vma
) 0);
2032 case R_IA64_PCREL21B
:
2033 case R_IA64_PCREL60B
:
2034 /* Depending on where this symbol is defined, we may or may not
2035 need a full plt entry. Only skip if we know we'll not need
2036 the entry -- static or symbolic, and the symbol definition
2037 has already been seen. */
2038 if (maybe_dynamic
&& rel
->r_addend
== 0)
2039 need_entry
= NEED_FULL_PLT
;
2045 case R_IA64_DIR32MSB
:
2046 case R_IA64_DIR32LSB
:
2047 case R_IA64_DIR64MSB
:
2048 case R_IA64_DIR64LSB
:
2049 /* Shared objects will always need at least a REL relocation. */
2050 if (bfd_link_pic (info
) || maybe_dynamic
)
2051 need_entry
= NEED_DYNREL
;
2054 case R_IA64_PCREL22
:
2055 case R_IA64_PCREL64I
:
2056 case R_IA64_PCREL32MSB
:
2057 case R_IA64_PCREL32LSB
:
2058 case R_IA64_PCREL64MSB
:
2059 case R_IA64_PCREL64LSB
:
2061 need_entry
= NEED_DYNREL
;
2068 if ((need_entry
& NEED_FPTR
) != 0
2071 (*info
->callbacks
->warning
)
2072 (info
, _("non-zero addend in @fptr reloc"), 0,
2073 abfd
, 0, (bfd_vma
) 0);
2076 if (get_dyn_sym_info (ia64_info
, h
, abfd
, rel
, TRUE
) == NULL
)
2080 /* Now, we only do lookup without insertion, which is very fast
2081 with the modified get_dyn_sym_info. */
2082 for (rel
= relocs
; rel
< relend
; ++rel
)
2084 struct elf64_ia64_dyn_sym_info
*dyn_i
;
2085 int dynrel_type
= R_IA64_NONE
;
2087 r_symndx
= ELF64_R_SYM (rel
->r_info
);
2088 if (r_symndx
>= symtab_hdr
->sh_info
)
2090 /* We're dealing with a global symbol -- find its hash entry
2091 and mark it as being referenced. */
2092 long indx
= r_symndx
- symtab_hdr
->sh_info
;
2093 h
= elf_sym_hashes (abfd
)[indx
];
2094 while (h
->root
.type
== bfd_link_hash_indirect
2095 || h
->root
.type
== bfd_link_hash_warning
)
2096 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
2098 /* PR15323, ref flags aren't set for references in the same
2100 h
->root
.non_ir_ref
= 1;
2106 /* We can only get preliminary data on whether a symbol is
2107 locally or externally defined, as not all of the input files
2108 have yet been processed. Do something with what we know, as
2109 this may help reduce memory usage and processing time later. */
2110 maybe_dynamic
= (h
&& ((!bfd_link_executable (info
)
2111 && (!SYMBOLIC_BIND (info
, h
)
2112 || info
->unresolved_syms_in_shared_libs
== RM_IGNORE
))
2114 || h
->root
.type
== bfd_link_hash_defweak
));
2117 switch (ELF64_R_TYPE (rel
->r_info
))
2119 case R_IA64_TPREL64MSB
:
2120 case R_IA64_TPREL64LSB
:
2121 case R_IA64_LTOFF_TPREL22
:
2122 case R_IA64_DTPREL32MSB
:
2123 case R_IA64_DTPREL32LSB
:
2124 case R_IA64_DTPREL64MSB
:
2125 case R_IA64_DTPREL64LSB
:
2126 case R_IA64_LTOFF_DTPREL22
:
2127 case R_IA64_DTPMOD64MSB
:
2128 case R_IA64_DTPMOD64LSB
:
2129 case R_IA64_LTOFF_DTPMOD22
:
2133 case R_IA64_LTOFF_FPTR22
:
2134 case R_IA64_LTOFF_FPTR64I
:
2135 case R_IA64_LTOFF_FPTR32MSB
:
2136 case R_IA64_LTOFF_FPTR32LSB
:
2137 case R_IA64_LTOFF_FPTR64MSB
:
2138 case R_IA64_LTOFF_FPTR64LSB
:
2139 need_entry
= NEED_FPTR
| NEED_GOT
| NEED_LTOFF_FPTR
;
2142 case R_IA64_FPTR64I
:
2143 case R_IA64_FPTR32MSB
:
2144 case R_IA64_FPTR32LSB
:
2145 case R_IA64_FPTR64MSB
:
2146 case R_IA64_FPTR64LSB
:
2147 if (bfd_link_pic (info
) || h
)
2148 need_entry
= NEED_FPTR
| NEED_DYNREL
;
2150 need_entry
= NEED_FPTR
;
2151 dynrel_type
= R_IA64_FPTR64LSB
;
2154 case R_IA64_LTOFF22
:
2155 case R_IA64_LTOFF64I
:
2156 need_entry
= NEED_GOT
;
2159 case R_IA64_LTOFF22X
:
2160 need_entry
= NEED_GOTX
;
2163 case R_IA64_PLTOFF22
:
2164 case R_IA64_PLTOFF64I
:
2165 case R_IA64_PLTOFF64MSB
:
2166 case R_IA64_PLTOFF64LSB
:
2167 need_entry
= NEED_PLTOFF
;
2171 need_entry
|= NEED_MIN_PLT
;
2175 case R_IA64_PCREL21B
:
2176 case R_IA64_PCREL60B
:
2177 /* Depending on where this symbol is defined, we may or may not
2178 need a full plt entry. Only skip if we know we'll not need
2179 the entry -- static or symbolic, and the symbol definition
2180 has already been seen. */
2181 if (maybe_dynamic
&& rel
->r_addend
== 0)
2182 need_entry
= NEED_FULL_PLT
;
2188 case R_IA64_DIR32MSB
:
2189 case R_IA64_DIR32LSB
:
2190 case R_IA64_DIR64MSB
:
2191 case R_IA64_DIR64LSB
:
2192 /* Shared objects will always need at least a REL relocation. */
2193 if (bfd_link_pic (info
) || maybe_dynamic
)
2194 need_entry
= NEED_DYNREL
;
2195 dynrel_type
= R_IA64_DIR64LSB
;
2198 case R_IA64_IPLTMSB
:
2199 case R_IA64_IPLTLSB
:
2202 case R_IA64_PCREL22
:
2203 case R_IA64_PCREL64I
:
2204 case R_IA64_PCREL32MSB
:
2205 case R_IA64_PCREL32LSB
:
2206 case R_IA64_PCREL64MSB
:
2207 case R_IA64_PCREL64LSB
:
2209 need_entry
= NEED_DYNREL
;
2210 dynrel_type
= R_IA64_PCREL64LSB
;
2217 dyn_i
= get_dyn_sym_info (ia64_info
, h
, abfd
, rel
, FALSE
);
2219 /* Record whether or not this is a local symbol. */
2222 /* Create what's needed. */
2223 if (need_entry
& (NEED_GOT
| NEED_GOTX
))
2227 got
= get_got (abfd
, ia64_info
);
2231 if (need_entry
& NEED_GOT
)
2232 dyn_i
->want_got
= 1;
2233 if (need_entry
& NEED_GOTX
)
2234 dyn_i
->want_gotx
= 1;
2236 if (need_entry
& NEED_FPTR
)
2238 /* Create the .opd section. */
2241 fptr
= get_fptr (abfd
, info
, ia64_info
);
2245 dyn_i
->want_fptr
= 1;
2247 if (need_entry
& NEED_LTOFF_FPTR
)
2248 dyn_i
->want_ltoff_fptr
= 1;
2249 if (need_entry
& (NEED_MIN_PLT
| NEED_FULL_PLT
))
2251 if (!ia64_info
->root
.dynobj
)
2252 ia64_info
->root
.dynobj
= abfd
;
2254 dyn_i
->want_plt
= 1;
2256 if (need_entry
& NEED_FULL_PLT
)
2257 dyn_i
->want_plt2
= 1;
2258 if (need_entry
& NEED_PLTOFF
)
2260 /* This is needed here, in case @pltoff is used in a non-shared
2264 pltoff
= get_pltoff (abfd
, ia64_info
);
2269 dyn_i
->want_pltoff
= 1;
2271 if ((need_entry
& NEED_DYNREL
) && (sec
->flags
& SEC_ALLOC
))
2275 srel
= get_reloc_section (abfd
, ia64_info
, sec
, TRUE
);
2279 if (!count_dyn_reloc (abfd
, dyn_i
, srel
, dynrel_type
))
2287 /* For cleanliness, and potentially faster dynamic loading, allocate
2288 external GOT entries first. */
2291 allocate_global_data_got (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2294 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*)data
;
2296 if ((dyn_i
->want_got
|| dyn_i
->want_gotx
)
2297 && ! dyn_i
->want_fptr
2298 && elf64_ia64_dynamic_symbol_p (dyn_i
->h
))
2300 /* GOT entry with FPTR is done by allocate_global_fptr_got. */
2301 dyn_i
->got_offset
= x
->ofs
;
2307 /* Next, allocate all the GOT entries used by LTOFF_FPTR relocs. */
2310 allocate_global_fptr_got (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2313 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*)data
;
2317 && elf64_ia64_dynamic_symbol_p (dyn_i
->h
))
2319 dyn_i
->got_offset
= x
->ofs
;
2325 /* Lastly, allocate all the GOT entries for local data. */
2328 allocate_local_got (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2331 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*) data
;
2333 if ((dyn_i
->want_got
|| dyn_i
->want_gotx
)
2334 && !elf64_ia64_dynamic_symbol_p (dyn_i
->h
))
2336 dyn_i
->got_offset
= x
->ofs
;
2342 /* Allocate function descriptors. We can do these for every function
2343 in a main executable that is not exported. */
2346 allocate_fptr (struct elf64_ia64_dyn_sym_info
*dyn_i
, void * data
)
2348 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*) data
;
2350 if (dyn_i
->want_fptr
)
2352 struct elf_link_hash_entry
*h
= dyn_i
->h
;
2355 while (h
->root
.type
== bfd_link_hash_indirect
2356 || h
->root
.type
== bfd_link_hash_warning
)
2357 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
2359 if (h
== NULL
|| !h
->def_dynamic
)
2361 /* A non dynamic symbol. */
2362 dyn_i
->fptr_offset
= x
->ofs
;
2366 dyn_i
->want_fptr
= 0;
2371 /* Allocate all the minimal PLT entries. */
2374 allocate_plt_entries (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2375 void * data ATTRIBUTE_UNUSED
)
2377 if (dyn_i
->want_plt
)
2379 struct elf_link_hash_entry
*h
= dyn_i
->h
;
2382 while (h
->root
.type
== bfd_link_hash_indirect
2383 || h
->root
.type
== bfd_link_hash_warning
)
2384 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
2386 /* ??? Versioned symbols seem to lose NEEDS_PLT. */
2387 if (elf64_ia64_dynamic_symbol_p (h
))
2389 dyn_i
->want_pltoff
= 1;
2393 dyn_i
->want_plt
= 0;
2394 dyn_i
->want_plt2
= 0;
2400 /* Allocate all the full PLT entries. */
2403 allocate_plt2_entries (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2406 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*)data
;
2408 if (dyn_i
->want_plt2
)
2410 struct elf_link_hash_entry
*h
= dyn_i
->h
;
2411 bfd_size_type ofs
= x
->ofs
;
2413 dyn_i
->plt2_offset
= ofs
;
2414 x
->ofs
= ofs
+ PLT_FULL_ENTRY_SIZE
;
2416 while (h
->root
.type
== bfd_link_hash_indirect
2417 || h
->root
.type
== bfd_link_hash_warning
)
2418 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
2419 dyn_i
->h
->plt
.offset
= ofs
;
2424 /* Allocate all the PLTOFF entries requested by relocations and
2425 plt entries. We can't share space with allocated FPTR entries,
2426 because the latter are not necessarily addressable by the GP.
2427 ??? Relaxation might be able to determine that they are. */
2430 allocate_pltoff_entries (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2433 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*)data
;
2435 if (dyn_i
->want_pltoff
)
2437 dyn_i
->pltoff_offset
= x
->ofs
;
2443 /* Allocate dynamic relocations for those symbols that turned out
2447 allocate_dynrel_entries (struct elf64_ia64_dyn_sym_info
*dyn_i
,
2450 struct elf64_ia64_allocate_data
*x
= (struct elf64_ia64_allocate_data
*)data
;
2451 struct elf64_ia64_link_hash_table
*ia64_info
;
2452 struct elf64_ia64_dyn_reloc_entry
*rent
;
2453 bfd_boolean dynamic_symbol
, shared
, resolved_zero
;
2454 struct elf64_ia64_link_hash_entry
*h_ia64
;
2456 ia64_info
= elf64_ia64_hash_table (x
->info
);
2457 if (ia64_info
== NULL
)
2460 /* Note that this can't be used in relation to FPTR relocs below. */
2461 dynamic_symbol
= elf64_ia64_dynamic_symbol_p (dyn_i
->h
);
2463 shared
= bfd_link_pic (x
->info
);
2464 resolved_zero
= (dyn_i
->h
2465 && ELF_ST_VISIBILITY (dyn_i
->h
->other
)
2466 && dyn_i
->h
->root
.type
== bfd_link_hash_undefweak
);
2468 /* Take care of the GOT and PLT relocations. */
2471 && (dynamic_symbol
|| shared
)
2472 && (dyn_i
->want_got
|| dyn_i
->want_gotx
))
2473 || (dyn_i
->want_ltoff_fptr
2475 && dyn_i
->h
->def_dynamic
))
2478 if (dyn_i
->h
!= NULL
&& dyn_i
->h
->def_dynamic
)
2480 h_ia64
= (struct elf64_ia64_link_hash_entry
*) dyn_i
->h
;
2481 elf_ia64_vms_tdata (h_ia64
->shl
)->fixups_off
+=
2482 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2483 ia64_info
->fixups_sec
->size
+=
2484 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2488 if (ia64_info
->rel_fptr_sec
&& dyn_i
->want_fptr
)
2490 /* VMS: only image reloc. */
2491 if (dyn_i
->h
== NULL
|| dyn_i
->h
->root
.type
!= bfd_link_hash_undefweak
)
2492 ia64_info
->rel_fptr_sec
->size
+= sizeof (Elf64_External_Rela
);
2495 if (!resolved_zero
&& dyn_i
->want_pltoff
)
2498 if (dyn_i
->h
!= NULL
&& dyn_i
->h
->def_dynamic
)
2500 h_ia64
= (struct elf64_ia64_link_hash_entry
*) dyn_i
->h
;
2501 elf_ia64_vms_tdata (h_ia64
->shl
)->fixups_off
+=
2502 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2503 ia64_info
->fixups_sec
->size
+=
2504 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2508 /* Take care of the normal data relocations. */
2510 for (rent
= dyn_i
->reloc_entries
; rent
; rent
= rent
->next
)
2512 int count
= rent
->count
;
2516 case R_IA64_FPTR32LSB
:
2517 case R_IA64_FPTR64LSB
:
2518 /* Allocate one iff !want_fptr and not PIE, which by this point
2519 will be true only if we're actually allocating one statically
2520 in the main executable. Position independent executables
2521 need a relative reloc. */
2522 if (dyn_i
->want_fptr
&& !bfd_link_pie (x
->info
))
2525 case R_IA64_PCREL32LSB
:
2526 case R_IA64_PCREL64LSB
:
2527 if (!dynamic_symbol
)
2530 case R_IA64_DIR32LSB
:
2531 case R_IA64_DIR64LSB
:
2532 if (!dynamic_symbol
&& !shared
)
2535 case R_IA64_IPLTLSB
:
2536 if (!dynamic_symbol
&& !shared
)
2538 /* Use two REL relocations for IPLT relocations
2539 against local symbols. */
2540 if (!dynamic_symbol
)
2543 case R_IA64_DTPREL32LSB
:
2544 case R_IA64_TPREL64LSB
:
2545 case R_IA64_DTPREL64LSB
:
2546 case R_IA64_DTPMOD64LSB
:
2553 if (!dynamic_symbol
)
2556 h_ia64
= (struct elf64_ia64_link_hash_entry
*) dyn_i
->h
;
2557 elf_ia64_vms_tdata (h_ia64
->shl
)->fixups_off
+=
2558 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2559 ia64_info
->fixups_sec
->size
+=
2560 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2567 elf64_ia64_adjust_dynamic_symbol (struct bfd_link_info
*info ATTRIBUTE_UNUSED
,
2568 struct elf_link_hash_entry
*h
)
2570 /* ??? Undefined symbols with PLT entries should be re-defined
2571 to be the PLT entry. */
2573 /* If this is a weak symbol, and there is a real definition, the
2574 processor independent code will have arranged for us to see the
2575 real definition first, and we can just use the same value. */
2576 if (h
->u
.weakdef
!= NULL
)
2578 BFD_ASSERT (h
->u
.weakdef
->root
.type
== bfd_link_hash_defined
2579 || h
->u
.weakdef
->root
.type
== bfd_link_hash_defweak
);
2580 h
->root
.u
.def
.section
= h
->u
.weakdef
->root
.u
.def
.section
;
2581 h
->root
.u
.def
.value
= h
->u
.weakdef
->root
.u
.def
.value
;
2585 /* If this is a reference to a symbol defined by a dynamic object which
2586 is not a function, we might allocate the symbol in our .dynbss section
2587 and allocate a COPY dynamic relocation.
2589 But IA-64 code is canonically PIC, so as a rule we can avoid this sort
2596 elf64_ia64_size_dynamic_sections (bfd
*output_bfd ATTRIBUTE_UNUSED
,
2597 struct bfd_link_info
*info
)
2599 struct elf64_ia64_allocate_data data
;
2600 struct elf64_ia64_link_hash_table
*ia64_info
;
2603 struct elf_link_hash_table
*hash_table
;
2605 hash_table
= elf_hash_table (info
);
2606 dynobj
= hash_table
->dynobj
;
2607 ia64_info
= elf64_ia64_hash_table (info
);
2608 if (ia64_info
== NULL
)
2610 BFD_ASSERT(dynobj
!= NULL
);
2613 /* Allocate the GOT entries. */
2615 if (ia64_info
->root
.sgot
)
2618 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_global_data_got
, &data
);
2619 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_global_fptr_got
, &data
);
2620 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_local_got
, &data
);
2621 ia64_info
->root
.sgot
->size
= data
.ofs
;
2624 /* Allocate the FPTR entries. */
2626 if (ia64_info
->fptr_sec
)
2629 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_fptr
, &data
);
2630 ia64_info
->fptr_sec
->size
= data
.ofs
;
2633 /* Now that we've seen all of the input files, we can decide which
2634 symbols need plt entries. Allocate the minimal PLT entries first.
2635 We do this even though dynamic_sections_created may be FALSE, because
2636 this has the side-effect of clearing want_plt and want_plt2. */
2639 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_plt_entries
, &data
);
2641 /* Align the pointer for the plt2 entries. */
2642 data
.ofs
= (data
.ofs
+ 31) & (bfd_vma
) -32;
2644 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_plt2_entries
, &data
);
2645 if (data
.ofs
!= 0 || ia64_info
->root
.dynamic_sections_created
)
2647 /* FIXME: we always reserve the memory for dynamic linker even if
2648 there are no PLT entries since dynamic linker may assume the
2649 reserved memory always exists. */
2651 BFD_ASSERT (ia64_info
->root
.dynamic_sections_created
);
2653 ia64_info
->root
.splt
->size
= data
.ofs
;
2656 /* Allocate the PLTOFF entries. */
2658 if (ia64_info
->pltoff_sec
)
2661 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_pltoff_entries
, &data
);
2662 ia64_info
->pltoff_sec
->size
= data
.ofs
;
2665 if (ia64_info
->root
.dynamic_sections_created
)
2667 /* Allocate space for the dynamic relocations that turned out to be
2669 elf64_ia64_dyn_sym_traverse (ia64_info
, allocate_dynrel_entries
, &data
);
2672 /* We have now determined the sizes of the various dynamic sections.
2673 Allocate memory for them. */
2674 for (sec
= dynobj
->sections
; sec
!= NULL
; sec
= sec
->next
)
2678 if (!(sec
->flags
& SEC_LINKER_CREATED
))
2681 /* If we don't need this section, strip it from the output file.
2682 There were several sections primarily related to dynamic
2683 linking that must be create before the linker maps input
2684 sections to output sections. The linker does that before
2685 bfd_elf_size_dynamic_sections is called, and it is that
2686 function which decides whether anything needs to go into
2689 strip
= (sec
->size
== 0);
2691 if (sec
== ia64_info
->root
.sgot
)
2693 else if (sec
== ia64_info
->root
.srelgot
)
2696 ia64_info
->root
.srelgot
= NULL
;
2698 /* We use the reloc_count field as a counter if we need to
2699 copy relocs into the output file. */
2700 sec
->reloc_count
= 0;
2702 else if (sec
== ia64_info
->fptr_sec
)
2705 ia64_info
->fptr_sec
= NULL
;
2707 else if (sec
== ia64_info
->rel_fptr_sec
)
2710 ia64_info
->rel_fptr_sec
= NULL
;
2712 /* We use the reloc_count field as a counter if we need to
2713 copy relocs into the output file. */
2714 sec
->reloc_count
= 0;
2716 else if (sec
== ia64_info
->root
.splt
)
2719 ia64_info
->root
.splt
= NULL
;
2721 else if (sec
== ia64_info
->pltoff_sec
)
2724 ia64_info
->pltoff_sec
= NULL
;
2726 else if (sec
== ia64_info
->fixups_sec
)
2729 ia64_info
->fixups_sec
= NULL
;
2731 else if (sec
== ia64_info
->transfer_sec
)
2739 /* It's OK to base decisions on the section name, because none
2740 of the dynobj section names depend upon the input files. */
2741 name
= bfd_get_section_name (dynobj
, sec
);
2743 if (strcmp (name
, ".got.plt") == 0)
2745 else if (CONST_STRNEQ (name
, ".rel"))
2749 /* We use the reloc_count field as a counter if we need to
2750 copy relocs into the output file. */
2751 sec
->reloc_count
= 0;
2759 sec
->flags
|= SEC_EXCLUDE
;
2762 /* Allocate memory for the section contents. */
2763 sec
->contents
= (bfd_byte
*) bfd_zalloc (dynobj
, sec
->size
);
2764 if (sec
->contents
== NULL
&& sec
->size
!= 0)
2769 if (elf_hash_table (info
)->dynamic_sections_created
)
2773 asection
*dynstrsec
;
2774 Elf_Internal_Dyn dyn
;
2775 const struct elf_backend_data
*bed
;
2776 unsigned int shl_num
= 0;
2777 bfd_vma fixups_off
= 0;
2779 unsigned int time_hi
, time_lo
;
2781 /* The .dynamic section must exist and be empty. */
2782 dynsec
= bfd_get_linker_section (hash_table
->dynobj
, ".dynamic");
2783 BFD_ASSERT (dynsec
!= NULL
);
2784 BFD_ASSERT (dynsec
->size
== 0);
2786 dynstrsec
= bfd_get_linker_section (hash_table
->dynobj
, ".vmsdynstr");
2787 BFD_ASSERT (dynstrsec
!= NULL
);
2788 BFD_ASSERT (dynstrsec
->size
== 0);
2789 dynstrsec
->size
= 1; /* Initial blank. */
2791 /* Ident + link time. */
2792 vms_get_time (&time_hi
, &time_lo
);
2794 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_IDENT
, 0))
2796 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_LINKTIME
,
2797 (((bfd_uint64_t
)time_hi
) << 32)
2802 strdyn_off
= dynsec
->size
;
2803 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_STRTAB_OFFSET
, 0))
2805 if (!_bfd_elf_add_dynamic_entry (info
, DT_STRSZ
, 0))
2809 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_PLTGOT_SEG
, 0))
2811 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_PLTGOT_OFFSET
, 0))
2815 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_FPMODE
, 0x9800000))
2817 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_LNKFLAGS
,
2818 VMS_LF_IMGSTA
| VMS_LF_MAIN
))
2821 /* Add entries for shared libraries. */
2822 for (abfd
= info
->input_bfds
; abfd
; abfd
= abfd
->link
.next
)
2826 bfd_size_type strindex
;
2827 bfd_byte
*newcontents
;
2828 bfd_vma fixups_shl_off
;
2830 if (!(abfd
->flags
& DYNAMIC
))
2832 BFD_ASSERT (abfd
->xvec
== output_bfd
->xvec
);
2834 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_NEEDED_IDENT
,
2835 elf_ia64_vms_ident (abfd
)))
2838 soname
= vms_get_module_name (abfd
->filename
, TRUE
);
2841 strindex
= dynstrsec
->size
;
2842 soname_len
= strlen (soname
) + 1;
2843 newcontents
= (bfd_byte
*) bfd_realloc (dynstrsec
->contents
,
2844 strindex
+ soname_len
);
2845 if (newcontents
== NULL
)
2847 memcpy (newcontents
+ strindex
, soname
, soname_len
);
2848 dynstrsec
->size
+= soname_len
;
2849 dynstrsec
->contents
= newcontents
;
2851 if (!_bfd_elf_add_dynamic_entry (info
, DT_NEEDED
, strindex
))
2854 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_FIXUP_NEEDED
,
2859 /* The fixups_off was in fact containing the size of the fixup
2860 section. Remap into the offset. */
2861 fixups_shl_off
= elf_ia64_vms_tdata (abfd
)->fixups_off
;
2862 elf_ia64_vms_tdata (abfd
)->fixups_off
= fixups_off
;
2864 if (!_bfd_elf_add_dynamic_entry
2865 (info
, DT_IA_64_VMS_FIXUP_RELA_CNT
,
2866 fixups_shl_off
/ sizeof (Elf64_External_VMS_IMAGE_FIXUP
)))
2868 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_FIXUP_RELA_OFF
,
2871 fixups_off
+= fixups_shl_off
;
2875 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_UNWINDSZ
, 0))
2877 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_UNWIND_CODSEG
, 0))
2879 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_UNWIND_INFOSEG
, 0))
2881 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_UNWIND_OFFSET
, 0))
2883 if (!_bfd_elf_add_dynamic_entry (info
, DT_IA_64_VMS_UNWIND_SEG
, 0))
2886 if (!_bfd_elf_add_dynamic_entry (info
, DT_NULL
, 0xdead))
2889 /* Fix the strtab entries. */
2890 bed
= get_elf_backend_data (hash_table
->dynobj
);
2892 if (dynstrsec
->size
> 1)
2893 dynstrsec
->contents
[0] = 0;
2895 dynstrsec
->size
= 0;
2897 /* Note: one 'spare' (ie DT_NULL) entry is added by
2898 bfd_elf_size_dynsym_hash_dynstr. */
2899 dyn
.d_tag
= DT_IA_64_VMS_STRTAB_OFFSET
;
2900 dyn
.d_un
.d_val
= dynsec
->size
/* + sizeof (Elf64_External_Dyn) */;
2901 bed
->s
->swap_dyn_out (hash_table
->dynobj
, &dyn
,
2902 dynsec
->contents
+ strdyn_off
);
2904 dyn
.d_tag
= DT_STRSZ
;
2905 dyn
.d_un
.d_val
= dynstrsec
->size
;
2906 bed
->s
->swap_dyn_out (hash_table
->dynobj
, &dyn
,
2907 dynsec
->contents
+ strdyn_off
+ bed
->s
->sizeof_dyn
);
2909 elf_ia64_vms_tdata (output_bfd
)->needed_count
= shl_num
;
2912 if (!create_ia64_vms_notes (output_bfd
, info
, time_hi
, time_lo
))
2916 /* ??? Perhaps force __gp local. */
2922 elf64_ia64_install_fixup (bfd
*output_bfd
,
2923 struct elf64_ia64_link_hash_table
*ia64_info
,
2924 struct elf_link_hash_entry
*h
,
2925 unsigned int type
, asection
*sec
, bfd_vma offset
,
2929 Elf64_External_VMS_IMAGE_FIXUP
*fixup
;
2930 struct elf64_ia64_link_hash_entry
*h_ia64
;
2932 Elf_Internal_Phdr
*phdr
;
2934 if (h
== NULL
|| !h
->def_dynamic
)
2937 h_ia64
= (struct elf64_ia64_link_hash_entry
*) h
;
2938 fixoff
= elf_ia64_vms_tdata (h_ia64
->shl
)->fixups_off
;
2939 elf_ia64_vms_tdata (h_ia64
->shl
)->fixups_off
+=
2940 sizeof (Elf64_External_VMS_IMAGE_FIXUP
);
2941 relsec
= ia64_info
->fixups_sec
;
2943 fixup
= (Elf64_External_VMS_IMAGE_FIXUP
*)(relsec
->contents
+ fixoff
);
2944 offset
+= sec
->output_section
->vma
+ sec
->output_offset
;
2946 /* FIXME: this is slow. We should cache the last one used, or create a
2948 phdr
= _bfd_elf_find_segment_containing_section
2949 (output_bfd
, sec
->output_section
);
2950 BFD_ASSERT (phdr
!= NULL
);
2952 bfd_putl64 (offset
- phdr
->p_vaddr
, fixup
->fixup_offset
);
2953 bfd_putl32 (type
, fixup
->type
);
2954 bfd_putl32 (phdr
- elf_tdata (output_bfd
)->phdr
, fixup
->fixup_seg
);
2955 bfd_putl64 (addend
, fixup
->addend
);
2956 bfd_putl32 (h
->root
.u
.def
.value
, fixup
->symvec_index
);
2957 bfd_putl32 (2, fixup
->data_type
);
2960 /* Store an entry for target address TARGET_ADDR in the linkage table
2961 and return the gp-relative address of the linkage table entry. */
2964 set_got_entry (bfd
*abfd
, struct bfd_link_info
*info
,
2965 struct elf64_ia64_dyn_sym_info
*dyn_i
,
2966 bfd_vma addend
, bfd_vma value
, unsigned int dyn_r_type
)
2968 struct elf64_ia64_link_hash_table
*ia64_info
;
2973 ia64_info
= elf64_ia64_hash_table (info
);
2974 if (ia64_info
== NULL
)
2977 got_sec
= ia64_info
->root
.sgot
;
2981 case R_IA64_TPREL64LSB
:
2982 case R_IA64_DTPMOD64LSB
:
2983 case R_IA64_DTPREL32LSB
:
2984 case R_IA64_DTPREL64LSB
:
2988 done
= dyn_i
->got_done
;
2989 dyn_i
->got_done
= TRUE
;
2990 got_offset
= dyn_i
->got_offset
;
2994 BFD_ASSERT ((got_offset
& 7) == 0);
2998 /* Store the target address in the linkage table entry. */
2999 bfd_put_64 (abfd
, value
, got_sec
->contents
+ got_offset
);
3001 /* Install a dynamic relocation if needed. */
3002 if (((bfd_link_pic (info
)
3004 || ELF_ST_VISIBILITY (dyn_i
->h
->other
) == STV_DEFAULT
3005 || dyn_i
->h
->root
.type
!= bfd_link_hash_undefweak
))
3006 || elf64_ia64_dynamic_symbol_p (dyn_i
->h
))
3007 && (!dyn_i
->want_ltoff_fptr
3008 || !bfd_link_pie (info
)
3010 || dyn_i
->h
->root
.type
!= bfd_link_hash_undefweak
))
3012 if (!dyn_i
->h
|| !dyn_i
->h
->def_dynamic
)
3014 dyn_r_type
= R_IA64_REL64LSB
;
3018 /* VMS: install a FIX32 or FIX64. */
3021 case R_IA64_DIR32LSB
:
3022 case R_IA64_FPTR32LSB
:
3023 dyn_r_type
= R_IA64_VMS_FIX32
;
3025 case R_IA64_DIR64LSB
:
3026 case R_IA64_FPTR64LSB
:
3027 dyn_r_type
= R_IA64_VMS_FIX64
;
3033 elf64_ia64_install_fixup
3034 (info
->output_bfd
, ia64_info
, dyn_i
->h
,
3035 dyn_r_type
, got_sec
, got_offset
, addend
);
3039 /* Return the address of the linkage table entry. */
3040 value
= (got_sec
->output_section
->vma
3041 + got_sec
->output_offset
3047 /* Fill in a function descriptor consisting of the function's code
3048 address and its global pointer. Return the descriptor's address. */
3051 set_fptr_entry (bfd
*abfd
, struct bfd_link_info
*info
,
3052 struct elf64_ia64_dyn_sym_info
*dyn_i
,
3055 struct elf64_ia64_link_hash_table
*ia64_info
;
3058 ia64_info
= elf64_ia64_hash_table (info
);
3059 if (ia64_info
== NULL
)
3062 fptr_sec
= ia64_info
->fptr_sec
;
3064 if (!dyn_i
->fptr_done
)
3066 dyn_i
->fptr_done
= 1;
3068 /* Fill in the function descriptor. */
3069 bfd_put_64 (abfd
, value
, fptr_sec
->contents
+ dyn_i
->fptr_offset
);
3070 bfd_put_64 (abfd
, _bfd_get_gp_value (abfd
),
3071 fptr_sec
->contents
+ dyn_i
->fptr_offset
+ 8);
3074 /* Return the descriptor's address. */
3075 value
= (fptr_sec
->output_section
->vma
3076 + fptr_sec
->output_offset
3077 + dyn_i
->fptr_offset
);
3082 /* Fill in a PLTOFF entry consisting of the function's code address
3083 and its global pointer. Return the descriptor's address. */
3086 set_pltoff_entry (bfd
*abfd
, struct bfd_link_info
*info
,
3087 struct elf64_ia64_dyn_sym_info
*dyn_i
,
3088 bfd_vma value
, bfd_boolean is_plt
)
3090 struct elf64_ia64_link_hash_table
*ia64_info
;
3091 asection
*pltoff_sec
;
3093 ia64_info
= elf64_ia64_hash_table (info
);
3094 if (ia64_info
== NULL
)
3097 pltoff_sec
= ia64_info
->pltoff_sec
;
3099 /* Don't do anything if this symbol uses a real PLT entry. In
3100 that case, we'll fill this in during finish_dynamic_symbol. */
3101 if ((! dyn_i
->want_plt
|| is_plt
)
3102 && !dyn_i
->pltoff_done
)
3104 bfd_vma gp
= _bfd_get_gp_value (abfd
);
3106 /* Fill in the function descriptor. */
3107 bfd_put_64 (abfd
, value
, pltoff_sec
->contents
+ dyn_i
->pltoff_offset
);
3108 bfd_put_64 (abfd
, gp
, pltoff_sec
->contents
+ dyn_i
->pltoff_offset
+ 8);
3110 /* Install dynamic relocations if needed. */
3112 && bfd_link_pic (info
)
3114 || ELF_ST_VISIBILITY (dyn_i
->h
->other
) == STV_DEFAULT
3115 || dyn_i
->h
->root
.type
!= bfd_link_hash_undefweak
))
3121 dyn_i
->pltoff_done
= 1;
3124 /* Return the descriptor's address. */
3125 value
= (pltoff_sec
->output_section
->vma
3126 + pltoff_sec
->output_offset
3127 + dyn_i
->pltoff_offset
);
3132 /* Called through qsort to sort the .IA_64.unwind section during a
3133 non-relocatable link. Set elf64_ia64_unwind_entry_compare_bfd
3134 to the output bfd so we can do proper endianness frobbing. */
3136 static bfd
*elf64_ia64_unwind_entry_compare_bfd
;
3139 elf64_ia64_unwind_entry_compare (const void * a
, const void * b
)
3143 av
= bfd_get_64 (elf64_ia64_unwind_entry_compare_bfd
, a
);
3144 bv
= bfd_get_64 (elf64_ia64_unwind_entry_compare_bfd
, b
);
3146 return (av
< bv
? -1 : av
> bv
? 1 : 0);
3149 /* Make sure we've got ourselves a nice fat __gp value. */
3151 elf64_ia64_choose_gp (bfd
*abfd
, struct bfd_link_info
*info
, bfd_boolean final
)
3153 bfd_vma min_vma
= (bfd_vma
) -1, max_vma
= 0;
3154 bfd_vma min_short_vma
= min_vma
, max_short_vma
= 0;
3155 struct elf_link_hash_entry
*gp
;
3158 struct elf64_ia64_link_hash_table
*ia64_info
;
3160 ia64_info
= elf64_ia64_hash_table (info
);
3161 if (ia64_info
== NULL
)
3164 /* Find the min and max vma of all sections marked short. Also collect
3165 min and max vma of any type, for use in selecting a nice gp. */
3166 for (os
= abfd
->sections
; os
; os
= os
->next
)
3170 if ((os
->flags
& SEC_ALLOC
) == 0)
3174 /* When this function is called from elfNN_ia64_final_link
3175 the correct value to use is os->size. When called from
3176 elfNN_ia64_relax_section we are in the middle of section
3177 sizing; some sections will already have os->size set, others
3178 will have os->size zero and os->rawsize the previous size. */
3179 hi
= os
->vma
+ (!final
&& os
->rawsize
? os
->rawsize
: os
->size
);
3187 if (os
->flags
& SEC_SMALL_DATA
)
3189 if (min_short_vma
> lo
)
3191 if (max_short_vma
< hi
)
3196 if (ia64_info
->min_short_sec
)
3199 > (ia64_info
->min_short_sec
->vma
3200 + ia64_info
->min_short_offset
))
3201 min_short_vma
= (ia64_info
->min_short_sec
->vma
3202 + ia64_info
->min_short_offset
);
3204 < (ia64_info
->max_short_sec
->vma
3205 + ia64_info
->max_short_offset
))
3206 max_short_vma
= (ia64_info
->max_short_sec
->vma
3207 + ia64_info
->max_short_offset
);
3210 /* See if the user wants to force a value. */
3211 gp
= elf_link_hash_lookup (elf_hash_table (info
), "__gp", FALSE
,
3215 && (gp
->root
.type
== bfd_link_hash_defined
3216 || gp
->root
.type
== bfd_link_hash_defweak
))
3218 asection
*gp_sec
= gp
->root
.u
.def
.section
;
3219 gp_val
= (gp
->root
.u
.def
.value
3220 + gp_sec
->output_section
->vma
3221 + gp_sec
->output_offset
);
3225 /* Pick a sensible value. */
3227 if (ia64_info
->min_short_sec
)
3229 bfd_vma short_range
= max_short_vma
- min_short_vma
;
3231 /* If min_short_sec is set, pick one in the middle bewteen
3232 min_short_vma and max_short_vma. */
3233 if (short_range
>= 0x400000)
3235 gp_val
= min_short_vma
+ short_range
/ 2;
3239 asection
*got_sec
= ia64_info
->root
.sgot
;
3241 /* Start with just the address of the .got. */
3243 gp_val
= got_sec
->output_section
->vma
;
3244 else if (max_short_vma
!= 0)
3245 gp_val
= min_short_vma
;
3246 else if (max_vma
- min_vma
< 0x200000)
3249 gp_val
= max_vma
- 0x200000 + 8;
3252 /* If it is possible to address the entire image, but we
3253 don't with the choice above, adjust. */
3254 if (max_vma
- min_vma
< 0x400000
3255 && (max_vma
- gp_val
>= 0x200000
3256 || gp_val
- min_vma
> 0x200000))
3257 gp_val
= min_vma
+ 0x200000;
3258 else if (max_short_vma
!= 0)
3260 /* If we don't cover all the short data, adjust. */
3261 if (max_short_vma
- gp_val
>= 0x200000)
3262 gp_val
= min_short_vma
+ 0x200000;
3264 /* If we're addressing stuff past the end, adjust back. */
3265 if (gp_val
> max_vma
)
3266 gp_val
= max_vma
- 0x200000 + 8;
3270 /* Validate whether all SHF_IA_64_SHORT sections are within
3271 range of the chosen GP. */
3273 if (max_short_vma
!= 0)
3275 if (max_short_vma
- min_short_vma
>= 0x400000)
3278 (*_bfd_error_handler
)
3279 (_("%s: short data segment overflowed (0x%lx >= 0x400000)"),
3280 bfd_get_filename (abfd
),
3281 (unsigned long) (max_short_vma
- min_short_vma
));
3284 else if ((gp_val
> min_short_vma
3285 && gp_val
- min_short_vma
> 0x200000)
3286 || (gp_val
< max_short_vma
3287 && max_short_vma
- gp_val
>= 0x200000))
3289 (*_bfd_error_handler
)
3290 (_("%s: __gp does not cover short data segment"),
3291 bfd_get_filename (abfd
));
3296 _bfd_set_gp_value (abfd
, gp_val
);
3302 elf64_ia64_final_link (bfd
*abfd
, struct bfd_link_info
*info
)
3304 struct elf64_ia64_link_hash_table
*ia64_info
;
3305 asection
*unwind_output_sec
;
3307 ia64_info
= elf64_ia64_hash_table (info
);
3308 if (ia64_info
== NULL
)
3311 /* Make sure we've got ourselves a nice fat __gp value. */
3312 if (!bfd_link_relocatable (info
))
3315 struct elf_link_hash_entry
*gp
;
3317 /* We assume after gp is set, section size will only decrease. We
3318 need to adjust gp for it. */
3319 _bfd_set_gp_value (abfd
, 0);
3320 if (! elf64_ia64_choose_gp (abfd
, info
, TRUE
))
3322 gp_val
= _bfd_get_gp_value (abfd
);
3324 gp
= elf_link_hash_lookup (elf_hash_table (info
), "__gp", FALSE
,
3328 gp
->root
.type
= bfd_link_hash_defined
;
3329 gp
->root
.u
.def
.value
= gp_val
;
3330 gp
->root
.u
.def
.section
= bfd_abs_section_ptr
;
3334 /* If we're producing a final executable, we need to sort the contents
3335 of the .IA_64.unwind section. Force this section to be relocated
3336 into memory rather than written immediately to the output file. */
3337 unwind_output_sec
= NULL
;
3338 if (!bfd_link_relocatable (info
))
3340 asection
*s
= bfd_get_section_by_name (abfd
, ELF_STRING_ia64_unwind
);
3343 unwind_output_sec
= s
->output_section
;
3344 unwind_output_sec
->contents
3345 = bfd_malloc (unwind_output_sec
->size
);
3346 if (unwind_output_sec
->contents
== NULL
)
3351 /* Invoke the regular ELF backend linker to do all the work. */
3352 if (!bfd_elf_final_link (abfd
, info
))
3355 if (unwind_output_sec
)
3357 elf64_ia64_unwind_entry_compare_bfd
= abfd
;
3358 qsort (unwind_output_sec
->contents
,
3359 (size_t) (unwind_output_sec
->size
/ 24),
3361 elf64_ia64_unwind_entry_compare
);
3363 if (! bfd_set_section_contents (abfd
, unwind_output_sec
,
3364 unwind_output_sec
->contents
, (bfd_vma
) 0,
3365 unwind_output_sec
->size
))
3373 elf64_ia64_relocate_section (bfd
*output_bfd
,
3374 struct bfd_link_info
*info
,
3376 asection
*input_section
,
3378 Elf_Internal_Rela
*relocs
,
3379 Elf_Internal_Sym
*local_syms
,
3380 asection
**local_sections
)
3382 struct elf64_ia64_link_hash_table
*ia64_info
;
3383 Elf_Internal_Shdr
*symtab_hdr
;
3384 Elf_Internal_Rela
*rel
;
3385 Elf_Internal_Rela
*relend
;
3386 bfd_boolean ret_val
= TRUE
; /* for non-fatal errors */
3389 symtab_hdr
= &elf_tdata (input_bfd
)->symtab_hdr
;
3390 ia64_info
= elf64_ia64_hash_table (info
);
3391 if (ia64_info
== NULL
)
3394 /* Infect various flags from the input section to the output section. */
3395 if (bfd_link_relocatable (info
))
3399 flags
= elf_section_data(input_section
)->this_hdr
.sh_flags
;
3400 flags
&= SHF_IA_64_NORECOV
;
3402 elf_section_data(input_section
->output_section
)
3403 ->this_hdr
.sh_flags
|= flags
;
3406 gp_val
= _bfd_get_gp_value (output_bfd
);
3409 relend
= relocs
+ input_section
->reloc_count
;
3410 for (; rel
< relend
; ++rel
)
3412 struct elf_link_hash_entry
*h
;
3413 struct elf64_ia64_dyn_sym_info
*dyn_i
;
3414 bfd_reloc_status_type r
;
3415 reloc_howto_type
*howto
;
3416 unsigned long r_symndx
;
3417 Elf_Internal_Sym
*sym
;
3418 unsigned int r_type
;
3422 bfd_boolean dynamic_symbol_p
;
3423 bfd_boolean undef_weak_ref
;
3425 r_type
= ELF64_R_TYPE (rel
->r_info
);
3426 if (r_type
> R_IA64_MAX_RELOC_CODE
)
3428 (*_bfd_error_handler
)
3429 (_("%B: unknown relocation type %d"),
3430 input_bfd
, (int) r_type
);
3431 bfd_set_error (bfd_error_bad_value
);
3436 howto
= ia64_elf_lookup_howto (r_type
);
3437 r_symndx
= ELF64_R_SYM (rel
->r_info
);
3441 undef_weak_ref
= FALSE
;
3443 if (r_symndx
< symtab_hdr
->sh_info
)
3445 /* Reloc against local symbol. */
3447 sym
= local_syms
+ r_symndx
;
3448 sym_sec
= local_sections
[r_symndx
];
3450 value
= _bfd_elf_rela_local_sym (output_bfd
, sym
, &msec
, rel
);
3451 if (!bfd_link_relocatable (info
)
3452 && (sym_sec
->flags
& SEC_MERGE
) != 0
3453 && ELF_ST_TYPE (sym
->st_info
) == STT_SECTION
3454 && sym_sec
->sec_info_type
== SEC_INFO_TYPE_MERGE
)
3456 struct elf64_ia64_local_hash_entry
*loc_h
;
3458 loc_h
= get_local_sym_hash (ia64_info
, input_bfd
, rel
, FALSE
);
3459 if (loc_h
&& ! loc_h
->sec_merge_done
)
3461 struct elf64_ia64_dyn_sym_info
*dynent
;
3464 for (count
= loc_h
->count
, dynent
= loc_h
->info
;
3470 _bfd_merged_section_offset (output_bfd
, &msec
,
3471 elf_section_data (msec
)->
3475 dynent
->addend
-= sym
->st_value
;
3476 dynent
->addend
+= msec
->output_section
->vma
3477 + msec
->output_offset
3478 - sym_sec
->output_section
->vma
3479 - sym_sec
->output_offset
;
3482 /* We may have introduced duplicated entries. We need
3483 to remove them properly. */
3484 count
= sort_dyn_sym_info (loc_h
->info
, loc_h
->count
);
3485 if (count
!= loc_h
->count
)
3487 loc_h
->count
= count
;
3488 loc_h
->sorted_count
= count
;
3491 loc_h
->sec_merge_done
= 1;
3497 bfd_boolean unresolved_reloc
;
3498 bfd_boolean warned
, ignored
;
3499 struct elf_link_hash_entry
**sym_hashes
= elf_sym_hashes (input_bfd
);
3501 RELOC_FOR_GLOBAL_SYMBOL (info
, input_bfd
, input_section
, rel
,
3502 r_symndx
, symtab_hdr
, sym_hashes
,
3504 unresolved_reloc
, warned
, ignored
);
3506 if (h
->root
.type
== bfd_link_hash_undefweak
)
3507 undef_weak_ref
= TRUE
;
3512 /* For relocs against symbols from removed linkonce sections,
3513 or sections discarded by a linker script, we just want the
3514 section contents zeroed. Avoid any special processing. */
3515 if (sym_sec
!= NULL
&& discarded_section (sym_sec
))
3516 RELOC_AGAINST_DISCARDED_SECTION (info
, input_bfd
, input_section
,
3517 rel
, 1, relend
, howto
, 0, contents
);
3519 if (bfd_link_relocatable (info
))
3522 hit_addr
= contents
+ rel
->r_offset
;
3523 value
+= rel
->r_addend
;
3524 dynamic_symbol_p
= elf64_ia64_dynamic_symbol_p (h
);
3535 case R_IA64_DIR32MSB
:
3536 case R_IA64_DIR32LSB
:
3537 case R_IA64_DIR64MSB
:
3538 case R_IA64_DIR64LSB
:
3539 /* Install a dynamic relocation for this reloc. */
3540 if ((dynamic_symbol_p
|| bfd_link_pic (info
))
3542 && (input_section
->flags
& SEC_ALLOC
) != 0)
3544 unsigned int dyn_r_type
;
3552 /* ??? People shouldn't be doing non-pic code in
3553 shared libraries nor dynamic executables. */
3554 (*_bfd_error_handler
)
3555 (_("%B: non-pic code with imm relocation against dynamic symbol `%s'"),
3557 h
? h
->root
.root
.string
3558 : bfd_elf_sym_name (input_bfd
, symtab_hdr
, sym
,
3567 /* If we don't need dynamic symbol lookup, find a
3568 matching RELATIVE relocation. */
3569 dyn_r_type
= r_type
;
3570 if (dynamic_symbol_p
)
3572 addend
= rel
->r_addend
;
3580 /* VMS: install a FIX64. */
3583 case R_IA64_DIR32LSB
:
3584 dyn_r_type
= R_IA64_VMS_FIX32
;
3586 case R_IA64_DIR64LSB
:
3587 dyn_r_type
= R_IA64_VMS_FIX64
;
3593 elf64_ia64_install_fixup
3594 (output_bfd
, ia64_info
, h
,
3595 dyn_r_type
, input_section
, rel
->r_offset
, addend
);
3601 case R_IA64_LTV32MSB
:
3602 case R_IA64_LTV32LSB
:
3603 case R_IA64_LTV64MSB
:
3604 case R_IA64_LTV64LSB
:
3605 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3608 case R_IA64_GPREL22
:
3609 case R_IA64_GPREL64I
:
3610 case R_IA64_GPREL32MSB
:
3611 case R_IA64_GPREL32LSB
:
3612 case R_IA64_GPREL64MSB
:
3613 case R_IA64_GPREL64LSB
:
3614 if (dynamic_symbol_p
)
3616 (*_bfd_error_handler
)
3617 (_("%B: @gprel relocation against dynamic symbol %s"),
3619 h
? h
->root
.root
.string
3620 : bfd_elf_sym_name (input_bfd
, symtab_hdr
, sym
,
3626 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3629 case R_IA64_LTOFF22
:
3630 case R_IA64_LTOFF22X
:
3631 case R_IA64_LTOFF64I
:
3632 dyn_i
= get_dyn_sym_info (ia64_info
, h
, input_bfd
, rel
, FALSE
);
3633 value
= set_got_entry (input_bfd
, info
, dyn_i
,
3634 rel
->r_addend
, value
, R_IA64_DIR64LSB
);
3636 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3639 case R_IA64_PLTOFF22
:
3640 case R_IA64_PLTOFF64I
:
3641 case R_IA64_PLTOFF64MSB
:
3642 case R_IA64_PLTOFF64LSB
:
3643 dyn_i
= get_dyn_sym_info (ia64_info
, h
, input_bfd
, rel
, FALSE
);
3644 value
= set_pltoff_entry (output_bfd
, info
, dyn_i
, value
, FALSE
);
3646 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3649 case R_IA64_FPTR64I
:
3650 case R_IA64_FPTR32MSB
:
3651 case R_IA64_FPTR32LSB
:
3652 case R_IA64_FPTR64MSB
:
3653 case R_IA64_FPTR64LSB
:
3654 dyn_i
= get_dyn_sym_info (ia64_info
, h
, input_bfd
, rel
, FALSE
);
3655 if (dyn_i
->want_fptr
)
3657 if (!undef_weak_ref
)
3658 value
= set_fptr_entry (output_bfd
, info
, dyn_i
, value
);
3660 if (!dyn_i
->want_fptr
|| bfd_link_pie (info
))
3662 /* Otherwise, we expect the dynamic linker to create
3665 if (dyn_i
->want_fptr
)
3667 if (r_type
== R_IA64_FPTR64I
)
3669 /* We can't represent this without a dynamic symbol.
3670 Adjust the relocation to be against an output
3671 section symbol, which are always present in the
3672 dynamic symbol table. */
3673 /* ??? People shouldn't be doing non-pic code in
3674 shared libraries. Hork. */
3675 (*_bfd_error_handler
)
3676 (_("%B: linking non-pic code in a position independent executable"),
3688 elf64_ia64_install_fixup
3689 (output_bfd
, ia64_info
, h
, R_IA64_VMS_FIXFD
,
3690 input_section
, rel
->r_offset
, 0);
3695 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3698 case R_IA64_LTOFF_FPTR22
:
3699 case R_IA64_LTOFF_FPTR64I
:
3700 case R_IA64_LTOFF_FPTR32MSB
:
3701 case R_IA64_LTOFF_FPTR32LSB
:
3702 case R_IA64_LTOFF_FPTR64MSB
:
3703 case R_IA64_LTOFF_FPTR64LSB
:
3704 dyn_i
= get_dyn_sym_info (ia64_info
, h
, input_bfd
, rel
, FALSE
);
3705 if (dyn_i
->want_fptr
)
3707 BFD_ASSERT (h
== NULL
|| !h
->def_dynamic
);
3708 if (!undef_weak_ref
)
3709 value
= set_fptr_entry (output_bfd
, info
, dyn_i
, value
);
3714 value
= set_got_entry (output_bfd
, info
, dyn_i
,
3715 rel
->r_addend
, value
, R_IA64_FPTR64LSB
);
3717 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3720 case R_IA64_PCREL32MSB
:
3721 case R_IA64_PCREL32LSB
:
3722 case R_IA64_PCREL64MSB
:
3723 case R_IA64_PCREL64LSB
:
3724 /* Install a dynamic relocation for this reloc. */
3725 if (dynamic_symbol_p
&& r_symndx
!= 0)
3727 /* VMS: doesn't exist ??? */
3732 case R_IA64_PCREL21B
:
3733 case R_IA64_PCREL60B
:
3734 /* We should have created a PLT entry for any dynamic symbol. */
3737 dyn_i
= get_dyn_sym_info (ia64_info
, h
, NULL
, NULL
, FALSE
);
3739 if (dyn_i
&& dyn_i
->want_plt2
)
3741 /* Should have caught this earlier. */
3742 BFD_ASSERT (rel
->r_addend
== 0);
3744 value
= (ia64_info
->root
.splt
->output_section
->vma
3745 + ia64_info
->root
.splt
->output_offset
3746 + dyn_i
->plt2_offset
);
3750 /* Since there's no PLT entry, Validate that this is
3752 BFD_ASSERT (undef_weak_ref
|| sym_sec
->output_section
!= NULL
);
3754 /* If the symbol is undef_weak, we shouldn't be trying
3755 to call it. There's every chance that we'd wind up
3756 with an out-of-range fixup here. Don't bother setting
3757 any value at all. */
3763 case R_IA64_PCREL21BI
:
3764 case R_IA64_PCREL21F
:
3765 case R_IA64_PCREL21M
:
3766 case R_IA64_PCREL22
:
3767 case R_IA64_PCREL64I
:
3768 /* The PCREL21BI reloc is specifically not intended for use with
3769 dynamic relocs. PCREL21F and PCREL21M are used for speculation
3770 fixup code, and thus probably ought not be dynamic. The
3771 PCREL22 and PCREL64I relocs aren't emitted as dynamic relocs. */
3772 if (dynamic_symbol_p
)
3776 if (r_type
== R_IA64_PCREL21BI
)
3777 msg
= _("%B: @internal branch to dynamic symbol %s");
3778 else if (r_type
== R_IA64_PCREL21F
|| r_type
== R_IA64_PCREL21M
)
3779 msg
= _("%B: speculation fixup to dynamic symbol %s");
3781 msg
= _("%B: @pcrel relocation against dynamic symbol %s");
3782 (*_bfd_error_handler
) (msg
, input_bfd
,
3783 h
? h
->root
.root
.string
3784 : bfd_elf_sym_name (input_bfd
,
3794 /* Make pc-relative. */
3795 value
-= (input_section
->output_section
->vma
3796 + input_section
->output_offset
3797 + rel
->r_offset
) & ~ (bfd_vma
) 0x3;
3798 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3801 case R_IA64_SEGREL32MSB
:
3802 case R_IA64_SEGREL32LSB
:
3803 case R_IA64_SEGREL64MSB
:
3804 case R_IA64_SEGREL64LSB
:
3806 /* Find the segment that contains the output_section. */
3807 Elf_Internal_Phdr
*p
= _bfd_elf_find_segment_containing_section
3808 (output_bfd
, sym_sec
->output_section
);
3812 r
= bfd_reloc_notsupported
;
3816 /* The VMA of the segment is the vaddr of the associated
3818 if (value
> p
->p_vaddr
)
3819 value
-= p
->p_vaddr
;
3822 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3827 case R_IA64_SECREL32MSB
:
3828 case R_IA64_SECREL32LSB
:
3829 case R_IA64_SECREL64MSB
:
3830 case R_IA64_SECREL64LSB
:
3831 /* Make output-section relative to section where the symbol
3832 is defined. PR 475 */
3834 value
-= sym_sec
->output_section
->vma
;
3835 r
= ia64_elf_install_value (hit_addr
, value
, r_type
);
3838 case R_IA64_IPLTMSB
:
3839 case R_IA64_IPLTLSB
:
3840 /* Install a dynamic relocation for this reloc. */
3841 if ((dynamic_symbol_p
|| bfd_link_pic (info
))
3842 && (input_section
->flags
& SEC_ALLOC
) != 0)
3848 if (r_type
== R_IA64_IPLTMSB
)
3849 r_type
= R_IA64_DIR64MSB
;
3851 r_type
= R_IA64_DIR64LSB
;
3852 ia64_elf_install_value (hit_addr
, value
, r_type
);
3853 r
= ia64_elf_install_value (hit_addr
+ 8, gp_val
, r_type
);
3856 case R_IA64_TPREL14
:
3857 case R_IA64_TPREL22
:
3858 case R_IA64_TPREL64I
:
3859 r
= bfd_reloc_notsupported
;
3862 case R_IA64_DTPREL14
:
3863 case R_IA64_DTPREL22
:
3864 case R_IA64_DTPREL64I
:
3865 case R_IA64_DTPREL32LSB
:
3866 case R_IA64_DTPREL32MSB
:
3867 case R_IA64_DTPREL64LSB
:
3868 case R_IA64_DTPREL64MSB
:
3869 r
= bfd_reloc_notsupported
;
3872 case R_IA64_LTOFF_TPREL22
:
3873 case R_IA64_LTOFF_DTPMOD22
:
3874 case R_IA64_LTOFF_DTPREL22
:
3875 r
= bfd_reloc_notsupported
;
3879 r
= bfd_reloc_notsupported
;
3888 case bfd_reloc_undefined
:
3889 /* This can happen for global table relative relocs if
3890 __gp is undefined. This is a panic situation so we
3891 don't try to continue. */
3892 (*info
->callbacks
->undefined_symbol
)
3893 (info
, "__gp", input_bfd
, input_section
, rel
->r_offset
, 1);
3896 case bfd_reloc_notsupported
:
3901 name
= h
->root
.root
.string
;
3903 name
= bfd_elf_sym_name (input_bfd
, symtab_hdr
, sym
,
3905 if (!(*info
->callbacks
->warning
) (info
, _("unsupported reloc"),
3907 input_section
, rel
->r_offset
))
3913 case bfd_reloc_dangerous
:
3914 case bfd_reloc_outofrange
:
3915 case bfd_reloc_overflow
:
3921 name
= h
->root
.root
.string
;
3923 name
= bfd_elf_sym_name (input_bfd
, symtab_hdr
, sym
,
3928 case R_IA64_TPREL14
:
3929 case R_IA64_TPREL22
:
3930 case R_IA64_TPREL64I
:
3931 case R_IA64_DTPREL14
:
3932 case R_IA64_DTPREL22
:
3933 case R_IA64_DTPREL64I
:
3934 case R_IA64_DTPREL32LSB
:
3935 case R_IA64_DTPREL32MSB
:
3936 case R_IA64_DTPREL64LSB
:
3937 case R_IA64_DTPREL64MSB
:
3938 case R_IA64_LTOFF_TPREL22
:
3939 case R_IA64_LTOFF_DTPMOD22
:
3940 case R_IA64_LTOFF_DTPREL22
:
3941 (*_bfd_error_handler
)
3942 (_("%B: missing TLS section for relocation %s against `%s' at 0x%lx in section `%A'."),
3943 input_bfd
, input_section
, howto
->name
, name
,
3947 case R_IA64_PCREL21B
:
3948 case R_IA64_PCREL21BI
:
3949 case R_IA64_PCREL21M
:
3950 case R_IA64_PCREL21F
:
3951 if (is_elf_hash_table (info
->hash
))
3953 /* Relaxtion is always performed for ELF output.
3954 Overflow failures for those relocations mean
3955 that the section is too big to relax. */
3956 (*_bfd_error_handler
)
3957 (_("%B: Can't relax br (%s) to `%s' at 0x%lx in section `%A' with size 0x%lx (> 0x1000000)."),
3958 input_bfd
, input_section
, howto
->name
, name
,
3959 rel
->r_offset
, input_section
->size
);
3963 if (!(*info
->callbacks
->reloc_overflow
) (info
,
3985 elf64_ia64_finish_dynamic_symbol (bfd
*output_bfd
,
3986 struct bfd_link_info
*info
,
3987 struct elf_link_hash_entry
*h
,
3988 Elf_Internal_Sym
*sym
)
3990 struct elf64_ia64_link_hash_table
*ia64_info
;
3991 struct elf64_ia64_dyn_sym_info
*dyn_i
;
3993 ia64_info
= elf64_ia64_hash_table (info
);
3994 if (ia64_info
== NULL
)
3997 dyn_i
= get_dyn_sym_info (ia64_info
, h
, NULL
, NULL
, FALSE
);
3999 /* Fill in the PLT data, if required. */
4000 if (dyn_i
&& dyn_i
->want_plt
)
4004 bfd_vma plt_addr
, pltoff_addr
, gp_val
;
4006 gp_val
= _bfd_get_gp_value (output_bfd
);
4008 plt_sec
= ia64_info
->root
.splt
;
4009 plt_addr
= 0; /* Not used as overriden by FIXUPs. */
4010 pltoff_addr
= set_pltoff_entry (output_bfd
, info
, dyn_i
, plt_addr
, TRUE
);
4012 /* Initialize the FULL PLT entry, if needed. */
4013 if (dyn_i
->want_plt2
)
4015 loc
= plt_sec
->contents
+ dyn_i
->plt2_offset
;
4017 memcpy (loc
, plt_full_entry
, PLT_FULL_ENTRY_SIZE
);
4018 ia64_elf_install_value (loc
, pltoff_addr
- gp_val
, R_IA64_IMM22
);
4020 /* Mark the symbol as undefined, rather than as defined in the
4021 plt section. Leave the value alone. */
4022 /* ??? We didn't redefine it in adjust_dynamic_symbol in the
4023 first place. But perhaps elflink.c did some for us. */
4024 if (!h
->def_regular
)
4025 sym
->st_shndx
= SHN_UNDEF
;
4029 elf64_ia64_install_fixup
4030 (output_bfd
, ia64_info
, h
, R_IA64_VMS_FIXFD
, ia64_info
->pltoff_sec
,
4031 pltoff_addr
- (ia64_info
->pltoff_sec
->output_section
->vma
4032 + ia64_info
->pltoff_sec
->output_offset
), 0);
4035 /* Mark some specially defined symbols as absolute. */
4036 if (h
== ia64_info
->root
.hdynamic
4037 || h
== ia64_info
->root
.hgot
4038 || h
== ia64_info
->root
.hplt
)
4039 sym
->st_shndx
= SHN_ABS
;
4045 elf64_ia64_finish_dynamic_sections (bfd
*abfd
,
4046 struct bfd_link_info
*info
)
4048 struct elf64_ia64_link_hash_table
*ia64_info
;
4051 ia64_info
= elf64_ia64_hash_table (info
);
4052 if (ia64_info
== NULL
)
4055 dynobj
= ia64_info
->root
.dynobj
;
4057 if (elf_hash_table (info
)->dynamic_sections_created
)
4059 Elf64_External_Dyn
*dyncon
, *dynconend
;
4061 asection
*unwind_sec
;
4063 unsigned int gp_seg
;
4065 Elf_Internal_Phdr
*phdr
;
4066 Elf_Internal_Phdr
*base_phdr
;
4067 unsigned int unwind_seg
= 0;
4068 unsigned int code_seg
= 0;
4070 sdyn
= bfd_get_linker_section (dynobj
, ".dynamic");
4071 BFD_ASSERT (sdyn
!= NULL
);
4072 dyncon
= (Elf64_External_Dyn
*) sdyn
->contents
;
4073 dynconend
= (Elf64_External_Dyn
*) (sdyn
->contents
+ sdyn
->size
);
4075 gp_val
= _bfd_get_gp_value (abfd
);
4076 phdr
= _bfd_elf_find_segment_containing_section
4077 (info
->output_bfd
, ia64_info
->pltoff_sec
->output_section
);
4078 BFD_ASSERT (phdr
!= NULL
);
4079 base_phdr
= elf_tdata (info
->output_bfd
)->phdr
;
4080 gp_seg
= phdr
- base_phdr
;
4081 gp_off
= gp_val
- phdr
->p_vaddr
;
4083 unwind_sec
= bfd_get_section_by_name (abfd
, ELF_STRING_ia64_unwind
);
4084 if (unwind_sec
!= NULL
)
4088 phdr
= _bfd_elf_find_segment_containing_section (abfd
, unwind_sec
);
4089 BFD_ASSERT (phdr
!= NULL
);
4090 unwind_seg
= phdr
- base_phdr
;
4092 code_sec
= bfd_get_section_by_name (abfd
, "$CODE$");
4093 phdr
= _bfd_elf_find_segment_containing_section (abfd
, code_sec
);
4094 BFD_ASSERT (phdr
!= NULL
);
4095 code_seg
= phdr
- base_phdr
;
4098 for (; dyncon
< dynconend
; dyncon
++)
4100 Elf_Internal_Dyn dyn
;
4102 bfd_elf64_swap_dyn_in (dynobj
, dyncon
, &dyn
);
4106 case DT_IA_64_VMS_FIXUP_RELA_OFF
:
4108 (ia64_info
->fixups_sec
->output_section
->vma
4109 + ia64_info
->fixups_sec
->output_offset
)
4110 - (sdyn
->output_section
->vma
+ sdyn
->output_offset
);
4113 case DT_IA_64_VMS_PLTGOT_OFFSET
:
4114 dyn
.d_un
.d_val
= gp_off
;
4117 case DT_IA_64_VMS_PLTGOT_SEG
:
4118 dyn
.d_un
.d_val
= gp_seg
;
4121 case DT_IA_64_VMS_UNWINDSZ
:
4122 if (unwind_sec
== NULL
)
4124 dyn
.d_tag
= DT_NULL
;
4125 dyn
.d_un
.d_val
= 0xdead;
4128 dyn
.d_un
.d_val
= unwind_sec
->size
;
4131 case DT_IA_64_VMS_UNWIND_CODSEG
:
4132 dyn
.d_un
.d_val
= code_seg
;
4135 case DT_IA_64_VMS_UNWIND_INFOSEG
:
4136 case DT_IA_64_VMS_UNWIND_SEG
:
4137 dyn
.d_un
.d_val
= unwind_seg
;
4140 case DT_IA_64_VMS_UNWIND_OFFSET
:
4144 /* No need to rewrite the entry. */
4148 bfd_elf64_swap_dyn_out (abfd
, &dyn
, dyncon
);
4152 /* Handle transfer addresses. */
4154 asection
*tfr_sec
= ia64_info
->transfer_sec
;
4155 struct elf64_vms_transfer
*tfr
;
4156 struct elf_link_hash_entry
*tfr3
;
4158 tfr
= (struct elf64_vms_transfer
*)tfr_sec
->contents
;
4159 bfd_putl32 (6 * 8, tfr
->size
);
4160 bfd_putl64 (tfr_sec
->output_section
->vma
4161 + tfr_sec
->output_offset
4162 + 6 * 8, tfr
->tfradr3
);
4164 tfr3
= elf_link_hash_lookup (elf_hash_table (info
), "ELF$TFRADR", FALSE
,
4168 && (tfr3
->root
.type
== bfd_link_hash_defined
4169 || tfr3
->root
.type
== bfd_link_hash_defweak
))
4171 asection
*tfr3_sec
= tfr3
->root
.u
.def
.section
;
4174 tfr3_val
= (tfr3
->root
.u
.def
.value
4175 + tfr3_sec
->output_section
->vma
4176 + tfr3_sec
->output_offset
);
4178 bfd_putl64 (tfr3_val
, tfr
->tfr3_func
);
4179 bfd_putl64 (_bfd_get_gp_value (info
->output_bfd
), tfr
->tfr3_gp
);
4182 /* FIXME: set linker flags,
4183 handle lib$initialize. */
4189 /* ELF file flag handling: */
4191 /* Function to keep IA-64 specific file flags. */
4193 elf64_ia64_set_private_flags (bfd
*abfd
, flagword flags
)
4195 BFD_ASSERT (!elf_flags_init (abfd
)
4196 || elf_elfheader (abfd
)->e_flags
== flags
);
4198 elf_elfheader (abfd
)->e_flags
= flags
;
4199 elf_flags_init (abfd
) = TRUE
;
4203 /* Merge backend specific data from an object file to the output
4204 object file when linking. */
4206 elf64_ia64_merge_private_bfd_data (bfd
*ibfd
, bfd
*obfd
)
4210 bfd_boolean ok
= TRUE
;
4212 /* Don't even pretend to support mixed-format linking. */
4213 if (bfd_get_flavour (ibfd
) != bfd_target_elf_flavour
4214 || bfd_get_flavour (obfd
) != bfd_target_elf_flavour
)
4217 in_flags
= elf_elfheader (ibfd
)->e_flags
;
4218 out_flags
= elf_elfheader (obfd
)->e_flags
;
4220 if (! elf_flags_init (obfd
))
4222 elf_flags_init (obfd
) = TRUE
;
4223 elf_elfheader (obfd
)->e_flags
= in_flags
;
4225 if (bfd_get_arch (obfd
) == bfd_get_arch (ibfd
)
4226 && bfd_get_arch_info (obfd
)->the_default
)
4228 return bfd_set_arch_mach (obfd
, bfd_get_arch (ibfd
),
4229 bfd_get_mach (ibfd
));
4235 /* Check flag compatibility. */
4236 if (in_flags
== out_flags
)
4239 /* Output has EF_IA_64_REDUCEDFP set only if all inputs have it set. */
4240 if (!(in_flags
& EF_IA_64_REDUCEDFP
) && (out_flags
& EF_IA_64_REDUCEDFP
))
4241 elf_elfheader (obfd
)->e_flags
&= ~EF_IA_64_REDUCEDFP
;
4243 if ((in_flags
& EF_IA_64_TRAPNIL
) != (out_flags
& EF_IA_64_TRAPNIL
))
4245 (*_bfd_error_handler
)
4246 (_("%B: linking trap-on-NULL-dereference with non-trapping files"),
4249 bfd_set_error (bfd_error_bad_value
);
4252 if ((in_flags
& EF_IA_64_BE
) != (out_flags
& EF_IA_64_BE
))
4254 (*_bfd_error_handler
)
4255 (_("%B: linking big-endian files with little-endian files"),
4258 bfd_set_error (bfd_error_bad_value
);
4261 if ((in_flags
& EF_IA_64_ABI64
) != (out_flags
& EF_IA_64_ABI64
))
4263 (*_bfd_error_handler
)
4264 (_("%B: linking 64-bit files with 32-bit files"),
4267 bfd_set_error (bfd_error_bad_value
);
4270 if ((in_flags
& EF_IA_64_CONS_GP
) != (out_flags
& EF_IA_64_CONS_GP
))
4272 (*_bfd_error_handler
)
4273 (_("%B: linking constant-gp files with non-constant-gp files"),
4276 bfd_set_error (bfd_error_bad_value
);
4279 if ((in_flags
& EF_IA_64_NOFUNCDESC_CONS_GP
)
4280 != (out_flags
& EF_IA_64_NOFUNCDESC_CONS_GP
))
4282 (*_bfd_error_handler
)
4283 (_("%B: linking auto-pic files with non-auto-pic files"),
4286 bfd_set_error (bfd_error_bad_value
);
4294 elf64_ia64_print_private_bfd_data (bfd
*abfd
, void * ptr
)
4296 FILE *file
= (FILE *) ptr
;
4297 flagword flags
= elf_elfheader (abfd
)->e_flags
;
4299 BFD_ASSERT (abfd
!= NULL
&& ptr
!= NULL
);
4301 fprintf (file
, "private flags = %s%s%s%s%s%s%s%s\n",
4302 (flags
& EF_IA_64_TRAPNIL
) ? "TRAPNIL, " : "",
4303 (flags
& EF_IA_64_EXT
) ? "EXT, " : "",
4304 (flags
& EF_IA_64_BE
) ? "BE, " : "LE, ",
4305 (flags
& EF_IA_64_REDUCEDFP
) ? "REDUCEDFP, " : "",
4306 (flags
& EF_IA_64_CONS_GP
) ? "CONS_GP, " : "",
4307 (flags
& EF_IA_64_NOFUNCDESC_CONS_GP
) ? "NOFUNCDESC_CONS_GP, " : "",
4308 (flags
& EF_IA_64_ABSOLUTE
) ? "ABSOLUTE, " : "",
4309 (flags
& EF_IA_64_ABI64
) ? "ABI64" : "ABI32");
4311 _bfd_elf_print_private_bfd_data (abfd
, ptr
);
4315 static enum elf_reloc_type_class
4316 elf64_ia64_reloc_type_class (const struct bfd_link_info
*info ATTRIBUTE_UNUSED
,
4317 const asection
*rel_sec ATTRIBUTE_UNUSED
,
4318 const Elf_Internal_Rela
*rela
)
4320 switch ((int) ELF64_R_TYPE (rela
->r_info
))
4322 case R_IA64_REL32MSB
:
4323 case R_IA64_REL32LSB
:
4324 case R_IA64_REL64MSB
:
4325 case R_IA64_REL64LSB
:
4326 return reloc_class_relative
;
4327 case R_IA64_IPLTMSB
:
4328 case R_IA64_IPLTLSB
:
4329 return reloc_class_plt
;
4331 return reloc_class_copy
;
4333 return reloc_class_normal
;
4337 static const struct bfd_elf_special_section elf64_ia64_special_sections
[] =
4339 { STRING_COMMA_LEN (".sbss"), -1, SHT_NOBITS
, SHF_ALLOC
+ SHF_WRITE
+ SHF_IA_64_SHORT
},
4340 { STRING_COMMA_LEN (".sdata"), -1, SHT_PROGBITS
, SHF_ALLOC
+ SHF_WRITE
+ SHF_IA_64_SHORT
},
4341 { NULL
, 0, 0, 0, 0 }
4345 elf64_ia64_object_p (bfd
*abfd
)
4348 asection
*group
, *unwi
, *unw
;
4351 char *unwi_name
, *unw_name
;
4354 if (abfd
->flags
& DYNAMIC
)
4357 /* Flags for fake group section. */
4358 flags
= (SEC_LINKER_CREATED
| SEC_GROUP
| SEC_LINK_ONCE
4361 /* We add a fake section group for each .gnu.linkonce.t.* section,
4362 which isn't in a section group, and its unwind sections. */
4363 for (sec
= abfd
->sections
; sec
!= NULL
; sec
= sec
->next
)
4365 if (elf_sec_group (sec
) == NULL
4366 && ((sec
->flags
& (SEC_LINK_ONCE
| SEC_CODE
| SEC_GROUP
))
4367 == (SEC_LINK_ONCE
| SEC_CODE
))
4368 && CONST_STRNEQ (sec
->name
, ".gnu.linkonce.t."))
4370 name
= sec
->name
+ 16;
4372 amt
= strlen (name
) + sizeof (".gnu.linkonce.ia64unwi.");
4373 unwi_name
= bfd_alloc (abfd
, amt
);
4377 strcpy (stpcpy (unwi_name
, ".gnu.linkonce.ia64unwi."), name
);
4378 unwi
= bfd_get_section_by_name (abfd
, unwi_name
);
4380 amt
= strlen (name
) + sizeof (".gnu.linkonce.ia64unw.");
4381 unw_name
= bfd_alloc (abfd
, amt
);
4385 strcpy (stpcpy (unw_name
, ".gnu.linkonce.ia64unw."), name
);
4386 unw
= bfd_get_section_by_name (abfd
, unw_name
);
4388 /* We need to create a fake group section for it and its
4390 group
= bfd_make_section_anyway_with_flags (abfd
, name
,
4395 /* Move the fake group section to the beginning. */
4396 bfd_section_list_remove (abfd
, group
);
4397 bfd_section_list_prepend (abfd
, group
);
4399 elf_next_in_group (group
) = sec
;
4401 elf_group_name (sec
) = name
;
4402 elf_next_in_group (sec
) = sec
;
4403 elf_sec_group (sec
) = group
;
4407 elf_group_name (unwi
) = name
;
4408 elf_next_in_group (unwi
) = sec
;
4409 elf_next_in_group (sec
) = unwi
;
4410 elf_sec_group (unwi
) = group
;
4415 elf_group_name (unw
) = name
;
4418 elf_next_in_group (unw
) = elf_next_in_group (unwi
);
4419 elf_next_in_group (unwi
) = unw
;
4423 elf_next_in_group (unw
) = sec
;
4424 elf_next_in_group (sec
) = unw
;
4426 elf_sec_group (unw
) = group
;
4429 /* Fake SHT_GROUP section header. */
4430 elf_section_data (group
)->this_hdr
.bfd_section
= group
;
4431 elf_section_data (group
)->this_hdr
.sh_type
= SHT_GROUP
;
4437 /* Handle an IA-64 specific section when reading an object file. This
4438 is called when bfd_section_from_shdr finds a section with an unknown
4442 elf64_vms_section_from_shdr (bfd
*abfd
,
4443 Elf_Internal_Shdr
*hdr
,
4447 flagword secflags
= 0;
4449 switch (hdr
->sh_type
)
4451 case SHT_IA_64_VMS_TRACE
:
4452 case SHT_IA_64_VMS_DEBUG
:
4453 case SHT_IA_64_VMS_DEBUG_STR
:
4454 secflags
= SEC_DEBUGGING
;
4457 case SHT_IA_64_UNWIND
:
4458 case SHT_IA_64_HP_OPT_ANOT
:
4462 if (strcmp (name
, ELF_STRING_ia64_archext
) != 0)
4470 if (! _bfd_elf_make_section_from_shdr (abfd
, hdr
, name
, shindex
))
4475 asection
*newsect
= hdr
->bfd_section
;
4477 if (! bfd_set_section_flags
4478 (abfd
, newsect
, bfd_get_section_flags (abfd
, newsect
) | secflags
))
4486 elf64_vms_object_p (bfd
*abfd
)
4488 Elf_Internal_Ehdr
*i_ehdrp
= elf_elfheader (abfd
);
4489 Elf_Internal_Phdr
*i_phdr
= elf_tdata (abfd
)->phdr
;
4491 unsigned int num_text
= 0;
4492 unsigned int num_data
= 0;
4493 unsigned int num_rodata
= 0;
4496 if (!elf64_ia64_object_p (abfd
))
4499 /* Many VMS compilers do not generate sections for the corresponding
4500 segment. This is boring as binutils tools won't be able to disassemble
4501 the code. So we simply create all the missing sections. */
4502 for (i
= 0; i
< i_ehdrp
->e_phnum
; i
++, i_phdr
++)
4504 /* Is there a section for this segment? */
4505 bfd_vma base_vma
= i_phdr
->p_vaddr
;
4506 bfd_vma limit_vma
= base_vma
+ i_phdr
->p_filesz
;
4508 if (i_phdr
->p_type
!= PT_LOAD
)
4511 /* We need to cover from base_vms to limit_vma. */
4513 while (base_vma
< limit_vma
)
4515 bfd_vma next_vma
= limit_vma
;
4521 /* Find a section covering [base_vma;limit_vma) */
4522 for (sec
= abfd
->sections
; sec
!= NULL
; sec
= sec
->next
)
4524 /* Skip uninteresting sections (either not in memory or
4526 if ((sec
->flags
& (SEC_ALLOC
| SEC_LOAD
)) == 0
4527 || sec
->vma
+ sec
->size
<= base_vma
)
4529 if (sec
->vma
<= base_vma
)
4531 /* This section covers (maybe partially) the beginning
4533 base_vma
= sec
->vma
+ sec
->size
;
4536 if (sec
->vma
< next_vma
)
4538 /* This section partially covers the end of the range.
4539 Used to compute the size of the hole. */
4540 next_vma
= sec
->vma
;
4544 /* No section covering [base_vma; next_vma). Create a fake one. */
4545 flags
= SEC_ALLOC
| SEC_LOAD
| SEC_HAS_CONTENTS
;
4546 if (i_phdr
->p_flags
& PF_X
)
4549 if (num_text
++ == 0)
4552 sprintf (name
, ".text$%u", num_text
);
4554 else if ((i_phdr
->p_flags
& (PF_R
| PF_W
)) == PF_R
)
4556 flags
|= SEC_READONLY
;
4557 sprintf (name
, ".rodata$%u", num_rodata
++);
4562 sprintf (name
, ".data$%u", num_data
++);
4565 /* Allocate name. */
4568 size_t name_len
= strlen (name
) + 1;
4569 nname
= bfd_alloc (abfd
, name_len
);
4572 memcpy (nname
, name
, name_len
);
4575 /* Create and fill new section. */
4576 nsec
= bfd_make_section_anyway_with_flags (abfd
, nname
, flags
);
4579 nsec
->vma
= base_vma
;
4580 nsec
->size
= next_vma
- base_vma
;
4581 nsec
->filepos
= i_phdr
->p_offset
+ (base_vma
- i_phdr
->p_vaddr
);
4583 base_vma
= next_vma
;
4590 elf64_vms_post_process_headers (bfd
*abfd
,
4591 struct bfd_link_info
*info ATTRIBUTE_UNUSED
)
4593 Elf_Internal_Ehdr
*i_ehdrp
= elf_elfheader (abfd
);
4595 i_ehdrp
->e_ident
[EI_OSABI
] = ELFOSABI_OPENVMS
;
4596 i_ehdrp
->e_ident
[EI_ABIVERSION
] = 2;
4600 elf64_vms_section_processing (bfd
*abfd ATTRIBUTE_UNUSED
,
4601 Elf_Internal_Shdr
*hdr
)
4603 if (hdr
->bfd_section
!= NULL
)
4605 const char *name
= bfd_get_section_name (abfd
, hdr
->bfd_section
);
4607 if (strcmp (name
, ".text") == 0)
4608 hdr
->sh_flags
|= SHF_IA_64_VMS_SHARED
;
4609 else if ((strcmp (name
, ".debug") == 0)
4610 || (strcmp (name
, ".debug_abbrev") == 0)
4611 || (strcmp (name
, ".debug_aranges") == 0)
4612 || (strcmp (name
, ".debug_frame") == 0)
4613 || (strcmp (name
, ".debug_info") == 0)
4614 || (strcmp (name
, ".debug_loc") == 0)
4615 || (strcmp (name
, ".debug_macinfo") == 0)
4616 || (strcmp (name
, ".debug_pubnames") == 0)
4617 || (strcmp (name
, ".debug_pubtypes") == 0))
4618 hdr
->sh_type
= SHT_IA_64_VMS_DEBUG
;
4619 else if ((strcmp (name
, ".debug_line") == 0)
4620 || (strcmp (name
, ".debug_ranges") == 0)
4621 || (strcmp (name
, ".trace_info") == 0)
4622 || (strcmp (name
, ".trace_abbrev") == 0)
4623 || (strcmp (name
, ".trace_aranges") == 0))
4624 hdr
->sh_type
= SHT_IA_64_VMS_TRACE
;
4625 else if (strcmp (name
, ".debug_str") == 0)
4626 hdr
->sh_type
= SHT_IA_64_VMS_DEBUG_STR
;
4632 /* The final processing done just before writing out a VMS IA-64 ELF
4636 elf64_vms_final_write_processing (bfd
*abfd
,
4637 bfd_boolean linker ATTRIBUTE_UNUSED
)
4639 Elf_Internal_Shdr
*hdr
;
4641 int unwind_info_sect_idx
= 0;
4643 for (s
= abfd
->sections
; s
; s
= s
->next
)
4645 hdr
= &elf_section_data (s
)->this_hdr
;
4647 if (strcmp (bfd_get_section_name (abfd
, hdr
->bfd_section
),
4648 ".IA_64.unwind_info") == 0)
4649 unwind_info_sect_idx
= elf_section_data (s
)->this_idx
;
4651 switch (hdr
->sh_type
)
4653 case SHT_IA_64_UNWIND
:
4654 /* VMS requires sh_info to point to the unwind info section. */
4655 hdr
->sh_info
= unwind_info_sect_idx
;
4660 if (! elf_flags_init (abfd
))
4662 unsigned long flags
= 0;
4664 if (abfd
->xvec
->byteorder
== BFD_ENDIAN_BIG
)
4665 flags
|= EF_IA_64_BE
;
4666 if (bfd_get_mach (abfd
) == bfd_mach_ia64_elf64
)
4667 flags
|= EF_IA_64_ABI64
;
4669 elf_elfheader (abfd
)->e_flags
= flags
;
4670 elf_flags_init (abfd
) = TRUE
;
4675 elf64_vms_write_shdrs_and_ehdr (bfd
*abfd
)
4677 unsigned char needed_count
[8];
4679 if (!bfd_elf64_write_shdrs_and_ehdr (abfd
))
4682 bfd_putl64 (elf_ia64_vms_tdata (abfd
)->needed_count
, needed_count
);
4684 if (bfd_seek (abfd
, sizeof (Elf64_External_Ehdr
), SEEK_SET
) != 0
4685 || bfd_bwrite (needed_count
, 8, abfd
) != 8)
4692 elf64_vms_close_and_cleanup (bfd
*abfd
)
4694 if (bfd_get_format (abfd
) == bfd_object
)
4698 /* Pad to 8 byte boundary for IPF/VMS. */
4699 isize
= bfd_get_size (abfd
);
4700 if ((isize
& 7) != 0)
4702 int ishort
= 8 - (isize
& 7);
4703 bfd_uint64_t pad
= 0;
4705 bfd_seek (abfd
, isize
, SEEK_SET
);
4706 bfd_bwrite (&pad
, ishort
, abfd
);
4710 return _bfd_elf_close_and_cleanup (abfd
);
4713 /* Add symbols from an ELF object file to the linker hash table. */
4716 elf64_vms_link_add_object_symbols (bfd
*abfd
, struct bfd_link_info
*info
)
4718 Elf_Internal_Shdr
*hdr
;
4719 bfd_size_type symcount
;
4720 bfd_size_type extsymcount
;
4721 bfd_size_type extsymoff
;
4722 struct elf_link_hash_entry
**sym_hash
;
4723 bfd_boolean dynamic
;
4724 Elf_Internal_Sym
*isymbuf
= NULL
;
4725 Elf_Internal_Sym
*isym
;
4726 Elf_Internal_Sym
*isymend
;
4727 const struct elf_backend_data
*bed
;
4728 struct elf_link_hash_table
*htab
;
4731 htab
= elf_hash_table (info
);
4732 bed
= get_elf_backend_data (abfd
);
4734 if ((abfd
->flags
& DYNAMIC
) == 0)
4740 /* You can't use -r against a dynamic object. Also, there's no
4741 hope of using a dynamic object which does not exactly match
4742 the format of the output file. */
4743 if (bfd_link_relocatable (info
)
4744 || !is_elf_hash_table (htab
)
4745 || info
->output_bfd
->xvec
!= abfd
->xvec
)
4747 if (bfd_link_relocatable (info
))
4748 bfd_set_error (bfd_error_invalid_operation
);
4750 bfd_set_error (bfd_error_wrong_format
);
4757 /* If we are creating a shared library, create all the dynamic
4758 sections immediately. We need to attach them to something,
4759 so we attach them to this BFD, provided it is the right
4760 format. FIXME: If there are no input BFD's of the same
4761 format as the output, we can't make a shared library. */
4762 if (bfd_link_pic (info
)
4763 && is_elf_hash_table (htab
)
4764 && info
->output_bfd
->xvec
== abfd
->xvec
4765 && !htab
->dynamic_sections_created
)
4767 if (! elf64_ia64_create_dynamic_sections (abfd
, info
))
4771 else if (!is_elf_hash_table (htab
))
4779 /* ld --just-symbols and dynamic objects don't mix very well.
4780 ld shouldn't allow it. */
4781 if ((s
= abfd
->sections
) != NULL
4782 && s
->sec_info_type
== SEC_INFO_TYPE_JUST_SYMS
)
4785 /* Be sure there are dynamic sections. */
4786 if (! elf64_ia64_create_dynamic_sections (htab
->dynobj
, info
))
4789 s
= bfd_get_section_by_name (abfd
, ".dynamic");
4792 /* VMS libraries do not have dynamic sections. Create one from
4794 Elf_Internal_Phdr
*phdr
;
4795 unsigned int i
, phnum
;
4797 phdr
= elf_tdata (abfd
)->phdr
;
4800 phnum
= elf_elfheader (abfd
)->e_phnum
;
4801 for (i
= 0; i
< phnum
; phdr
++)
4802 if (phdr
->p_type
== PT_DYNAMIC
)
4804 s
= bfd_make_section (abfd
, ".dynamic");
4807 s
->vma
= phdr
->p_vaddr
;
4808 s
->lma
= phdr
->p_paddr
;
4809 s
->size
= phdr
->p_filesz
;
4810 s
->filepos
= phdr
->p_offset
;
4811 s
->flags
|= SEC_HAS_CONTENTS
;
4812 s
->alignment_power
= bfd_log2 (phdr
->p_align
);
4819 /* Extract IDENT. */
4820 if (!bfd_malloc_and_get_section (abfd
, s
, &dynbuf
))
4827 for (extdyn
= dynbuf
;
4828 extdyn
< dynbuf
+ s
->size
;
4829 extdyn
+= bed
->s
->sizeof_dyn
)
4831 Elf_Internal_Dyn dyn
;
4833 bed
->s
->swap_dyn_in (abfd
, extdyn
, &dyn
);
4834 if (dyn
.d_tag
== DT_IA_64_VMS_IDENT
)
4836 bfd_uint64_t tagv
= dyn
.d_un
.d_val
;
4837 elf_ia64_vms_ident (abfd
) = tagv
;
4841 if (extdyn
>= dynbuf
+ s
->size
)
4843 /* Ident not found. */
4844 goto error_free_dyn
;
4848 /* We do not want to include any of the sections in a dynamic
4849 object in the output file. We hack by simply clobbering the
4850 list of sections in the BFD. This could be handled more
4851 cleanly by, say, a new section flag; the existing
4852 SEC_NEVER_LOAD flag is not the one we want, because that one
4853 still implies that the section takes up space in the output
4855 bfd_section_list_clear (abfd
);
4857 /* FIXME: should we detect if this library is already included ?
4858 This should be harmless and shouldn't happen in practice. */
4861 hdr
= &elf_tdata (abfd
)->symtab_hdr
;
4862 symcount
= hdr
->sh_size
/ bed
->s
->sizeof_sym
;
4864 /* The sh_info field of the symtab header tells us where the
4865 external symbols start. We don't care about the local symbols at
4867 extsymcount
= symcount
- hdr
->sh_info
;
4868 extsymoff
= hdr
->sh_info
;
4871 if (extsymcount
!= 0)
4873 isymbuf
= bfd_elf_get_elf_syms (abfd
, hdr
, extsymcount
, extsymoff
,
4875 if (isymbuf
== NULL
)
4878 /* We store a pointer to the hash table entry for each external
4880 amt
= extsymcount
* sizeof (struct elf_link_hash_entry
*);
4881 sym_hash
= (struct elf_link_hash_entry
**) bfd_alloc (abfd
, amt
);
4882 if (sym_hash
== NULL
)
4883 goto error_free_sym
;
4884 elf_sym_hashes (abfd
) = sym_hash
;
4887 for (isym
= isymbuf
, isymend
= isymbuf
+ extsymcount
;
4893 asection
*sec
, *new_sec
;
4896 struct elf_link_hash_entry
*h
;
4897 bfd_boolean definition
;
4898 bfd_boolean size_change_ok
;
4899 bfd_boolean type_change_ok
;
4901 unsigned int old_alignment
;
4904 flags
= BSF_NO_FLAGS
;
4906 value
= isym
->st_value
;
4908 common
= bed
->common_definition (isym
);
4910 bind
= ELF_ST_BIND (isym
->st_info
);
4914 /* This should be impossible, since ELF requires that all
4915 global symbols follow all local symbols, and that sh_info
4916 point to the first global symbol. Unfortunately, Irix 5
4921 if (isym
->st_shndx
!= SHN_UNDEF
&& !common
)
4929 case STB_GNU_UNIQUE
:
4930 flags
= BSF_GNU_UNIQUE
;
4934 /* Leave it up to the processor backend. */
4938 if (isym
->st_shndx
== SHN_UNDEF
)
4939 sec
= bfd_und_section_ptr
;
4940 else if (isym
->st_shndx
== SHN_ABS
)
4941 sec
= bfd_abs_section_ptr
;
4942 else if (isym
->st_shndx
== SHN_COMMON
)
4944 sec
= bfd_com_section_ptr
;
4945 /* What ELF calls the size we call the value. What ELF
4946 calls the value we call the alignment. */
4947 value
= isym
->st_size
;
4951 sec
= bfd_section_from_elf_index (abfd
, isym
->st_shndx
);
4953 sec
= bfd_abs_section_ptr
;
4954 else if (sec
->kept_section
)
4956 /* Symbols from discarded section are undefined. We keep
4958 sec
= bfd_und_section_ptr
;
4959 isym
->st_shndx
= SHN_UNDEF
;
4961 else if ((abfd
->flags
& (EXEC_P
| DYNAMIC
)) != 0)
4965 name
= bfd_elf_string_from_elf_section (abfd
, hdr
->sh_link
,
4968 goto error_free_vers
;
4970 if (bed
->elf_add_symbol_hook
)
4972 if (! (*bed
->elf_add_symbol_hook
) (abfd
, info
, isym
, &name
, &flags
,
4974 goto error_free_vers
;
4976 /* The hook function sets the name to NULL if this symbol
4977 should be skipped for some reason. */
4982 /* Sanity check that all possibilities were handled. */
4985 bfd_set_error (bfd_error_bad_value
);
4986 goto error_free_vers
;
4989 if (bfd_is_und_section (sec
)
4990 || bfd_is_com_section (sec
))
4995 size_change_ok
= FALSE
;
4996 type_change_ok
= bed
->type_change_ok
;
5001 if (! bfd_is_und_section (sec
))
5002 h
= elf_link_hash_lookup (htab
, name
, TRUE
, FALSE
, FALSE
);
5004 h
= ((struct elf_link_hash_entry
*) bfd_wrapped_link_hash_lookup
5005 (abfd
, info
, name
, TRUE
, FALSE
, FALSE
));
5007 goto error_free_sym
;
5011 if (is_elf_hash_table (htab
))
5013 while (h
->root
.type
== bfd_link_hash_indirect
5014 || h
->root
.type
== bfd_link_hash_warning
)
5015 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
5017 /* Remember the old alignment if this is a common symbol, so
5018 that we don't reduce the alignment later on. We can't
5019 check later, because _bfd_generic_link_add_one_symbol
5020 will set a default for the alignment which we want to
5021 override. We also remember the old bfd where the existing
5022 definition comes from. */
5023 switch (h
->root
.type
)
5028 case bfd_link_hash_defined
:
5029 if (abfd
->selective_search
)
5032 case bfd_link_hash_defweak
:
5033 old_bfd
= h
->root
.u
.def
.section
->owner
;
5036 case bfd_link_hash_common
:
5037 old_bfd
= h
->root
.u
.c
.p
->section
->owner
;
5038 old_alignment
= h
->root
.u
.c
.p
->alignment_power
;
5043 if (! (_bfd_generic_link_add_one_symbol
5044 (info
, abfd
, name
, flags
, sec
, value
, NULL
, FALSE
, bed
->collect
,
5045 (struct bfd_link_hash_entry
**) sym_hash
)))
5046 goto error_free_vers
;
5049 while (h
->root
.type
== bfd_link_hash_indirect
5050 || h
->root
.type
== bfd_link_hash_warning
)
5051 h
= (struct elf_link_hash_entry
*) h
->root
.u
.i
.link
;
5055 h
->unique_global
= (flags
& BSF_GNU_UNIQUE
) != 0;
5057 /* Set the alignment of a common symbol. */
5058 if ((common
|| bfd_is_com_section (sec
))
5059 && h
->root
.type
== bfd_link_hash_common
)
5064 align
= bfd_log2 (isym
->st_value
);
5067 /* The new symbol is a common symbol in a shared object.
5068 We need to get the alignment from the section. */
5069 align
= new_sec
->alignment_power
;
5071 if (align
> old_alignment
5072 /* Permit an alignment power of zero if an alignment of one
5073 is specified and no other alignments have been specified. */
5074 || (isym
->st_value
== 1 && old_alignment
== 0))
5075 h
->root
.u
.c
.p
->alignment_power
= align
;
5077 h
->root
.u
.c
.p
->alignment_power
= old_alignment
;
5080 if (is_elf_hash_table (htab
))
5082 /* Check the alignment when a common symbol is involved. This
5083 can change when a common symbol is overridden by a normal
5084 definition or a common symbol is ignored due to the old
5085 normal definition. We need to make sure the maximum
5086 alignment is maintained. */
5087 if ((old_alignment
|| common
)
5088 && h
->root
.type
!= bfd_link_hash_common
)
5090 unsigned int common_align
;
5091 unsigned int normal_align
;
5092 unsigned int symbol_align
;
5096 symbol_align
= ffs (h
->root
.u
.def
.value
) - 1;
5097 if (h
->root
.u
.def
.section
->owner
!= NULL
5098 && (h
->root
.u
.def
.section
->owner
->flags
& DYNAMIC
) == 0)
5100 normal_align
= h
->root
.u
.def
.section
->alignment_power
;
5101 if (normal_align
> symbol_align
)
5102 normal_align
= symbol_align
;
5105 normal_align
= symbol_align
;
5109 common_align
= old_alignment
;
5110 common_bfd
= old_bfd
;
5115 common_align
= bfd_log2 (isym
->st_value
);
5117 normal_bfd
= old_bfd
;
5120 if (normal_align
< common_align
)
5122 /* PR binutils/2735 */
5123 if (normal_bfd
== NULL
)
5124 (*_bfd_error_handler
)
5125 (_("Warning: alignment %u of common symbol `%s' in %B"
5126 " is greater than the alignment (%u) of its section %A"),
5127 common_bfd
, h
->root
.u
.def
.section
,
5128 1 << common_align
, name
, 1 << normal_align
);
5130 (*_bfd_error_handler
)
5131 (_("Warning: alignment %u of symbol `%s' in %B"
5132 " is smaller than %u in %B"),
5133 normal_bfd
, common_bfd
,
5134 1 << normal_align
, name
, 1 << common_align
);
5138 /* Remember the symbol size if it isn't undefined. */
5139 if ((isym
->st_size
!= 0 && isym
->st_shndx
!= SHN_UNDEF
)
5140 && (definition
|| h
->size
== 0))
5143 && h
->size
!= isym
->st_size
5144 && ! size_change_ok
)
5145 (*_bfd_error_handler
)
5146 (_("Warning: size of symbol `%s' changed"
5147 " from %lu in %B to %lu in %B"),
5149 name
, (unsigned long) h
->size
,
5150 (unsigned long) isym
->st_size
);
5152 h
->size
= isym
->st_size
;
5155 /* If this is a common symbol, then we always want H->SIZE
5156 to be the size of the common symbol. The code just above
5157 won't fix the size if a common symbol becomes larger. We
5158 don't warn about a size change here, because that is
5159 covered by --warn-common. Allow changed between different
5161 if (h
->root
.type
== bfd_link_hash_common
)
5162 h
->size
= h
->root
.u
.c
.size
;
5164 if (ELF_ST_TYPE (isym
->st_info
) != STT_NOTYPE
5165 && (definition
|| h
->type
== STT_NOTYPE
))
5167 unsigned int type
= ELF_ST_TYPE (isym
->st_info
);
5169 if (h
->type
!= type
)
5171 if (h
->type
!= STT_NOTYPE
&& ! type_change_ok
)
5172 (*_bfd_error_handler
)
5173 (_("Warning: type of symbol `%s' changed"
5174 " from %d to %d in %B"),
5175 abfd
, name
, h
->type
, type
);
5181 /* Set a flag in the hash table entry indicating the type of
5182 reference or definition we just found. Keep a count of
5183 the number of dynamic symbols we find. A dynamic symbol
5184 is one which is referenced or defined by both a regular
5185 object and a shared object. */
5191 if (bind
!= STB_WEAK
)
5192 h
->ref_regular_nonweak
= 1;
5196 BFD_ASSERT (!h
->def_dynamic
);
5202 BFD_ASSERT (definition
);
5205 ((struct elf64_ia64_link_hash_entry
*)h
)->shl
= abfd
;
5210 if (isymbuf
!= NULL
)
5216 /* If this object is the same format as the output object, and it is
5217 not a shared library, then let the backend look through the
5220 This is required to build global offset table entries and to
5221 arrange for dynamic relocs. It is not required for the
5222 particular common case of linking non PIC code, even when linking
5223 against shared libraries, but unfortunately there is no way of
5224 knowing whether an object file has been compiled PIC or not.
5225 Looking through the relocs is not particularly time consuming.
5226 The problem is that we must either (1) keep the relocs in memory,
5227 which causes the linker to require additional runtime memory or
5228 (2) read the relocs twice from the input file, which wastes time.
5229 This would be a good case for using mmap.
5231 I have no idea how to handle linking PIC code into a file of a
5232 different format. It probably can't be done. */
5234 && is_elf_hash_table (htab
)
5235 && bed
->check_relocs
!= NULL
5236 && (*bed
->relocs_compatible
) (abfd
->xvec
, info
->output_bfd
->xvec
))
5240 for (o
= abfd
->sections
; o
!= NULL
; o
= o
->next
)
5242 Elf_Internal_Rela
*internal_relocs
;
5245 if ((o
->flags
& SEC_RELOC
) == 0
5246 || o
->reloc_count
== 0
5247 || ((info
->strip
== strip_all
|| info
->strip
== strip_debugger
)
5248 && (o
->flags
& SEC_DEBUGGING
) != 0)
5249 || bfd_is_abs_section (o
->output_section
))
5252 internal_relocs
= _bfd_elf_link_read_relocs (abfd
, o
, NULL
, NULL
,
5254 if (internal_relocs
== NULL
)
5257 ok
= (*bed
->check_relocs
) (abfd
, info
, o
, internal_relocs
);
5259 if (elf_section_data (o
)->relocs
!= internal_relocs
)
5260 free (internal_relocs
);
5271 if (isymbuf
!= NULL
)
5278 elf64_vms_link_add_archive_symbols (bfd
*abfd
, struct bfd_link_info
*info
)
5281 struct bfd_link_hash_entry
**pundef
;
5282 struct bfd_link_hash_entry
**next_pundef
;
5284 /* We only accept VMS libraries. */
5285 if (info
->output_bfd
->xvec
!= abfd
->xvec
)
5287 bfd_set_error (bfd_error_wrong_format
);
5291 /* The archive_pass field in the archive itself is used to
5292 initialize PASS, since we may search the same archive multiple
5294 pass
= ++abfd
->archive_pass
;
5296 /* Look through the list of undefined symbols. */
5297 for (pundef
= &info
->hash
->undefs
; *pundef
!= NULL
; pundef
= next_pundef
)
5299 struct bfd_link_hash_entry
*h
;
5305 next_pundef
= &(*pundef
)->u
.undef
.next
;
5307 /* When a symbol is defined, it is not necessarily removed from
5309 if (h
->type
!= bfd_link_hash_undefined
5310 && h
->type
!= bfd_link_hash_common
)
5312 /* Remove this entry from the list, for general cleanliness
5313 and because we are going to look through the list again
5314 if we search any more libraries. We can't remove the
5315 entry if it is the tail, because that would lose any
5316 entries we add to the list later on. */
5317 if (*pundef
!= info
->hash
->undefs_tail
)
5319 *pundef
= *next_pundef
;
5320 next_pundef
= pundef
;
5325 /* Look for this symbol in the archive hash table. */
5326 symidx
= _bfd_vms_lib_find_symbol (abfd
, h
->root
.string
);
5327 if (symidx
== BFD_NO_MORE_SYMBOLS
)
5329 /* Nothing in this slot. */
5333 element
= bfd_get_elt_at_index (abfd
, symidx
);
5334 if (element
== NULL
)
5337 if (element
->archive_pass
== -1 || element
->archive_pass
== pass
)
5339 /* Next symbol if this archive is wrong or already handled. */
5343 orig_element
= element
;
5344 if (bfd_is_thin_archive (abfd
))
5346 element
= _bfd_vms_lib_get_imagelib_file (element
);
5347 if (element
== NULL
|| !bfd_check_format (element
, bfd_object
))
5349 orig_element
->archive_pass
= -1;
5353 else if (! bfd_check_format (element
, bfd_object
))
5355 element
->archive_pass
= -1;
5359 /* Unlike the generic linker, we know that this element provides
5360 a definition for an undefined symbol and we know that we want
5361 to include it. We don't need to check anything. */
5362 if (! (*info
->callbacks
->add_archive_element
) (info
, element
,
5363 h
->root
.string
, &element
))
5365 if (! elf64_vms_link_add_object_symbols (element
, info
))
5368 orig_element
->archive_pass
= pass
;
5375 elf64_vms_bfd_link_add_symbols (bfd
*abfd
, struct bfd_link_info
*info
)
5377 switch (bfd_get_format (abfd
))
5380 return elf64_vms_link_add_object_symbols (abfd
, info
);
5383 return elf64_vms_link_add_archive_symbols (abfd
, info
);
5386 bfd_set_error (bfd_error_wrong_format
);
5392 elf64_ia64_vms_mkobject (bfd
*abfd
)
5394 return bfd_elf_allocate_object
5395 (abfd
, sizeof (struct elf64_ia64_vms_obj_tdata
), IA64_ELF_DATA
);
5399 /* Size-dependent data and functions. */
5400 static const struct elf_size_info elf64_ia64_vms_size_info
= {
5401 sizeof (Elf64_External_VMS_Ehdr
),
5402 sizeof (Elf64_External_Phdr
),
5403 sizeof (Elf64_External_Shdr
),
5404 sizeof (Elf64_External_Rel
),
5405 sizeof (Elf64_External_Rela
),
5406 sizeof (Elf64_External_Sym
),
5407 sizeof (Elf64_External_Dyn
),
5408 sizeof (Elf_External_Note
),
5411 64, 3, /* ARCH_SIZE, LOG_FILE_ALIGN */
5412 ELFCLASS64
, EV_CURRENT
,
5413 bfd_elf64_write_out_phdrs
,
5414 elf64_vms_write_shdrs_and_ehdr
,
5415 bfd_elf64_checksum_contents
,
5416 bfd_elf64_write_relocs
,
5417 bfd_elf64_swap_symbol_in
,
5418 bfd_elf64_swap_symbol_out
,
5419 bfd_elf64_slurp_reloc_table
,
5420 bfd_elf64_slurp_symbol_table
,
5421 bfd_elf64_swap_dyn_in
,
5422 bfd_elf64_swap_dyn_out
,
5423 bfd_elf64_swap_reloc_in
,
5424 bfd_elf64_swap_reloc_out
,
5425 bfd_elf64_swap_reloca_in
,
5426 bfd_elf64_swap_reloca_out
5429 #define ELF_ARCH bfd_arch_ia64
5430 #define ELF_MACHINE_CODE EM_IA_64
5431 #define ELF_MAXPAGESIZE 0x10000 /* 64KB */
5432 #define ELF_COMMONPAGESIZE 0x200 /* 16KB */
5434 #define elf_backend_section_from_shdr \
5435 elf64_ia64_section_from_shdr
5436 #define elf_backend_section_flags \
5437 elf64_ia64_section_flags
5438 #define elf_backend_fake_sections \
5439 elf64_ia64_fake_sections
5440 #define elf_backend_final_write_processing \
5441 elf64_ia64_final_write_processing
5442 #define elf_backend_add_symbol_hook \
5443 elf64_ia64_add_symbol_hook
5444 #define elf_info_to_howto \
5445 elf64_ia64_info_to_howto
5447 #define bfd_elf64_bfd_reloc_type_lookup \
5448 ia64_elf_reloc_type_lookup
5449 #define bfd_elf64_bfd_reloc_name_lookup \
5450 ia64_elf_reloc_name_lookup
5451 #define bfd_elf64_bfd_is_local_label_name \
5452 elf64_ia64_is_local_label_name
5453 #define bfd_elf64_bfd_relax_section \
5454 elf64_ia64_relax_section
5456 #define elf_backend_object_p \
5459 /* Stuff for the BFD linker: */
5460 #define bfd_elf64_bfd_link_hash_table_create \
5461 elf64_ia64_hash_table_create
5462 #define elf_backend_create_dynamic_sections \
5463 elf64_ia64_create_dynamic_sections
5464 #define elf_backend_check_relocs \
5465 elf64_ia64_check_relocs
5466 #define elf_backend_adjust_dynamic_symbol \
5467 elf64_ia64_adjust_dynamic_symbol
5468 #define elf_backend_size_dynamic_sections \
5469 elf64_ia64_size_dynamic_sections
5470 #define elf_backend_omit_section_dynsym \
5471 ((bfd_boolean (*) (bfd *, struct bfd_link_info *, asection *)) bfd_true)
5472 #define elf_backend_relocate_section \
5473 elf64_ia64_relocate_section
5474 #define elf_backend_finish_dynamic_symbol \
5475 elf64_ia64_finish_dynamic_symbol
5476 #define elf_backend_finish_dynamic_sections \
5477 elf64_ia64_finish_dynamic_sections
5478 #define bfd_elf64_bfd_final_link \
5479 elf64_ia64_final_link
5481 #define bfd_elf64_bfd_merge_private_bfd_data \
5482 elf64_ia64_merge_private_bfd_data
5483 #define bfd_elf64_bfd_set_private_flags \
5484 elf64_ia64_set_private_flags
5485 #define bfd_elf64_bfd_print_private_bfd_data \
5486 elf64_ia64_print_private_bfd_data
5488 #define elf_backend_plt_readonly 1
5489 #define elf_backend_want_plt_sym 0
5490 #define elf_backend_plt_alignment 5
5491 #define elf_backend_got_header_size 0
5492 #define elf_backend_want_got_plt 1
5493 #define elf_backend_may_use_rel_p 1
5494 #define elf_backend_may_use_rela_p 1
5495 #define elf_backend_default_use_rela_p 1
5496 #define elf_backend_want_dynbss 0
5497 #define elf_backend_hide_symbol elf64_ia64_hash_hide_symbol
5498 #define elf_backend_fixup_symbol _bfd_elf_link_hash_fixup_symbol
5499 #define elf_backend_reloc_type_class elf64_ia64_reloc_type_class
5500 #define elf_backend_rela_normal 1
5501 #define elf_backend_special_sections elf64_ia64_special_sections
5502 #define elf_backend_default_execstack 0
5504 /* FIXME: PR 290: The Intel C compiler generates SHT_IA_64_UNWIND with
5505 SHF_LINK_ORDER. But it doesn't set the sh_link or sh_info fields.
5506 We don't want to flood users with so many error messages. We turn
5507 off the warning for now. It will be turned on later when the Intel
5508 compiler is fixed. */
5509 #define elf_backend_link_order_error_handler NULL
5511 /* VMS-specific vectors. */
5513 #undef TARGET_LITTLE_SYM
5514 #define TARGET_LITTLE_SYM ia64_elf64_vms_vec
5515 #undef TARGET_LITTLE_NAME
5516 #define TARGET_LITTLE_NAME "elf64-ia64-vms"
5517 #undef TARGET_BIG_SYM
5518 #undef TARGET_BIG_NAME
5520 /* These are VMS specific functions. */
5522 #undef elf_backend_object_p
5523 #define elf_backend_object_p elf64_vms_object_p
5525 #undef elf_backend_section_from_shdr
5526 #define elf_backend_section_from_shdr elf64_vms_section_from_shdr
5528 #undef elf_backend_post_process_headers
5529 #define elf_backend_post_process_headers elf64_vms_post_process_headers
5531 #undef elf_backend_section_processing
5532 #define elf_backend_section_processing elf64_vms_section_processing
5534 #undef elf_backend_final_write_processing
5535 #define elf_backend_final_write_processing elf64_vms_final_write_processing
5537 #undef bfd_elf64_close_and_cleanup
5538 #define bfd_elf64_close_and_cleanup elf64_vms_close_and_cleanup
5540 #undef elf_backend_section_from_bfd_section
5542 #undef elf_backend_symbol_processing
5544 #undef elf_backend_want_p_paddr_set_to_zero
5547 #define ELF_OSABI ELFOSABI_OPENVMS
5549 #undef ELF_MAXPAGESIZE
5550 #define ELF_MAXPAGESIZE 0x10000 /* 64KB */
5553 #define elf64_bed elf64_ia64_vms_bed
5555 #define elf_backend_size_info elf64_ia64_vms_size_info
5557 /* Use VMS-style archives (in particular, don't use the standard coff
5559 #define bfd_elf64_archive_functions
5561 #undef bfd_elf64_archive_p
5562 #define bfd_elf64_archive_p _bfd_vms_lib_ia64_archive_p
5563 #undef bfd_elf64_write_archive_contents
5564 #define bfd_elf64_write_archive_contents _bfd_vms_lib_write_archive_contents
5565 #undef bfd_elf64_mkarchive
5566 #define bfd_elf64_mkarchive _bfd_vms_lib_ia64_mkarchive
5568 #define bfd_elf64_archive_slurp_armap \
5569 _bfd_vms_lib_slurp_armap
5570 #define bfd_elf64_archive_slurp_extended_name_table \
5571 _bfd_vms_lib_slurp_extended_name_table
5572 #define bfd_elf64_archive_construct_extended_name_table \
5573 _bfd_vms_lib_construct_extended_name_table
5574 #define bfd_elf64_archive_truncate_arname \
5575 _bfd_vms_lib_truncate_arname
5576 #define bfd_elf64_archive_write_armap \
5577 _bfd_vms_lib_write_armap
5578 #define bfd_elf64_archive_read_ar_hdr \
5579 _bfd_vms_lib_read_ar_hdr
5580 #define bfd_elf64_archive_write_ar_hdr \
5581 _bfd_vms_lib_write_ar_hdr
5582 #define bfd_elf64_archive_openr_next_archived_file \
5583 _bfd_vms_lib_openr_next_archived_file
5584 #define bfd_elf64_archive_get_elt_at_index \
5585 _bfd_vms_lib_get_elt_at_index
5586 #define bfd_elf64_archive_generic_stat_arch_elt \
5587 _bfd_vms_lib_generic_stat_arch_elt
5588 #define bfd_elf64_archive_update_armap_timestamp \
5589 _bfd_vms_lib_update_armap_timestamp
5591 /* VMS link methods. */
5592 #undef bfd_elf64_bfd_link_add_symbols
5593 #define bfd_elf64_bfd_link_add_symbols elf64_vms_bfd_link_add_symbols
5595 #undef elf_backend_want_got_sym
5596 #define elf_backend_want_got_sym 0
5598 #undef bfd_elf64_mkobject
5599 #define bfd_elf64_mkobject elf64_ia64_vms_mkobject
5601 /* Redefine to align segments on block size. */
5602 #undef ELF_MAXPAGESIZE
5603 #define ELF_MAXPAGESIZE 0x200 /* 512B */
5605 #undef elf_backend_want_got_plt
5606 #define elf_backend_want_got_plt 0
5608 #include "elf64-target.h"