abrown opened PR #3993 from isle-load
to main
:
This change moves the majority of the lowerings for CLIF's
load
instruction over to ISLE. To do so, it also migrates the previous
mechanism for creating anAmode
(lower_to_amode
) to several ISLE
rules (seeto_amode
).<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
abrown updated PR #3993 from isle-load
to main
.
cfallin submitted PR review.
cfallin submitted PR review.
cfallin created PR review comment:
This would be a little clearer with the specific condition in the name I think -- maybe
const_shift_lt_eq_3
or somesuch?
cfallin created PR review comment:
I think
ishl_imm
is converted during legalization toishl
+iconst
so we can probably remove this TODO.
cfallin created PR review comment:
I think we need to check whether
c + offset
fits in the constant immediate, right?If so, I think we can do this with something like (it's a hack, but):
rule (to_amode flags (iadd (iconst (low32_will_sign_extend_to_64 c)) base) (u32_add <c offset)))
in other words, make
u32_add
an extractor as well, and take an in-arg (use arg polarity for this) with the half of the sum we already know (c
). For the arg-flipped version below we need to use theu32_add
extractor inside thelow32_will_sign_extend...
instead.(open to ideas how we might clean this up in ISLE, by the way -- aside from fitzgen's ideas around higher-order extractors, I kind of like the notion of separate constraint clauses as well, which would allow us to write something like
(given (u32_add_fits offset c))
after the LHS...)
cfallin created PR review comment:
s/c >> amount/c << amount/, I think?
cfallin created PR review comment:
From the implementation below it looks like it's actually checking whether the value will fit in a
u32
, so basically, positive values <= 4GiB? Is that right? Do we want to check <= 2GiB or -2GiB <= x <= 2GiB instead?(pre-existing confusion I know but it's worthwhile to fix this while we're here!)
abrown updated PR #3993 from isle-load
to main
.
abrown submitted PR review.
abrown created PR review comment:
Done; it would be nice to have arithmetic expressions in ISLE somehow, a la
(shift <= 3)
.
abrown updated PR #3993 from isle-load
to main
.
abrown updated PR #3993 from isle-load
to main
.
abrown submitted PR review.
abrown created PR review comment:
Good catch; that logic was all wrong. Take a look at the new helpers and their logic.
abrown updated PR #3993 from isle-load
to main
.
abrown updated PR #3993 from isle-load
to main
.
abrown has marked PR #3993 as ready for review.
abrown submitted PR review.
abrown created PR review comment:
I don't like having two of these weird helpers doing almost the same thing. It would be great if some of this logic could just exist in ISLE, but in the meantime... suggestions appreciated.
abrown requested cfallin for a review on PR #3993.
cfallin submitted PR review.
cfallin created PR review comment:
IIRC (and I might not, this stuff is subtle!) I think this comment should be adjusted slightly: negative values are fine if they sign-extend correctly, no? (The logic looks correct below, concern is just with the comment.)
cfallin submitted PR review.
cfallin created PR review comment:
bits()
returns ani64
, so won't the.try_into().unwrap()
panic if given a negative value in theImm64
? I think since we're working with raw bits here then determining possibility of representation below, we can cast the raw bits withas u64
.
cfallin created PR review comment:
I think this will use a
movzx
for 32-bit loads as well? Strictly speaking this should be fine, and it looks like it matches how loads happen today actually, but it might be a bit more idiomatic, and I think one byte shorter in encoding, to use a 32-bitmov
instead.
cfallin created PR review comment:
Longer-term I want to extend ISLE semantics a bit to make this work without the in-args, as we talked about (for others watching, I'll write more about some ideas soon!). For now I wonder if we could collapse these two extractors into one by passing a default type like
$I64
to theType
for the non-extend case?
abrown submitted PR review.
abrown created PR review comment:
Ok, changed.
abrown updated PR #3993 from isle-load
to main
.
abrown submitted PR review.
abrown created PR review comment:
I'll add a TODO issue for this; I have been fuzzing with no issues but, being a bit paranoid, want to let oss-fuzz check this for a while before changing the logic: https://github.com/bytecodealliance/wasmtime/issues/4006.
abrown merged PR #3993.
Last updated: Jan 24 2025 at 00:11 UTC