Stream: general

Topic: WAMR linkage questions


view this post on Zulip Alexandru Ene (May 25 2021 at 10:01):

Hello,

I have a project where I integrated both WASMTime and now working on adding WAMR as well. I need both for ... reasons :grinning:.
That being said, it seems that WAMR has a similar but not identical API with WASMTIME.
More specifically, adding import functions to WAMR is not really supported in the same way. I can create a wasm_func_t from the imports of a module that's bound to my native function, but then it's unclear how to link this to a WAMR module.

Is wasm_register_natives the only way we can register imports after instantiation?

I tried adding the fucntions as externs to: wasm_instance_new, but this is expecting that the module imports list is identical with the imports parameter. For a module that's using WASI as well as custom methods this is impossible :grinning:

view this post on Zulip Alexandru Ene (May 25 2021 at 22:43):

For reference, I will add some information here about linking in WAMR as it is different than in other VMs:
1) WAMR allows missing imports in a wasm module (this is actually a nice feature).
2) wasm_runtime_register_natives_raw or without the raw is the way to add functions that are searched at link time. Be sure to call this before module initialization. This method doesn't need wasm_extern_t* so that's nice.

view this post on Zulip lum1n0us (May 26 2021 at 01:50):

WAMR supports two kinds of linkage. The WASM-C-API way and a WAMR private runtime linking. It is better not to use them mixed.

WAMR renames the header of WASM-C-API as wasm_c_api.h. What WARM did in Envoy is a reference for that: Wamr::link.

If we called the WASM-C-API linkage manually, WARM private runtime linking is automatic. WARM will search all imports in the user-provided search path with module names and imported item names. There is an example here.

WebAssembly Micro Runtime (WAMR). Contribute to bytecodealliance/wasm-micro-runtime development by creating an account on GitHub.
WebAssembly for Proxies (C++ host implementation). Contribute to proxy-wasm/proxy-wasm-cpp-host development by creating an account on GitHub.
WebAssembly Micro Runtime (WAMR). Contribute to bytecodealliance/wasm-micro-runtime development by creating an account on GitHub.

view this post on Zulip Alexandru Ene (May 26 2021 at 09:37):

Thank you, i ended up getting what. i want from it eventually. The thing that confused me is that this wasm_c_api and wasm_export.h look so close to what wasmtime has, that it has confused me. :grinning:


Last updated: Jan 24 2025 at 00:11 UTC