diff options
Diffstat (limited to 'winsup')
-rw-r--r-- | winsup/cygwin/ChangeLog | 7 | ||||
-rw-r--r-- | winsup/cygwin/errno.cc | 1 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_raw.cc | 13 |
3 files changed, 15 insertions, 6 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 6debe68..b8eca83 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,10 @@ +2003-08-17 Corinna Vinschen <corinna@vinschen.de> + + * errno.cc (errmap): Map ERROR_INVALID_BLOCK_LENGTH to EIO. + * fhandler_raw.cc (fhandler_dev_raw::raw_read): Set more accurate + errnos instead of EACCES. + (fhandler_dev_raw::raw_write): Ditto. + 2003-08-17 Christopher Faylor <cgf@redhat.com> * path.cc (special_name): Accommodate all special names with diff --git a/winsup/cygwin/errno.cc b/winsup/cygwin/errno.cc index 127eff9..cbe31d0 100644 --- a/winsup/cygwin/errno.cc +++ b/winsup/cygwin/errno.cc @@ -112,6 +112,7 @@ static NO_COPY struct X (NOACCESS, EFAULT), X (FILE_INVALID, ENXIO), X (INVALID_ADDRESS, EOVERFLOW), + X (INVALID_BLOCK_LENGTH, EIO), { 0, NULL, 0} }; diff --git a/winsup/cygwin/fhandler_raw.cc b/winsup/cygwin/fhandler_raw.cc index ebd8ef0..42f8407 100644 --- a/winsup/cygwin/fhandler_raw.cc +++ b/winsup/cygwin/fhandler_raw.cc @@ -202,7 +202,10 @@ fhandler_dev_raw::raw_read (void *ptr, size_t& ulen) ret = writebuf (); if (ret) { - set_errno (is_eom (ret) ? ENOSPC : EACCES); + if (is_eom (ret)) + set_errno (ENOSPC); + else + __seterrno (); goto err; } @@ -267,8 +270,7 @@ fhandler_dev_raw::raw_read (void *ptr, size_t& ulen) { if (!is_eof (ret) && !is_eom (ret)) { - debug_printf ("return -1, set errno to EACCES"); - set_errno (EACCES); + __seterrno (); goto err; } @@ -309,8 +311,7 @@ fhandler_dev_raw::raw_read (void *ptr, size_t& ulen) { if (!is_eof (ret) && !is_eom (ret)) { - debug_printf ("return -1, set errno to EACCES"); - set_errno (EACCES); + __seterrno (); goto err; } if (bytes_read) @@ -442,7 +443,7 @@ fhandler_dev_raw::raw_write (const void *ptr, size_t len) has_written = 1; if (!is_eom (ret)) { - set_errno (EACCES); + __seterrno (); return -1; } eom_detected = 1; |