From: Nick Clifton Date: Wed, 18 Feb 2009 15:28:56 +0000 (+0000) Subject: PR 9841 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=121230679fd8a176e4d08340bf4ce9027426da81;p=binutils-gdb.git PR 9841 * elf32-avr.c: Handle case where no local symbos exist correctly. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 808778f15ed..977c9ab962d 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2009-02-18 Bjoern Haase + + PR 9841 + * elf32-avr.c: Handle case where no local symbos exist correctly. + 2009-02-16 Christophe Lyon bfd/ diff --git a/bfd/elf32-avr.c b/bfd/elf32-avr.c index afcef18aa30..9190db35d5b 100644 --- a/bfd/elf32-avr.c +++ b/bfd/elf32-avr.c @@ -1415,7 +1415,6 @@ elf32_avr_relax_delete_bytes (bfd *abfd, Elf_Internal_Rela *irelalign; Elf_Internal_Sym *isym; Elf_Internal_Sym *isymbuf = NULL; - Elf_Internal_Sym *isymend; bfd_vma toaddr; struct elf_link_hash_entry **sym_hashes; struct elf_link_hash_entry **end_hashes; @@ -1553,13 +1552,19 @@ elf32_avr_relax_delete_bytes (bfd *abfd, /* Adjust the local symbols defined in this section. */ isym = (Elf_Internal_Sym *) symtab_hdr->contents; - isymend = isym + symtab_hdr->sh_info; - for (; isym < isymend; isym++) + /* Fix PR 9841, there may be no local symbols. */ + if (isym != NULL) { - if (isym->st_shndx == sec_shndx - && isym->st_value > addr - && isym->st_value < toaddr) - isym->st_value -= count; + Elf_Internal_Sym *isymend; + + isymend = isym + symtab_hdr->sh_info; + for (; isym < isymend; isym++) + { + if (isym->st_shndx == sec_shndx + && isym->st_value > addr + && isym->st_value < toaddr) + isym->st_value -= count; + } } /* Now adjust the global symbols defined in this section. */