From f6e688f76be9d0327cabd52f5f75478abaace764 Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Wed, 1 Aug 2007 07:43:36 +0000 Subject: [PATCH] PR4694 * aoutx.h (final_link): Write a zero in first word of stringtab if no symbols rather than corrupting last byte of text/data. --- bfd/ChangeLog | 7 +++++++ bfd/aoutx.h | 17 +++++++---------- 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index f51aa26..0ebb3d1 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 af7d45b..2b5507e 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; } -- 2.7.4