From: Alan Modra Date: Wed, 1 Aug 2007 07:43:36 +0000 (+0000) Subject: PR4694 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f6e688f76be9d0327cabd52f5f75478abaace764;p=binutils-gdb.git PR4694 * aoutx.h (final_link): Write a zero in first word of stringtab if no symbols rather than corrupting last byte of text/data. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index f51aa26c77c..0ebb3d1c0e3 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,10 @@ +2007-08-01 Alan Modra + + PR4694 + * aoutx.h (final_link): Write a zero in first word of + stringtab if no symbols rather than corrupting last byte + of text/data. + 2007-07-31 Jakub Jelinek * elf.c (get_program_header_size): Adjacent loadable .note* diff --git a/bfd/aoutx.h b/bfd/aoutx.h index af7d45be3a7..2b5507e1002 100644 --- a/bfd/aoutx.h +++ b/bfd/aoutx.h @@ -5557,22 +5557,19 @@ NAME (aout, final_link) (bfd *abfd, exec_hdr (abfd)->a_drsize / obj_reloc_entry_size (abfd); /* Write out the string table, unless there are no symbols. */ + if (bfd_seek (abfd, obj_str_filepos (abfd), SEEK_SET) != 0) + goto error_return; if (abfd->symcount > 0) { - if (bfd_seek (abfd, obj_str_filepos (abfd), SEEK_SET) != 0 - || ! emit_stringtab (abfd, aout_info.strtab)) + if (!emit_stringtab (abfd, aout_info.strtab)) goto error_return; } - else if (obj_textsec (abfd)->reloc_count == 0 - && obj_datasec (abfd)->reloc_count == 0) + else { - bfd_byte b; - file_ptr pos; + bfd_byte b[BYTES_IN_WORD]; - b = 0; - pos = obj_datasec (abfd)->filepos + exec_hdr (abfd)->a_data - 1; - if (bfd_seek (abfd, pos, SEEK_SET) != 0 - || bfd_bwrite (&b, (bfd_size_type) 1, abfd) != 1) + memset (b, 0, BYTES_IN_WORD); + if (bfd_bwrite (b, (bfd_size_type) BYTES_IN_WORD, abfd) != BYTES_IN_WORD) goto error_return; }