Text::CSV_XS versions before 1.62 for Perl have a use-after-free when registered callbacks extend the Perl argument stack, which may enable type confusion or memory corruption.

The Parse, print, getline, and getline_all methods invoke registered callbacks (for example after_parse, before_print, or on_error) and cache the Perl argument stack pointer across the call. If a callback extends the argument stack enough to trigger a reallocation, the return value is written through the stale pointer into the freed buffer, and the caller reads the original $self argument as the return value instead.

Calling code that expects parsed data from getline_all receives the Text::CSV_XS object in its place, leading to logic errors or crashes. Text::CSV_XS objects used without any registered callbacks are not affected.

Project Subscriptions

No data.

Advisories

No advisories yet.

Fixes

Solution

Upgrade to 1.62 or later.


Workaround

No workaround given by the vendor.

History

Wed, 29 Apr 2026 14:45:00 +0000

Type Values Removed Values Added
Description Text::CSV_XS versions before 1.62 for Perl have a use-after-free when registered callbacks extend the Perl argument stack, which may enable type confusion or memory corruption. The Parse, print, getline, and getline_all methods invoke registered callbacks (for example after_parse, before_print, or on_error) and cache the Perl argument stack pointer across the call. If a callback extends the argument stack enough to trigger a reallocation, the return value is written through the stale pointer into the freed buffer, and the caller reads the original $self argument as the return value instead. Calling code that expects parsed data from getline_all receives the Text::CSV_XS object in its place, leading to logic errors or crashes. Text::CSV_XS objects used without any registered callbacks are not affected.
Title Text::CSV_XS versions before 1.62 for Perl have a use-after-free when registered callbacks extend the Perl argument stack, which may enable type confusion or memory corruption
Weaknesses CWE-416
CWE-825
References

Projects

Sign in to view the affected projects.

cve-icon MITRE

Status: PUBLISHED

Assigner: CPANSec

Published:

Updated: 2026-04-29T14:22:29.358Z

Reserved: 2026-04-26T15:31:25.111Z

Link: CVE-2026-7111

cve-icon Vulnrichment

No data.

cve-icon NVD

Status : Received

Published: 2026-04-29T15:16:09.183

Modified: 2026-04-29T15:16:09.183

Link: CVE-2026-7111

cve-icon Redhat

No data.

cve-icon OpenCVE Enrichment

No data.

Weaknesses