alexcrichton requested abrown for a review on PR #9543.
alexcrichton opened PR #9543 from alexcrichton:push-memory-type-down-in-compilers
to bytecodealliance:main
:
This commit has more refactoring to simplify handling of linear memories in Wasmtime. The end goal is to remove the static/dynamic distinction and simplify the internal implementation and external interface. This is along the same lines of #9528, #9532, #9531, and #9530. The goal of this PR is a series of standalone commits which work towards futher "pushing down" the usage of
MemoryStyle
down to the consumers of bounds check code. The goal here is to remove layers of abstraction and instead unify everything around the same abstraction ofTunables
andwasmtime_environ::Memory
. Many fields in Winch/CraneliftHeapData
have been removed in favor of storingMemory
directly.This PR affects generated golden tests because previously the global value for the heap bound was not generated if the heap was a "static" heap. With the eventual removal of static/dynamic distinction it's easier to just always generate this and have it not get used most of the time. Thus while the clif output tests are changing none of the actual generated code itself should be changing.
alexcrichton requested wasmtime-compiler-reviewers for a review on PR #9543.
alexcrichton requested pchickey for a review on PR #9543.
alexcrichton requested wasmtime-core-reviewers for a review on PR #9543.
abrown submitted PR review.
abrown created PR review comment:
It's this extra global that is causing the changes in the disassembly tests, right? E.g.,
gv5
?
abrown submitted PR review.
abrown created PR review comment:
It would appear that
gv4
is not being used in those tests, so we're adding an unused global here and I'm debating the pros and cons of that.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Right yeah this is the global being added. I wrote up a bit above about this but it's essentially easier given the current code shape to assume that the global value is always there rather than calculate if it'll be needed in a function body and create it and/or lazily creating it on-demand. My hope is that the "overhead" here is just a few bytes in a vector per-function which in theory doesn't have too much impact, but I'll admit I haven't measured.
alexcrichton requested fitzgen for a review on PR #9543.
abrown submitted PR review:
Well, beyond my question about the additional global, which I'm not terribly opposed to anyways, I think this makes sense.
alexcrichton updated PR #9543.
alexcrichton commented on PR #9543:
@fitzgen mind giving a once-over confirmation here as well?
fitzgen submitted PR review:
LGTM!
fitzgen merged PR #9543.
Last updated: Jan 24 2025 at 00:11 UTC