From 44852b190c1f9b646fa36abd214dab0f5f82e773 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Sat, 7 Oct 2000 12:52:15 +0000 Subject: [PATCH] Make elf section symbols global for link-once sections. --- bfd/ChangeLog | 4 ++++ bfd/elf.c | 8 +++++--- gas/ChangeLog | 7 +++++++ gas/config/obj-elf.c | 15 +++++++++++++++ gas/write.c | 2 +- 5 files changed, 32 insertions(+), 4 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 7069fb86e70..3347191d75f 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,7 @@ +2000-10-07 Alan Modra + + * elf.c (swap_out_syms): Handle global section symbols. + 2000-10-05 DJ Delorie * peigen.c (_bfd_pei_swap_scnhdr_out): note extended relocs diff --git a/bfd/elf.c b/bfd/elf.c index 3aede147dfa..bc8dec7a275 100644 --- a/bfd/elf.c +++ b/bfd/elf.c @@ -4352,8 +4352,9 @@ swap_out_syms (abfd, sttp, relocatable_p) flagword flags = syms[idx]->flags; int type; - if (flags & BSF_SECTION_SYM) - /* Section symbols have no names. */ + /* Section symbols usually have no name. The exception is + link-once section symbols, which we make global. */ + if ((flags & (BSF_SECTION_SYM | BSF_GLOBAL)) == BSF_SECTION_SYM) sym.st_name = 0; else { @@ -4461,7 +4462,8 @@ swap_out_syms (abfd, sttp, relocatable_p) type = (*bed->elf_backend_get_symbol_type) (&type_ptr->internal_elf_sym, type); if (flags & BSF_SECTION_SYM) - sym.st_info = ELF_ST_INFO (STB_LOCAL, STT_SECTION); + sym.st_info = ELF_ST_INFO ((flags & BSF_GLOBAL + ? STB_GLOBAL : STB_LOCAL), STT_SECTION); else if (bfd_is_com_section (syms[idx]->section)) sym.st_info = ELF_ST_INFO (STB_GLOBAL, type); else if (bfd_is_und_section (syms[idx]->section)) diff --git a/gas/ChangeLog b/gas/ChangeLog index ff9c3b87609..7533a9e1da8 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,10 @@ +2000-10-07 Alan Modra + + * write.c (write_relocs): Fix a comment. + + * config/obj-elf.c (elf_frob_symbol): Make section syms global on + link-once sections. + 2000-10-05 Jim Wilson * config/tc-ia64.c (resources_match): Handle IA64_RS_PRr. diff --git a/gas/config/obj-elf.c b/gas/config/obj-elf.c index 4e7f3a36d06..0f49ab6339f 100644 --- a/gas/config/obj-elf.c +++ b/gas/config/obj-elf.c @@ -1742,6 +1742,21 @@ elf_frob_symbol (symp, puntp) && S_IS_DEFINED (symp)) symbol_get_bfdsym (symp)->flags |= BSF_OBJECT; #endif + + if (symbol_section_p (symp)) + { + asection *symsec = S_GET_SEGMENT (symp); + + if ((bfd_get_section_flags (stdoutput, symsec) & SEC_LINK_ONCE) != 0 + || strncmp (segment_name (symsec), ".gnu.linkonce", + sizeof ".gnu.linkonce" - 1) == 0) + { + /* Make section syms global on ELF linkonce sections. + This way, any reference to the section symbol will + resolve to the section that actually stays in. */ + S_SET_EXTERNAL (symp); + } + } } void diff --git a/gas/write.c b/gas/write.c index 907ba2f1b66..802d4611a5f 100644 --- a/gas/write.c +++ b/gas/write.c @@ -1008,7 +1008,7 @@ write_relocs (abfd, sec, xxx) } /* If this is an undefined symbol which was equated to another - symbol, then use generate the reloc against the latter symbol + symbol, then generate the reloc against the latter symbol rather than the former. */ sym = fixp->fx_addsy; while (symbol_equated_p (sym)