mdbx-windows: повтор чтения заголовка при ERROR_LOCK_VIOLATION.

This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2022-11-08 23:32:34 +03:00
parent 144cbbabb8
commit 2dfdac2821

View File

@ -11425,12 +11425,24 @@ __cold static int read_header(MDBX_env *env, MDBX_meta *dest,
TRACE("reading meta[%d]: offset %u, bytes %u, retry-left %u", meta_number, TRACE("reading meta[%d]: offset %u, bytes %u, retry-left %u", meta_number,
offset, MIN_PAGESIZE, retryleft); offset, MIN_PAGESIZE, retryleft);
int err = osal_pread(env->me_lazy_fd, buffer, MIN_PAGESIZE, offset); int err = osal_pread(env->me_lazy_fd, buffer, MIN_PAGESIZE, offset);
if (err != MDBX_SUCCESS) {
if (err == MDBX_ENODATA && offset == 0 && loop_count == 0 && if (err == MDBX_ENODATA && offset == 0 && loop_count == 0 &&
env->me_dxb_mmap.filesize == 0 && env->me_dxb_mmap.filesize == 0 &&
mode_bits /* non-zero for DB creation */ != 0) mode_bits /* non-zero for DB creation */ != 0) {
NOTICE("read meta: empty file (%d, %s)", err, mdbx_strerror(err)); NOTICE("read meta: empty file (%d, %s)", err, mdbx_strerror(err));
else return err;
}
#if defined(_WIN32) || defined(_WIN64)
if (err == ERROR_LOCK_VIOLATION) {
SleepEx(0, true);
err = osal_pread(env->me_lazy_fd, buffer, MIN_PAGESIZE, offset);
if (err == ERROR_LOCK_VIOLATION && --retryleft) {
WARNING("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err,
mdbx_strerror(err));
continue;
}
}
#endif /* Windows */
if (err != MDBX_SUCCESS) {
ERROR("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err, ERROR("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err,
mdbx_strerror(err)); mdbx_strerror(err));
return err; return err;
@ -11438,6 +11450,17 @@ __cold static int read_header(MDBX_env *env, MDBX_meta *dest,
char again[MIN_PAGESIZE]; char again[MIN_PAGESIZE];
err = osal_pread(env->me_lazy_fd, again, MIN_PAGESIZE, offset); err = osal_pread(env->me_lazy_fd, again, MIN_PAGESIZE, offset);
#if defined(_WIN32) || defined(_WIN64)
if (err == ERROR_LOCK_VIOLATION) {
SleepEx(0, true);
err = osal_pread(env->me_lazy_fd, again, MIN_PAGESIZE, offset);
if (err == ERROR_LOCK_VIOLATION && --retryleft) {
WARNING("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err,
mdbx_strerror(err));
continue;
}
}
#endif /* Windows */
if (err != MDBX_SUCCESS) { if (err != MDBX_SUCCESS) {
ERROR("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err, ERROR("read meta[%u,%u]: %i, %s", offset, MIN_PAGESIZE, err,
mdbx_strerror(err)); mdbx_strerror(err));