Stream: git-wasmtime

Topic: wasmtime / PR #4534 Implement variant translation in fuse...


view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 18:39):

alexcrichton opened PR #4534 from translate-variant to main:

This commit implements the most general case of variants for fused
adapter trampolines. Additionally a number of other primitive types are
filled out here to assist with testing variants. The implementation
internally was relatively straightforward given the shape of variants,
but there's room for future optimization as necessary especially around
converting locals to various types.

This commit also introduces a "one off" fuzzer for adapters to ensure
that the generated adapter is valid. I hope to extend this fuzz
generator as more types are implemented to assist in various corner
cases that might arise. For now the fuzzer simply tests that the output
wasm module is valid, not that it actually executes correctly. I hope to
integrate with a fuzzer along the lines of #4307 one day to test the
run-time-correctness of the generated adapters as well, at which point
this fuzzer would become obsolete.

Finally this commit also fixes an issue with u8 translation where
upper bits weren't zero'd out and were passed raw across modules.
Instead smaller-than-32 types now all mask out their upper bits and do
sign-extension as appropriate for unsigned/signed variants.

<!--

Please ensure that the following steps are all taken care of before submitting
the PR.

Please ensure all communication adheres to the code of conduct.
-->

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 18:39):

alexcrichton requested fitzgen for a review on PR #4534.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 18:39):

alexcrichton has marked PR #4534 as ready for review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 19:45):

alexcrichton updated PR #4534 from translate-variant to main.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 19:55):

alexcrichton updated PR #4534 from translate-variant to main.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen created PR review comment:

Might not want to derive(Arbitary) for FuncType as the params are potentially unbounded in length here, and I assume we have an implementation limit we want to stay below, right?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen created PR review comment:

Alternatively, you could add a wrapper type for bounding Vec lengths similar to what you did for NonZeroLenVec.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen created PR review comment:

Huh. I didn't realize there wasn't an i32.extend8_u instruction. Strange there are signed extension instructions where there aren't corresponding unsigned variants. Yeah you can just do the masking, but also you can do the signed version via signed shifting back and forth. So why not omit or include both?

@sunfishcode do you happen to know the answer to the above, out of curiosity?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 26 2022 at 21:00):

fitzgen created PR review comment:

Why not add this to the top level wasmtime/fuzz/* fuzz targets? You don't think it is worth spending oss-fuzz time on until we get the full blown value round tripping stuff working?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:10):

alexcrichton created PR review comment:

Yeah I don't think this really all that high value of a fuzz target since it's purely "is it a valid wasm module" which is a much weaker claim than "hey it actually works". Eventually when we're actually running these I think it makes sense to run on oss-fuzz but for now this is mostly just a development aide which is intended to help suss out corner cases (worked really well for a memory64 patch I'll post after this)

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:10):

alexcrichton submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:11):

alexcrichton submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:11):

alexcrichton created PR review comment:

While we do have limits in the system they're generally elsewhere at the wasmparser validation layer or the runtime implementation layer. Here in this specific compiler there are few limits imposed and at least so far nothing has blown up. If I run into issues locally with this though running the fuzzer I'll probably do the newtype trick.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:13):

alexcrichton submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:13):

alexcrichton created PR review comment:

Double-checking again to make sure I didn't miss something, apparently there's i64.extend32_u but that's the only one.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 27 2022 at 14:14):

alexcrichton merged PR #4534.


Last updated: Jan 24 2025 at 00:11 UTC