Stream: git-wasmtime

Topic: wasmtime / PR #4254 X64: port the rest of icmp to ISLE


view this post on Zulip Wasmtime GitHub notifications bot (Jun 10 2022 at 03:04):

elliottt opened PR #4254 from trevor/icmp-isle-port to main:

<!--

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 (Jun 10 2022 at 04:31):

elliottt has marked PR #4254 as ready for review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 10 2022 at 05:47):

elliottt updated PR #4254 from trevor/icmp-isle-port to main.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 10 2022 at 05:53):

elliottt created PR review comment:

Is the setnz in the original necessary here; it seems like andq with an immediate $1 should be enough?

view this post on Zulip Wasmtime GitHub notifications bot (Jun 10 2022 at 05:53):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 10 2022 at 05:53):

elliottt edited PR review comment.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 18:40):

elliottt requested cfallin for a review on PR #4254.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin created PR review comment:

Could we add a comment here describing what without_eq means (probably just summarizing the doc comment for IntCC::without_equal() and/or pointing to it)?

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin created PR review comment:

I am wondering now if this and is necessary: it's masking high bits off the result of the or for res above, but in the end this is a combination of setcc results, which are all 0/1...

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin created PR review comment:

emit_cmp remains used because of the branch cases below, right?

It's worth thinking a bit about how we're going to factor this apart so branches can use the icmp logic as well (perhaps it becomes a helper that returns "result in rflags with this CC if possible, otherwise this 0/1 bool in register"), but that's not strictly necessary for this PR. If you're looking for a next thing to do, sketching out the conditional branch lowering (s390x already uses ISLE for this, as a reference point) would be good while this is in your cache :-)

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin created PR review comment:

Likewise here, a quick summary or pointer would be helpful.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:04):

cfallin created PR review comment:

Indeed, it seems redundant. I suspect it might have been an artifact of lowering this in separate "generate the flags" and "use in trueif, brif, ..." halves, where the and generates flags (and also incidentally produces the 0/1 output directly).

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:53):

elliottt created PR review comment:

Great point! I'll experiment with returning the result of the or instead :)

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 19:53):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 20:20):

elliottt created PR review comment:

As we discussed in a DM, as the setcc instructions only set the lowest byte and leave the upper 56 bits of the register preserved, the and will be necessary.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 20:20):

elliottt submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 20:20):

elliottt updated PR #4254 from trevor/icmp-isle-port to main.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 20:28):

elliottt updated PR #4254 from trevor/icmp-isle-port to main.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 21:54):

cfallin submitted PR review.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 13 2022 at 23:34):

elliottt merged PR #4254.


Last updated: Jan 24 2025 at 00:11 UTC