From 5b88fe819c03655b537bd6331b4fa1e435975b1e Mon Sep 17 00:00:00 2001 From: Leonid Yuriev Date: Mon, 24 Jun 2019 00:56:26 +0300 Subject: [PATCH] mdbx: fix pwrite() for WRITE_MAX. Change-Id: If4924d20c1e267c2d3a190c860b89fc2fda0d517 --- src/osal.c | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/src/osal.c b/src/osal.c index 38f0156c..a8f88383 100644 --- a/src/osal.c +++ b/src/osal.c @@ -583,17 +583,25 @@ int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes, return (bytes == written) ? MDBX_SUCCESS : MDBX_EIO /* ERROR_WRITE_FAULT */; return GetLastError(); #else - int rc; - intptr_t written; - do { + while (true) { STATIC_ASSERT_MSG(sizeof(off_t) >= sizeof(size_t), "libmdbx requires 64-bit file I/O on 64-bit systems"); - written = pwrite(fd, buf, bytes, offset); + const intptr_t written = + pwrite(fd, buf, (bytes <= MAX_WRITE) ? bytes : MAX_WRITE, offset); if (likely(bytes == (size_t)written)) return MDBX_SUCCESS; - rc = errno; - } while (rc == EINTR); - return (written < 0) ? rc : MDBX_EIO /* Use which error code (ENOSPC)? */; + if (written < 0) { + const int rc = errno; + if (rc != EINTR) + return rc; + } else if (written > 0) { + bytes -= written; + offset += written; + buf = (char *)buf + written; + } else { + return -1; + } + } #endif }