* elf-hppa.h (elf_hppa_final_link): Fix formatting in comment.
Skip excluded sections in determing __gp value. (elf_hppa_final_link_relocate): Use the symbol's address in R_PARISC_FPTR64 relocations that don't need an opd entry. * elf64-hppa.c (allocate_dynrel_entries): Simplify code. (elf64_hppa_finalize_dynreloc): Likewise. (elf64_hppa_size_dynamic_sections): Move comments and fix typo. (elf64_hppa_finish_dynamic_symbol): Break up assert.
This commit is contained in:
parent
82b47e62fc
commit
d663e1cd53
3 changed files with 51 additions and 39 deletions
|
@ -1,3 +1,14 @@
|
||||||
|
2002-06-16 John David Anglin <dave@hiauly1.hia.nrc.ca>
|
||||||
|
|
||||||
|
* elf-hppa.h (elf_hppa_final_link): Fix formatting in comment.
|
||||||
|
Skip excluded sections in determing __gp value.
|
||||||
|
(elf_hppa_final_link_relocate): Use the symbol's address in
|
||||||
|
R_PARISC_FPTR64 relocations that don't need an opd entry.
|
||||||
|
* elf64-hppa.c (allocate_dynrel_entries): Simplify code.
|
||||||
|
(elf64_hppa_finalize_dynreloc): Likewise.
|
||||||
|
(elf64_hppa_size_dynamic_sections): Move comments and fix typo.
|
||||||
|
(elf64_hppa_finish_dynamic_symbol): Break up assert.
|
||||||
|
|
||||||
2002-06-14 Sergey Grigoriev <serge@leopold.Physik.Uni-Augsburg.DE>
|
2002-06-14 Sergey Grigoriev <serge@leopold.Physik.Uni-Augsburg.DE>
|
||||||
|
|
||||||
* pei-i386.c (COFF_SECTION_ALIGNMENT_ENTRIES): Enable 16 byte
|
* pei-i386.c (COFF_SECTION_ALIGNMENT_ENTRIES): Enable 16 byte
|
||||||
|
|
|
@ -1296,22 +1296,22 @@ elf_hppa_final_link (abfd, info)
|
||||||
address of the .plt + gp_offset.
|
address of the .plt + gp_offset.
|
||||||
|
|
||||||
If no .plt is found, then look for .dlt, .opd and .data (in
|
If no .plt is found, then look for .dlt, .opd and .data (in
|
||||||
that order) and set __gp to the base address of whichever section
|
that order) and set __gp to the base address of whichever
|
||||||
is found first. */
|
section is found first. */
|
||||||
|
|
||||||
sec = hppa_info->plt_sec;
|
sec = hppa_info->plt_sec;
|
||||||
if (sec)
|
if (sec && ! (sec->flags & SEC_EXCLUDE))
|
||||||
gp_val = (sec->output_offset
|
gp_val = (sec->output_offset
|
||||||
+ sec->output_section->vma
|
+ sec->output_section->vma
|
||||||
+ hppa_info->gp_offset);
|
+ hppa_info->gp_offset);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sec = hppa_info->dlt_sec;
|
sec = hppa_info->dlt_sec;
|
||||||
if (!sec)
|
if (!sec || (sec->flags & SEC_EXCLUDE))
|
||||||
sec = hppa_info->opd_sec;
|
sec = hppa_info->opd_sec;
|
||||||
if (!sec)
|
if (!sec || (sec->flags & SEC_EXCLUDE))
|
||||||
sec = bfd_get_section_by_name (abfd, ".data");
|
sec = bfd_get_section_by_name (abfd, ".data");
|
||||||
if (!sec)
|
if (!sec || (sec->flags & SEC_EXCLUDE))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
gp_val = sec->output_offset + sec->output_section->vma;
|
gp_val = sec->output_offset + sec->output_section->vma;
|
||||||
|
@ -2074,11 +2074,14 @@ elf_hppa_final_link_relocate (rel, input_bfd, output_bfd,
|
||||||
hppa_info->opd_sec->contents + dyn_h->opd_offset + 24);
|
hppa_info->opd_sec->contents + dyn_h->opd_offset + 24);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* We want the value of the OPD offset for this symbol, not
|
if (dyn_h->want_opd)
|
||||||
the symbol's actual address. */
|
/* We want the value of the OPD offset for this symbol. */
|
||||||
value = (dyn_h->opd_offset
|
value = (dyn_h->opd_offset
|
||||||
+ hppa_info->opd_sec->output_offset
|
+ hppa_info->opd_sec->output_offset
|
||||||
+ hppa_info->opd_sec->output_section->vma);
|
+ hppa_info->opd_sec->output_section->vma);
|
||||||
|
else
|
||||||
|
/* We want the address of the symbol. */
|
||||||
|
value += addend;
|
||||||
|
|
||||||
bfd_put_64 (input_bfd, value, hit_data);
|
bfd_put_64 (input_bfd, value, hit_data);
|
||||||
return bfd_reloc_ok;
|
return bfd_reloc_ok;
|
||||||
|
|
|
@ -1532,15 +1532,11 @@ allocate_dynrel_entries (dyn_h, data)
|
||||||
|
|
||||||
for (rent = dyn_h->reloc_entries; rent; rent = rent->next)
|
for (rent = dyn_h->reloc_entries; rent; rent = rent->next)
|
||||||
{
|
{
|
||||||
switch (rent->type)
|
/* Allocate one iff we are building a shared library, the relocation
|
||||||
{
|
isn't a R_PARISC_FPTR64, or we don't want an opd entry. */
|
||||||
case R_PARISC_FPTR64:
|
if (!shared && rent->type == R_PARISC_FPTR64 && dyn_h->want_opd)
|
||||||
/* Allocate one iff we are building a shared library and don't
|
|
||||||
want an opd entry. */
|
|
||||||
if (!x->info->shared && dyn_h->want_opd)
|
|
||||||
continue;
|
continue;
|
||||||
break;
|
|
||||||
}
|
|
||||||
hppa_info->other_rel_sec->_raw_size += sizeof (Elf64_External_Rela);
|
hppa_info->other_rel_sec->_raw_size += sizeof (Elf64_External_Rela);
|
||||||
|
|
||||||
/* Make sure this symbol gets into the dynamic symbol table if it is
|
/* Make sure this symbol gets into the dynamic symbol table if it is
|
||||||
|
@ -1722,10 +1718,9 @@ elf64_hppa_size_dynamic_sections (output_bfd, info)
|
||||||
|
|
||||||
if (strcmp (name, ".plt") == 0)
|
if (strcmp (name, ".plt") == 0)
|
||||||
{
|
{
|
||||||
|
/* Strip this section if we don't need it; see the comment below. */
|
||||||
if (s->_raw_size == 0)
|
if (s->_raw_size == 0)
|
||||||
{
|
{
|
||||||
/* Strip this section if we don't need it; see the
|
|
||||||
comment below. */
|
|
||||||
strip = true;
|
strip = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -1736,24 +1731,29 @@ elf64_hppa_size_dynamic_sections (output_bfd, info)
|
||||||
}
|
}
|
||||||
else if (strcmp (name, ".dlt") == 0)
|
else if (strcmp (name, ".dlt") == 0)
|
||||||
{
|
{
|
||||||
|
/* Strip this section if we don't need it; see the comment below. */
|
||||||
if (s->_raw_size == 0)
|
if (s->_raw_size == 0)
|
||||||
{
|
{
|
||||||
/* Strip this section if we don't need it; see the
|
|
||||||
comment below. */
|
|
||||||
strip = true;
|
strip = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (strcmp (name, ".opd") == 0)
|
else if (strcmp (name, ".opd") == 0)
|
||||||
{
|
{
|
||||||
|
/* Strip this section if we don't need it; see the comment below. */
|
||||||
if (s->_raw_size == 0)
|
if (s->_raw_size == 0)
|
||||||
{
|
{
|
||||||
/* Strip this section if we don't need it; see the
|
|
||||||
comment below. */
|
|
||||||
strip = true;
|
strip = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (strncmp (name, ".rela", 4) == 0)
|
else if (strncmp (name, ".rela", 5) == 0)
|
||||||
{
|
{
|
||||||
|
/* If we don't need this section, strip it from the output file.
|
||||||
|
This is mostly to handle .rela.bss and .rela.plt. We must
|
||||||
|
create both sections in create_dynamic_sections, because they
|
||||||
|
must be created before the linker maps input sections to output
|
||||||
|
sections. The linker does that before adjust_dynamic_symbol
|
||||||
|
is called, and it is that function which decides whether
|
||||||
|
anything needs to go into these sections. */
|
||||||
if (s->_raw_size == 0)
|
if (s->_raw_size == 0)
|
||||||
{
|
{
|
||||||
/* If we don't need this section, strip it from the
|
/* If we don't need this section, strip it from the
|
||||||
|
@ -1951,9 +1951,6 @@ elf64_hppa_finish_dynamic_symbol (output_bfd, info, h, sym)
|
||||||
spltrel = hppa_info->plt_rel_sec;
|
spltrel = hppa_info->plt_rel_sec;
|
||||||
sdltrel = hppa_info->dlt_rel_sec;
|
sdltrel = hppa_info->dlt_rel_sec;
|
||||||
|
|
||||||
BFD_ASSERT (stub != NULL && splt != NULL
|
|
||||||
&& sopd != NULL && sdlt != NULL)
|
|
||||||
|
|
||||||
/* Incredible. It is actually necessary to NOT use the symbol's real
|
/* Incredible. It is actually necessary to NOT use the symbol's real
|
||||||
value when building the dynamic symbol table for a shared library.
|
value when building the dynamic symbol table for a shared library.
|
||||||
At least for symbols that refer to functions.
|
At least for symbols that refer to functions.
|
||||||
|
@ -1963,6 +1960,8 @@ elf64_hppa_finish_dynamic_symbol (output_bfd, info, h, sym)
|
||||||
the original values (in elf64_hppa_link_output_symbol_hook). */
|
the original values (in elf64_hppa_link_output_symbol_hook). */
|
||||||
if (dyn_h && dyn_h->want_opd)
|
if (dyn_h && dyn_h->want_opd)
|
||||||
{
|
{
|
||||||
|
BFD_ASSERT (sopd != NULL)
|
||||||
|
|
||||||
/* Save away the original value and section index so that we
|
/* Save away the original value and section index so that we
|
||||||
can restore them later. */
|
can restore them later. */
|
||||||
dyn_h->st_value = sym->st_value;
|
dyn_h->st_value = sym->st_value;
|
||||||
|
@ -1984,6 +1983,8 @@ elf64_hppa_finish_dynamic_symbol (output_bfd, info, h, sym)
|
||||||
bfd_vma value;
|
bfd_vma value;
|
||||||
Elf_Internal_Rela rel;
|
Elf_Internal_Rela rel;
|
||||||
|
|
||||||
|
BFD_ASSERT (splt != NULL && spltrel != NULL)
|
||||||
|
|
||||||
/* We do not actually care about the value in the PLT entry
|
/* We do not actually care about the value in the PLT entry
|
||||||
if we are creating a shared library and the symbol is
|
if we are creating a shared library and the symbol is
|
||||||
still undefined, we create a dynamic relocation to fill
|
still undefined, we create a dynamic relocation to fill
|
||||||
|
@ -2034,6 +2035,8 @@ elf64_hppa_finish_dynamic_symbol (output_bfd, info, h, sym)
|
||||||
int insn;
|
int insn;
|
||||||
unsigned int max_offset;
|
unsigned int max_offset;
|
||||||
|
|
||||||
|
BFD_ASSERT (stub != NULL)
|
||||||
|
|
||||||
/* Install the generic stub template.
|
/* Install the generic stub template.
|
||||||
|
|
||||||
We are modifying the contents of the stub section, so we do not
|
We are modifying the contents of the stub section, so we do not
|
||||||
|
@ -2357,15 +2360,10 @@ elf64_hppa_finalize_dynreloc (dyn_h, data)
|
||||||
{
|
{
|
||||||
Elf64_Internal_Rela rel;
|
Elf64_Internal_Rela rel;
|
||||||
|
|
||||||
switch (rent->type)
|
/* Allocate one iff we are building a shared library, the relocation
|
||||||
{
|
isn't a R_PARISC_FPTR64, or we don't want an opd entry. */
|
||||||
case R_PARISC_FPTR64:
|
if (!info->shared && rent->type == R_PARISC_FPTR64 && dyn_h->want_opd)
|
||||||
/* Allocate one iff we are building a shared library and don't
|
|
||||||
want an opd entry. */
|
|
||||||
if (!info->shared && dyn_h->want_opd)
|
|
||||||
continue;
|
continue;
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create a dynamic relocation for this entry.
|
/* Create a dynamic relocation for this entry.
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue