I would like to run multiple concurrent functions from a bundle of linked modules. No memory is used from these modules, only non-mutable access to store data. In that case, can I link/instantiate modules once and bind them into a Linker and finally clone the linker and use it with another store that references the same data with an Arc?
Can you use Arc<YourSharedData>
as the T
of Linker
?
Yup, that's the plan.
In that case, can I create a new Store each time I want to call a Func or do I need to keep it consistent with previous module instantiation and registration calls?
(considering I'm not using Globals or Memory)
If the Module is truly stateless, you could probably get away with keeping only a fixed set (e.g. one per thread) of stores & module-instances. And reuse them to call the module exports on
So I need to create module instances for each thread. Is there a cheaper way? If only Store were clonable...
Also maybe of interest is: InstancePre
aha, cool!
So I can pre-instantiate modules once and then clone it to each thread.
much better, thanks :-)
I can confirm you'll want an instance-per-thread model at least here because you can only call functions on instances and an instance cannot itself be used concurrently on more than one thread at a time. Creation of a Store
should be cheap so if you find that being a hot spot let us know so we can optimize it
I was wondering: if I receive a func as return type from a call, is there a way to call it on a different store, given that such stores have no memory/globals and instance were imported the same way in all stores?
Could you clarify what you mean by "receive a func as return type"? Are you referring to the function references proposal?
Yup. I noticed "Val" can contain a variant Val::Func(Option<Func>).
No, a Func
is associated with a particular Store
. Especially a Func
that represents an underlying Wasm function.
A Store
is the lifetime/context/data for a set of Wasm instances, so if the Store
goes away or the wrong Store
is paired with some operation, we can't really do anything
Ok, I see. Is there a way to resolve a Func pointer back to the function name, if it's exported? The "one instance-set/store per thread" model is getting very strict if what starts in one thread must always live in the same thread for the whole duration of the pool.
you can have multiple stores on a single thread, and you can also send a store to a different thread, it just isn't Sync
regarding function names: I don't think we expose anything like that. it gets a little tricky where a function can be defined in one module and given a name there, and then imported in another module and given a different name there, so I'm not sure which name we would expose as the canonical one in this case. but we could probably create something to expose the name from the custom names section, if any
Could you say more about what you're trying to do? It could be reasonable - for example - for a module to return the name of a func it "knows" it exports and the host could call that dynamically on a different instance of that module
My current situation is this: I would like to build modules that can manage higher order functions (as in: return function ptrs, receive function ptrs as parameters) and I would like to possibly run such higher order functions in a concurrent way, possibly making use of multiple threads.
Initially, I thought that this would only resolve in having one Store for each thread, but since function pointers only make sense in the same Store they came from, I think I've hit a wall.
sharing and calling function references from the same instance, concurrently across threads is fundamentally impossible in Wasm without the shared-everything proposal, which is still very much in flux at the standards level, and not implemented in wasmtime yet
the proposal is currently in phase 1 out of 5: https://github.com/WebAssembly/proposals?tab=readme-ov-file#phase-1---feature-proposal-cg
I see. Thanks for your support, it really helped to avoid going in the wrong direction :-)
good luck!
hehe
Last updated: Jan 24 2025 at 00:11 UTC