From 5c488d70337675f6e7e61f2beeacfff5424a4072 Mon Sep 17 00:00:00 2001 From: Leonid Yuriev Date: Mon, 24 Jun 2019 00:56:26 +0300 Subject: [PATCH] mdbx: backport - 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 2350ce7a..d398a87e 100644 --- a/src/osal.c +++ b/src/osal.c @@ -533,17 +533,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 }