Hello! I'm experimenting with incorporating wasm into an established C-ffi system (specifically dart-lang). The use case is that C or binary files can not be distributed through the package system, but wasm potentially could. Then it would be up to the toolchain to recreate the intended native dynamic library locally.
What I'm experimenting with is a simple exported C function:
EXPORT int64_t add_five(int64_t input) { return input + 5; }
Compile it to wasm dynamic:
zig build-lib -dynamic shared.c -target wasm32-freestanding
Make it a .so:
wasmtime wasm2obj ../dart-wasm/zig/shared.wasm shared.o
zig build-lib -dynamic shared.o
And then expect to use shared.so with the initially intended header and C-ffi.
Of course this fails on multiple levels. Hence the question:
Hi Safa! :wave: That use case sounds at least extremely closely related to the goals of the RLBox project. @Deian Stefan and @Shravan Narayan could say more about whether it might be good fit, though
@Till Schneidereit thanks for the swift response. The use case does not involve sandboxing or security at the moment. My current objective is to figure out how to recreate (or wrap&expose) the C ABI/API surface after C->wasm->native compilation.
ah, I see. This could potentially still give you a toolchain that does what you want-with improved security thrown in as a bonus :stuck_out_tongue:
@Safa Sofuoglu Yup, RLBox definitely does cover this as a part of what it does. While our focus is security and sandboxing, we had to cover ABI compatibility issue as part of what we did.
We had address multiple challenges in preserving details across the C->Wasm->native boundary, specifically
long
means different things on different platforms/compilersFor RLBox, we basically end up solving this through a combination of a C++ wrapper type system and template meta-programming to get things working transparently.
I think I broadly see 3 ways to address this
Hope this helps
@Shravan Narayan your answer is immensely helpful, thanks! I'll start by inspecting RLBox source.
Safa Sofuoglu has marked this topic as resolved.
@Safa Sofuoglu Oh also re- a generator, if you want to use an existing generator you can also use witx (you have to manually write the witx interface file for libraries you care about). Then you can use witx bindgen tool
https://bytecodealliance.github.io/witx-bindgen/
Last updated: Jan 24 2025 at 00:11 UTC