cfallin opened PR #4856 from s390x-ra2-semantics
to main
:
This is a step toward ultimately removing modify-operands, which along
with removal of pinned vregs, lets us move to a completely
constraint-based and fully-SSA regalloc input and get some nice
advantages eventually.There are still a few uses of
mod
operands and pinned vregs remaining,
especially around the "regpair" abstraction. Those proved to be a bit
trickier to update though, so will have to be done separately.<!--
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.
-->
uweigand created PR review comment:
This is just a minor nit, but it would feel slightly cleaner to me to pass
rn
instead ofrd.to_reg()
. (Of course those two expression have the same value in this branch of theif
.) In fact, I'm even wondering whether it wouldn't be cleanest to rename all thoseri
torn
-- that should make it more obious that aAluRR { op, rd, rn, rm }
has identical semantic to aAluRRR { op, rd, rn, rm }
ifrd
is tied torn
.
uweigand created PR review comment:
Now these changes I really dislike, sorry. I've been careful to ensure that the disassembly output of cranelift is always valid s390x assembler code, and could be fed right back into the assembler (e.g. to verify binary encodings).
With these changes we now get lots of output that simply isn't valid assembler -- I'd really prefer to avoid that. Now, I understand that the same printers in
mod.rs
are also used on the intermediate representation, and there you definitely need to see both vregs of the tied operands ...What would you think of a solution using a helper like
pretty_print_tied_regpair
or so, which would show just a single (real) register name if the two operands match, but would show something likedst|src
(ordst<-src
or whatever) if they do not?
uweigand submitted PR review.
uweigand submitted PR review.
uweigand created PR review comment:
Again probably cleaner to use
r
instead ofdst
here.
uweigand submitted PR review.
uweigand created PR review comment:
In fact, the whole
same_reg
logic can probably go away then, as the assertion that the two register are actually tied is now made duringemit
anyway.
cfallin updated PR #4856 from s390x-ra2-semantics
to main
.
cfallin submitted PR review.
cfallin created PR review comment:
This is a great idea actually; thanks! It nicely solves the issue of showing all info when viewing pre-regalloc VCode, but showing machine code as it really is once regalloc occurs. I've made this change, and I plan to adopt it to the mod operands in the other backends as well.
cfallin submitted PR review.
cfallin created PR review comment:
Updated to use
rn
's value, thanks. I actually lean slightly toward keeping these fields namedri
, to make it clear that they are artificial instruction fields, the "input" side of the dest reg, rather than a realrn
field (this also made it easier to grep for things when updating tests just now!). But I'm happy to alter the field name as well if you feel strongly about this.
cfallin created PR review comment:
Done!
cfallin submitted PR review.
uweigand created PR review comment:
These two
lgr
look new - this is why the new code is two instructions longer than the old code. Not sure if this is something that could still be improved in regalloc, or if this is just one of those random changes ... In any case, not a big deal, I just wanted to point it out.
uweigand submitted PR review.
uweigand submitted PR review.
cfallin submitted PR review.
cfallin created PR review comment:
I briefly looked but it was nothing really obvious. It's possible that my changes in bytecodealliance/regalloc2#74 might help a bit, but I'm not sure; let's see if it reverts back once I update tests there with this merged :-)
cfallin updated PR #4856 from s390x-ra2-semantics
to main
.
cfallin has enabled auto merge for PR #4856.
cfallin requested elliottt for a review on PR #4856.
cfallin requested alexcrichton for a review on PR #4856.
cfallin requested fitzgen for a review on PR #4856.
alexcrichton submitted PR review.
cfallin merged PR #4856.
Last updated: Jan 24 2025 at 00:11 UTC