From: Chris Demetriou Date: Fri, 24 Apr 2009 19:48:21 +0000 (+0000) Subject: 2008-04-23 Elliott Hughes X-Git-Tag: sid-snapshot-20090501~63 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=6d1e3092b4f527690c739a113caa7a123959c807;p=external%2Fbinutils.git 2008-04-23 Elliott Hughes * output.cc (Output_file::close): After short writes, continue writing from the correct offset in the buffer being written. --- diff --git a/gold/ChangeLog b/gold/ChangeLog index bec3a75..c9a42a8 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,8 @@ +2008-04-23 Elliott Hughes + + * output.cc (Output_file::close): After short writes, continue + writing from the correct offset in the buffer being written. + 2009-04-23 Chris Demetriou * configure.ac (HAVE_TR1_UNORDERED_MAP_REHASH): New define. diff --git a/gold/output.cc b/gold/output.cc index d70c37a..b532136 100644 --- a/gold/output.cc +++ b/gold/output.cc @@ -3460,15 +3460,20 @@ Output_file::close() if (this->map_is_anonymous_ && !this->is_temporary_) { size_t bytes_to_write = this->file_size_; + size_t offset = 0; while (bytes_to_write > 0) { - ssize_t bytes_written = ::write(this->o_, this->base_, bytes_to_write); + ssize_t bytes_written = ::write(this->o_, this->base_ + offset, + bytes_to_write); if (bytes_written == 0) gold_error(_("%s: write: unexpected 0 return-value"), this->name_); else if (bytes_written < 0) gold_error(_("%s: write: %s"), this->name_, strerror(errno)); else - bytes_to_write -= bytes_written; + { + bytes_to_write -= bytes_written; + offset += bytes_written; + } } } this->unmap();