Crypt::SysRandom::XS versions before 0.010 for Perl is vulnerable to a heap buffer overflow in the XS function random_bytes().
The function does not validate that the length parameter is non-negative. If a negative value (e.g. -1) is supplied, the expression length + 1u causes an integer wraparound, resulting in a zero-byte allocation. The subsequent call to chosen random function (e.g. getrandom) passes the original negative value, which is implicitly converted to a large unsigned value (typically SIZE_MAX). This can result in writes beyond the allocated buffer, leading to heap memory corruption and application crash (denial of service).
In common usage, the length argument is typically hardcoded by the caller, which reduces the likelihood of attacker-controlled exploitation. Applications that pass untrusted input to this parameter may be affected.
References
| Link | Resource |
|---|---|
| https://metacpan.org/dist/Crypt-SysRandom-XS/changes | Release Notes |
| https://metacpan.org/release/LEONT/Crypt-SysRandom-XS-0.011/source/lib/Crypt/SysRandom/XS.xs#L51-52 | Issue Tracking |
Configurations
History
03 Mar 2026, 19:35
| Type | Values Removed | Values Added |
|---|---|---|
| References | () https://metacpan.org/dist/Crypt-SysRandom-XS/changes - Release Notes | |
| References | () https://metacpan.org/release/LEONT/Crypt-SysRandom-XS-0.011/source/lib/Crypt/SysRandom/XS.xs#L51-52 - Issue Tracking | |
| CPE | cpe:2.3:a:leont:crypt\:\:sysrandom\:\:xs:*:*:*:*:*:perl:*:* | |
| First Time |
Leont
Leont crypt\ |
27 Feb 2026, 19:16
| Type | Values Removed | Values Added |
|---|---|---|
| CVSS |
v2 : v3 : |
v2 : unknown
v3 : 7.5 |
27 Feb 2026, 14:06
| Type | Values Removed | Values Added |
|---|---|---|
| Summary |
|
27 Feb 2026, 00:16
| Type | Values Removed | Values Added |
|---|---|---|
| New CVE |
Information
Published : 2026-02-27 00:16
Updated : 2026-03-03 19:35
NVD link : CVE-2026-2597
Mitre link : CVE-2026-2597
CVE.ORG link : CVE-2026-2597
JSON object : View
Products Affected
leont
- crypt\
