CVE-2025-15646: HTML::Gumbo versions before 0.19 for Perl disclose heap memory via type confusion
Robert Rothenberg 01 Jul 2026 14:40 UTC
========================================================================
CVE-2025-15646 CPAN Security Group
========================================================================
CVE ID: CVE-2025-15646
Distribution: HTML-Gumbo
Versions: before 0.19
MetaCPAN: https://metacpan.org/dist/HTML-Gumbo
VCS Repo: https://github.com/bestpractical/HTML-Gumbo
HTML::Gumbo versions before 0.19 for Perl disclose heap memory via type
confusion
Description
-----------
HTML::Gumbo versions before 0.19 for Perl disclose heap memory via type
confusion.
Support for the <template> element was added to libgumbo 0.10.0 in
2015, but the walk_tree function in lib/HTML/Gumbo.xs was not updated
to support it. The element was treated as a text-node, where strlen()
over-reads the heap block that the pointer addresses.
Any caller that runs parse() with the default format => 'string', or
with format => 'tree', on input containing a <template> element
serializes the over-read bytes into the returned result, disclosing
bounded heap contents. format => 'callback' reaches a croak on the
unhandled node type and is unaffected.
Problem types
-------------
- CWE-843 Access of Resource Using Incompatible Type (Type Confusion)
- CWE-125 Out-of-bounds Read
Solutions
---------
Upgrade to HTML-Gumbo 0.19 or later, which adds GUMBO_NODE_TEMPLATE to
the container node types handled by walk_tree.
References
----------
https://github.com/bestpractical/HTML-Gumbo/commit/15c0598909d4a64f47ef0a1abc5051f4e113c186.patch
https://metacpan.org/release/BPS/HTML-Gumbo-0.19/changes
https://bugs.debian.org/1104789
Timeline
--------
- 2015-04-30: Gumbo 0.10.0 released with support for the <template>
element.
- 2025-05-06: Reported to the Debian bug tracker (#1104789).
- 2025-05-17: Fix committed upstream.
- 2026-05-21: Version 0.19 released with fix.
Credits
-------
Vincent Lefevre, finder
Niko Tyni, remediation developer