mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:14:12 +08:00
mdbx: workaround for encryptfs's copy_file_range()
bug(s) (backport).
Выяснилось что утилита `mdbx_copy` и функции `mdbx_env_copy()` могут создавать ПРОБЛЕМЫ если целевой файл расположен в encryptfs (такая файловая система в Linux). При этом может быть четыре исхода в зависимости от версии ядра и положения звезд на небе: - всё хорошо; - плохие данные в копии без возврата ошибок; - ошибка EINVAL(22) при копировании; - oops или зависание ядра, отвал смонтированной encryptfs и т.п. В текущем понимании, причина обусловлена ошибой в коде fs, которая проявляется при использовании системного вызова `copy_file_range`.
This commit is contained in:
parent
1bd0eb35bc
commit
471e854551
@ -9,6 +9,7 @@ Fixes:
|
|||||||
- Fixed builds with older `stdatomic.h` versions,
|
- Fixed builds with older `stdatomic.h` versions,
|
||||||
where the `ATOMIC_*_LOCK_FREE` macros mistakenly redefined using functions (backport).
|
where the `ATOMIC_*_LOCK_FREE` macros mistakenly redefined using functions (backport).
|
||||||
- Added workaround for `mremap()` defect to avoid assertion failure (backport).
|
- Added workaround for `mremap()` defect to avoid assertion failure (backport).
|
||||||
|
- Workaround for `encryptfs` bug(s) in the `copy_file_range` implementation.
|
||||||
|
|
||||||
|
|
||||||
## v0.11.12 (Эребуни) at 2022-10-12
|
## v0.11.12 (Эребуни) at 2022-10-12
|
||||||
|
@ -19670,6 +19670,11 @@ __cold static int mdbx_env_copy_asis(MDBX_env *env, MDBX_txn *read_txn,
|
|||||||
#if MDBX_USE_COPYFILERANGE
|
#if MDBX_USE_COPYFILERANGE
|
||||||
static bool copyfilerange_unavailable;
|
static bool copyfilerange_unavailable;
|
||||||
bool not_the_same_filesystem = false;
|
bool not_the_same_filesystem = false;
|
||||||
|
struct statfs statfs_info;
|
||||||
|
if (fstatfs(fd, &statfs_info) ||
|
||||||
|
statfs_info.f_type == /* ECRYPTFS_SUPER_MAGIC */ 0xf15f)
|
||||||
|
/* avoid use copyfilerange_unavailable() to ecryptfs due bugs */
|
||||||
|
not_the_same_filesystem = true;
|
||||||
#endif /* MDBX_USE_COPYFILERANGE */
|
#endif /* MDBX_USE_COPYFILERANGE */
|
||||||
for (size_t offset = meta_bytes; rc == MDBX_SUCCESS && offset < used_size;) {
|
for (size_t offset = meta_bytes; rc == MDBX_SUCCESS && offset < used_size;) {
|
||||||
#if MDBX_USE_SENDFILE
|
#if MDBX_USE_SENDFILE
|
||||||
@ -19703,7 +19708,9 @@ __cold static int mdbx_env_copy_asis(MDBX_env *env, MDBX_txn *read_txn,
|
|||||||
if (bytes_copied == 0)
|
if (bytes_copied == 0)
|
||||||
break;
|
break;
|
||||||
rc = errno;
|
rc = errno;
|
||||||
if (rc == EXDEV)
|
if (rc == EXDEV || rc == /* workaround for ecryptfs bug(s),
|
||||||
|
maybe usefull for others fs */
|
||||||
|
EINVAL)
|
||||||
not_the_same_filesystem = true;
|
not_the_same_filesystem = true;
|
||||||
else if (ignore_enosys(rc) == MDBX_RESULT_TRUE)
|
else if (ignore_enosys(rc) == MDBX_RESULT_TRUE)
|
||||||
copyfilerange_unavailable = true;
|
copyfilerange_unavailable = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user