CVE-2023-44378

Source
https://nvd.nist.gov/vuln/detail/CVE-2023-44378
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2023-44378.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2023-44378
Aliases
Published
2023-10-09T13:33:54Z
Modified
2025-10-22T18:39:27.023364Z
Severity
  • 7.1 (High) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:C/C:N/I:H/A:N CVSS Calculator
Summary
gnark vulnerable to unsoundness in variable comparison/non-unique binary decomposition
Details

gnark is a zk-SNARK library that offers a high-level API to design circuits. Prior to version 0.9.0, for some in-circuit values, it is possible to construct two valid decomposition to bits. In addition to the canonical decomposition of a, for small values there exists a second decomposition for a+r (where r is the modulus the values are being reduced by). The second decomposition was possible due to overflowing the field where the values are defined. Upgrading to version 0.9.0 should fix the issue without needing to change the calls to value comparison methods.

Database specific
{
    "cwe_ids": [
        "CWE-191",
        "CWE-697"
    ]
}
References

Affected packages

Git / github.com/consensys/gnark

Affected ranges

Type
GIT
Repo
https://github.com/consensys/gnark
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed

Affected versions

v0.*

v0.1.0-alpha
v0.2.0-alpha
v0.2.1-alpha
v0.3.0
v0.3.0-alpha
v0.3.1
v0.3.3
v0.3.4
v0.3.5
v0.3.6
v0.3.7
v0.3.8
v0.4.0
v0.5.0
v0.5.1
v0.5.2
v0.6.0
v0.6.1
v0.6.2
v0.6.3
v0.6.4
v0.7.0
v0.7.1
v0.8.0
v0.8.1
v0.9.0-alpha