Skip to content

WASI-enabled WebAssembly C/C++ toolchain

License

Notifications You must be signed in to change notification settings

anuraaga/wasi-sdk

This branch is 1 commit ahead of, 97 commits behind WebAssembly/wasi-sdk:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

7cb56d1 · Mar 24, 2023
Jan 19, 2023
Mar 17, 2023
Dec 1, 2020
Mar 24, 2023
Mar 23, 2023
Jan 3, 2023
Jan 2, 2023
Dec 16, 2022
Apr 20, 2020
May 27, 2020
Oct 6, 2019
Jan 2, 2023
Feb 20, 2020
Mar 23, 2023
Mar 9, 2023
Mar 9, 2023
Mar 13, 2023
Jan 2, 2023
Mar 23, 2023
Apr 7, 2020
Nov 19, 2021
Apr 26, 2022
Mar 23, 2023
Mar 23, 2023
Mar 6, 2019

Repository files navigation

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 the 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".

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

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=14
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.

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 wask-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 does not yet support threads. Specifically, WASI does not yet have an API for creating and managing threads yet, and WASI libc does not yet have pthread support.

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.

About

WASI-enabled WebAssembly C/C++ toolchain

Resources

License

Code of conduct

Stars

Watchers

Forks

Languages

  • Shell 34.5%
  • C 22.8%
  • Makefile 17.8%
  • CMake 11.0%
  • Python 6.8%
  • Dockerfile 5.9%
  • C++ 1.2%