Stream: git-wasmtime

Topic: wasmtime / PR #6912 winch: Add support for parametric ins...


view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera requested cfallin for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera requested wasmtime-compiler-reviewers for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera opened PR #6912 from saulecabrera:winch-parametric to bytecodealliance:main:

This commit introduces support for the drop and select instructions.

Additionally, it refactors the CodeGenContext::drop_last implementation, enhancing flexibility for callers to determine the handling of elements to be dropped. This refactoring simplifies scenarios where a Memory entry is at the top of the stack.

<!--
Please make sure you include the following information:

Our development process is documented in the Wasmtime book:
https://docs.wasmtime.dev/contributing-development-process.html

Please ensure all communication follows the code of conduct:
https://github.com/bytecodealliance/wasmtime/blob/main/CODE_OF_CONDUCT.md
-->

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera requested fitzgen for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera requested wasmtime-core-reviewers for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:24):

saulecabrera requested wasmtime-core-reviewers for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:26):

saulecabrera created PR review comment:

I'm planning on doing this refactor, but I didn't want to introduce it as part of this change.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 14:26):

saulecabrera submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 15:53):

cfallin submitted PR review:

Generally looks good, thanks! Just a few questions below.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 15:53):

cfallin submitted PR review:

Generally looks good, thanks! Just a few questions below.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 15:53):

cfallin created PR review comment:

I'm somewhat surprised that select is being implemented with actual local control flow here; is there any reason we can't use a conditional move? That's the usual lowering in e.g. Cranelift (and avoiding actual branches is sometimes important at the guest-code level for Spectre mitigations).

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 15:53):

cfallin created PR review comment:

It's not entirely clear what's going on in the diff here (i.e. why things changed): is it that the registers weren't actually freed before?

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:27):

saulecabrera updated PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:28):

saulecabrera submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:28):

saulecabrera created PR review comment:

is there any reason we can't use a conditional move?

Good catch; no particular reason why we can't use a conditional move here, it's just that I didn't consider it initially, but there are very good arguments to do so. I've refactored this code to use conditional moves instead in https://github.com/bytecodealliance/wasmtime/pull/6912/commits/c56125cd833ff8107b285f4a2872d0930c014eef

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:33):

saulecabrera submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:33):

saulecabrera created PR review comment:

The registers were actually freed, implicitly as part of the previous implementation of the drop_last function, with the new implementation, the processing of certain values like registers and memory are explicit and up to the caller. I noticed that this change to the drop_last function has the potential to reduce a bit the boilerplate in calls, hence the NOTE / TODO comment. Hope this clarifies things up.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:33):

saulecabrera requested cfallin for a review on PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:36):

cfallin submitted PR review:

LGTM!

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 17:36):

cfallin has enabled auto merge for PR #6912.

view this post on Zulip Wasmtime GitHub notifications bot (Aug 25 2023 at 18:36):

cfallin merged PR #6912.


Last updated: Jan 24 2025 at 00:11 UTC