SputnikVM: A Blockchain Virtual Machine

Build Status License

| Name | Description | Crates.io | Documentation | |--------------------|:---------------------------------------------:|:-------------------------------------------------------------------------------------------------------------------:|:----------------------------------------------------------------------------------------------------:| | sputnikvm | Core library for the Ethereum Virtual Machine | crates.io | Documentation | | sputnikvm-stateful | Merkle Trie stateful wrapper for SputnikVM | crates.io | Documentation |

SputnikVM is an implementation of an Ethereum Virtual Machine. It aims to be an efficient, pluggable virtual machine for different Ethereum-based blockchains.

We encourage all Ethereum'esque blockchains to adopt SputnikVM, and to make use of SputnikVM's RFC governance project which governs the parameters of each blockchain's VM. This way we can draw from the experience of the community and learn from other proposed RFCs.

Features

Supported Networks

| Network | Crates.io | Documentation | |------------------|:---------------------------------------------------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------:| | Ethereum Classic | crates.io | Documentation | | Ethereum | crates.io | Documentation | | Ellaism | crates.io | Documentation | | Ubiq | crates.io | Documentation | | Expanse | crates.io | Documentation | | Musicoin | crates.io | Documentation |

Precompiled Contracts

The core library has the initial four precompiled contracts embedded. To use the bn128 and modexp precompiled contracts introduced by the Byzantium hard fork, pull the following crates.

| Name | Description | Crates.io | Documentation | |------------------------------|:----------------------------:|:---------------------------------------------------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------------------------------------------:| | sputnikvm-precompiled-bn128 | bn128 precompiled contracts | crates.io | Documentation | | sputnikvm-precompiled-modexp | modexp precompiled contracts | crates.io | Documentation |

Related projects

Dependencies

Ensure you have at least rustc 1.26.2 (594fb253c 2018-06-01). Rust 1.25.0 and before is not supported.

Documentation

Build from sources

SputnikVM is written Rust. If you are not familiar with Rust please see the getting started guide.

Build

To start working with SputnikVM you'll need to install rustup, then you can do:

bash $ git clone git@github.com:ETCDEVTeam/sputnikvm.git $ cd sputnikvm $ cargo build --release --all

Testing

We currently use two ways to test SputnikVM and ensure its execution aligns with other Ethereum Virtual Machine implementations:

To learn more about building SputnikVM from source please read wiki page Building and Testing

License

Apache 2.0