From: H.J. Lu Date: Wed, 4 Oct 2006 11:50:43 +0000 (+0000) Subject: 2006-10-04 H.J. Lu X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=3b578682c112442b8873dcdc540c3c3a7177e086;p=binutils-gdb.git 2006-10-04 H.J. Lu * readelf.c (debug_apply_rela_addends): Don't ignore relocation against symbols without type. --- diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 812afc2eb83..0509d7a654a 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,8 @@ +2006-10-04 H.J. Lu + + * readelf.c (debug_apply_rela_addends): Don't ignore relocation + against symbols without type. + 2006-09-25 Pedro Alves * nlmconv.c (main) : Use LITMEMCPY. diff --git a/binutils/readelf.c b/binutils/readelf.c index b1f3fc63a58..bb18415e7b9 100644 --- a/binutils/readelf.c +++ b/binutils/readelf.c @@ -7747,6 +7747,10 @@ debug_apply_rela_addends (void *file, if (ELF32_R_SYM (rp->r_info) != 0 && ELF32_ST_TYPE (sym->st_info) != STT_SECTION + /* Relocations against symbols without type can happen. + Gcc -feliminate-dwarf2-dups may generate symbols + without type for debug info. */ + && ELF32_ST_TYPE (sym->st_info) != STT_NOTYPE /* Relocations against object symbols can happen, eg when referencing a global array. For an example of this see the _clz.o binary in libgcc.a. */ @@ -7776,6 +7780,7 @@ debug_apply_rela_addends (void *file, if (ELF64_R_SYM (rp->r_info) != 0 && ELF64_ST_TYPE (sym->st_info) != STT_SECTION + && ELF64_ST_TYPE (sym->st_info) != STT_NOTYPE && ELF64_ST_TYPE (sym->st_info) != STT_OBJECT) { warn (_("skipping unexpected symbol type %s in relocation in section .rela.%s\n"),