You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Alex Crichton 4933762d81
Add release notes for 3.0.1 and update some versions (#5364)
2 years ago
..
ocaml fuzz: improve the spec interpreter (#4881) 2 years ago
src fuzz: improve the spec interpreter (#4881) 2 years ago
tests fuzz: improve the spec interpreter (#4881) 2 years ago
Cargo.toml Add release notes for 3.0.1 and update some versions (#5364) 2 years ago
README.md fuzz: improve wasm-spec-interpreter documentation, add library path (#4007) 3 years ago
build.rs fuzz: improve the spec interpreter (#4881) 2 years ago

README.md

wasm-spec-interpreter

This project shows how to use ocaml-interop to call into the Wasm spec interpreter. There are several steps to making this work:

  • building the OCaml Wasm spec interpreter as a static library
  • building a Rust-to-OCaml FFI bridge using ocaml-interop and a custom OCaml wrapper
  • linking both things into a Rust crate

Dependencies

This crate only builds in an environment with:

  • make (the Wasm spec interpreter uses a Makefile)
  • ocamlopt, ocamlbuild (available with, e.g., dnf install ocaml)
  • Linux tools (e.g. ar); currently it is easiest to build the static libraries in a single environment but this could be fixed in the future (TODO)
  • libgmp, for the OCaml zarith package
  • git is used by build.rs to retrieve the repository containing the Wasm spec interpreter; it is safe to completely remove ocaml/spec to get a new copy

Build

cargo build --features build-libinterpret

Use FFI_LIB_DIR=path/to/lib/... to specify a different location for the static library (this is mainly for debugging). If the build-libinterpret feature is not provided, this crate will build successfully but fail at runtime.

Test

cargo test --features build-libinterpret