From 92d203a12c3d1d16cf4d46439f29884bd745bbdc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=9B=D0=B5=D0=BE=D0=BD=D0=B8=D0=B4=20=D0=AE=D1=80=D1=8C?= =?UTF-8?q?=D0=B5=D0=B2=20=28Leonid=20Yuriev=29?= Date: Sun, 9 Oct 2022 19:41:13 +0300 Subject: [PATCH] =?UTF-8?q?mdbx:=20=D0=B8=D1=81=D0=BF=D1=80=D0=B0=D0=B2?= =?UTF-8?q?=D0=BB=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BB=D0=BE=D0=B6=D0=BD=D0=BE?= =?UTF-8?q?=D0=B3=D0=BE=20=D1=81=D1=80=D0=B0=D0=B1=D0=B0=D1=82=D1=8B=D0=B2?= =?UTF-8?q?=D0=B0=D0=BD=D0=B8=D1=8F=20=D0=BA=D0=BE=D0=BD=D1=82=D1=80=D0=BE?= =?UTF-8?q?=D0=BB=D1=8F=20"invalid=20page-address"=20=D0=B2=20`page=5Fchec?= =?UTF-8?q?k()`.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit При проверке использовалось глобальное значение me_dxb_mmap.current, к которому не должны обращаться читающие транзакции. В результате, в сложных много-поточных сценариях с изменением размера БД и её переполнением, проверка могла выдавать ложно-положительный результат. С точки зрения пользователя, ошибка могла проявляться как возврат `MDBX_CORRUPTED` из читающей транзакции, когда включен "безопасный режим" (дополнительный контроль), а в параллельной пишущей транзакции происходит увеличение размера БД с последующим переполнением и откатом этой транзакции. При этом никакого повреждения структуры БД нет. --- src/core.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/core.c b/src/core.c index 12e7bd8a..c4ae564e 100644 --- a/src/core.c +++ b/src/core.c @@ -18476,9 +18476,9 @@ __cold static int page_check(MDBX_cursor *const mc, const MDBX_page *const mp) { unsigned flags_mask = P_ILL_BITS; unsigned flags_expected = 0; if (offset < 0 || - offset > (ptrdiff_t)(env->me_dxb_mmap.current - ((mp->mp_flags & P_SUBP) - ? PAGEHDRSZ + 1 - : env->me_psize))) { + offset > (ptrdiff_t)(pgno2bytes(env, mc->mc_txn->mt_next_pgno) - + ((mp->mp_flags & P_SUBP) ? PAGEHDRSZ + 1 + : env->me_psize))) { /* should be dirty page without MDBX_WRITEMAP, or a subpage of. */ flags_mask -= P_SUBP; if ((env->me_flags & MDBX_WRITEMAP) != 0 ||