diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 210d6ad747..0e2a4c7e36 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,23 @@ +2000-07-19 H.J. Lu + + * elf32-arm.h (elf32_arm_size_dynamic_sections): Also set + DF_TEXTREL if DT_TEXTREL is set. + * elf32-i370.c (i370_elf_size_dynamic_sections): Likewise. + * elf32-i386.c (elf_i386_size_dynamic_sections): Likewise. + * elf32-m68k.c (elf_m68k_size_dynamic_sections): Likewise. + * elf32-mips.c (_bfd_mips_elf_size_dynamic_sections): Likewise. + * elf32-ppc.c (ppc_elf_size_dynamic_sections): Likewise. + * elf32-sparc.c (elf32_sparc_size_dynamic_sections): Likewise. + * elf64-alpha.c (elf64_alpha_size_dynamic_sections): Likewise. + * elf64-hppa.c (elf64_hppa_size_dynamic_sections): Likewise. + * elf64-ia64.c (elf64_ia64_size_dynamic_sections): Likewise. + * elf64-sparc.c (sparc64_elf_size_dynamic_sections): Likewise. + + * bfd/elflink.h (NAME(bfd_elf,size_dynamic_sections)): Also + set DF_SYMBOLIC for symbolic link. Also set DT_RUNPATH if + DT_RPATH is set. + Set the DT_FLAGS and DT_FLAGS_1 entries if necessary. + 2000-07-19 H.J. Lu * bfd-in.h (bfd_elf_set_dt_needed_soname): New. diff --git a/bfd/elf32-arm.h b/bfd/elf32-arm.h index 828a58320b..6b748ef638 100644 --- a/bfd/elf32-arm.h +++ b/bfd/elf32-arm.h @@ -2991,6 +2991,7 @@ elf32_arm_size_dynamic_sections (output_bfd, info) { if (! bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf32-i370.c b/bfd/elf32-i370.c index 0715d86d08..67c6964cd9 100644 --- a/bfd/elf32-i370.c +++ b/bfd/elf32-i370.c @@ -959,6 +959,7 @@ i370_elf_size_dynamic_sections (output_bfd, info) { if (! bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c index 997ae5434f..ace82876df 100644 --- a/bfd/elf32-i386.c +++ b/bfd/elf32-i386.c @@ -1238,6 +1238,7 @@ elf_i386_size_dynamic_sections (output_bfd, info) { if (! bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf32-m68k.c b/bfd/elf32-m68k.c index b01523477b..bee73b5a57 100644 --- a/bfd/elf32-m68k.c +++ b/bfd/elf32-m68k.c @@ -1307,6 +1307,7 @@ elf_m68k_size_dynamic_sections (output_bfd, info) { if (!bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf32-mips.c b/bfd/elf32-mips.c index 1e9e99bca1..27ae18abb9 100644 --- a/bfd/elf32-mips.c +++ b/bfd/elf32-mips.c @@ -8319,6 +8319,7 @@ _bfd_mips_elf_size_dynamic_sections (output_bfd, info) { if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } if (! MIPS_ELF_ADD_DYNAMIC_ENTRY (info, DT_PLTGOT, 0)) diff --git a/bfd/elf32-ppc.c b/bfd/elf32-ppc.c index 6dc3effc3f..3c7999b760 100644 --- a/bfd/elf32-ppc.c +++ b/bfd/elf32-ppc.c @@ -2044,6 +2044,7 @@ ppc_elf_size_dynamic_sections (output_bfd, info) { if (! bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf32-sparc.c b/bfd/elf32-sparc.c index 70d65a5f87..002938479d 100644 --- a/bfd/elf32-sparc.c +++ b/bfd/elf32-sparc.c @@ -1056,6 +1056,7 @@ elf32_sparc_size_dynamic_sections (output_bfd, info) { if (! bfd_elf32_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf64-alpha.c b/bfd/elf64-alpha.c index 84f3075e4c..b4025c0228 100644 --- a/bfd/elf64-alpha.c +++ b/bfd/elf64-alpha.c @@ -3312,6 +3312,7 @@ elf64_alpha_size_dynamic_sections (output_bfd, info) { if (! bfd_elf64_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf64-hppa.c b/bfd/elf64-hppa.c index b90b47878f..b5edaf1457 100644 --- a/bfd/elf64-hppa.c +++ b/bfd/elf64-hppa.c @@ -1789,6 +1789,7 @@ elf64_hppa_size_dynamic_sections (output_bfd, info) { if (! bfd_elf64_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf64-ia64.c b/bfd/elf64-ia64.c index cacfd6593f..a8bebf219f 100644 --- a/bfd/elf64-ia64.c +++ b/bfd/elf64-ia64.c @@ -2517,6 +2517,7 @@ elf64_ia64_size_dynamic_sections (output_bfd, info) { if (! bfd_elf64_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } } diff --git a/bfd/elf64-sparc.c b/bfd/elf64-sparc.c index ca2e7c1d2f..b2b8cbf9ec 100644 --- a/bfd/elf64-sparc.c +++ b/bfd/elf64-sparc.c @@ -1803,6 +1803,7 @@ sparc64_elf_size_dynamic_sections (output_bfd, info) { if (! bfd_elf64_add_dynamic_entry (info, DT_TEXTREL, 0)) return false; + info->flags |= DF_TEXTREL; } /* Add dynamic STT_REGISTER symbols and corresponding DT_SPARC_REGISTER diff --git a/bfd/elflink.h b/bfd/elflink.h index 7fa35a936c..1bf366873a 100644 --- a/bfd/elflink.h +++ b/bfd/elflink.h @@ -2837,6 +2837,7 @@ NAME(bfd_elf,size_dynamic_sections) (output_bfd, soname, rpath, { if (! elf_add_dynamic_entry (info, DT_SYMBOLIC, 0)) return false; + info->flags |= DF_SYMBOLIC; } if (rpath != NULL) @@ -2846,7 +2847,8 @@ NAME(bfd_elf,size_dynamic_sections) (output_bfd, soname, rpath, indx = _bfd_stringtab_add (elf_hash_table (info)->dynstr, rpath, true, true); if (indx == (bfd_size_type) -1 - || ! elf_add_dynamic_entry (info, DT_RPATH, indx)) + || ! elf_add_dynamic_entry (info, DT_RPATH, indx) + || ! elf_add_dynamic_entry (info, DT_RUNPATH, indx)) return false; } @@ -3135,6 +3137,22 @@ NAME(bfd_elf,size_dynamic_sections) (output_bfd, soname, rpath, elf_tdata (output_bfd)->cverdefs = cdefs; } + if (info->flags) + { + if (! elf_add_dynamic_entry (info, DT_FLAGS, info->flags)) + return false; + } + + if (info->flags_1) + { + if (! info->shared) + info->flags_1 &= ~ (DF_1_INITFIRST + | DF_1_NODELETE + | DF_1_NOOPEN); + if (! elf_add_dynamic_entry (info, DT_FLAGS_1, info->flags_1)) + return false; + } + /* Work out the size of the version reference section. */ s = bfd_get_section_by_name (dynobj, ".gnu.version_r");