Ecosyste.ms: Advisories
An open API service providing security vulnerability metadata for many open source software ecosystems.
Security Advisories: GSA_kwCzR0hTQS02ODQ1LXh3MjItZmZ4ds4AA5Ef
Vyper sha3 codegen bug
Summary
There is an error in the stack management when compiling the IR
for sha3_64
. Concretely, the height
variable is miscalculated.
The vulnerability can't be triggered without writing the IR
by hand. That is, it cannot be triggered from regular vyper code, it can only be triggered by using the fang
binary directly (this binary used to be called vyper-ir
prior to v0.3.4).
Details
To compile sha3_64
, the arg[0]
and arg[1]
have to be compiled:
https://github.com/vyperlang/vyper/blob/c150fc49ee9375a930d177044559b83cb95f7963/vyper/ir/compile_ir.py#L585-L586
As can be seen, after compiling the 0th arg, the height
variable isn't increased. If new withargs
are defined in the inner scope, they are manipulated correctly, because both their height
is off and also the global height
is off and thus their placement on the stack is computed correctly.
sha3_64
is used for retrieval in mappings. No flow that would cache the key
was found, the issue shouldn't be possible to trigger when compiling the compiler-generated IR
.
PoC
Suppose the following hand-written IR:
(with _loc
(with val 1
(with key 2
(sha3_64 val key)))
(seq
(sstore _loc
(with x (sload _loc)
(with ans (add x 1) (seq (assert (ge ans x)) ans))))))
after compilation:
the generated bytecode: 6001600281806020525f5260405f2090509050805460018101818110610026579050815550005b5f80fd
0000 60 PUSH1 0x01
0002 60 PUSH1 0x02
0004 81 DUP2
0005 80 DUP1 *********** bad code here!!!!!!
0006 60 PUSH1 0x20
0008 52 MSTORE
It can be seen that the second DUP
will dup the item on the top of the stack which is incorrect.
Patches
Patched in https://github.com/vyperlang/vyper/pull/4063.
Impact
Versions v0.2.0-v0.3.10 were evaluated, and access of the variable with the invalid height is not reachable from IR generated by the vyper front-end. Because the issue isn't triggered during normal compilation of vyper code, the impact is considered low.
Permalink: https://github.com/advisories/GHSA-6845-xw22-ffxvJSON: https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS02ODQ1LXh3MjItZmZ4ds4AA5Ef
Source: GitHub Advisory Database
Origin: Unspecified
Severity: Low
Classification: General
Published: 10 months ago
Updated: 5 months ago
CVSS Score: 3.7
CVSS vector: CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:L/I:N/A:N
Identifiers: GHSA-6845-xw22-ffxv, CVE-2024-24559
References:
- https://github.com/vyperlang/vyper/security/advisories/GHSA-6845-xw22-ffxv
- https://github.com/vyperlang/vyper/blob/c150fc49ee9375a930d177044559b83cb95f7963/vyper/ir/compile_ir.py#L585-L586
- https://nvd.nist.gov/vuln/detail/CVE-2024-24559
- https://github.com/vyperlang/vyper/pull/4063
- https://github.com/vyperlang/vyper/commit/d9f9fdadd81a148cbc68f02dbbbcdc0c92fad652
- https://github.com/advisories/GHSA-6845-xw22-ffxv
Blast Radius: 8.8
Affected Packages
pypi:vyper
Dependent packages: 5Dependent repositories: 236
Downloads: 73,745 last month
Affected Version Ranges: < 0.4.0
Fixed in: 0.4.0
All affected versions: 0.2.1, 0.2.2, 0.2.3, 0.2.4, 0.2.5, 0.2.6, 0.2.7, 0.2.8, 0.2.9, 0.2.10, 0.2.11, 0.2.12, 0.2.13, 0.2.14, 0.2.15, 0.2.16, 0.3.0, 0.3.1, 0.3.2, 0.3.3, 0.3.4, 0.3.5, 0.3.6, 0.3.7, 0.3.8, 0.3.9, 0.3.10
All unaffected versions: 0.4.0