Stream: git-wasmtime

Topic: wasmtime / issue #5709 Legalize `b{and,or,xor}_not` into ...


view this post on Zulip Wasmtime GitHub notifications bot (Feb 04 2023 at 22:19):

alexcrichton commented on issue #5709:

Ok I've pushed up an alternate strategy of reaching my goal:

A single egraph-rule is retained for x^-1 being translated to ~x, which is enough to trigger wasm modules to use andn on x86_64, for example.

One shortcoming remaining, however, is that the backends currently only pattern match (band x (bnot y)), not (band (bnot y) x), for example. This means that if the order of the operands in the *.wat test I added are swapped then the andn instruction isn't generated. Is this something that should be fixed with an egraph rule? I thought I remembered reading there's a "move constants to the right" rule so should there similarly be a "move bnot to the right" rule? Or should the backends all have duplicate patterns for each order?

view this post on Zulip Wasmtime GitHub notifications bot (Feb 04 2023 at 23:01):

cfallin commented on issue #5709:

One shortcoming remaining, however, is that the backends currently only pattern match (band x (bnot y)), not (band (bnot y) x), for example. This means that if the order of the operands in the *.wat test I added are swapped then the andn instruction isn't generated. Is this something that should be fixed with an egraph rule? I thought I remembered reading there's a "move constants to the right" rule so should there similarly be a "move bnot to the right" rule?

That seems like a reasonable thing to try, yup!

view this post on Zulip Wasmtime GitHub notifications bot (Feb 05 2023 at 00:46):

alexcrichton commented on issue #5709:

Ok I've pushed up a commit which does that and it seems to work well for at least the small unit tests.

view this post on Zulip Wasmtime GitHub notifications bot (Feb 06 2023 at 16:23):

jameysharp commented on issue #5709:

I wouldn't expect a "move bnot to the right" egraph rule to work reliably for backend patterns. It correctly declares that they're equivalent expressions, but then during elaboration we pick one expression as our final choice to hand to the backend, and there's no guarantee we'll pick the one with bnot on the right, since the two alternatives have equal cost. I assume it's working now because elaboration happens to be picking the last-added option in the e-class in case of ties, or something like that.

I think the backends need to match both patterns instead. Which is annoying, since the patterns overlap; we have to give them different priorities.

I also think we need to work on helping ISLE understand commutative operators. It could generate every unique version of a rule with operands swapped, given a commutative flag on terms or something. We'd have to put some thought into how that interacts with overlap checking though.

view this post on Zulip Wasmtime GitHub notifications bot (Feb 06 2023 at 17:44):

alexcrichton commented on issue #5709:

Ok! I've removed the egraph bits for that and added more lowering rules

view this post on Zulip Wasmtime GitHub notifications bot (Feb 10 2023 at 15:23):

uweigand commented on issue #5709:

Isn't this the same, given that bnot is XOR with -1, and XOR is associative?

view this post on Zulip Wasmtime GitHub notifications bot (Feb 10 2023 at 17:29):

alexcrichton commented on issue #5709:

Ah yes indeed!


Last updated: Jan 24 2025 at 00:11 UTC