Lexbor — это библиотека движка веб-браузера. До версии 2.7.0 кодировщик ISO-2022-JP в Lexbor не мог сбросить переменную временного размера между итерациями. Оператор ctx->buffer_used -= size с устаревшим размером = 3 вызывает целочисленное опустошение, которое переносится на SIZE_MAX.
После этого вызывается memcpy с отрицательной длиной, что приводит к выходному чтению из стека и выходной записи в кучу. Исходными данными частично можно управлять через содержимое дерева DOM. Эта уязвимость исправлена в версии 2.7.0.
Показать оригинальное описание (EN)
Lexbor is a web browser engine library. Prior to 2.7.0, the ISO‑2022‑JP encoder in Lexbor fails to reset the temporary size variable between iterations. The statement ctx->buffer_used -= size with a stale size = 3 causes an integer underflow that wraps to SIZE_MAX. Afterwards, memcpy is called with a negative length, leading to an out‑of‑bounds read from the stack and an out‑of‑bounds write to the heap. The source data is partially controllable via the contents of the DOM tree. This vulnerability is fixed in 2.7.0.
Характеристики атаки
Последствия
Строка CVSS v4.0
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Lexbor Lexbor
cpe:2.3:a:lexbor:lexbor:*:*:*:*:*:*:*:*
|
— |
2.7.0
|