CVE-2026-43894
jq: Wild stack write via signed-integer overflow in decNumber D2U() macro
Published:
5/11/2026
Last updated:
5/11/2026
Reserved:
5/4/2026
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).
CNA assigner:
GitHub_M (a0819718-46f1-4df5-94e2-005712e83aaa)
Requested by:
n/a
Products affected (1)
| Product |
Vendor |
Version |
| jq |
jqlang
|
2.5.1
|