diff options
author | Hans-Peter Nilsson <hp@axis.com> | 2000-09-27 07:52:24 +0000 |
---|---|---|
committer | Hans-Peter Nilsson <hp@axis.com> | 2000-09-27 07:52:24 +0000 |
commit | 35a79b8d9878c0c495dddc04c020efdc0f8e9541 (patch) | |
tree | 235afa23826bce92a3b979fdab7c64b05d66be02 | |
parent | 0f98f9b1aff12ac0e068de2eb975010947334bd5 (diff) | |
download | binutils-redhat-35a79b8d9878c0c495dddc04c020efdc0f8e9541.tar.gz |
* elfcode.h (elf_object_p): Preserve and clear abfd section
information. Restore at error.
-rw-r--r-- | bfd/ChangeLog | 5 | ||||
-rw-r--r-- | bfd/elfcode.h | 9 |
2 files changed, 14 insertions, 0 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 737df3c0be..0103b1da88 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2000-09-26 Hans-Peter Nilsson <hp@axis.com> + + * elfcode.h (elf_object_p): Preserve and clear abfd section + information. Restore at error. + 2000-09-26 Paul Sokolovsky <Paul.Sokolovsky@technologist.com> * peigen.c (_bfd_pei_swap_aouthdr_in): If some DataDirectory diff --git a/bfd/elfcode.h b/bfd/elfcode.h index 92bb3367e5..b94f74be68 100644 --- a/bfd/elfcode.h +++ b/bfd/elfcode.h @@ -500,9 +500,16 @@ elf_object_p (abfd) char *shstrtab; /* Internal copy of section header stringtab */ struct elf_backend_data *ebd; struct elf_obj_tdata *preserved_tdata = elf_tdata (abfd); + struct sec *preserved_sections = abfd->sections; + unsigned int preserved_section_count = abfd->section_count; struct elf_obj_tdata *new_tdata = NULL; asection *s; + /* Clear section information, since there might be a recognized bfd that + we now check if we can replace, and we don't want to append to it. */ + abfd->sections = NULL; + abfd->section_count = 0; + /* Read in the ELF header in external format. */ if (bfd_read ((PTR) & x_ehdr, sizeof (x_ehdr), 1, abfd) != sizeof (x_ehdr)) @@ -745,6 +752,8 @@ elf_object_p (abfd) if (new_tdata != NULL) bfd_release (abfd, new_tdata); elf_tdata (abfd) = preserved_tdata; + abfd->sections = preserved_sections; + abfd->section_count = preserved_section_count; return (NULL); } |