LIBPNG — это справочная библиотека для использования в приложениях, которые читают, создают и манипулируют файлами растровых изображений PNG (Portable Network Graphics). С версии 1.0.9 до версии 1.6.57 передача указателя, полученного из png_get_PLTE, png_get_tRNS или png_get_hIST, обратно в соответствующий установщик в той же паре png_struct/png_info заставляет установщик читать из освобожденной памяти и копировать его содержимое в буфер замены. Установщик освобождает внутренний буфер перед копированием указателя, предоставленного вызывающей стороной, который теперь висит.
Освобожденная область может содержать устаревшие данные (создание незаметно поврежденных метаданных фрагмента) или данные из последующих выделений кучи (утечка несвязанного содержимого кучи в структуру фрагмента). Эта уязвимость исправлена в версии 1.6.57.
Показать оригинальное описание (EN)
LIBPNG is a reference library for use in applications that read, create, and manipulate PNG (Portable Network Graphics) raster image files. From 1.0.9 to before 1.6.57, passing a pointer obtained from png_get_PLTE, png_get_tRNS, or png_get_hIST back into the corresponding setter on the same png_struct/png_info pair causes the setter to read from freed memory and copy its contents into the replacement buffer. The setter frees the internal buffer before copying from the caller-supplied pointer, which now dangles. The freed region may contain stale data (producing silently corrupted chunk metadata) or data from subsequent heap allocations (leaking unrelated heap contents into the chunk struct). This vulnerability is fixed in 1.6.57.
Характеристики атаки
Последствия
Строка CVSS v3.1