From: Dave Anglin Date: Sun, 20 Nov 2005 19:21:06 +0000 (+0000) Subject: * som.c (som_decode_symclass): Decode BSF_WEAK symbols in the same X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f29ba312286c54e1b013a5adf42c58fd4642bf56;p=binutils-gdb.git * som.c (som_decode_symclass): Decode BSF_WEAK symbols in the same manner as bfd_decode_symclass. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 49da6ebb239..57ba88a73ce 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2005-11-20 John David Anglin + + * som.c (som_decode_symclass): Decode BSF_WEAK symbols in the same + manner as bfd_decode_symclass. + 2005-11-18 Alan Modra * elf64-ppc.c (ppc64_elf_check_relocs): Don't set has_14bit_branch diff --git a/bfd/som.c b/bfd/som.c index c1195c9a10a..0c9e1b79f9c 100644 --- a/bfd/som.c +++ b/bfd/som.c @@ -5355,11 +5355,30 @@ som_decode_symclass (asymbol *symbol) if (bfd_is_com_section (symbol->section)) return 'C'; if (bfd_is_und_section (symbol->section)) - return 'U'; + { + if (symbol->flags & BSF_WEAK) + { + /* If weak, determine if it's specifically an object + or non-object weak. */ + if (symbol->flags & BSF_OBJECT) + return 'v'; + else + return 'w'; + } + else + return 'U'; + } if (bfd_is_ind_section (symbol->section)) return 'I'; if (symbol->flags & BSF_WEAK) - return 'W'; + { + /* If weak, determine if it's specifically an object + or non-object weak. */ + if (symbol->flags & BSF_OBJECT) + return 'V'; + else + return 'W'; + } if (!(symbol->flags & (BSF_GLOBAL | BSF_LOCAL))) return '?';