mdbx: add MDBX_EIO.

This commit is contained in:
Leo Yuriev 2017-05-22 19:59:16 +03:00
parent 994481e4f4
commit 0eee938c5f
2 changed files with 9 additions and 7 deletions

View File

@ -101,6 +101,7 @@ typedef DWORD mdbx_tid_t;
#define MDBX_ENOMEM ERROR_OUTOFMEMORY #define MDBX_ENOMEM ERROR_OUTOFMEMORY
#define MDBX_EROFS ERROR_FILE_READ_ONLY #define MDBX_EROFS ERROR_FILE_READ_ONLY
#define MDBX_ENOSYS ERROR_NOT_SUPPORTED #define MDBX_ENOSYS ERROR_NOT_SUPPORTED
#define MDBX_EIO ERROR_WRITE_FAULT
#else #else
@ -118,7 +119,7 @@ typedef pthread_t mdbx_tid_t;
#define MDBX_ENOMEM ENOMEM #define MDBX_ENOMEM ENOMEM
#define MDBX_EROFS EROFS #define MDBX_EROFS EROFS
#define MDBX_ENOSYS ENOSYS #define MDBX_ENOSYS ENOSYS
#define MDBX_EIO EIO
#endif #endif
/*--------------------------------------------------------------------------*/ /*--------------------------------------------------------------------------*/

View File

@ -139,7 +139,7 @@ int mdbx_asprintf(char **strp, const char *fmt, ...) {
int mdbx_memalign_alloc(size_t alignment, size_t bytes, void **result) { int mdbx_memalign_alloc(size_t alignment, size_t bytes, void **result) {
#if _MSC_VER #if _MSC_VER
*result = _aligned_malloc(bytes, alignment); *result = _aligned_malloc(bytes, alignment);
return *result ? MDB_SUCCESS : ERROR_OUTOFMEMORY; return *result ? MDB_SUCCESS : MDBX_ENOMEM /* ERROR_OUTOFMEMORY */;
#elif __GLIBC_PREREQ(2, 16) || __STDC_VERSION__ >= 201112L #elif __GLIBC_PREREQ(2, 16) || __STDC_VERSION__ >= 201112L
*result = memalign(alignment, bytes); *result = memalign(alignment, bytes);
return *result ? MDB_SUCCESS : errno; return *result ? MDB_SUCCESS : errno;
@ -343,7 +343,7 @@ int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t bytes, off_t offset) {
ssize_t read = pread(fd, buf, bytes, offset); ssize_t read = pread(fd, buf, bytes, offset);
if (read < 0) { if (read < 0) {
int rc = errno; int rc = errno;
return (rc == MDB_SUCCESS) ? /* paranoia */ EIO : rc; return (rc == MDB_SUCCESS) ? /* paranoia */ MDBX_EIO : rc;
} }
#endif #endif
return (bytes == (size_t)read) ? MDB_SUCCESS : MDBX_ENODATA; return (bytes == (size_t)read) ? MDB_SUCCESS : MDBX_ENODATA;
@ -362,7 +362,7 @@ int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes,
DWORD written; DWORD written;
if (likely(WriteFile(fd, buf, (DWORD)bytes, &written, &ov))) if (likely(WriteFile(fd, buf, (DWORD)bytes, &written, &ov)))
return (bytes == written) ? MDB_SUCCESS : ERROR_WRITE_FAULT; return (bytes == written) ? MDB_SUCCESS : MDBX_EIO /* ERROR_WRITE_FAULT */;
return mdbx_get_errno_checked(); return mdbx_get_errno_checked();
#else #else
int rc; int rc;
@ -373,7 +373,7 @@ int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes,
return MDB_SUCCESS; return MDB_SUCCESS;
rc = errno; rc = errno;
} while (rc == EINTR); } while (rc == EINTR);
return (written < 0) ? rc : EIO /* Use which error code (ENOSPC)? */; return (written < 0) ? rc : MDBX_EIO /* Use which error code (ENOSPC)? */;
#endif #endif
} }
@ -388,7 +388,8 @@ int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
written += iov[i].iov_len; written += iov[i].iov_len;
offset += iov[i].iov_len; offset += iov[i].iov_len;
} }
return (expected_written == written) ? MDB_SUCCESS : ERROR_WRITE_FAULT; return (expected_written == written) ? MDB_SUCCESS
: MDBX_EIO /* ERROR_WRITE_FAULT */;
#else #else
int rc; int rc;
ssize_t written; ssize_t written;
@ -398,7 +399,7 @@ int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
return MDB_SUCCESS; return MDB_SUCCESS;
rc = errno; rc = errno;
} while (rc == EINTR); } while (rc == EINTR);
return (written < 0) ? rc : EIO /* Use which error code? */; return (written < 0) ? rc : MDBX_EIO /* Use which error code? */;
#endif #endif
} }