🚀 A fast WebAssembly interpreter and the most universal WASM runtime
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.
 
 
 
 
 
 
Go to file
Volodymyr Shymanskyy e242879e7c
Update docs
5 years ago
.github/workflows Update tests.yml 5 years ago
extra Update docs 5 years ago
platforms Update docs 5 years ago
source Minor changes to m3_GetMemory (#46) 5 years ago
test Update run-spec-test.py 5 years ago
.gitignore Add iOS platform 5 years ago
CMakeLists.txt Fix WasiEnv build 5 years ago
DEV.md Update docs 5 years ago
LICENSE Update LICENSE 5 years ago
README.md Update docs 5 years ago

README.md

Wasm3

WAPM GitHub issues Tests status GitHub license

A high performance WebAssembly interpreter written in C.

15.8x faster than other wasm interpreters (wac, life, wasm-micro-runtime)
4..5x slower than state of the art wasm JIT engines (liftoff, cranelift)
11.5x slower than native execution
* Based on CoreMark 1.0 benchmark. Your mileage may vary.

Getting Started

Here's an online demo and a small getting started guide:

LIVE DEMO

Status

wasm3 passes the WebAssembly spec testsuite and is able to run many WASI apps.

Minimum useful system requirements: ~64Kb for code and ~10Kb RAM

wasm3 runs on a wide range of platforms:

  • Linux, Windows, OS X
  • Android, iOS
  • Raspberry Pi, Orange Pi and other SBCs
  • MCUs:
    Arduino MKR*, Arduino Due, Particle Photon,
    ESP8266, ESP32, Air602 (W600), nRF52, nRF51,
    Blue Pill (STM32F103C8T6), MXChip AZ3166 (EMW3166),
    Maix (K210), HiFive1 (E310), Fomu (ICE40UP5K), ATmega1284 etc.
  • OpenWRT-enabled routers
  • Browsers... yes, using WebAssembly itself!
  • wasm3 can execute wasm3 (self-hosting)

wasm3 is built on top of Steven Massey's novel interpreter topology, with:

  • Wasm 1.0 spec conformance
  • WASI support
  • Support of x86, x64, ARM, MIPS, RISC-V, Xtensa architectures

Building

See DEV.md

Testing & Fuzzing

See test/README.md

License

This project is released under The MIT License (MIT)