[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