Skip to content
πŸš€ The fastest WebAssembly interpreter (and the most universal wasm runtime)
C Objective-C C++ HTML Python CMake Other
Branch: master
Clone or download

Latest commit

Latest commit eb57b07 Jun 3, 2020

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github/workflows Reduce timeout again Jun 2, 2020
docs Add SparkFun Artemis Mar 26, 2020
extra Blacklist some tests for Win32 x86 builds Mar 11, 2020
platforms Update ESP32 WASI implementation. Fix #140 Jun 2, 2020
source Support MinGW. Fix #146 Jun 2, 2020
test Improve remote testing (use :load-hex to load spec test binaries) May 29, 2020
.gitignore Add iOS platform Jan 10, 2020
CMakeLists.txt Support MinGW. Fix #146 Jun 2, 2020
LICENSE Update LICENSE Nov 9, 2019
README.md Update README.md Apr 24, 2020

README.md

Wasm3

WAPM GitHub issues Tests status GitHub license

A high performance WebAssembly interpreter written in C.

∼ 8x faster than other known wasm interpreters
∼ 4-5x slower than state of the art wasm JIT engines
∼ 12x slower than native execution
* Based on CoreMark 1.0 benchmark. Your mileage may vary.

Twitter Discord Telegram

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 architectures (x86, x86_64, ARM, RISC-V, PowerPC, MIPS, Xtensa, ARC32, ...) and platforms:

  • Linux, Windows, OS X, FreeBSD
  • Android, iOS
  • OpenWRT-enabled routers
  • Raspberry Pi, Orange Pi and other SBCs
  • MCUs: Arduino, ESP8266, ESP32, Particle, ... see full list
  • Browsers... yes, using WebAssembly itself!
  • wasm3 can execute wasm3 (self-hosting)

Post-MVP features support

β˜‘ Sign-extension operators
β˜‘ Non-trapping float-to-int conversions
� Bulk memory operations
� Multi-value
� Import/Export of Mutable Globals
� Tail call
� Fixed-width SIMD

Libraries

Wasm3 can be used as a library for:

C/C++ β”‚ GoLang β”‚ Rust β”‚ Arduino, PlatformIO, Particle

Motivation

Why use a "slow interpreter" versus a "fast JIT"?

In many situations, speed is not the main concern. Runtime executable size, code density, memory usage, startup latency can be all improved with the interpreter approach. Portability and security are much easier to achieve and maintain. Additionally, development impedance is much lower. A simple library like Wasm3 is easy to compile and integrate into an existing project. (Wasm3 builds in a just few seconds). Finally, on some platforms (i.e. iOS and WebAssembly itself) you can't generate executable code pages in runtime, so JIT is unavailable.

Why would you want to run WASM on microcontrollers?

Wasm3 started as a research project and remains so by many means. Evaluating the engine in different environments is part of the research. Given that we have Lua, JS, Python, Lisp, ... running on MCUs, WebAssembly is actually a promising alternative. It provides toolchain decoupling as well as a completely sandboxed, well-defined, predictible environment. Among practical use cases we can list edge computing, scripting, running IoT rules, smart contracts, etc.

Further Resources

Demos
Build and Development instructions
Supported Hardware
Testing & Fuzzing
Performance
Interpreter Architecture
Logging

License

This project is released under The MIT License (MIT)

You can’t perform that action at this time.