mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 17:38:20 +08:00
mdbx: drops mdbx_write(), using mdbx_pwrite() instead of.
Change-Id: Iff3de2d5ef3fa2e92607d46b96d4526e464e593b
This commit is contained in:
parent
08c334c8bc
commit
38110579ba
@ -11281,6 +11281,7 @@ static THREAD_RESULT __cold THREAD_CALL mdbx_env_copythr(void *arg) {
|
|||||||
uint8_t *ptr;
|
uint8_t *ptr;
|
||||||
int toggle = 0;
|
int toggle = 0;
|
||||||
int rc;
|
int rc;
|
||||||
|
size_t offset = pgno2bytes(my->mc_env, NUM_METAS);
|
||||||
|
|
||||||
#if defined(F_SETNOSIGPIPE)
|
#if defined(F_SETNOSIGPIPE)
|
||||||
/* OS X delivers SIGPIPE to the whole process, not the thread that caused it.
|
/* OS X delivers SIGPIPE to the whole process, not the thread that caused it.
|
||||||
@ -11309,7 +11310,7 @@ static THREAD_RESULT __cold THREAD_CALL mdbx_env_copythr(void *arg) {
|
|||||||
ptr = my->mc_wbuf[toggle];
|
ptr = my->mc_wbuf[toggle];
|
||||||
again:
|
again:
|
||||||
if (wsize > 0 && !my->mc_error) {
|
if (wsize > 0 && !my->mc_error) {
|
||||||
rc = mdbx_write(my->mc_fd, ptr, wsize);
|
rc = mdbx_pwrite(my->mc_fd, ptr, wsize, offset);
|
||||||
if (rc != MDBX_SUCCESS) {
|
if (rc != MDBX_SUCCESS) {
|
||||||
#if defined(SIGPIPE) && !defined(_WIN32) && !defined(_WIN64)
|
#if defined(SIGPIPE) && !defined(_WIN32) && !defined(_WIN64)
|
||||||
if (rc == EPIPE) {
|
if (rc == EPIPE) {
|
||||||
@ -11320,7 +11321,9 @@ static THREAD_RESULT __cold THREAD_CALL mdbx_env_copythr(void *arg) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
my->mc_error = rc;
|
my->mc_error = rc;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
offset += wsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If there's an overflow page tail, write it too */
|
/* If there's an overflow page tail, write it too */
|
||||||
@ -11708,7 +11711,7 @@ int __cold mdbx_env_copy2fd(MDBX_env *env, mdbx_filehandle_t fd,
|
|||||||
/* Firstly write a stub to meta-pages.
|
/* Firstly write a stub to meta-pages.
|
||||||
* Now we sure to incomplete copy will not be used. */
|
* Now we sure to incomplete copy will not be used. */
|
||||||
memset(buffer, -1, pgno2bytes(env, NUM_METAS));
|
memset(buffer, -1, pgno2bytes(env, NUM_METAS));
|
||||||
rc = mdbx_write(fd, buffer, pgno2bytes(env, NUM_METAS));
|
rc = mdbx_pwrite(fd, buffer, pgno2bytes(env, NUM_METAS), 0);
|
||||||
if (likely(rc == MDBX_SUCCESS)) {
|
if (likely(rc == MDBX_SUCCESS)) {
|
||||||
memset(buffer, 0, pgno2bytes(env, NUM_METAS));
|
memset(buffer, 0, pgno2bytes(env, NUM_METAS));
|
||||||
rc = (flags & MDBX_CP_COMPACT)
|
rc = (flags & MDBX_CP_COMPACT)
|
||||||
|
68
src/osal.c
68
src/osal.c
@ -1,4 +1,4 @@
|
|||||||
/* https://en.wikipedia.org/wiki/Operating_system_abstraction_layer */
|
/* https://en.wikipedia.org/wiki/Operating_system_abstraction_layer */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2015-2019 Leonid Yuriev <leo@yuriev.ru>
|
* Copyright 2015-2019 Leonid Yuriev <leo@yuriev.ru>
|
||||||
@ -569,21 +569,21 @@ int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t bytes, uint64_t offset) {
|
|||||||
|
|
||||||
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,
|
||||||
uint64_t offset) {
|
uint64_t offset) {
|
||||||
|
while (true) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
if (bytes > MAX_WRITE)
|
|
||||||
return ERROR_INVALID_PARAMETER;
|
|
||||||
|
|
||||||
OVERLAPPED ov;
|
OVERLAPPED ov;
|
||||||
ov.hEvent = 0;
|
ov.hEvent = 0;
|
||||||
ov.Offset = (DWORD)offset;
|
ov.Offset = (DWORD)offset;
|
||||||
ov.OffsetHigh = HIGH_DWORD(offset);
|
ov.OffsetHigh = HIGH_DWORD(offset);
|
||||||
|
|
||||||
DWORD written;
|
DWORD written;
|
||||||
if (likely(WriteFile(fd, buf, (DWORD)bytes, &written, &ov)))
|
if (unlikely(!WriteFile(fd, buf,
|
||||||
return (bytes == written) ? MDBX_SUCCESS : MDBX_EIO /* ERROR_WRITE_FAULT */;
|
(bytes <= MAX_WRITE) ? (DWORD)bytes : MAX_WRITE,
|
||||||
|
&written, &ov)))
|
||||||
return GetLastError();
|
return GetLastError();
|
||||||
|
if (likely(bytes == written))
|
||||||
|
return MDBX_SUCCESS;
|
||||||
#else
|
#else
|
||||||
while (true) {
|
|
||||||
STATIC_ASSERT_MSG(sizeof(off_t) >= sizeof(size_t),
|
STATIC_ASSERT_MSG(sizeof(off_t) >= sizeof(size_t),
|
||||||
"libmdbx requires 64-bit file I/O on 64-bit systems");
|
"libmdbx requires 64-bit file I/O on 64-bit systems");
|
||||||
const intptr_t written =
|
const intptr_t written =
|
||||||
@ -594,16 +594,14 @@ int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t bytes,
|
|||||||
const int rc = errno;
|
const int rc = errno;
|
||||||
if (rc != EINTR)
|
if (rc != EINTR)
|
||||||
return rc;
|
return rc;
|
||||||
} else if (written > 0) {
|
continue;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
bytes -= written;
|
bytes -= written;
|
||||||
offset += written;
|
offset += written;
|
||||||
buf = (char *)buf + written;
|
buf = (char *)buf + written;
|
||||||
} else {
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
||||||
uint64_t offset, size_t expected_written) {
|
uint64_t offset, size_t expected_written) {
|
||||||
@ -633,52 +631,6 @@ int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int mdbx_write(mdbx_filehandle_t fd, const void *buf, size_t bytes) {
|
|
||||||
#ifdef SIGPIPE
|
|
||||||
sigset_t set, old;
|
|
||||||
sigemptyset(&set);
|
|
||||||
sigaddset(&set, SIGPIPE);
|
|
||||||
int rc = pthread_sigmask(SIG_BLOCK, &set, &old);
|
|
||||||
if (rc != 0)
|
|
||||||
return rc;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const char *ptr = buf;
|
|
||||||
for (;;) {
|
|
||||||
size_t chunk = (MAX_WRITE < bytes) ? MAX_WRITE : bytes;
|
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
|
||||||
DWORD written;
|
|
||||||
if (unlikely(!WriteFile(fd, ptr, (DWORD)chunk, &written, NULL)))
|
|
||||||
return GetLastError();
|
|
||||||
#else
|
|
||||||
intptr_t written = write(fd, ptr, chunk);
|
|
||||||
if (written < 0) {
|
|
||||||
int rc = errno;
|
|
||||||
#ifdef SIGPIPE
|
|
||||||
if (rc == EPIPE) {
|
|
||||||
/* Collect the pending SIGPIPE, otherwise at least OS X
|
|
||||||
* gives it to the process on thread-exit (ITS#8504). */
|
|
||||||
int tmp;
|
|
||||||
sigwait(&set, &tmp);
|
|
||||||
written = 0;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
pthread_sigmask(SIG_SETMASK, &old, NULL);
|
|
||||||
#endif
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (likely(bytes == (size_t)written)) {
|
|
||||||
#ifdef SIGPIPE
|
|
||||||
pthread_sigmask(SIG_SETMASK, &old, NULL);
|
|
||||||
#endif
|
|
||||||
return MDBX_SUCCESS;
|
|
||||||
}
|
|
||||||
ptr += written;
|
|
||||||
bytes -= written;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int mdbx_filesync(mdbx_filehandle_t fd, bool filesize_changed) {
|
int mdbx_filesync(mdbx_filehandle_t fd, bool filesize_changed) {
|
||||||
#if defined(_WIN32) || defined(_WIN64)
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
(void)filesize_changed;
|
(void)filesize_changed;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* https://en.wikipedia.org/wiki/Operating_system_abstraction_layer */
|
/* https://en.wikipedia.org/wiki/Operating_system_abstraction_layer */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2015-2019 Leonid Yuriev <leo@yuriev.ru>
|
* Copyright 2015-2019 Leonid Yuriev <leo@yuriev.ru>
|
||||||
@ -494,7 +494,6 @@ int mdbx_pwritev(mdbx_filehandle_t fd, struct iovec *iov, int iovcnt,
|
|||||||
int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t count, uint64_t offset);
|
int mdbx_pread(mdbx_filehandle_t fd, void *buf, size_t count, uint64_t offset);
|
||||||
int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t count,
|
int mdbx_pwrite(mdbx_filehandle_t fd, const void *buf, size_t count,
|
||||||
uint64_t offset);
|
uint64_t offset);
|
||||||
int mdbx_write(mdbx_filehandle_t fd, const void *buf, size_t count);
|
|
||||||
|
|
||||||
int mdbx_thread_create(mdbx_thread_t *thread,
|
int mdbx_thread_create(mdbx_thread_t *thread,
|
||||||
THREAD_RESULT(THREAD_CALL *start_routine)(void *),
|
THREAD_RESULT(THREAD_CALL *start_routine)(void *),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user