scottmcm opened PR #7693 from scottmcm:more-i128
to bytecodealliance:main
:
This uses
iconst_u
andiconst_s
a bunch more in ISLE opts.We can now enable some of the patterns that had to be excluded before to avoid generating
iconst.i128
that doesn't exist, since these rules do the right thing. For example,x - x
with this PR will now giveuextend.i128 (iconst.i64 0)
whenx
isi128
, rather than staying unchanged as it did before.There's a bunch of things that still don't have it, like const-prop, since the constant values are still only 64-bit, not 128-bit, so those patterns are still restricted to the smaller types.
<!--
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
-->
scottmcm requested elliottt for a review on PR #7693.
scottmcm requested wasmtime-compiler-reviewers for a review on PR #7693.
scottmcm submitted PR review.
scottmcm created PR review comment:
I like how elegant this is now, but it's still restricted to 64-bit and smaller because
iconst_s $I128 k
will emit a sign-extended constant that's probably the same thing it started with.
scottmcm submitted PR review.
scottmcm created PR review comment:
I was unable to find any way to trigger this where the
fits_in_64
mattered. When it's onlyty_int
, since it's coming fromicmp
it seems to always be$I8
-- anything else as the result would need a vector type, but trying with a vector type (seeeq_self_v128
) it's not triggering even without the 64-bit limitation.
scottmcm submitted PR review.
scottmcm created PR review comment:
I could pull these (and the reduce ones) into a separate PR if you want, since they're not really following the bigger theme of the PR. They just came from looking at cprop -- which in general can't do 128-bit constants usefully -- and trying to find what would be possible on the extended constants that
iconst_u
andiconst_s
generate. See thebor_extended_constants_i128
test below as an example of where this happens.
github-actions[bot] commented on PR #7693:
Subscribe to Label Action
cc @cfallin, @fitzgen
<details>
This issue or pull request has been labeled: "cranelift", "isle"Thus the following users have been cc'd because of the following labels:
- cfallin: isle
- fitzgen: isle
To subscribe or unsubscribe from this label, edit the <code>.github/subscribe-to-label.json</code> configuration file.
Learn more.
</details>
fitzgen submitted PR review:
Looks great, thanks! Just a couple things below before merging.
fitzgen submitted PR review:
Looks great, thanks! Just a couple things below before merging.
fitzgen created PR review comment:
I think we will want to pull these out into a new, dedicated PR. It isn't obvious that these rewrites are (always? usually?) improvements on their own since we are going from two ops to three and most CPUs, AFAIK, aren't faster at doing eg 8-bit adds than 32-bit adds. I could see this possibly unlocking further rewrites, but are intentionally very careful about the kinds of rewrites that we introduce just to unlock other optimizations because we aren't working with a full e-graph here, but an acyclic one that is intended to run with less time budget. All that is to say, this might still be beneficial, but I'd like to get more eyes on it and discussion about it first, and we can land the rest of this stuff in the meantime.
fitzgen created PR review comment:
Mind adding a comment to this effect?
scottmcm submitted PR review.
scottmcm created PR review comment:
Makes sense. I can also experiment with doing it only for things where one of the inner ones is itself an extend, since I think that's the only cases where I used it in the tests anyway, and would keep the excess down since the extra reduce would collapse with the extend.
scottmcm updated PR #7693.
scottmcm submitted PR review.
scottmcm created PR review comment:
Done.
fitzgen submitted PR review:
Thanks!
fitzgen merged PR #7693.
Last updated: Jan 24 2025 at 00:11 UTC