mdbx: rework mdbx_pread().

This commit is contained in:
Leo Yuriev 2017-04-25 19:58:00 +03:00
parent aa59522dbe
commit 5ed0ccfcbb
2 changed files with 6 additions and 9 deletions

View File

@ -3737,7 +3737,7 @@ static int __cold mdbx_setup_dxb(MDB_env *env, MDB_meta *meta, int lck_rc) {
int err = mdbx_read_header(env, meta); int err = mdbx_read_header(env, meta);
if (unlikely(err != MDB_SUCCESS)) { if (unlikely(err != MDB_SUCCESS)) {
if (lck_rc != /* lck exclusive */ MDBX_RESULT_TRUE || err != MDBX_ENODATA || if (lck_rc != /* lck exclusive */ MDBX_RESULT_TRUE || err != MDBX_ENODATA ||
(env->me_flags & MDB_RDONLY)) (env->me_flags & MDB_RDONLY) != 0)
return err; return err;
mdbx_debug("create new database"); mdbx_debug("create new database");

View File

@ -337,19 +337,16 @@ int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t bytes, off_t offset) {
DWORD read = 0; DWORD read = 0;
if (unlikely(!ReadFile(fd, buf, (DWORD)bytes, &read, &ov))) { if (unlikely(!ReadFile(fd, buf, (DWORD)bytes, &read, &ov))) {
int rc = GetLastError(); int rc = GetLastError();
if (rc == ERROR_HANDLE_EOF)
return (read == 0 && offset == 0) ? MDBX_ENODATA : ERROR_READ_FAULT;
return (rc == MDB_SUCCESS) ? /* paranoia */ ERROR_READ_FAULT : rc; return (rc == MDB_SUCCESS) ? /* paranoia */ ERROR_READ_FAULT : rc;
} }
return (read == bytes) ? MDB_SUCCESS : ERROR_READ_FAULT;
#else #else
ssize_t read = pread(fd, buf, bytes, offset); ssize_t read = pread(fd, buf, bytes, offset);
if (likely(bytes == (size_t)read)) if (read < 0) {
return MDB_SUCCESS; int rc = errno;
if (read < 0) return (rc == MDB_SUCCESS) ? /* paranoia */ EIO : rc;
return errno; }
return (read == 0 && offset == 0) ? MDBX_ENODATA : EIO;
#endif #endif
return (bytes == (size_t)read) ? MDB_SUCCESS : MDBX_ENODATA;
} }
int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes, int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes,