From df34342bde777c2565334574e0cbf3872b8f51e0 Mon Sep 17 00:00:00 2001 From: Ian Lance Taylor Date: Mon, 25 Oct 1993 20:09:46 +0000 Subject: [PATCH] * libbfd.c (bfd_write): If not everything is written out, set bfd_error to system_call_error. If the return value is non-negative, set errno to ENOSPC (if ENOSPC is defined). (bfd_seek): If the seek fails, set bfd_error to system_call_error. (bfd_generic_set_section_contents): For a bad offset + count, set bfd_error to bad_value. * seclet.c (rel): Don't abort. Instead, return false. --- bfd/ChangeLog | 10 ++++++ bfd/libbfd.c | 86 +++++++++++++++++++++++++++++++-------------------- bfd/seclet.c | 2 +- 3 files changed, 64 insertions(+), 34 deletions(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 36d1dd33b3..ef4a435fb1 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,13 @@ +Mon Oct 25 16:05:23 1993 Ian Lance Taylor (ian@tweedledumb.cygnus.com) + + * libbfd.c (bfd_write): If not everything is written out, set + bfd_error to system_call_error. If the return value is + non-negative, set errno to ENOSPC (if ENOSPC is defined). + (bfd_seek): If the seek fails, set bfd_error to system_call_error. + (bfd_generic_set_section_contents): For a bad offset + count, set + bfd_error to bad_value. + * seclet.c (rel): Don't abort. Instead, return false. + Mon Oct 25 09:59:37 1993 Ken Raeburn (raeburn@cygnus.com) * aoutx.h (reloc_type_lookup): Handle BFD_RELOC_SPARC_WDISP22. diff --git a/bfd/libbfd.c b/bfd/libbfd.c index 1ab0fe3427..1c939701f7 100644 --- a/bfd/libbfd.c +++ b/bfd/libbfd.c @@ -216,17 +216,25 @@ DEFUN(bfd_read,(ptr, size, nitems, abfd), } bfd_size_type -DEFUN(bfd_write,(ptr, size, nitems, abfd), - CONST PTR ptr AND - bfd_size_type size AND - bfd_size_type nitems AND - bfd *abfd) +bfd_write (ptr, size, nitems, abfd) + CONST PTR ptr; + bfd_size_type size; + bfd_size_type nitems; + bfd *abfd; { - int nwrote = fwrite (ptr, 1, (int)(size*nitems), bfd_cache_lookup(abfd)); + int nwrote = fwrite (ptr, 1, (int) (size * nitems), bfd_cache_lookup (abfd)); #ifdef FILE_OFFSET_IS_CHAR_INDEX if (nwrote > 0) abfd->where += nwrote; #endif + if (nwrote != size * nitems) + { +#ifdef ENOSPC + if (nwrote >= 0) + errno = ENOSPC; +#endif + bfd_error = system_call_error; + } return nwrote; } @@ -343,8 +351,11 @@ DEFUN(bfd_seek,(abfd, position, direction), result = fseek (f, file_position, direction); if (result != 0) - /* Force redetermination of `where' field. */ - bfd_tell (abfd); + { + /* Force redetermination of `where' field. */ + bfd_tell (abfd); + bfd_error = system_call_error; + } else { #ifdef FILE_OFFSET_IS_CHAR_INDEX @@ -541,11 +552,11 @@ DESCRIPTION */ /* Sign extension to bfd_signed_vma. */ -#define COERCE16(x) ((bfd_signed_vma) (((x) ^ 0x8000) - 0x8000)) -#define COERCE32(x) ((bfd_signed_vma) (((x) ^ 0x80000000) - 0x80000000)) +#define COERCE16(x) (((bfd_signed_vma) (x) ^ 0x8000) - 0x8000) +#define COERCE32(x) (((bfd_signed_vma) (x) ^ 0x80000000) - 0x80000000) #define EIGHT_GAZILLION (((HOST_64_BIT)0x80000000) << 32) -#define COERCE64(x) ((bfd_signed_vma)\ - (((x) ^ EIGHT_GAZILLION) - EIGHT_GAZILLION)) +#define COERCE64(x) \ + (((bfd_signed_vma) (x) ^ EIGHT_GAZILLION) - EIGHT_GAZILLION) bfd_vma DEFUN(bfd_getb16,(addr), @@ -597,21 +608,23 @@ bfd_vma bfd_getb32 (addr) register bfd_byte *addr; { - return ((((addr[0] << 8) | addr[1]) << 8) | addr[2]) << 8 | addr[3]; + return (((((bfd_vma)addr[0] << 8) | addr[1]) << 8) + | addr[2]) << 8 | addr[3]; } bfd_vma bfd_getl32 (addr) register bfd_byte *addr; { - return ((((addr[3] << 8) | addr[2]) << 8) | addr[1]) << 8 | addr[0]; + return (((((bfd_vma)addr[3] << 8) | addr[2]) << 8) + | addr[1]) << 8 | addr[0]; } bfd_signed_vma bfd_getb_signed_32 (addr) register bfd_byte *addr; { - return COERCE32(((((addr[0] << 8) | addr[1]) << 8) + return COERCE32((((((bfd_vma)addr[0] << 8) | addr[1]) << 8) | addr[2]) << 8 | addr[3]); } @@ -619,7 +632,7 @@ bfd_signed_vma bfd_getl_signed_32 (addr) register bfd_byte *addr; { - return COERCE32(((((addr[3] << 8) | addr[2]) << 8) + return COERCE32((((((bfd_vma)addr[3] << 8) | addr[2]) << 8) | addr[1]) << 8 | addr[0]); } @@ -635,7 +648,7 @@ DEFUN(bfd_getb64,(addr), addr[2]) << 8) | addr[3]) ); - low = ((((((((addr[4]) << 8) | + low = (((((((((bfd_vma)addr[4]) << 8) | addr[5]) << 8) | addr[6]) << 8) | addr[7])); @@ -660,7 +673,7 @@ DEFUN(bfd_getl64,(addr), addr[5]) << 8) | addr[4])); - low = (((((((addr[3] << 8) | + low = ((((((((bfd_vma)addr[3] << 8) | addr[2]) << 8) | addr[1]) << 8) | addr[0]) ); @@ -685,7 +698,7 @@ DEFUN(bfd_getb_signed_64,(addr), addr[2]) << 8) | addr[3]) ); - low = ((((((((addr[4]) << 8) | + low = (((((((((bfd_vma)addr[4]) << 8) | addr[5]) << 8) | addr[6]) << 8) | addr[7])); @@ -710,7 +723,7 @@ DEFUN(bfd_getl_signed_64,(addr), addr[5]) << 8) | addr[4])); - low = (((((((addr[3] << 8) | + low = ((((((((bfd_vma)addr[3] << 8) | addr[2]) << 8) | addr[1]) << 8) | addr[0]) ); @@ -809,20 +822,27 @@ DEFUN(bfd_generic_get_section_contents, (abfd, section, location, offset, count) in read-write files, though. See other set_section_contents functions to see why it doesn't work for new sections. */ boolean -DEFUN(bfd_generic_set_section_contents, (abfd, section, location, offset, count), - bfd *abfd AND - sec_ptr section AND - PTR location AND - file_ptr offset AND - bfd_size_type count) +bfd_generic_set_section_contents (abfd, section, location, offset, count) + bfd *abfd; + sec_ptr section; + PTR location; + file_ptr offset; + bfd_size_type count; { - if (count == 0) - return true; - if ((bfd_size_type)(offset+count) > bfd_get_section_size_after_reloc(section) - || bfd_seek(abfd, (file_ptr)(section->filepos + offset), SEEK_SET) == -1 - || bfd_write(location, (bfd_size_type)1, count, abfd) != count) - return (false); /* on error */ - return (true); + if (count == 0) + return true; + + if (offset + count > bfd_get_section_size_after_reloc (section)) + { + bfd_error = bad_value; + return false; + } + + if (bfd_seek (abfd, (file_ptr) (section->filepos + offset), SEEK_SET) == -1 + || bfd_write (location, (bfd_size_type) 1, count, abfd) != count) + return false; + + return true; } /* diff --git a/bfd/seclet.c b/bfd/seclet.c index 5dcc59ab0e..5a6c37d3bb 100644 --- a/bfd/seclet.c +++ b/bfd/seclet.c @@ -90,7 +90,7 @@ DEFUN(rel,(abfd, seclet, output_section, data, relocateable), seclet->offset, seclet->size) == false) { - abort(); + return false; } } return true;