Advisory Database
  • Advisories
  • Dependency Scanning
  1. golang
  2. ›
  3. github.com/tharsis/evmos/v2
  4. ›
  5. CVE-2024-32644

CVE-2024-32644: Evmos transaction execution not accounting for all state transition after interaction with precompiles

April 10, 2024 (updated April 19, 2024)

An external contributor, @iczc, discovered 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.

Below, are described the steps to perform the attack:

  • User send a tx to a smart contract (SC) that is calling a precompile.
  • The SC perform a state transition of its state from A to B.
  • The SC call the precompile.
  • The SC perform a state transition of its state from B to A (revert of the previous).
  • Once the transaction is executed, and the final Commit is performed, the state A will not be committed to the store because A is the same as originStorage.

If the tx is executed correctly, this is what happens at the store level:

  • Initial state A is loaded from the KVStore and the dirtyStorage is set to B.
  • Before running the precompile, the dirtyStorage is committed to the KVStore without changing the originStorage.
  • Now, since we have a dirtyStorage, it is updated to the previous value A without changing the originStorage.

Since the tx executed correctly, the evm calls the commit to persist the dirtyStorage. However, since dirtyStorage is equal to originStorage, nothing will be changed.

To summarize, 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.

References

  • github.com/advisories/GHSA-3fp5-2xwh-fxm6
  • github.com/evmos/evmos
  • github.com/evmos/evmos/blob/b196a522ba4951890b40992e9f97aa610f8b5f9c/x/evm/statedb/state_object.go
  • github.com/evmos/evmos/blob/b196a522ba4951890b40992e9f97aa610f8b5f9c/x/evm/statedb/statedb.go
  • github.com/evmos/evmos/blob/b196a522ba4951890b40992e9f97aa610f8b5f9c/x/evm/statedb/statedb.go
  • github.com/evmos/evmos/commit/08982b5ee726b97bc50eaf58d1914829648b6a5f
  • github.com/evmos/evmos/security/advisories/GHSA-3fp5-2xwh-fxm6
  • nvd.nist.gov/vuln/detail/CVE-2024-32644

Code Behaviors & Features

Detect and mitigate CVE-2024-32644 with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions up to 2.0.2

Solution

Unfortunately, there is no solution available yet.

Impact 9.1 CRITICAL

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:H

Learn more about CVSS

Weakness

  • CWE-662: Improper Synchronization

Source file

go/github.com/tharsis/evmos/v2/CVE-2024-32644.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Sun, 26 Oct 2025 12:19:38 +0000.