alexcrichton opened PR #4190 from use-a-magic
to main
:
This commit is motivated by my work on the component model
implementation for imported functions. Currently all context pointers in
wasm are*mut VMContext
but with the component model my plan is to
make some pointers instead along the lines of*mut VMComponentContext
.
In doing this though one worry I have is breaking what has otherwise
been a core invariant of Wasmtime for quite some time, subtly
introducing bugs by accident.To help assuage my worry I've opted here to erase knowledge of
*mut VMContext
where possible. Instead where applicable a context
pointer is simply known as*mut ()
and the embedder doesn't actually
know anything about this context beyond the value of the pointer. This
will help prevent Wasmtime from accidentally ever trying to interpret
this context pointer as an actualVMContext
when it might instead be a
VMComponentContext
.Overall this was a pretty smooth transition. The main change here is
that theVMTrampoline
(now sporting more docs) has its first argument
changed to*mut ()
. The second argument, the caller context, is still
configured as*mut VMContext
though because all functions are always
called from wasm still. Eventually for component-to-component calls I
think we'll probably "fake" the second argument as the same as the first
argument, losing track of the original caller, as an intentional way of
isolating components from each other.Along the way there are a few host locations which do actually assume
that the first argument is indeed aVMContext
. These are valid
assumptions that are upheld from a correct implementation, but I opted
to add a "magic" field toVMContext
to assert this in debug mode. This
new "magic" field is inintialized during normal vmcontext initialization
and it's checked whenever aVMContext
is reinterpreted as an
Instance
(but only in debug mode). My hope here is to catch any future
accidental mistakes, if ever.<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
alexcrichton requested fitzgen for a review on PR #4190.
fitzgen submitted PR review.
fitzgen submitted PR review.
fitzgen created PR review comment:
// Also note that this magic is only ever invalid in the presence of
fitzgen created PR review comment:
wat
fitzgen created PR review comment:
Can we make the
*mut ()
to*mut VMContext
cast (that we've done in two different places now) go through a helper function that does the magic value debug assertion eagerly?
fitzgen created PR review comment:
/// * `*mut VMContext` - this is the "caller" context, which at this time is
alexcrichton updated PR #4190 from use-a-magic
to main
.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
I have word
alexcrichton updated PR #4190 from use-a-magic
to main
.
alexcrichton merged PR #4190.
Last updated: Jan 24 2025 at 00:11 UTC