From: Ulrich Drepper Date: Thu, 23 Aug 2001 02:46:15 +0000 (+0000) Subject: Update. X-Git-Tag: cvs/glibc-2-2-5~394 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=40b145c443205234d7996c8f2bb6200905b13a4b;p=platform%2Fupstream%2Fglibc.git Update. * elf/dl-addr.c (_dl_addr): Handle broken binaries with zero symbol sizes a bit better. --- diff --git a/ChangeLog b/ChangeLog index cb91ed7..10f1e12 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,8 @@ 2001-08-22 Ulrich Drepper + * elf/dl-addr.c (_dl_addr): Handle broken binaries with zero + symbol sizes a bit better. + * sysdeps/ia64/strncpy.S: Complete rewrite. Contributed by Jakub Jelinek . diff --git a/elf/dl-addr.c b/elf/dl-addr.c index 96fa2e2..ebb6285 100644 --- a/elf/dl-addr.c +++ b/elf/dl-addr.c @@ -77,7 +77,8 @@ _dl_addr (const void *address, Dl_info *info) there is no way in ELF to know the size of the dynamic symbol table!! */ for (matchsym = NULL; (void *) symtab < (void *) strtab; ++symtab) if (addr >= match->l_addr + symtab->st_value - && addr < match->l_addr + symtab->st_value + symtab->st_size + && ((symtab->st_size == 0 && addr == match->l_addr + symtab->st_value) + || addr < match->l_addr + symtab->st_value + symtab->st_size) && symtab->st_name < strtabsize && (matchsym == NULL || matchsym->st_value < symtab->st_value) && (ELFW(ST_BIND) (symtab->st_info) == STB_GLOBAL