CVE-2026-5089 PUBLISHED

YAML::Syck versions before 1.38 for Perl has an out-of-bounds read

Assigner: CPANSec
Reserved: 28.03.2026 Published: 12.05.2026 Updated: 12.05.2026

YAML::Syck versions before 1.38 for Perl has an out-of-bounds read.

The base60 (sexagesimal) parsing code in perl_syck.h has a buffer underflow bug in both int#base60 and float#base60 handlers. When processing the leftmost segment of a colon-separated value (e.g., the 1 in 1:30:45), the inner while loop can decrement a pointer past the start of the string buffer:

<pre>while ( colon >= ptr && *colon != ':' ) { colon--; } if ( *colon == ':' ) *colon = '\0'; // colon may be ptr-1 here </pre>

When no colon is found (final/leftmost segment), colon becomes ptr-1, and the subsequent *colon dereference reads one byte before the allocated buffer.

Product Status

Vendor TODDR
Product YAML::Syck
Versions Default: unaffected
  • affected from 0 to 1.38 (excl.)

Solutions

Upgrade to YAML::Syck version 1.38 or later.

References

Problem Types

  • CWE-124 Buffer Underwrite ('Buffer Underflow') CWE