libsixel is a SIXEL encoder/decoder implementation derived from kmiya's sixel. Versions 1.8.7 and prior contain an integer overflow which leads to a heap buffer overflow via sixelframeconverttorgb888() in frame.c, where allocation size and pointer offset computations for palettised images (PAL1, PAL2, PAL4) are performed using int arithmetic before casting to sizet. For images whose pixel count exceeds INTMAX / 4, the overflow produces an undersized heap allocation for the conversion buffer and a negative pointer offset for the normalization sub-buffer, after which sixelhelpernormalize_pixelformat() writes the full image data starting from the invalid pointer, causing massive heap corruption confirmed by ASAN. An attacker providing a specially crafted large palettised PNG can corrupt the heap of the victim process, resulting in a reliable crash and potential arbitrary code execution. This issue has been fixed in version 1.8.7-r1.
{
"binaries": [
{
"binary_version": "1.8.2-2.1",
"binary_name": "libsixel-bin"
},
{
"binary_version": "1.8.2-2.1",
"binary_name": "libsixel-dev"
},
{
"binary_version": "1.8.2-2.1",
"binary_name": "libsixel-examples"
},
{
"binary_version": "1.8.2-2.1",
"binary_name": "libsixel1"
}
]
}{
"binaries": [
{
"binary_version": "1.10.3-3build1",
"binary_name": "libsixel-bin"
},
{
"binary_version": "1.10.3-3build1",
"binary_name": "libsixel-dev"
},
{
"binary_version": "1.10.3-3build1",
"binary_name": "libsixel-examples"
},
{
"binary_version": "1.10.3-3build1",
"binary_name": "libsixel1"
}
]
}