diff options
author | Alan Modra <amodra@bigpond.net.au> | 2008-07-07 04:37:53 +0000 |
---|---|---|
committer | Alan Modra <amodra@bigpond.net.au> | 2008-07-07 04:37:53 +0000 |
commit | 03e13e45fff8cc6d0a86c7559aed3cad552343a9 (patch) | |
tree | 135ac735057cfc7af5125542c3a2affe54f84d95 /binutils/objdump.c | |
parent | b537f3e148146bd432d435e95ca31c6848cfffb5 (diff) | |
download | binutils-redhat-03e13e45fff8cc6d0a86c7559aed3cad552343a9.tar.gz |
* objdump.c (find_symbol_for_address): Prefer symbols in current
section.
Diffstat (limited to 'binutils/objdump.c')
-rw-r--r-- | binutils/objdump.c | 35 |
1 files changed, 23 insertions, 12 deletions
diff --git a/binutils/objdump.c b/binutils/objdump.c index d171d14f4f..58947245ee 100644 --- a/binutils/objdump.c +++ b/binutils/objdump.c @@ -740,6 +740,27 @@ find_symbol_for_address (bfd_vma vma, == bfd_asymbol_value (sorted_syms[thisplace - 1]))) --thisplace; + /* Prefer a symbol in the current section if we have multple symbols + with the same value, as can occur with overlays or zero size + sections. */ + min = thisplace; + while (min < max + && (bfd_asymbol_value (sorted_syms[min]) + == bfd_asymbol_value (sorted_syms[thisplace]))) + { + if (sorted_syms[min]->section == sec + && info->symbol_is_valid (sorted_syms[min], info)) + { + thisplace = min; + + if (place != NULL) + *place = thisplace; + + return sorted_syms[thisplace]; + } + ++min; + } + /* If the file is relocatable, and the symbol could be from this section, prefer a symbol from this section over symbols from others, even if the other symbol's value might be closer. @@ -759,19 +780,9 @@ find_symbol_for_address (bfd_vma vma, || !info->symbol_is_valid (sorted_syms[thisplace], info)) { long i; - long newplace; - - for (i = thisplace + 1; i < sorted_symcount; i++) - { - if (bfd_asymbol_value (sorted_syms[i]) - != bfd_asymbol_value (sorted_syms[thisplace])) - break; - } - - --i; - newplace = sorted_symcount; + long newplace = sorted_symcount; - for (; i >= 0; i--) + for (i = min - 1; i >= 0; i--) { if ((sorted_syms[i]->section == sec || !want_section) && info->symbol_is_valid (sorted_syms[i], info)) |