alexcrichton opened PR #8811 from alexcrichton:no-gc-scope-without-gc-values
to bytecodealliance:main
:
This commit skips the creation of a LIFO scope for GC
Rooted<T>
values for hostcalls using statically typed arguments/results (e.g.Func::wrap
) where none of the arguments/results have GC values. This removes the last bit of "GC business" onFunc::wrap
calls that don't do anything related to GC.<!--
Please make sure you include the following information:
If this work has been discussed elsewhere, please include a link to that
conversation. If it was discussed in an issue, just mention "issue #...".Explain why this change is needed. If the details are in an issue already,
this can be brief.Our development process is documented in the Wasmtime book:
https://docs.wasmtime.dev/contributing-development-process.htmlPlease ensure all communication follows the code of conduct:
https://github.com/bytecodealliance/wasmtime/blob/main/CODE_OF_CONDUCT.md
-->
alexcrichton requested wasmtime-core-reviewers for a review on PR #8811.
alexcrichton requested fitzgen for a review on PR #8811.
fitzgen submitted PR review.
fitzgen submitted PR review.
fitzgen created PR review comment:
I think this could actually be bad: if I define a host call with only integer params and results, but then create an
externref
inside it[^0], then thatexternref
will be rooted in the outer LIFO scope, rather than just being rooted in theCaller
's scope, which is probably the store's scope. That means theexternref
is going to leak for the whole extent of the program. So I don't think we can actually do this.Is reading a vec's length and then later a well-predicted compare-and-branch to out-of-line code really that expensive?
[^0]: Maybe I then re-entrantly call some other Wasm export, giving it that
externref
. Doesn't really matter why I did it, just that I did it.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
My thinking was that it's still safe in that case, right? It means it'll be rooted long but a manual rooting scope can always be created to avoid that.
Perf-wise this was locally showing a 40% perf improvement but I cannot reproduce it against the latest
main
. Turns out that I was testing before #8806 landed, and now that that PR has landed this PR is largely perf-neutral. The benchmark here is pretty micro-benchmark-y but at the same time I think it's a nice feature of Wasmtime that the overhead for calling the host is as low as possible, so cleaning up the assembly as much as we can I think is reasonable.
alexcrichton edited PR review comment.
fitzgen submitted PR review.
fitzgen created PR review comment:
it's a nice feature of Wasmtime that the overhead for calling the host is as low as possible, so cleaning up the assembly as much as we can I think is reasonable.
Agreed in general.
My thinking was that it's still safe in that case, right? It means it'll be rooted longer but a manual rooting scope can always be created to avoid that.
It is memory safe, yes, but it is a fairly big footgun, IMO. At minimum, we would need to be very clear about when a
Caller
is vs. isn't a rooting scope in our existing docs around rooting and scopes (I think onRooted
? maybe onRootScope
? I forget)But if this isn't a perf win anymore, then is it really worth adding the footgun?
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Ok I think that's reasonable yeah. I'll close this and we can revisit if it ever becomes necessary but that seems unlikely too.
alexcrichton closed without merge PR #8811.
Last updated: Jan 24 2025 at 00:11 UTC