WASI-enabled WebAssembly C/C++ toolchain
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
Joel Dice 7ff81cb10c
add wasi-sdk-p2.cmake (#430)
7 months ago
.github/workflows Force-fetch tags in CI to fix `git describe` 9 months ago
ci exclude 32-bit Windows artifact in download-workflow-artifacts.sh (#417) 9 months ago
cmake/Platform Update how wasi-sdk uses cmake (#161) 4 years ago
docker add wasi-sdk-p2.cmake (#430) 7 months ago
src Add DWARF debugging information to all artifacts by default (#422) 8 months ago
tests Add DWARF debugging information to all artifacts by default (#422) 8 months ago
.dockerignore Enable ccache for CI builds of LLVM (#277) 2 years ago
.gitattributes Add a .gitattributes file to make *.sh files use LF line endings. (#267) 2 years ago
.gitignore Fix windows SDK builds (#126) 5 years ago
.gitmodules add shared library support (#338) 1 year ago
CODE_OF_CONDUCT.md Add a CODE_OF_CONDUCT.md file. 5 years ago
Dockerfile Update LLVM to 18.1.2 and add wasm-component-ld (#402) 10 months ago
LICENSE Add a LICENSE file, "Apache-2.0 WITH LLVM-exception". (#100) 5 years ago
Makefile add wasi-sdk-p2.cmake (#430) 7 months ago
README.md add python3 as build requirement (#415) 9 months ago
RELEASING.md Replace multiple version scripts with a Python script 10 months ago
deb_from_installation.sh Replace multiple version scripts with a Python script 10 months ago
docker_build.sh Thread UID/GID through Docker 10 months ago
strip_symbols.sh Do not use GNU find features on FreeBSD (#345) 1 year ago
tar_from_installation.sh Replace multiple version scripts with a Python script 10 months ago
version.py Don't add git hash to version if minor==0 (#409) 9 months ago
wasi-sdk-p2.cmake add wasi-sdk-p2.cmake (#430) 7 months ago
wasi-sdk-pthread.cmake Enhancement of WASI_SDK_PREFIX in toolchain files (#349) 1 year ago
wasi-sdk.cmake Enhancement of WASI_SDK_PREFIX in toolchain files (#349) 1 year ago
wasi-sdk.control initial commit 6 years ago

README.md

WASI SDK

Quick Start

Download SDK packages here.

About this repository

This repository contains no compiler or library code itself; it uses git submodules to pull in the upstream Clang and LLVM tree, as well as the wasi-libc tree.

The libc portion of this SDK is maintained in wasi-libc.

Upstream Clang and LLVM (from 9.0 onwards) can compile for WASI out of the box, and WebAssembly support is included in them by default. So, all that's done here is to provide builds configured to set the default target and sysroot for convenience.

One could also use a standard Clang installation, build a sysroot from the sources mentioned above, and compile with --target=wasm32-wasi --sysroot=/path/to/sysroot. In this scenario, one would also need the libclang_rt.builtins-wasm32.a objects available separately in the release downloads which must be extracted into $CLANG_INSTALL_DIR/$CLANG_VERSION/lib/wasi/.

Clone

This repository uses git submodule, to clone it you need use the command below :

git clone --recursive https://github.com/WebAssembly/wasi-sdk.git

Requirements

The Wasm-sdk's build process needs some packages :

  • cmake
  • clang
  • ninja
  • python3

Please refer to your OS documentation to install those packages.

Build

To build the full package:

cd wasi-sdk
NINJA_FLAGS=-v make package

The built package can be found into dist directory. For releasing a new version of the package on GitHub, see RELEASING.md.

Install

A typical installation from the release binaries might look like the following:

export WASI_VERSION=20
export WASI_VERSION_FULL=${WASI_VERSION}.0
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-${WASI_VERSION}/wasi-sdk-${WASI_VERSION_FULL}-linux.tar.gz
tar xvf wasi-sdk-${WASI_VERSION_FULL}-linux.tar.gz

Use

Use the clang installed in the wasi-sdk directory:

export WASI_SDK_PATH=`pwd`/wasi-sdk-${WASI_VERSION_FULL}
CC="${WASI_SDK_PATH}/bin/clang --sysroot=${WASI_SDK_PATH}/share/wasi-sysroot"
$CC foo.c -o foo.wasm

Note: ${WASI_SDK_PATH}/share/wasi-sysroot contains the WASI-specific includes/libraries/etc. The --sysroot=... option is not necessary if WASI_SDK_PATH is /opt/wasi-sdk. For troubleshooting, one can replace the --sysroot path with a manual build of wasi-libc.

Integrating with a CMake build system

Use a toolchain file to setup the wasi-sdk platform.

$ cmake -DCMAKE_TOOLCHAIN_FILE=${WASI_SDK_PATH}/share/cmake/wasi-sdk.cmake ...

or the wasi-sdk-thread platform

$ cmake -DCMAKE_TOOLCHAIN_FILE=${WASI_SDK_PATH}/share/cmake/wasi-sdk-pthread.cmake ...

Notes for Autoconf

Autoconf 2.70 now recognizes WASI.

For convenience when building packages that aren't yet updated, updated config.sub and config.guess files are installed at share/misc/config.* in the install directory.

Docker Image

We provide a docker image including WASI SDK that can be used for building projects without a separate installation of the SDK. Autotools, CMake, and Ninja are included in this image, and standard environment variables are set to use WASI SDK for building.

For example, this command can build a make-based project with the Docker image.

docker run -v `pwd`:/src -w /src ghcr.io/webassembly/wasi-sdk make

Take note of the notable limitations below when building projects, for example many projects will need threads support disabled in a configure step before building with WASI SDK.

Notable Limitations

This repository does not yet support C++ exceptions. C++ code is supported only with -fno-exceptions for now. Similarly, there is not yet support for setjmp/longjmp. Work on support for exception handling is underway at the language level which will support both of these features.

This repository experimentally supports threads with --target=wasm32-wasi-threads. It uses WebAssembly's threads primitives (atomics, wait/notify, shared memory) and wasi-threads for spawning threads. Note: this is experimental — do not expect long-term stability!

This repository does not yet support dynamic libraries. While there are some efforts to design a system for dynamic libraries in wasm, it is still in development and not yet generally usable.

There is no support for networking. It is a goal of WASI to support networking in the future though.