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.
 
 
 
Jakub Konka f3a5186230
Refactor poll_oneoff on *nix (#137)
5 years ago
.github/workflows Add beta & nightly builds 5 years ago
misc_testsuite@39cfd6cb71 Refactor poll_oneoff on *nix (#137) 5 years ago
src Refactor poll_oneoff on *nix (#137) 5 years ago
tests Sync with latest wasmtime rev 5 years ago
wasi-common-cbindgen Improve Cargo.toml files for publishing (#141) 5 years ago
winx Implement clock_time_get on Windows (#119) 5 years ago
.gitignore Add .vscode to .gitignore 5 years ago
.gitmodules Check out submodules in Azure 5 years ago
.rustfmt.toml Set up CI, add format and test scripts. 6 years ago
CODE_OF_CONDUCT.md Add contributing guide and code of conduct 6 years ago
CONTRIBUTING.md Add contributing guide and code of conduct 6 years ago
Cargo.toml Implement clock_time_get on Windows (#119) 5 years ago
LICENSE Extract common interface from lucet-wasi 6 years ago
LICENSE.cloudabi-utils Eliminate whitespace diffs with upstream LICENSE files. 6 years ago
README.md Add Github Actions badge to README 5 years ago
build.rs Refactor poll_oneoff on *nix (#137) 5 years ago
clippy.toml Set up CI, add format and test scripts. 6 years ago

README.md

wasi-common

build-status rustc-1.37

This repo will ultimately serve as a library providing a common implementation of WASI hostcalls for re-use in any WASI (and potentially non-WASI) runtimes such as Wasmtime and Lucet.

The library is an adaption of lucet-wasi crate from the Lucet project, and it is currently based on 40ae1df git revision.

Please note that the library requires Rust compiler version at least 1.37.0.

Supported syscalls

*nix

In our *nix implementation, we currently support the entire WASI API with the exception of socket hostcalls:

  • sock_recv
  • sock_send
  • sock_shutdown

We expect these to be implemented when network access is standardised.

We also currently do not support the proc_raise hostcall, as it is expected to be dropped entirely from WASI.

Windows

In our Windows implementation, we currently support the minimal subset of WASI API which allows for running the very basic "Hello world!" style WASM apps. More coming shortly, so stay tuned!

Development hints

When testing the crate, you may want to enable and run full wasm32 integration testsuite. This requires wasm32-wasi target installed which can be done as follows using rustup

rustup target add wasm32-wasi

Next initiate submodules containing the integration testsuite

git submodule update --init

Now, you should be able to run the integration testsuite by enabling the wasm_tests feature

cargo test --features wasm_tests

Third-Party Code

Significant parts of our hostcall implementations are derived from the C implementations in cloudabi-utils. See LICENSE.cloudabi-utils for license information.