Goal Reached Thanks to every supporter — we hit 100%!

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

CVE-2026-33023— libsixel: Use-after-free in load_with_gdkpixbuf()

CVSS 7.8 · High EPSS 0.01% · P0
Get alerts for future matching vulnerabilitiesLog in to subscribe

I. Basic Information for CVE-2026-33023

Vulnerability Information

Have questions about the vulnerability? See if Shenlong's analysis helps!
View Shenlong Deep Dive ↗

Although we use advanced large model technology, its output may still contain inaccurate or outdated information.Shenlong tries to ensure data accuracy, but please verify and judge based on the actual situation.

Vulnerability Title
libsixel: Use-after-free in load_with_gdkpixbuf()
Source: NVD (National Vulnerability Database)
Vulnerability Description
libsixel is a SIXEL encoder/decoder implementation derived from kmiya's sixel. In versions 1.8.7 and prior, when built with the --with-gdk-pixbuf2 option, a use-after-free vulnerability exists in load_with_gdkpixbuf() in loader.c. The cleanup path manually frees the sixel_frame_t object and its internal buffers without consulting the reference count, even though the object was created via the refcounted constructor sixel_frame_new() and exposed to the public callback. A callback that calls sixel_frame_ref(frame) to retain a logically valid reference will hold a dangling pointer after sixel_helper_load_image_file() returns, and any subsequent access to the frame or its fields triggers a use-after-free confirmed by AddressSanitizer. The root cause is a consistency failure between two cleanup strategies in the same codebase: sixel_frame_unref() is used in load_with_builtin() but raw free() is used in load_with_gdkpixbuf(). An attacker supplying a crafted image to any application built against libsixel with gdk-pixbuf2 support can trigger this reliably, potentially leading to information disclosure, memory corruption, or code execution. This issue has been fixed in version 1.8.7-r1.
Source: NVD (National Vulnerability Database)
CVSS Information
CVSS:3.1/AV:L/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H
Source: NVD (National Vulnerability Database)
Vulnerability Type
释放后使用
Source: NVD (National Vulnerability Database)
Vulnerability Title
libsixel 资源管理错误漏洞
Source: CNNVD (China National Vulnerability Database)
Vulnerability Description
libsixel是Hayaki Saito个人开发者的一个为DEC SIXEL图形和其他转换器程序提供编码/解码实现的软件包。 libsixel 1.8.7及之前版本存在资源管理错误漏洞,该漏洞源于使用--with-gdk-pixbuf2选项构建时,load_with_gdkpixbuf函数存在释放后重用问题,可能导致处理特制图像时触发释放后重用,造成信息泄露、内存损坏或代码执行。
Source: CNNVD (China National Vulnerability Database)
CVSS Information
N/A
Source: CNNVD (China National Vulnerability Database)
Vulnerability Type
N/A
Source: CNNVD (China National Vulnerability Database)

Affected Products

VendorProductAffected VersionsCPESubscribe
saitohalibsixel < 1.8.7-r1 -

II. Public POCs for CVE-2026-33023

#POC DescriptionSource LinkShenlong Link
AI-Generated POCPremium

No public POC found.

Login to generate AI POC

III. Intelligence Information for CVE-2026-33023

登录查看更多情报信息。

Same Patch Batch · saitoha · 2026-04-14 · 5 CVEs total

CVE-2026-330217.3 HIGHlibsixel: Use-after-free in sixel_encoder_encode_bytes()
CVE-2026-330197.1 HIGHlibsixel: Integer overflow leads to Out-of-bounds Read in img2sixel
CVE-2026-330207.1 HIGHlibsixel: Integer Overflow in write_png_to_file() leads to Heap-based Buffer Overflow
CVE-2026-330187.0 HIGHlibsixel: Use-After-Free in load_gif()

IV. Related Vulnerabilities

V. Comments for CVE-2026-33023

No comments yet


Leave a comment