SDL_image — это библиотека для загрузки изображений различных форматов в виде поверхностей SDL. В do_layer_surface() в src/IMG_xcf.c значения индексов пикселей из декодированных данных фрагмента XCF используются непосредственно как индексы цветовой карты без проверки их на соответствие размеру цветовой карты (cm_num). Созданный файл .xcf с небольшой цветовой картой и индексами пикселей, выходящими за пределы допустимого диапазона, приводит к чтению за пределами кучи размером до 762 байтов за пределами выделения цветовой карты.
Затрагиваются оба пути кода IMAGE_INDEXED (bpp=1 и bpp=2). Утекшие байты кучи записываются в данные пикселей выходной поверхности, что делает их потенциально наблюдаемыми в визуализированном изображении. Эта уязвимость исправлена коммитом 996bf12888925932daace576e09c3053410896f8.
Показать оригинальное описание (EN)
SDL_image is a library to load images of various formats as SDL surfaces. In do_layer_surface() in src/IMG_xcf.c, pixel index values from decoded XCF tile data are used directly as colormap indices without validating them against the colormap size (cm_num). A crafted .xcf file with a small colormap and out-of-range pixel indices causes heap out-of-bounds reads of up to 762 bytes past the colormap allocation. Both IMAGE_INDEXED code paths are affected (bpp=1 and bpp=2). The leaked heap bytes are written into the output surface pixel data, making them potentially observable in the rendered image. This vulnerability is fixed with commit 996bf12888925932daace576e09c3053410896f8.
Характеристики атаки
Последствия
Строка CVSS v3.1