-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Executor: Add create_runtime_from_artifact_bytes
#14184
Conversation
Also export `WasmtimeRuntime`, returned by the `create_runtime*` functions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please note that AFAIK this can have performance implications on module instantiation, not just on module creation.
On Linux this most likely won't make a difference because when deserializing a precompiled module from a slice wasmtime
will just create an internal memfd mapping for it anyway, but for macOS it cannot do so (since macOS doesn't have an equivalent of memfd) so it will prevent the copy-on-write instantiation codepath from kicking in.
@koute You are right, I missed that: /// All of the CoW strategies (with `CopyOnWrite` suffix) are only supported when either:
/// a) we're running on Linux,
/// b) we're running on an Unix-like system and we're precompiling
/// our module beforehand.
/// * Linux - this feature is supported for all instances of [`Module`].
/// Modules backed by an existing mmap (such as those created by
/// [`Module::deserialize_file`]) will reuse that mmap to cow-initialize
/// memory. Other instance of [`Module`] may use the `memfd_create`
/// syscall to create an initialization image to `mmap`.
/// * Unix (not Linux) - this feature is only supported when loading modules
/// from a precompiled file via [`Module::deserialize_file`] where there
/// is a file descriptor to use to map data into the process. Note that
/// the module must have been compiled with this setting enabled as well.
I did some benchmarks here. Might make testing on Mac a little slower but we can live with it. |
Can someone please take a look at the latest commit before I merge this in? I'm wondering if there's a technical reason we didn't already have a |
Probably just an oversight. From the Polkadot PVF validation side the instancing strategy isn't that important we only ever create one instance, not like for the runtime. However, the runtime doesn't use pre-compiled. |
PULL REQUEST
Overview
See title. Also export
WasmtimeRuntime
, returned by thecreate_runtime*
functions.I benchmarked the performance regression out of curiosity: bytecodealliance/wasmtime#6420. But since runtime creation is not at all a bottleneck, it makes sense to always use this new function for the reasons given in the related issue and PR.
Relevant Issues/PRs
Needed for paritytech/polkadot#7246 (comment)
Closes #13861