Stream: git-wasmtime

Topic: wasmtime / Issue #2726 Function arguments when returning ...


view this post on Zulip Wasmtime GitHub notifications bot (Mar 14 2021 at 15:12):

willygroup opened Issue #2726:

Hi,
I'm pretty new to the whole rust/wasm world.
I'm passing to rust host from rust wasm function that returns a simple struct.
I'm compiling with cargo and the target wasm32-unknown-unknown.
I saw that when I check the module exports this function get an extra arguments... making some guessing I find out that is the memory pointer for the return struct...

I cannot find out some documentation for this behaviour... someone can please address me to the right direction?
Thanks a lot :smiling_face:

view this post on Zulip Wasmtime GitHub notifications bot (Mar 14 2021 at 15:35):

bjorn3 commented on Issue #2726:

making some guessing I find out that is the memory pointer for the return struct...

Correct

I cannot find out some documentation for this behaviour... someone can please address me to the right direction?

Apart from reading the source of rustc and LLVM there isn't really for wasm32-unknown-unknown. Probably the best description is https://github.com/rust-lang/rust/pull/81388#issuecomment-767438600. For wasm32-unknown-emscripten and wasm32-wasi, the official C abi for wasm is followed, but for wasm32-unknown-unknown this is not the case. By accident LLVM was allowed to do it's own abi adjustments and now it can't be changed anymore without breaking wasm-bindgen. (source: I broke it by accident a while ago by doing something that prevented LLVM from doing it's own abi adjustments.)

view this post on Zulip Wasmtime GitHub notifications bot (Mar 15 2021 at 14:23):

alexcrichton commented on Issue #2726:

The C ABI for the wasm32 target is currently documented at https://github.com/WebAssembly/tool-conventions/blob/master/BasicCABI.md, although the Rust ABI for wasm32-unknown-unknown differs from Clang for historical reasons. Using the wasm32-wasi target, however, the ABIs will be the same.

view this post on Zulip Wasmtime GitHub notifications bot (Mar 15 2021 at 14:23):

alexcrichton closed Issue #2726:

Hi,
I'm pretty new to the whole rust/wasm world.
I'm passing to rust host from rust wasm function that returns a simple struct.
I'm compiling with cargo and the target wasm32-unknown-unknown.
I saw that when I check the module exports this function get an extra arguments... making some guessing I find out that is the memory pointer for the return struct...

I cannot find out some documentation for this behaviour... someone can please address me to the right direction?
Thanks a lot :smiling_face:

view this post on Zulip Wasmtime GitHub notifications bot (Mar 17 2021 at 07:24):

willygroup commented on Issue #2726:

Ok!
Thanks a lot for your work!! :-)


Last updated: Jan 24 2025 at 00:11 UTC