Используйте теги для того, чтобы помечать важные точки в истории изменений (например, релизы)
  • v0.12.3
    v0.12.3 "Акула"
    
    Выпуск с существенными доработками и новой функциональностью в память о закрытом open-source проекте "Акула".
    
    Благодарности:
    --------------
    
     - [Alex Sharov](https://t.me/AskAlexSharov) и команде [Erigon](https://github.com/ledgerwatch/erigon) за тестирование.
     - [Simon Leier](https://t.me/leisim) за сообщение о сбоях и тестирование.
    
    Новое:
    ------
    
     - Использование адреса [https://libmdbx.dqdkfa.ru/dead-github](https://libmdbx.dqdkfa.ru/dead-github)
       для отсылки к сохранённым в web.archive.org копиям ресурсов, уничтоженных администрацией Github.
    
     - Реализована prefault-запись при выделении страниц для read-write отображений.
       Это приводит к кратному снижению системных издержек и существенному увеличению
       производительности в соответствующих сценариях использования, когда:
        - размер БД и объём данных существенно больше ОЗУ;
        - используется режим `MDBX_WRITEMAP`;
        - не-мелкие транзакции (по ходу транзакции выделяется многие сотни или тысячи страниц).
    
       В режиме `MDBX_WRITEMAP` выделение/переиспользование страниц приводит
       к page-fault и чтению страницы с диска, даже если содержимое страницы
       не нужно (будет перезаписано). Это является следствием работы подсистемы
       виртуальной памяти, а штатный способ лечения через `MADV_REMOVE`
       работает не на всех ФС и обычно дороже получаемой экономии.
    
       Теперь в libmdbx используется "упреждающая запись" таких страниц,
       которая на системах с [unified page cache](https://www.opennet.ru/base/dev/ubc.txt.html)
       приводит к "вталкиванию" данных, устраняя необходимость чтения с диска при
       обращении к такой странице памяти.
    
       Новый функционал работает в согласованности с автоматическим управлением read-ahead
       и кэшем статуса присутствия страниц в ОЗУ, посредством [mincore()](https://man7.org/linux/man-pages/man2/mincore.2.html).
    
     - Добавлена опция `MDBX_opt_prefault_write_enable` для возможности принудительного
       включения/выключения prefault-записи.
    
     - Реализован динамический выбор между сквозной записью на диск и обычной записью
       с последующим [fdatasync()](https://man7.org/linux/man-pages/man3/fdatasync.3p.html)
       управляемый опцией `MDBX_opt_writethrough_threshold`.
    
       В долговечных (durable) режимах данные на диск могут быть сброшены двумя способами:
         - сквозной записью через файловый дескриптор открытый с `O_DSYNC`;
         - обычной записью с последующим вызовом `fdatasync()`.
    
       Первый способ выгоднее при записи малого количества страниц и/или если
       канал взаимодействия с диском/носителем имеет близкую к нулю задержку.
       Второй способ выгоднее если требуется записать много страниц и/или канал
       взаимодействия имеет весомую задержку (датацентры, облака). Добавленная
       опция `MDBX_opt_writethrough_threshold` позволяет во время выполнения
       задать порог для динамического выбора способа записи в зависимости от
       объема и конкретных условия использования.
    
     - Автоматическая установка `MDBX_opt_rp_augment_limit` в зависимости от размера БД.
    
     - Запрещение разного режима `MDBX_WRITEMAP` между процессами в режимах
       с отложенной/ленивой записью, так как в этом случае невозможно
       обеспечить сброс данных на диск во всех случаях на всех поддерживаемых платформах.
    
     - Добавлена опция сборки `MDBX_MMAP_USE_MS_ASYNC` позволяющая отключить
       использование системного вызова `msync(MS_ASYNC)`, в использовании
       которого нет необходимости на подавляющем большинстве актуальных ОС.
       По-умолчанию `MDBX_MMAP_USE_MS_ASYNC=0` (выключено) на Linux и других
       системах с unified page cache. Такое поведение (без использования
       `msync(MS_ASYNC)`) соответствует неизменяемой (hardcoded) логике LMDB. В
       результате, в простых/наивных бенчмарках, libmdbx опережает LMDB
       примерна также как при реальном применении.
    
       На всякий случай стоит еще раз отметить/напомнить, что на Windows
       предположительно libmdbx будет отставать от LMDB в сценариях с
       множеством мелких транзакций, так как libmdbx осознанно использует на
       Windows файловые блокировки, которые медленные (плохо реализованы в ядре
       ОС), но позволяют застраховать пользователей от массы неверных действий
       приводящих к повреждению БД.
    
     - Поддержка не-печатных имен для subDb.
    
     - Добавлен явный выбор `tls_model("local-dynamic")` для обзода проблемы
       `relocation R_X86_64_TPOFF32 against FOO cannot be used with -shared`
       из-за ошибки в CLANG приводящей к использованию неверного режима `ls_model`.
    
     - Изменение тактики слияния страниц при удалении.
       Теперь слияние выполняется преимущественно с уже измененной/грязной страницей.
       Если же справа и слева обе страницы с одинаковым статусом,
       то с наименее заполненной, как прежде. В сценариях с массивным удалением
       это позволяет увеличить производительность до 50%.
    
     - Добавлен контроль отсутствия LCK-файлов с альтернативным именованием.
    
    Исправления (без корректировок новых функций):
    ----------------------------------------------
    
     - Изменение размера отображения если это требуется для сброса данных на
       диск при вызове `mdbx_env_sync()` из параллельного потока выполнения вне
       работающей транзакции.
    
     - Исправление регресса после коммита db72763de049d6e4546f838277fe83b9081ad1de от 2022-10-08
       в логике возврата грязных страниц в режиме `MDBX_WRITEMAP`, из-за чего
       освободившиеся страницы использовались не немедленно, а попадали в
       retired-список совершаемой транзакции и происходил необоснованный рост
       размера транзакции.
    
     - Устранение SIGSEGV или ошибочного вызова `free()` в ситуациях
       повторного открытия среды посредством `mdbx_env_open()`.
    
     - Устранение ошибки совершенной в коммите fe20de136c22ed3bc4c6d3f673e79c106e824f60 от 2022-09-18,
       в результате чего на Linux в режиме `MDBX_WRITEMAP` никогда не вызывался `msync()`.
       Проблема существует только в релизе 0.12.2.
    
     - Добавление подсчета грязных страниц в `MDBX_WRITEMAP` для предоставления посредством `mdbx_txn_info()`
       актуальной информации об объеме изменений в процессе транзакций чтения-записи.
    
     - Исправление несущественной опечатки в условиях `#if` определения порядка байт.
    
     - Исправление сборки для случая `MDBX_PNL_ASCENDING=1`.
    
    Ликвидация технических долгов и мелочи:
    ---------------------------------------
    
     - Доработка поддержки авто-слияния записей GC внутри `page_alloc_slowpath()`.
     - Устранение несущественных предупреждений Coverity.
     - Использование единого курсора для поиска в GC.
     - Переработка внутренних флагов связанных с выделением страниц из GC.
     - Доработка подготовки резерва перед обновлением GC при включенном BigFoot.
     - Оптимизация `pnl_merge()` для случаев неперекрывающихся объединяемых списков.
     - Оптимизация поддержки отсортированного списка страниц в `dpl_append()`.
     - Ускорение работы `mdbx_chk` при обработке пользовательских записей в `@MAIN`.
     - Переработка LRU-отметок для спиллинга.
     - Переработка контроля "некогерентности" Unified page cache для уменьшения накладных расходов.
     - Рефакторинг и микрооптимизация.
    
    20 files changed, 4504 insertions(+), 2924 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.12.2
    v0.12.2 "Иван Ярыгин"
    
    Выпуск с существенными доработками и новой функциональностью
    в память о российском борце [Иване Сергеевиче Ярыгине](https://ru.wikipedia.org/wiki/Ярыгин,_Иван_Сергеевич).
    
    На Олимпийских играх в Мюнхене в 1972 году Иван Ярыгин уложил всех соперников на лопатки,
    суммарно затратив менее 9 минут. Этот рекорд никем не побит до сих пор.
    
    Новое:
    ------
    
     - Поддержка всех основных опций при сборке посредством CMake.
    
     - Требования к CMake понижены до версии 3.0.2 для возможности сборки для устаревших платформ.
    
     - Добавлена возможность профилирования работы GC в сложных и/или нагруженных
       сценариях (например Ethereum/Erigon). По-умолчанию соответствующий код отключен,
       а для его активации необходимо указать опцию сборки `MDBX_ENABLE_PROFGC=1`.
    
     - Добавлена функция `mdbx_env_warmup()` для "прогрева" БД с возможностью
       закрепления страниц в памяти.
       В утилиты `mdbx_chk`, `mdbx_copy` и `mdbx_dump` добавлены опции `-u` и `-U`
       для активации соответствующего функционала.
    
     - Отключение учета «грязных» страниц в не требующих этого режимах
       (`MDBX_WRITEMAP` при `MDBX_AVOID_MSYNC=0`). Доработка позволяет снизить
       накладные расходы и была запланирована давно, но откладывалась так как
       требовала других изменений.
    
     - Вытеснение из памяти (спиллинг) «грязных» страниц с учетом размера
       large/overflow-страниц. Доработка позволяет корректно соблюдать политику
       задаваемую опциями `MDBX_opt_txn_dp_limit`,
       `MDBX_opt_spill_max_denominator`, `MDBX_opt_spill_min_denominator` и
       была запланирована давно, но откладывалась так как требовала других
       изменений.
    
     - Для Windows в API добавлены UNICODE-зависимые определения макросов
      `MDBX_DATANAME`, `MDBX_LOCKNAME` и `MDBX_LOCK_SUFFIX`.
    
     - Переход на преимущественное использование типа `size_t` для
       уменьшения накладных расходов на платформе Эльбрус.
    
     - В API добавлены функции `mdbx_limits_valsize4page_max()` и
       `mdbx_env_get_valsize4page_max()` возвращающие максимальный размер в
       байтах значения, которое может быть размещена в одной
       large/overflow-странице, а не последовательности из двух или более таких
       страниц. Для таблиц с поддержкой дубликатов вынос значений на
       large/overflow-страницы не поддерживается, поэтому результат совпадает с
       `mdbx_limits_valsize_max()`.
    
     - В API добавлены функции `mdbx_limits_pairsize4page_max()`и
       `mdbx_env_get_pairsize4page_max()` возвращающие в байтах максимальный
       суммарный размер пары ключ-значение для их размещения на одной листовой
       страницы, без выноса значения на отдельную large/overflow-страницу. Для
       таблиц с поддержкой дубликатов вынос значений на large/overflow-страницы
       не поддерживается, поэтому результат определяет максимальный/допустимый
       суммарный размер пары ключ-значение.
    
     - Реализовано использование асинхронной (overlapped) записи в Windows,
       включая использования небуфферизированного ввода-вывода и `WriteGather()`.
       Это позволяет сократить накладные расходы и частично обойти проблемы
       Windows с низкой производительностью ввода-вывода, включая большие
       задержки `FlushFileBuffers()`. Новый код также обеспечивает консолидацию
       записываемых регионов на всех платформах, а на Windows использование
       событий (events) сведено к минимум, одновременно с автоматических
       использованием `WriteGather()`. Поэтому ожидается существенное снижение
       накладных расходов взаимодействия с ОС, а в Windows это ускорение, в
       некоторых сценариях, может быть кратным в сравнении с LMDB.
    
     - Добавлена опция сборки `MDBX_AVOID_MSYNC`, которая определяет
       поведение libmdbx в режиме `MDBX_WRITE_MAP` (когда данные изменяются
       непосредственно в отображенных в ОЗУ страницах БД):
    
        * Если `MDBX_AVOID_MSYNC=0` (по умолчанию на всех системах кроме Windows),
          то (как прежде) сохранение данных выполняется посредством `msync()`,
          либо `FlushViewOfFile()` на Windows. На платформах с полноценной
          подсистемой виртуальной памяти и адекватным файловым вводом-выводом
          это обеспечивает минимум накладных расходов (один системный вызов)
          и максимальную производительность. Однако, на Windows приводит
          к значительной деградации, в том числе из-за того что после
          `FlushViewOfFile()` требуется также вызов `FlushFileBuffers()`
          с массой проблем и суеты внутри ядра ОС.
    
        * Если `MDBX_AVOID_MSYNC=1` (по умолчанию только на Windows), то
          сохранение данных выполняется явной записью в файл каждой измененной
          страницы БД. Это требует дополнительных накладных расходов, как
          на отслеживание измененных страниц (ведение списков "грязных"
          страниц), так и на системные вызовы для их записи.
          Кроме этого, с точки зрения подсистемы виртуальной памяти ядра ОС,
          страницы БД измененные в ОЗУ и явно записанные в файл, могут либо
          оставаться "грязными" и быть повторно записаны ядром ОС позже,
          либо требовать дополнительных накладных расходов для отслеживания
          PTE (Page Table Entries), их модификации и дополнительного копирования
          данных. Тем не менее, по имеющейся информации, на Windows такой путь
          записи данных в целом обеспечивает более высокую производительность.
    
     - Улучшение эвристики включения авто-слияния записей GC.
    
     - Изменение формата LCK и семантики некоторых внутренних полей. Версии
       libmdbx использующие разный формат не смогут работать с одной БД
       одновременно, а только поочередно (LCK-файл переписывается при открытии
       первым открывающим БД процессом).
    
     - В `C++` API добавлены методы фиксации транзакции с получением информации
       о задержках.
    
     - Added `MDBX_HAVE_BUILT IN_CPU_SUPPORTS` build option to control use GCC's
       `__builtin_cpu_supports()` function, which could be unavailable on a fake
       OSes (macos, ios, android, etc).
    
    Исправления (без корректировок вышеперечисленных новых функций):
    ----------------------------------------------------------------
    
     - Устранения ряда предупреждений при сборке посредством MinGW.
     - Устранение ложно-положительных сообщений от Valgrind об использовании
       не инициализированных данных из-за выравнивающих зазоров в `struct troika`.
     - Исправлен возврат неожиданной ошибки `MDBX_BUSY` из функций `mdbx_env_set_option()`,
       `mdbx_env_set_syncbytes()` и `mdbx_env_set_syncperiod()`.
     - Небольшие исправления для совместимости с CMake 3.8
     - Больше контроля и осторожности (паранойи) для страховки от дефектов `mremap()`.
     - Костыль для починки сборки со старыми версиями `stdatomic.h` из GNU Lib C,
       где макросы `ATOMIC_*_LOCK_FREE` ошибочно переопределяются через функции.
     - Использование `fcntl64(F_GETLK64/F_SETLK64/F_SETLKW64)` при наличии.
       Это решает проблему срабатывания проверочного утверждения при сборке для
       платформ где тип `off_t` шире соответствующих полей `структуры flock`,
       используемой для блокировки файлов.
     - Доработан сбор информации о задержках при фиксации транзакций:
        * Устранено искажение замеров длительности обновления GC
          при включении отладочного внутреннего аудита;
        * Защита от undeflow-нуля только общей задержки в метриках,
          чтобы исключить ситуации, когда сумма отдельных стадий
          больше общей длительности.
     - Ряд исправлений для устранения срабатываний проверочных утверждения в
       отладочных сборках.
     - Более осторожное преобразование к типу `mdbx_tid_t` для устранения
       предупреждений.
     - Исправление лишнего сброса данных на диск в режиме `MDBX_SAFE_NOSYNC`
       при обновлении GC.
     - Fixed an extra check for `MDBX_APPENDDUP` inside `mdbx_cursor_put()`
       which could result in returning `MDBX_EKEYMISMATCH` for valid cases.
     - Fixed nasty `clz()` bug (by using `_BitScanReverse()`, only MSVC builds affected).
    
    Мелочи:
    -------
    
     - Исторические ссылки cвязанные с удалённым на ~~github~~ проектом  перенаправлены на [web.archive.org](https://web.archive.org/web/https://github.com/erthink/libmdbx).
     - Синхронизированны конструкции CMake между проектами.
     - Добавлено предупреждение о небезопасности RISC-V.
     - Добавлено описание параметров `MDBX_debug_func` и `MDBX_debug_func`.
     - Добавлено обходное решение для минимизации ложно-положительных
       конфликтов при использовании файловых блокировок в Windows.
     - Проверка атомарности C11-операций c 32/64-битными данными.
     - Уменьшение в 42 раза значения по-умолчанию для `me_options.dp_limit`
       в отладочных сборках.
     - Добавление платформы `gcc-riscv64-linux-gnu` в список для цели `cross-gcc`.
     - Небольшие правки скрипта `long_stochastic.sh` для работы в Windows.
     - Удаление ненужного вызова `LockFileEx()` внутри `mdbx_env_copy()`.
     - Добавлено описание использования файловых дескрипторов в различных режимах.
     - Добавлено использование `_CrtDbgReport()` в отладочных сборках.
     - Fixed an extra ensure/assertion check of `oldest_reader` inside `txn_end()`.
     - Removed description of deprecated usage of `MDBX_NODUPDATA`.
     - Fixed regression ASAN/Valgring-enabled builds.
     - Fixed minor MingGW warning.
    
    64 files changed, 5573 insertions(+), 2510 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.11.13
    0.11.13 "Swashplate"
    
    The stable bugfix release in memory of [Boris Yuryev](https://ru.wikipedia.org/wiki/Юрьев,_Борис_Николаевич) on his 133rd birthday.
    
    Fixes:
    ------
    
     - Fixed builds with older libc versions after using `fcntl64()` (backport).
     - Fixed builds with  older `stdatomic.h` versions,
       where the `ATOMIC_*_LOCK_FREE` macros mistakenly redefined using functions (backport).
     - Added workaround for `mremap()` defect to avoid assertion failure (backport).
     - Workaround for `encryptfs` bug(s) in the `copy_file_range` implementation  (backport).
     - Fixed unexpected `MDBX_BUSY` from `mdbx_env_set_option()`, `mdbx_env_set_syncbytes()`
       and `mdbx_env_set_syncperiod()` (backport).
     - CMake requirements lowered to version 3.0.2 (backport).
     - Added admonition of insecure for RISC-V (backport).
    
    Minors:
    -------
    
     - Minor clarification output of `--help` for `mdbx_test` (backport).
     - Added admonition of insecure for RISC-V (backport).
     - Stochastic scripts and CMake files synchronized with the `devel` branch.
     - Use `--dont-check-ram-size` for small-tests make-targets (backport).
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    30 files changed, 405 insertions(+), 136 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.12
    0.11.12 "Эребуни"
    
    The stable bugfix release.
    
    Fixes:
    ------
    
     - Fixed static assertion failure on platforms where the `off_t` type is wider
       than corresponding fields of `struct flock` used for file locking (backport).
       Now _libmdbx_ will use `fcntl64(F_GETLK64/F_SETLK64/F_SETLKW64)` if available.
     - Fixed assertion check inside `page_retire_ex()` (backport).
    
    Minors:
    -------
    
     - Fixed `-Wint-to-pointer-cast` warnings while casting to `mdbx_tid_t` (backport).
     - Removed needless `LockFileEx()` inside `mdbx_env_copy()` (backport).
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    11 files changed, 96 insertions(+), 49 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.11
    0.11.11 "Тендра-1790"
    
    The stable bugfix release.
    It is planned that this will be the last release of the v0.11 branch.
    
    Fixes:
    ------
    
     - Fixed an extra check for `MDBX_APPENDDUP` inside `mdbx_cursor_put()` which could result in returning `MDBX_EKEYMISMATCH` for valid cases.
     - Fixed an extra ensure/assertion check of `oldest_reader` inside `mdbx_txn_end()`.
     - Fixed derived C++ builds by removing `MDBX_INTERNAL_FUNC` for `mdbx_w2mb()` and `mdbx_mb2w()`.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    10 files changed, 38 insertions(+), 21 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.1
    0.12.1 "Positive Proxima"
    
    The planned frontward release with new superior features on the day of 20 anniversary of [Positive Technologies](https://ptsecurty.com).
    
    New:
    ---
    
     - The `Big Foot` feature which significantly reduces GC overhead for processing large lists of retired pages from huge transactions.
       Now _libmdbx_ avoid creating large chunks of PNLs (page number lists) which required a long sequences of free pages, aka large/overflow pages.
       Thus avoiding searching, allocating and storing such sequences inside GC.
     - Improved hot/online validation and checking of database pages both for more robustness and performance.
     - New solid and fast method to latch meta-pages called `Troika`.
       The minimum of memory barriers, reads, comparisons and conditional transitions are used.
     - New `MDBX_VALIDATION` environment options to extra validation of DB structure and pages content for carefully/safe handling damaged or untrusted DB.
     - Accelerated ×16/×8/×4 by AVX512/AVX2/SSE2/Neon implementations of search page sequences.
     - Added the `gcrtime_seconds16dot16` counter to the "Page Operation Statistics" that accumulates time spent for GC searching and reclaiming.
     - Copy-with-compactification now clears/zeroes unused gaps inside database pages.
     - The `C` and `C++` APIs has been extended and/or refined to simplify using `wchar_t` pathnames.
       On Windows the `mdbx_env_openW()`, `mdbx_env_get_pathW()`, `mdbx_env_copyW()`, `mdbx_env_open_for_recoveryW()` are available for now,
       but the `mdbx_env_get_path()` has been replaced in favor of `mdbx_env_get_pathW()`.
     - Added explicit error message for Buildroot's Microblaze toolchain maintainers.
     - Added `MDBX_MANAGE_BUILD_FLAGS` build options for CMake.
     - Speed-up internal `bsearch`/`lower_bound` implementation using branchless tactic, including workaround for CLANG x86 optimiser bug.
     - A lot internal refinement and micro-optimisations.
     - Internally counted volume of dirty pages (unused for now but for coming features).
    
    Fixes:
    -----
    
     - Never use modern `__cxa_thread_atexit()` on Apple's OSes.
     - Don't check owner for finished transactions.
     - Fixed typo in `MDBX_EINVAL` which breaks MingGW builds with CLANG.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    37 files changed, 7604 insertions(+), 7417 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.10
    aaa9112c · mdbx: release v0.11.10 ·
    The stable bugfix release.
    It is planned that this will be the last release of the v0.11 branch.
    
    New:
    ----
    
     - The C++ API has been refined to simplify support for `wchar_t` in path names.
     - Added explicit error message for Buildroot's Microblaze toolchain maintainers.
    
    Fixes:
    ------
    
     - Never use modern `__cxa_thread_atexit()` on Apple's OSes.
     - Use `MultiByteToWideChar(CP_THREAD_ACP)` instead of `mbstowcs()`.
     - Don't check owner for finished transactions.
     - Fixed typo in `MDBX_EINVAL` which breaks MingGW builds with CLANG.
    
    Minors:
    -------
    
     - Fixed variable name typo.
     - Using `ldd` to check used dso.
     - Added `MDBX_WEAK_IMPORT_ATTRIBUTE` macro.
     - Use current transaction geometry for untouched parameters when `env_set_geometry()` called within a write transaction.
     - Minor clarified `iov_page()` failure case.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    14 files changed, 263 insertions(+), 252 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.9
    e444c70c · mdbx: release v0.11.9 ·
    The stable bugfix release.
    It is planned that this will be the last release of the v0.11 branch.
    
    Acknowledgements:
    -----------------
    
     - [Alex Sharov](https://github.com/AskAlexSharov) and Erigon team for reporting and testing.
     - [Andrew Ashikhmin](https://gitflic.ru/user/yperbasis) for contributing.
    
    New:
    ----
    
     - Ability to customise `MDBX_LOCK_SUFFIX`, `MDBX_DATANAME`, `MDBX_LOCKNAME` just by predefine ones during build.
     - Added to [`mdbx::env_managed`](https://libmdbx.dqdkfa.ru/group__cxx__api.html#classmdbx_1_1env__managed)'s methods a few overloads with `const char* pathname` parameter (C++ API).
    
    Fixes:
    ------
    
     - Fixed hang copy-with-compactification of a corrupted DB
       or in case the volume of output pages is a multiple of `MDBX_ENVCOPY_WRITEBUF`.
     - Fixed standalone non-CMake build on MacOS (`#include AvailabilityMacros.h>`).
     - Fixed unexpected `MDBX_PAGE_FULL` error in rare cases with large database page sizes.
    
    Minors:
    -------
    
     - Minor fixes Doxygen references, comments, descriptions, etc.
     - Fixed copy&paste typo inside `meta_checktxnid()`.
     - Minor fix `meta_checktxnid()` to avoid assertion in debug mode.
     - Minor fix `mdbx_env_set_geometry()` to avoid returning `EINVAL` in particular rare cases.
     - Minor refine/fix batch-get testcase for large page size.
     - Added `--pagesize NN` option to long-stotastic test script.
     - Updated Valgrind-suppressions file for modern GCC.
     - Fixed `has no symbols` warning from Apple's ranlib.
    
    For earlier versions please refer to the git's tags and the [ChangeLog](https://gitflic.ru/project/erthink/libmdbx/blob?file=ChangeLog.md).
    
    18 files changed, 318 insertions(+), 178 deletions(-)
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.12.0
    Not a release but preparation for changing feature set and API.
  • v0.11.8
    bd80e01e · mdbx: release v0.11.8 ·
    The stable release with an important fixes and workaround for the critical macOS thread-local-storage issue.
    
    Acknowledgements:
    -----------------
    
     - [Masatoshi Fukunaga](https://github.com/mah0x211) for [Lua bindings](https://github.com/mah0x211/lua-libmdbx).
    
    New:
    ----
    
     - Added most of transactions flags to the public API.
     - Added `MDBX_NOSUCCESS_EMPTY_COMMIT` build option to return non-success result (`MDBX_RESULT_TRUE`) on empty commit.
     - Reworked validation and import of DBI-handles into a transaction.
       Assumes  these changes will be invisible to most users, but will cause fewer surprises in complex DBI cases.
     - Added ability to open DB in without-LCK (exclusive read-only) mode in case no permissions to create/write LCK-file.
    
    Fixes:
    ------
    
     - A series of fixes and improvements for automatically generated documentation (Doxygen).
     - Fixed copy&paste bug with could lead to `SIGSEGV` (nullptr dereference) in the exclusive/no-lck mode.
     - Fixed minor warnings from modern Apple's CLANG 13.
     - Fixed minor warnings from CLANG 14 and in-development CLANG 15.
     - Fixed `SIGSEGV` regression in without-LCK (exclusive read-only) mode.
     - Fixed `mdbx_check_fs_local()` for CDROM case on Windows.
     - Fixed nasty typo of typename which caused false `MDBX_CORRUPTED` error in a rare execution path,
       when the size of the thread-ID type not equal to 8.
     - Fixed write-after-free memory corruption on latest `macOS` during finalization/cleanup of thread(s) that executed read transaction(s).
       > The issue was suddenly discovered by a [CI](https://en.wikipedia.org/wiki/Continuous_integration)
       > after adding an iteration with macOS 11 "Big Sur", and then reproduced on recent release of macOS 12 "Monterey".
       > The issue was never noticed nor reported on macOS 10 "Catalina" nor others.
       > Analysis shown that the problem caused by a change in the behavior of the system library (internals of dyld and pthread)
       > during thread finalization/cleanup: now a memory allocated for a `__thread` variable(s) is released
       > before execution of the registered Thread-Local-Storage destructor(s),
       > thus a TLS-destructor will write-after-free just by legitime dereference any `__thread` variable.
       > This is unexpected crazy-like behavior since the order of resources releasing/destroying
       > is not the reverse of ones acquiring/construction order. Nonetheless such surprise
       > is now workarounded by using atomic compare-and-swap operations on a 64-bit signatures/cookies.
     - Fixed Elbrus/E2K LCC 1.26 compiler warnings (memory model for atomic operations, etc).
    
    Minors:
    -------
    
     - Refined `release-assets` GNU Make target.
     - Added logging to `mdbx_fetch_sdb()` to help debugging complex DBI-handels use cases.
     - Added explicit error message from probe of no-support for `std::filesystem`.
     - Added contributors "score" table by `git fame` to generated docs.
     - Added `mdbx_assert_fail()` to public API (mostly for backtracing).
     - Now C++20 concepts used/enabled only when `__cpp_lib_concepts >= 202002`.
     - Don't provide nor report package information if used as a CMake subproject.
    
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
  • v0.11.7
    40ec559c · mdbx: release v0.11.7 ·
    The stable risen release after the Github's intentional malicious disaster.
    
    We have migrated to a reliable trusted infrastructure
    -----------------------------------------------------
    
    The origin for now is at [GitFlic](https://gitflic.ru/project/erthink/libmdbx)
    since on 2022-04-15 the Github administration, without any warning nor
    explanation, deleted _libmdbx_ along with a lot of other projects,
    simultaneously blocking access for many developers.
    For the same reason ~~Github~~ is blacklisted forever.
    
    GitFlic already support Russian and English languages, plan to support more,
    including 和 中文. You are welcome!
    
    New:
    ----
    
     - Added the `tools-static` make target to build statically linked MDBX tools.
     - Support for Microsoft Visual Studio 2022.
     - Support build by MinGW' make from command line without CMake.
     - Added `mdbx::filesystem` C++ API namespace that corresponds to `std::filesystem` or `std::experimental::filesystem`.
     - Created [website](https://libmdbx.website.yandexcloud.net/) for online auto-generated documentation.
     - Used `todo4recovery://erased_by_github/` for dead (or temporarily lost) resources deleted by ~~Github~~.
     - Added `--loglevel=` command-line option to the `mdbx_test` tool.
     - Added few fast smoke-like tests into CMake builds.
    
    Fixes:
    ------
    
     - Fixed a race between starting a transaction and creating a DBI descriptor that could lead to `SIGSEGV` in the cursor tracking code.
     - Clarified description of `MDBX_EPERM` error returned from `mdbx_env_set_geometry()`.
     - Fixed non-promoting the parent transaction to be dirty in case the undo of the geometry update failed during abortion of a nested transaction.
     - Resolved linking issues with `libstdc++fs`/`libc++fs`/`libc++experimental` for C++ `std::filesystem` or `std::experimental::filesystem` for legacy compilers.
     - Added workaround for GNU Make 3.81 and earlier.
     - Added workaround for Elbrus/LCC 1.25 compiler bug of class inline `static constexpr` member field.
     - [Fixed](https://github.com/ledgerwatch/erigon/issues/3874) minor assertion regression (only debug builds were affected).
     - Fixed detection of `C++20` concepts accessibility.
     - Fixed detection of Clang's LTO availability for Android.
     - Fixed build for ARM/ARM64 by MSVC.
     - Fixed non-x86 Windows builds with `MDBX_WITHOUT_MSVC_CRT=ON` and `MDBX_BUILD_SHARED_LIBRARY=ON`.
    
    Minors:
    -------
    
     - Resolve minor MSVC warnings: avoid `/INCREMENTAL[:YES]` with `/LTCG`, `/W4` with `/W3`, the `C5105` warning.
     - Switched to using `MDBX_EPERM` instead of `MDBX_RESULT_TRUE' to indicate that the geometry cannot be updated.
     - Added `NULL` checking during memory allocation inside `mdbx_chk`.
     - Resolved all warnings from MinGW while used without CMake.
     - Added inheretable `target_include_directories()` to `CMakeLists.txt` for easy integration.
     - Added build-time checks and paranoid runtime assertions for the `off_t` arguments of `fcntl()` which are used for locking.
     - Added `-Wno-lto-type-mismatch` to avoid false-positive warnings from old GCC during LTO-enabled builds.
     - Added checking for TID (system thread id) to avoid hang on 32-bit Bionic/Android  within `pthread_mutex_lock()`.
     - Reworked `MDBX_BUILD_TARGET` of CMake builds.
     - Added `CMAKE_HOST_ARCH` and `CMAKE_HOST_CAN_RUN_EXECUTABLES_BUILT_FOR_TARGET`.
    
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
    
  • v0.11.6
    d5e4c198 · mdbx: release v0.11.6 ·
    The stable release with the complete workaround for an incoherence flaw of Linux unified page/buffer cache.
    Nonetheless the cause for this trouble may be an issue of Intel CPU cache/MESI.
    See [issue#269](https://github.com/erthink/libmdbx/issues/269) for more information.
    
    Acknowledgements:
    -----------------
    
     - [David Bouyssié](https://github.com/david-bouyssie) for [Scala bindings](https://github.com/david-bouyssie/mdbx4s).
     - [Michelangelo Riccobene](https://github.com/mriccobene) for reporting and testing.
    
    Fixes:
    ------
    
     - [Added complete workaround](https://github.com/erthink/libmdbx/issues/269) for an incoherence flaw of Linux unified page/buffer cache.
     - [Fixed](https://github.com/erthink/libmdbx/issues/272) cursor reusing for read-only transactions.
     - Fixed copy&paste typo inside `mdbx::cursor::find_multivalue()`.
    
    Minors:
    -------
    
     - Minor refine C++ API for convenience.
     - Minor internals refines.
     - Added `lib-static` and `lib-shared` targets for make.
     - Added minor workaround for AppleClang 13.3 bug.
     - Clarified error messages of a signature/version mismatch.
    
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.11.5
    d01e44db · mdbx: release v0.11.5 ·
    The stable release with the hotfix/workaround for a flaw of Linux 4.19 (at least) unified page/buffer cache.
    See [issue#269](https://github.com/erthink/libmdbx/issues/269) for more information.
    
    Acknowledgements:
    -----------------
    
     - [Simon Leier](https://github.com/leisim) for reporting and testing.
     - [Kai Wetlesen](https://github.com/kaiwetlesen) for [RPMs](http://copr.fedorainfracloud.org/coprs/kwetlesen/libmdbx/).
     - [Tullio Canepa](https://github.com/canepat) for reporting C++ API issue and contributing.
    
    Fixes:
    ------
    
     - [Added workaround](https://github.com/erthink/libmdbx/issues/269) for a flaw of Linux 4.19 (at least) unified page/buffer cache.
     - [Fixed/Reworked](https://github.com/erthink/libmdbx/pull/270) move-assignment operators for "managed" classes of C++ API.
     - Fixed potential `SIGSEGV` while open DB with overrided non-default page size.
     - [Made](https://github.com/erthink/libmdbx/issues/267) `mdbx_env_open()` idempotence in failure cases.
     - Refined/Fixed pages reservation inside `mdbx_update_gc()` to avoid non-reclamation in a rare cases.
     - Fixed typo in a retained space calculation for the hsr-callback.
    
    Minors:
    -------
    
     - Reworked functions for meta-pages, split-off non-volatile.
     - Disentangled C11-atomic fences/barriers and pure-functions (with `__attribute__((__pure__))`) to avoid compiler misoptimization.
     - Fixed hypotetic unaligned access to 64-bit dwords on ARM with `__ARM_FEATURE_UNALIGNED` defined.
     - Reasonable paranoia that makes clarity for code readers.
     - Minor fixes Doxygen references, comments, descriptions, etc.
    
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.11.4
    daa7f04f · mdbx: release v0.11.4 ·
    The stable release with fixes for large and huge databases sized of 4..128 TiB.
    
    Acknowledgements:
    
     - Ledgerwatch, Binance and Positive Technologies teams for reporting, assistance in investigation and testing.
     - Alex Sharov for reporting, testing and provide resources for remote debugging/investigation.
     - Kris Zyp for Deno support.
    
    ## New features, extensions and improvements:
    
     - Added treating the `UINT64_MAX` value as maximum for given option inside `mdbx_env_set_option()`.
     - Added `to_hex/to_base58/to_base64::output(std::ostream&)` overloads without using temporary string objects as buffers.
     - Added `--geometry-jitter=YES|no` option to the test framework.
     - Added support for [Deno](https://deno.land/) support by [Kris Zyp](https://github.com/kriszyp).
    
    ## Fixes:
    
     - Fixed handling `MDBX_opt_rp_augment_limit` for GC's records from huge transactions (Erigon/Akula/Ethereum).
     - [Fixed](https://github.com/erthink/libmdbx/issues/258) build on Android (avoid including `sys/sem.h`).
     - [Fixed](https://github.com/erthink/libmdbx/pull/261) missing copy assignment operator for `mdbx::move_result`.
     - Fixed missing `&` for `std::ostream &operator<<()` overloads.
     - Fixed unexpected `EXDEV` (Cross-device link) error from `mdbx_env_copy()`.
     - Fixed base64 encoding/decoding bugs in auxillary C++ API.
     - Fixed overflow of `pgno_t` during checking PNL on 64-bit platforms.
     - [Fixed](https://github.com/erthink/libmdbx/issues/260) excessive PNL checking after sort for spilling.
     - Reworked checking `MAX_PAGENO` and DB upper-size geometry limit.
     - [Fixed](https://github.com/erthink/libmdbx/issues/265) build for some combinations of versions of  MSVC and Windows SDK.
    
    ## Minors:
    
     - Added workaround for CLANG bug [D79919/PR42445](https://reviews.llvm.org/D79919).
     - Fixed build test on Android (using `pthread_barrier_t` stub).
     - Disabled C++20 concepts for CLANG < 14 on Android.
     - Fixed minor `unused parameter` warning.
     - Added CI for Android.
     - Refine/cleanup internal logging.
     - Refined line splitting inside hex/base58/base64 encoding to avoid `\n` at the end.
     - Added workaround for modern libstdc++ with CLANG < 4.x
     - Relaxed txn-check rules for auxiliary functions.
     - Clarified a comments and descriptions, etc.
     - Using the `-fno-semantic interposition` option to reduce the overhead to calling self own public functions.
    
    Signed-off-by: Леонид Юрьев (Leonid Yuriev) <leo@yuriev.ru>
    
    
  • v0.11.3
    mdbx: release v0.11.3
    
    Acknowledgements:
    -----------------
    
     - [gcxfd <i@rmw.link>](https://github.com/gcxfd) for reporting, contributing and testing.
     - [장세연 (Чан Се Ен)](https://github.com/sasgas) for reporting and testing.
     - [Alex Sharov](https://github.com/AskAlexSharov) for reporting, testing and provide resources for remote debugging/investigation.
    
    New features, extensions and improvements:
    ------------------------------------------
    
     - [Added](https://github.com/erthink/libmdbx/issues/236) `mdbx_cursor_get_batch()`.
     - [Added](https://github.com/erthink/libmdbx/issues/250) `MDBX_SET_UPPERBOUND`.
     - C++ API is finalized now.
     - The GC update stage has been [significantly speeded](https://github.com/erthink/libmdbx/issues/254) when fixing huge Erigon's transactions (Ethereum ecosystem).
    
    Fixes:
    ------
    
     - Disabled C++20 concepts for stupid AppleClang 13.x
     - Fixed internal collision of `MDBX_SHRINK_ALLOWED` with `MDBX_ACCEDE`.
    
    Minors:
    -------
    
     - Fixed returning `MDBX_RESULT_TRUE` (unexpected -1) from `mdbx_env_set_option()`.
     - Added `mdbx_env_get_syncbytes()` and `mdbx_env_get_syncperiod()`.
     - [Clarified](https://github.com/erthink/libmdbx/pull/249) description of `MDBX_INTEGERKEY`.
     - Reworked/simplified `mdbx_env_sync_internal()`.
     - [Fixed](https://github.com/erthink/libmdbx/issues/248) extra assertion inside `mdbx_cursor_put()` for `MDBX_DUPFIXED` cases.
     - Avoiding extra looping inside `mdbx_env_info_ex()`.
     - Explicitly enabled core dumps from stochastic tests scripts on Linux.
     - [Fixed](https://github.com/erthink/libmdbx/issues/253) `mdbx_override_meta()` to avoid false-positive assertions.
     - For compatibility reverted returning `MDBX_ENODATA`for some cases.
    
    
    
  • v0.11.2
    d47eed07 · mdbx: release v0.11.2 ·
    mdbx: release v0.11.2
    
    Acknowledgements:
    -----------------
    
     - [장세연 (Чан Се Ен)](https://github.com/sasgas) for contributing to C++ API.
     - [Alain Picard](https://github.com/castortech) for [Java bindings](https://github.com/castortech/mdbxjni).
     - [Alex Sharov](https://github.com/AskAlexSharov) for reporting and testing.
     - [Kris Zyp](https://github.com/kriszyp) for reporting and testing.
     - [Artem Vorotnikov](https://github.com/vorot93) for support [Rust wrapper](https://github.com/vorot93/libmdbx-rs).
    
    Fixes:
    ------
    
     - [Fixed compilation](erthink/libmdbx#239) with `devtoolset-9` on CentOS/RHEL 7.
     - [Fixed unexpected `MDBX_PROBLEM` error](erthink/libmdbx#242) because of update an obsolete meta-page.
     - [Fixed returning `MDBX_NOTFOUND` error](erthink/libmdbx#243) in case an inexact value found for `MDBX_GET_BOTH` operation.
     - [Fixed compilation](erthink/libmdbx#245) without kernel/libc-devel headers.
    
    Minors:
    -------
    
     - Fixed `constexpr`-related macros for legacy compilers.
     - Allowed to define 'CMAKE_CXX_STANDARD` using an environment variable.
     - Simplified collection statistics of page operation .
     - Added `MDBX_FORCE_BUILD_AS_MAIN_PROJECT` cmake option.
     - Remove unneeded `#undef P_DIRTY`.
    
    Signed-off-by: Leonid Yuriev <leo@yuriev.ru>
    
    
  • v0.11.1
    113162b6 · mdbx: release v0.11.1 ·
    mdbx: release v0.11.1
    
    Backward compatibility break:
    -----------------------------
    
    The database format signature has been changed to prevent
    forward-interoperability with an previous releases, which may lead to a
    [false positive diagnosis of database corruption](https://github.com/erthink/libmdbx/issues/238)
    due to flaws of an old library versions.
    
    This change is mostly invisible:
    
     - previously versions are unable to read/write a new DBs;
     - but the new release is able to handle an old DBs and will silently upgrade ones.
    
    Acknowledgements:
    -----------------
     - [Alex Sharov](https://github.com/AskAlexSharov) for reporting and testing.
    
    Signed-off-by: Leonid Yuriev <leo@yuriev.ru>
    
    
  • v0.11.0
    mdbx: not a release, but alter DB signature.
    
    
  • v0.10.5
    mdbx: release v0.10.5 (hotfix).
        
    Acknowledgements:
    -----------------
     - [Noel Kuntze](https://github.com/Thermi) for immediately bug reporting.
        
    Fixes:
    ------
     - Fixed unaligned access regression after the `#pragma pack` fix for modern compilers.
     - Added UBSAN-test to CI to avoid a regression(s) similar to lately fixed.
     - Fixed possibility of meta-pages clashing after manually turn to a particular meta-page using `mdbx_chk` utility.
        
    Minors:
    -------
     - Refined handling of weak or invalid meta-pages while a DB opening.
     - Refined providing information for the @MAIN and @GC sub-databases of a last committed modification transaction's ID.
        
    Signed-off-by: Leonid Yuriev <leo@yuriev.ru>
    
    
    
  • v0.10.4
    590b225f · mdbx: release v0.10.4 ·
    mdbx: release v0.10.4
    
    Acknowledgements:
    -----------------
     - [Artem Vorotnikov](https://github.com/vorot93) for support [Rust wrapper](https://github.com/vorot93/mdbx-rs).
     - [Andrew Ashikhmin](https://github.com/yperbasis) for contributing to C++ API.
    
    Fixes:
    ------
     - Fixed possibility of looping update GC during transaction commit (no public issue since the problem was discovered inside [Positive Technologies](https://www.ptsecurity.ru).
     - Fixed `#pragma pack` to avoid provoking some compilers to generate code with [unaligned access](https://github.com/erthink/libmdbx/issues/235).
     - Fixed `noexcept` for potentially throwing `txn::put()` of C++ API.
    
    Minors:
    -------
     - Added stochastic test script for checking small transactions cases.
     - Removed extra transaction commit/restart inside test framework.
     - In debugging builds fixed a too small (single page) by default DB shrink threshold.