afonso360 requested wasmtime-compiler-reviewers for a review on PR #7453.
afonso360 requested abrown for a review on PR #7453.
afonso360 opened PR #7453 from afonso360:egraphs-shifts-2
to bytecodealliance:main
:
:wave: Hey,
This PR adds a few mid-end rules that merge consecutive shift and rotate instructions. Here's an overview of the rules added.
Merge consecutive shifts by a constant
(ishl (ishl x k1) k2) == (ishl x (add k1 k2)) if k1 + k2 < ty_bits (ushr (ushr x k1) k2) == (ushr x (add k1 k2)) if k1 + k2 < ty_bits (sshr (sshr x k1) k2) == (sshr x (add k1 k2)) if k1 + k2 < ty_bits
Merge consecutive shifts by a constant if they overflow the type size
(ishl (ishl x k1) k2) == 0 if k1 + k2 >= ty_bits (ushr (ushr x k1) k2) == 0 if k1 + k2 >= ty_bits
Merge consecutive rotates
(rotl (rotr x y) y) == x (rotr (rotl x y) y) == x (rotr (rotr x y) z) == (rotr x (iadd y z)) (rotl (rotl x y) z) == (rotl x (iadd y z)) (rotr (rotl x y) z) == (rotr x (isub y z)) (rotl (rotr x y) z) == (rotl x (isub y z))
fitzgen submitted PR review:
LGTM with minor nitpick about comment. Thanks!
fitzgen submitted PR review:
LGTM with minor nitpick about comment. Thanks!
fitzgen created PR review comment:
This one is a little subtle because the example identities in the comment do not hold, but the rules are correct because they are doing the shift mask on
k{1,2}
before the add, and when you do that it is correct.Mind updating the comment like so?
;; Simliarly, if the shift amount overflows the type, then we can turn ;; it into a 0 ;; ;; (ishl (ishl x k1) k2) == 0 if shift_mask(k1) + shift_mask(k2) >= ty_bits ;; (ushr (ushr x k1) k2) == 0 if shift_mask(k1) + shift_mask(k2) >= ty_bits
afonso360 updated PR #7453.
afonso360 has enabled auto merge for PR #7453.
afonso360 merged PR #7453.
Last updated: Jan 24 2025 at 00:11 UTC