mdbx: fix div-by-zero while copy-with-compaction for non-resizeable DB.

Change-Id: Ice7f5675c3b2864195874f2e3c4ade9148cad048
This commit is contained in:
Leonid Yuriev 2020-04-28 18:23:13 +03:00
parent fac0d47913
commit eec465704d

View File

@ -15233,19 +15233,15 @@ done:
static __cold void compact_fixup_meta(MDBX_env *env, MDBX_meta *meta) { static __cold void compact_fixup_meta(MDBX_env *env, MDBX_meta *meta) {
/* Calculate filesize taking in account shrink/growing thresholds */ /* Calculate filesize taking in account shrink/growing thresholds */
if (meta->mm_geo.next > meta->mm_geo.now) { if (meta->mm_geo.next != meta->mm_geo.now) {
const pgno_t aligned = pgno_align2os_pgno(
env,
pgno_add(meta->mm_geo.next,
meta->mm_geo.grow - meta->mm_geo.next % meta->mm_geo.grow));
meta->mm_geo.now = aligned;
} else if (meta->mm_geo.next < meta->mm_geo.now) {
meta->mm_geo.now = meta->mm_geo.next; meta->mm_geo.now = meta->mm_geo.next;
const pgno_t aligner = const pgno_t aligner =
meta->mm_geo.grow ? meta->mm_geo.grow : meta->mm_geo.shrink; meta->mm_geo.grow ? meta->mm_geo.grow : meta->mm_geo.shrink;
const pgno_t aligned = pgno_align2os_pgno( if (aligner) {
env, meta->mm_geo.next + aligner - meta->mm_geo.next % aligner); const pgno_t aligned = pgno_align2os_pgno(
meta->mm_geo.now = aligned; env, meta->mm_geo.next + aligner - meta->mm_geo.next % aligner);
meta->mm_geo.now = aligned;
}
} }
if (meta->mm_geo.now < meta->mm_geo.lower) if (meta->mm_geo.now < meta->mm_geo.lower)