diff options
author | Daniel Jacobowitz <drow@false.org> | 2005-05-17 19:44:55 +0000 |
---|---|---|
committer | Daniel Jacobowitz <drow@false.org> | 2005-05-17 19:44:55 +0000 |
commit | 26ae6d5ed03b3e749598b33ffd0aaefbaf9a6d7d (patch) | |
tree | a2a86631e13f89e100ac36db20db4170c9610924 /bfd/format.c | |
parent | 970c3dbce892feccbd6334ebc431a82b84934efd (diff) | |
download | gdb-26ae6d5ed03b3e749598b33ffd0aaefbaf9a6d7d.zip gdb-26ae6d5ed03b3e749598b33ffd0aaefbaf9a6d7d.tar.gz gdb-26ae6d5ed03b3e749598b33ffd0aaefbaf9a6d7d.tar.bz2 |
* elf.c (_bfd_elf_write_object_contents): Check for non-NULL
elf_shstrtab.
* format.c (bfd_check_format_matches): Set output_has_begun
for both_direction.
* section.c (bfd_set_section_contents): Use bfd_write_p. Remove
special case for both_direction.
Diffstat (limited to 'bfd/format.c')
-rw-r--r-- | bfd/format.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/bfd/format.c b/bfd/format.c index 3a36210..4ccca2a 100644 --- a/bfd/format.c +++ b/bfd/format.c @@ -173,6 +173,14 @@ bfd_check_format_matches (bfd *abfd, bfd_format format, char ***matching) if (matching) free (matching_vector); + /* If the file was opened for update, then `output_has_begun' + some time ago when the file was created. Do not recompute + sections sizes or alignments in _bfd_set_section_contents. + We can not set this flag until after checking the format, + because it will interfere with creation of BFD sections. */ + if (abfd->direction == both_direction) + abfd->output_has_begun = TRUE; + return TRUE; /* File position has moved, BTW. */ } @@ -319,6 +327,14 @@ bfd_check_format_matches (bfd *abfd, bfd_format format, char ***matching) if (matching) free (matching_vector); + /* If the file was opened for update, then `output_has_begun' + some time ago when the file was created. Do not recompute + sections sizes or alignments in _bfd_set_section_contents. + We can not set this flag until after checking the format, + because it will interfere with creation of BFD sections. */ + if (abfd->direction == both_direction) + abfd->output_has_begun = TRUE; + return TRUE; /* File position has moved, BTW. */ } |