CVE-2024-32481
Description
Vyper is a pythonic Smart Contract Language for the Ethereum virtual machine. Starting in version 0.3.8 and prior to version 0.4.0b1, when looping over a range of the form range(start, start + N), if start is negative, the execution will always revert. This issue is caused by an incorrect assertion inserted by the code generation of the range stmt.parse_For_range(). The issue arises when start is signed, instead of using sle, le is used and start is interpreted as an unsigned integer for the comparison. If it is a negative number, its 255th bit is set to 1 and is hence interpreted as a very large unsigned integer making the assertion always fail. Any contract having a range(start, start + N) where start is a signed integer with the possibility for start to be negative is affected. If a call goes through the loop while supplying a negative start the execution will revert. Version 0.4.0b1 fixes the issue.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
vyperPyPI | >= 0.3.8, < 0.4.0 | 0.4.0 |
Affected products
2Patches
Vulnerability mechanics
References
6- github.com/vyperlang/vyper/commit/3de1415ee77a9244eb04bdb695e249d3ec9ed868nvdPatchWEB
- github.com/vyperlang/vyper/commit/5319cfbe14951e007ccdb323257e5ada869b35d5nvdPatchWEB
- github.com/vyperlang/vyper/security/advisories/GHSA-ppx5-q359-pvwjnvdExploitVendor AdvisoryWEB
- github.com/advisories/GHSA-ppx5-q359-pvwjghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2024-32481ghsaADVISORY
- github.com/vyperlang/vyper/blob/9136169468f317a53b4e7448389aa315f90b95ba/vyper/codegen/stmt.pynvdProductWEB
News mentions
0No linked articles in our index yet.