Skip to content

Latest commit

 

History

History
114 lines (74 loc) · 2.63 KB

README.md

File metadata and controls

114 lines (74 loc) · 2.63 KB

flexEmu

General purpose bytecode emulator with per-step proof. It can be used to generate challenge proof of optimistic rollup, and other scenarios in blockchain which need state proof.

See more introductions here: en / zh.

Platforms

flexEmu could emulate program built with:

  • Arch: MIPS32
  • OS: Linux
  • Executable File Format: ELF 32-bit MSB

May support more in the future.

Development Environment

X86-64 Linux & Apple Silicon MacOS.

X86-64 Linux:

Fully supported, for developing and production environment. Any issue will be fixed soon.

Apple Silicon MacOS:

Not fully supported yet, only for developing.

Getting Started

The project contains three major Rust crates:

  • ./flexemu : main entrypoint of the flexEmu emulator.
  • ./rust-mips-example: examples crate. It is configured to build into a linux mips binary, which can be run by flexEmu.
  • ./flexemu-workflow: Rust binary to demonstrate how flexEmu work with onchain contracts to provide interacting fraud proof.

Prerequisites

Installing MUSL toolchains

  • Add mips-unknown-linux-musl target for rust:
rustup target add mips-unknown-linux-musl
  • Download musl toolchain from musl.cc: mips-linux-musl-cross

  • For Apple Silicon:

brew tap richard-vd/musl-cross
brew install richard-vd/musl-cross/musl-cross --without-x86_64 --with-mips

Run Example

Compile rust-mips-example:

cargo build --target mips-unknown-linux-musl --release 

Compile flexEmu:

cargo build --release

Run Example1:

RUST_LOG=error ./flexemu --config config.toml.example run --env E1=a --env E2=b ../target/mips-unknown-linux-musl/release/rust-mips-example E1 E2

Output:

Run rust-mips-example
E1=a
E2=b

Run Example2:

RUST_LOG=error ./flexemu --config config.toml.example run ../rooch/flexemu/target/mips-unknown-linux-musl/release/arith-example 1 11

Output:

thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `10`,
 right: `11`: expect 11, but got 10', rust-mips-example/src/arith_example.rs:13:5
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

License

Distributed under the Apache License 2.0. See LICENSE for more information.

Acknowledgments