Wasm工具安装使用

[TOC]

编译工具

Emscripten是一个编译C,C++到wasm文件的工具链,安装过程如下:

git clone [https://github.com/juj/emsdk.git](https://github.com/juj/emsdk.git)
cd emsdk
./emsdk install --build=Release sdk-incoming-64bit binaryen-master-64bit
./emsdk activate --global --build=Release sdk-incoming-64bit binaryen-master-64bit
source ./emsdk_env.sh

参考链接: https://developer.mozilla.org/zh-CN/docs/WebAssembly/C_to_wasm 此时就可以使用emcc命令编译一个文件了:

emcc hello.c -s WASM=1 -o hello.html

然后使用emrun来实现浏览器的显示:

emrun --no_browser --port 8080 .

通过浏览器打开http://localhost:8080/hello.html 就可以看到输出信息了。

运行工具

可以运行wasm的工具有多个,C++ 版本有两个:

[https://github.com/AndrewScheidecker/WAVM](https://github.com/AndrewScheidecker/WAVM)
[https://github.com/WebAssembly/wabt](https://github.com/WebAssembly/wabt)

前者功能更强大一些,后者是官方的解析工具。

pct@Chandler:~/workspace/ABA/Codes/wasm$ ls WAVM/cmake-build-debug/bin/


Assemble Disassemble HashMapTest HashSetTest Test wavix wavm

wavm可以运行wasm文件。并且支持部分c库函数,如printf,即它在内部对env作了一部分处理。

pct@Chandler:~/workspace/ABA/Codes/wasm$ ls wabt/bin/


spectest-interp wabt-unittests wasm2c wasm2wat wasm-interp wasm-objdump wasm-opcodecnt wasm-validate wast2json wat2wasm wat-desugar

wasm-interp工具可以执行wasm文件。不支持printf函数。 go版本的有一个:

https://github.com/go-interpreter/wagon

它可以编译出两个工具:

pct@Chandler:~/go/src/github.com/go-interpreter/wagon/cmd$ tree


.



├── wasm-dump



│   ├── hex.go



│   ├── main



│   └── main.go



└── wasm-run



    ├── basic.wasm



    ├── hello.wasm



    ├── main

wasm-run可以执行wasm文件,不支持c库函数,也不支持参数,需要自己添加。

调试工具

我们可以通过hexdump -C命令来查看wasm文件的字节内容,也可以通过wagon项目的wasm-dump命令来查看文件内容。 还可以通过wabt的工具来查看:

wast2wasm simple.wat -v

最后更新于