diff options
author | Alan Modra <amodra@gmail.com> | 2007-07-26 13:45:59 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2007-07-26 13:45:59 +0000 |
commit | 33774f084b0c1094d0ae966e4339db378fc60b53 (patch) | |
tree | 458b22ba1e8e1f76e33ff9a933b3038c0df81b59 /bfd | |
parent | e62071b60e0a89780a5b3a153365805346b38614 (diff) | |
download | gdb-33774f084b0c1094d0ae966e4339db378fc60b53.zip gdb-33774f084b0c1094d0ae966e4339db378fc60b53.tar.gz gdb-33774f084b0c1094d0ae966e4339db378fc60b53.tar.bz2 |
* elflink.c (_bfd_elf_fix_symbol_flags): Remove unnecessary
check on dynobj. Remove bed shadow.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 3 | ||||
-rw-r--r-- | bfd/elflink.c | 19 |
2 files changed, 9 insertions, 13 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 19a7c49..954a47d 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,5 +1,8 @@ 2007-07-26 Alan Modra <amodra@bigpond.net.au> + * elflink.c (_bfd_elf_fix_symbol_flags): Remove unnecessary + check on dynobj. Remove bed shadow. + * srec.c (srec_get_section_contents): Return immediately on count zero. Check that offset and count are within section. * libbfd.c (_bfd_generic_get_section_contents): Check that diff --git a/bfd/elflink.c b/bfd/elflink.c index 07a6aec..1e98cb7 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -2368,7 +2368,7 @@ bfd_boolean _bfd_elf_fix_symbol_flags (struct elf_link_hash_entry *h, struct elf_info_failed *eif) { - const struct elf_backend_data *bed = NULL; + const struct elf_backend_data *bed; /* If this symbol was mentioned in a non-ELF file, try to set DEF_REGULAR and REF_REGULAR correctly. This is the only way to @@ -2429,13 +2429,10 @@ _bfd_elf_fix_symbol_flags (struct elf_link_hash_entry *h, } /* Backend specific symbol fixup. */ - if (elf_hash_table (eif->info)->dynobj) - { - bed = get_elf_backend_data (elf_hash_table (eif->info)->dynobj); - if (bed->elf_backend_fixup_symbol - && !(*bed->elf_backend_fixup_symbol) (eif->info, h)) - return FALSE; - } + bed = get_elf_backend_data (elf_hash_table (eif->info)->dynobj); + if (bed->elf_backend_fixup_symbol + && !(*bed->elf_backend_fixup_symbol) (eif->info, h)) + return FALSE; /* If this is a final link, and the symbol was defined as a common symbol in a regular object file, and there was no definition in @@ -2473,11 +2470,7 @@ _bfd_elf_fix_symbol_flags (struct elf_link_hash_entry *h, hide it from the dynamic linker. */ if (ELF_ST_VISIBILITY (h->other) != STV_DEFAULT && h->root.type == bfd_link_hash_undefweak) - { - const struct elf_backend_data *bed; - bed = get_elf_backend_data (elf_hash_table (eif->info)->dynobj); - (*bed->elf_backend_hide_symbol) (eif->info, h, TRUE); - } + (*bed->elf_backend_hide_symbol) (eif->info, h, TRUE); /* If this is a weak defined symbol in a dynamic object, and we know the real definition in the dynamic object, copy interesting flags |