Appendix C. Complete WAMR Guide
WebAssembly Micro Runtime
A Bytecode Alliance project
Build WAMR | Build AOT Compiler | Embed WAMR | Export Native API | Build Wasm Apps | Samples
WebAssembly Micro Runtime (WAMR) is a lightweight standalone WebAssembly (Wasm) runtime with small footprint, high performance and highly configurable features for applications cross from embedded, IoT, edge to Trusted Execution Environment (TEE), smart contract, cloud native and so on. It includes a few parts as below:
VMcore: A set of runtime libraries for loading and running Wasm modules. It supports rich running modes including interpreter, Ahead-of-Time compilation(AoT) and Just-in-Time compilation (JIT). WAMR supports two JIT tiers - Fast JIT, LLVM JIT, and dynamic tier-up from Fast JIT to LLVM JIT.
iwasm: The executable binary built with WAMR VMcore which supports WASI and command line interface.
wamrc: The AOT compiler to compile Wasm file into AOT file
Useful components and tools for building real solutions with WAMR vmcore:
App-framework: A framework for supporting APIs for the Wasm applications
App-manager: A framework for dynamical loading the Wasm module remotely
WAMR-IDE: An experimental VSCode extension for developping WebAssembly applications with C/C++
Key features
Full compliant to the W3C Wasm MVP
Small runtime binary size (core vmlib on cortex-m4f with tail-call/bulk memroy/shared memroy support, text size from bloaty)
~58.9K for fast interpreter
~56.3K for classic interpreter
~29.4K for aot runtime
~21.4K for libc-wasi library
~3.7K for libc-builtin library
Near to native speed by AOT and JIT
Self-implemented AOT module loader to enable AOT working on Linux, Windows, MacOS, Android, SGX and MCU systems
Choices of Wasm application libc support: the built-in libc subset for the embedded environment or WASI for the standard libc
Multiple modules as dependencies, ref to document and sample
wasi-threads, ref to document and sample
Source debugging support, ref to document
Berkeley/Posix Socket support, ref to document and sample
Wasm post-MVP features
wasm-c-api, ref to document and sample
128-bit SIMD, ref to samples/workload
Reference Types, ref to document and sample
Supported architectures and platforms
The WAMR VMcore supports the following architectures:
X86-64, X86-32
ARM, THUMB (ARMV7 Cortex-M7 and Cortex-A15 are tested)
AArch64 (Cortex-A57 and Cortex-A53 are tested)
RISCV64, RISCV32 (RISC-V LP64 and RISC-V LP64D are tested)
XTENSA, MIPS, ARC
The following platforms are supported, click each link below for how to build iwasm on that platform. Refer to WAMR porting guide for how to port WAMR to a new platform.
Getting started
Samples and Benchmarks
Performance and memory
Memory usage tuning: the memory model and how to tune the memory usage
Memory usage profiling: how to profile the memory usage
Performance tuning: how to tune the performance
Benchmarks: checkout these links for how to run the benchmarks: PolyBench, CoreMark, Sightglass, JetStream2
Performance and footprint data: the performance and footprint data
Project Technical Steering Committee
The WAMR PTSC Charter governs the operations of the project TSC. The current TSC members:
dongsheng28849455 - Dongsheng Yan, dongsheng.yan@sony.com
loganek - Marcin Kolny, mkolny@amazon.co.uk
lum1n0us - Liang He, liang.he@intel.com
no1wudi Qi Huang, huangqi3@xiaomi.com
qinxk-inter - Xiaokang Qin, xiaokang.qxk@antgroup.com
ttrenner - Trenner, Thomas, trenner.thomas@siemens.com
wei-tang - Wei Tang, tangwei.tang@antgroup.com
wenyongh - Wenyong Huang, wenyong.huang@intel.com
woodsmc - Woods, Chris, chris.woods@siemens.com
xujuntwt95329 - Jun Xu, Jun1.Xu@intel.com
xwang98 - Xin Wang, xin.wang@intel.com (chair)
yamt - Takashi Yamamoto, yamamoto@midokura.com
License
WAMR uses the same license as LLVM: the Apache 2.0 license
with the LLVM exception. See the LICENSE file for details. This license allows you to freely use, modify, distribute and sell your own products based on WAMR. Any contributions you make will be under the same license.
More resources
Last updated