CVE-2024-32644
CVSS V2 None
CVSS V3 None
Description
Evmos is a scalable, high-throughput Proof-of-Stake EVM blockchain that is fully compatible and interoperable with Ethereum. Prior to 17.0.0, there is a way to mint arbitrary tokens due to the possibility to have two different states not in sync during the execution of a transaction. The exploit is based on the fact that to sync the Cosmos SDK state and the EVM one, we rely on the `stateDB.Commit()` method. When we call this method, we iterate though all the `dirtyStorage` and, **if and only if** it is different than the `originStorage`, we set the new state. Setting the new state means we update the Cosmos SDK KVStore. If a contract storage state that is the same before and after a transaction, but is changed during the transaction and can call an external contract after the change, it can be exploited to make the transaction similar to non-atomic. The vulnerability is **critical** since this could lead to drain of funds through creative SC interactions. The issue has been patched in versions >=V17.0.0.
Overview
- CVE ID
- CVE-2024-32644
- Assigner
- GitHub_M
- Vulnerability Status
- PUBLISHED
- Published Version
- 2024-04-19T14:53:44.423Z
- Last Modified Date
- 2024-06-04T17:51:58.104Z
Weakness Enumerations
References
Reference URL | Reference Tags |
---|---|
https://github.com/evmos/evmos/security/advisories/GHSA-3fp5-2xwh-fxm6 | x_refsource_CONFIRM |
https://github.com/evmos/evmos/commit/08982b5ee726b97bc50eaf58d1914829648b6a5f | x_refsource_MISC |
https://github.com/evmos/evmos/blob/b196a522ba4951890b40992e9f97aa610f8b5f9c/x/evm/statedb/statedb.go#L460-L465 | x_refsource_MISC |
Sources
Source Name | Source URL |
---|---|
NIST | https://nvd.nist.gov/vuln/detail/CVE-2024-32644 |
MITRE | https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2024-32644 |
History
Created | Old Value | New Value | Data Type | Notes |
---|---|---|---|---|
2024-06-26 08:44:29 | Added to TrackCVE |