Evmone
Fast Ethereum Virtual Machine implementation
Install / Use
/learn @ipsilon/EvmoneREADME
evmone
Fast Ethereum Virtual Machine implementation
evmone is a C++ implementation of the Ethereum Virtual Machine (EVM). Created by members of the Ipsilon (ex-Ewasm) team, the project aims for clean, standalone EVM implementation that can be imported as an execution module by Ethereum Client projects. The codebase of evmone is optimized to provide fast and efficient execution of EVM smart contracts.
Characteristic of evmone
- Exposes the EVMC API.
- Requires C++20 standard.
- The intx library is used to provide 256-bit integer precision.
- The ethash library is used to provide Keccak hash function implementation
needed for the special
KECCAK256instruction. - Contains two interpreters:
- Baseline (default)
- Advanced (select with the
advancedoption)
Baseline Interpreter
- Provides relatively straight-forward but efficient EVM implementation.
- Performs only minimalistic
JUMPDESTanalysis.
Advanced Interpreter
- The indirect call threading is the dispatch method used - a loaded EVM program is a table with pointers to functions implementing virtual instructions.
- The gas cost and stack requirements of block of instructions is precomputed and applied once per block during execution.
- Performs extensive and expensive bytecode analysis before execution.
Usage
As geth plugin
evmone implements the EVMC API for Ethereum Virtual Machines. It can be used as a plugin replacing geth's internal EVM. But for that a modified version of geth is needed. The Ewasm's fork of go-ethereum provides binary releases of geth with EVMC support.
Next, download evmone from Releases.
Start the downloaded geth with --vm.evm option pointing to the evmone shared library.
geth --vm.evm=./libevmone.so
Building from source
To build the evmone EVMC module (shared library), test, and benchmark:
-
Fetch the source code:
git clone --recursive https://github.com/ethereum/evmone cd evmone -
Configure the project build and dependencies:
Linux / OSX
cmake -S . -B build -DEVMONE_TESTING=ONWindows
cmake -S . -B build -DEVMONE_TESTING=ON -G "Visual Studio 16 2019" -A x64 -
Build:
cmake --build build --parallel -
Run the unit tests or benchmarking tool:
build/bin/evmone-unittests build/bin/evmone-bench test/evm-benchmarks/benchmarks
Precompiles
Ethereum Precompiled Contracts (precompiles for short) are supported by evmone with some exceptions:
- The
ecrecoveris implemented directly by evmone and has degraded performance. - For
expmodstubs are enabled by default — they will correctly respond to known inputs. The CMake optionEVMONE_PRECOMPILES_GMP=1enables full implementation but this requires GMP (e.g. libgmp-dev) library at build and execution time.
Tools
evm-test
The evm-test executes a collection of unit tests on any EVMC-compatible Ethereum Virtual Machine implementation. The collection of tests comes from the evmone project.
evm-test ./evmone.so
Docker
Docker images with evmone are available on Docker Hub: https://hub.docker.com/r/ethereum/evmone.
Having the evmone shared library inside a docker is not very useful on its own, but the image can be used as the base of another one or you can run benchmarks with it.
docker run --entrypoint evmone-bench ethereum/evmone /src/test/benchmarks
References
Maintainer
Paweł Bylica @chfast
License
Licensed under the Apache License, Version 2.0.
