From: Ian Lance Taylor Date: Fri, 6 Jan 1995 21:50:28 +0000 (+0000) Subject: * elfcode.h (elf_slurp_symbol_table): Don't set BSF_GLOBAL for an X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=42cf6d7950ebbb91215bac2035055ceb0d5ccda4;p=binutils-gdb.git * elfcode.h (elf_slurp_symbol_table): Don't set BSF_GLOBAL for an undefined or common symbol. (elf_link_add_object_symbols): Likewise. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 99d067db5ed..35cb9754bc3 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +Fri Jan 6 16:39:40 1995 Ian Lance Taylor + + * elfcode.h (elf_slurp_symbol_table): Don't set BSF_GLOBAL for an + undefined or common symbol. + (elf_link_add_object_symbols): Likewise. + Wed Jan 4 14:14:05 1995 Jeff Law (law@snake.cs.utah.edu) * som.c (bfd_section_from_som_symbol): Only return sections which diff --git a/bfd/elfcode.h b/bfd/elfcode.h index f0b515b232f..ec3828efa3c 100644 --- a/bfd/elfcode.h +++ b/bfd/elfcode.h @@ -2801,7 +2801,9 @@ elf_slurp_symbol_table (abfd, symptrs, dynamic) sym->symbol.flags |= BSF_LOCAL; break; case STB_GLOBAL: - sym->symbol.flags |= BSF_GLOBAL; + if (i_sym.st_shndx != SHN_UNDEF + && i_sym.st_shndx != SHN_COMMON) + sym->symbol.flags |= BSF_GLOBAL; break; case STB_WEAK: sym->symbol.flags |= BSF_WEAK; @@ -4202,7 +4204,13 @@ elf_link_add_object_symbols (abfd, info) continue; } else if (bind == STB_GLOBAL) - flags = BSF_GLOBAL; + { + if (sym.st_shndx != SHN_UNDEF + && sym.st_shndx != SHN_COMMON) + flags = BSF_GLOBAL; + else + flags = 0; + } else if (bind == STB_WEAK) flags = BSF_WEAK; else