CVE-2026-43894
MEDIUMjq: Wild stack write via signed-integer overflow in decNumber D2U() macro
Title source: cnaDescription
jq is a command-line JSON processor. In 1.8.1 and earlier, when decNumberFromString is given a number literal of INT_MAX-1 (2147483646) digits, the D2U() macro overflows during signed-int arithmetic. The wrapped negative value bypasses the heap-allocation size check, causes the function to use a 30-byte stack buffer, and then writes ≈715 million 16-bit units (≈1.4 GiB) at an offset 1.43 GiB below the stack frame. The written content is fully attacker-controlled (the parsed decimal digits, packed 3-per-unit).
References (1)
Core 1
Core References
X_Refsource_Confirm x_refsource_confirm
https://github.com/jqlang/jq/security/advisories/GHSA-5v7p-2r57-2g4g
Scores
CVSS v3
6.2
EPSS
0.0016
EPSS Percentile
5.3%
Attack Vector
LOCAL
CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H
CISA SSVC
Vulnrichment
Exploitation
poc
Automatable
no
Technical Impact
partial
Details
CWE
CWE-190
Status
published
Products (2)
jqlang/jq
< 1.8.1
jqlang/jq
<= 1.8.1
Published
May 11, 2026
Tracked Since
May 11, 2026