Vulnerability Details CVE-2026-33020
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 sixel_frame_convert_to_rgb888() in frame.c, where allocation size and pointer offset computations for palettised images (PAL1, PAL2, PAL4) are performed using int arithmetic before casting to size_t. For images whose pixel count exceeds INT_MAX / 4, the overflow produces an undersized heap allocation for the conversion buffer and a negative pointer offset for the normalization sub-buffer, after which sixel_helper_normalize_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.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.0
EPSS Ranking 3.3%
CVSS Severity
CVSS v3 Score 7.1
Products affected by CVE-2026-33020
-
cpe:2.3:a:saitoha:libsixel:0.11.0
-
cpe:2.3:a:saitoha:libsixel:0.12.0
-
cpe:2.3:a:saitoha:libsixel:0.14.0
-
cpe:2.3:a:saitoha:libsixel:0.15.0
-
cpe:2.3:a:saitoha:libsixel:0.16.0
-
cpe:2.3:a:saitoha:libsixel:0.16.1
-
cpe:2.3:a:saitoha:libsixel:0.17.0
-
cpe:2.3:a:saitoha:libsixel:0.17.1
-
cpe:2.3:a:saitoha:libsixel:0.17.2
-
cpe:2.3:a:saitoha:libsixel:0.18.0
-
cpe:2.3:a:saitoha:libsixel:0.19.0
-
cpe:2.3:a:saitoha:libsixel:0.19.1
-
cpe:2.3:a:saitoha:libsixel:0.19.2
-
cpe:2.3:a:saitoha:libsixel:0.19.3
-
cpe:2.3:a:saitoha:libsixel:0.19.4
-
cpe:2.3:a:saitoha:libsixel:0.19.5
-
cpe:2.3:a:saitoha:libsixel:0.19.6
-
cpe:2.3:a:saitoha:libsixel:0.20.0
-
cpe:2.3:a:saitoha:libsixel:0.21.0
-
cpe:2.3:a:saitoha:libsixel:0.21.1
-
cpe:2.3:a:saitoha:libsixel:0.22.0
-
cpe:2.3:a:saitoha:libsixel:0.22.1
-
cpe:2.3:a:saitoha:libsixel:0.22.2
-
cpe:2.3:a:saitoha:libsixel:0.22.3
-
cpe:2.3:a:saitoha:libsixel:0.23.0
-
cpe:2.3:a:saitoha:libsixel:0.23.1
-
cpe:2.3:a:saitoha:libsixel:0.23.2
-
cpe:2.3:a:saitoha:libsixel:0.24.0
-
cpe:2.3:a:saitoha:libsixel:0.24.2
-
cpe:2.3:a:saitoha:libsixel:0.25.0
-
cpe:2.3:a:saitoha:libsixel:0.25.1
-
cpe:2.3:a:saitoha:libsixel:0.25.2
-
cpe:2.3:a:saitoha:libsixel:0.25.3
-
cpe:2.3:a:saitoha:libsixel:0.25.4
-
cpe:2.3:a:saitoha:libsixel:0.25.5
-
cpe:2.3:a:saitoha:libsixel:0.26.0
-
cpe:2.3:a:saitoha:libsixel:0.27.0
-
cpe:2.3:a:saitoha:libsixel:0.27.1
-
cpe:2.3:a:saitoha:libsixel:0.28.0
-
cpe:2.3:a:saitoha:libsixel:1.0.0
-
cpe:2.3:a:saitoha:libsixel:1.0.1
-
cpe:2.3:a:saitoha:libsixel:1.0.2
-
cpe:2.3:a:saitoha:libsixel:1.0.3
-
cpe:2.3:a:saitoha:libsixel:1.1.0
-
cpe:2.3:a:saitoha:libsixel:1.1.1
-
cpe:2.3:a:saitoha:libsixel:1.1.2
-
cpe:2.3:a:saitoha:libsixel:1.1.3
-
cpe:2.3:a:saitoha:libsixel:1.1.4
-
cpe:2.3:a:saitoha:libsixel:1.1.5
-
cpe:2.3:a:saitoha:libsixel:1.2.0
-
cpe:2.3:a:saitoha:libsixel:1.2.1
-
cpe:2.3:a:saitoha:libsixel:1.2.2
-
cpe:2.3:a:saitoha:libsixel:1.2.3
-
cpe:2.3:a:saitoha:libsixel:1.3.0
-
cpe:2.3:a:saitoha:libsixel:1.3.1
-
cpe:2.3:a:saitoha:libsixel:1.3.2
-
cpe:2.3:a:saitoha:libsixel:1.3.3
-
cpe:2.3:a:saitoha:libsixel:1.3.4
-
cpe:2.3:a:saitoha:libsixel:1.3.5
-
cpe:2.3:a:saitoha:libsixel:1.3.6
-
cpe:2.3:a:saitoha:libsixel:1.4.0
-
cpe:2.3:a:saitoha:libsixel:1.4.1
-
cpe:2.3:a:saitoha:libsixel:1.4.10
-
cpe:2.3:a:saitoha:libsixel:1.4.11
-
cpe:2.3:a:saitoha:libsixel:1.4.12
-
cpe:2.3:a:saitoha:libsixel:1.4.13
-
cpe:2.3:a:saitoha:libsixel:1.4.2
-
cpe:2.3:a:saitoha:libsixel:1.4.3
-
cpe:2.3:a:saitoha:libsixel:1.4.4
-
cpe:2.3:a:saitoha:libsixel:1.4.5
-
cpe:2.3:a:saitoha:libsixel:1.4.6
-
cpe:2.3:a:saitoha:libsixel:1.4.7
-
cpe:2.3:a:saitoha:libsixel:1.4.8
-
cpe:2.3:a:saitoha:libsixel:1.4.9
-
cpe:2.3:a:saitoha:libsixel:1.5.0
-
cpe:2.3:a:saitoha:libsixel:1.5.1
-
cpe:2.3:a:saitoha:libsixel:1.5.2
-
cpe:2.3:a:saitoha:libsixel:1.5.3
-
cpe:2.3:a:saitoha:libsixel:1.6.0
-
cpe:2.3:a:saitoha:libsixel:1.6.1
-
cpe:2.3:a:saitoha:libsixel:1.7.0
-
cpe:2.3:a:saitoha:libsixel:1.7.1
-
cpe:2.3:a:saitoha:libsixel:1.7.2
-
cpe:2.3:a:saitoha:libsixel:1.7.3
-
cpe:2.3:a:saitoha:libsixel:1.8.0
-
cpe:2.3:a:saitoha:libsixel:1.8.1
-
cpe:2.3:a:saitoha:libsixel:1.8.2
-
cpe:2.3:a:saitoha:libsixel:1.8.3
-
cpe:2.3:a:saitoha:libsixel:1.8.4
-
cpe:2.3:a:saitoha:libsixel:1.8.5
-
cpe:2.3:a:saitoha:libsixel:1.8.6
-
cpe:2.3:a:saitoha:libsixel:1.8.7