I've got a regalloc/cranelift question that others might know better how to debug. I've got a CLIF function which emits xconst8 x23, 0
in pulley bytecode which is storing the immediate 0 in register x23
. The register x23
is a callee-save register, though, so it needs to be saved at the beginning of the function. This function, however is only saving x25
for some other reason. Basically I'm not sure why the compute_clobbers
function is only returning x25 and not other registers (x23 isn't the only one)
my guess is that this is some typo or missing piece by accident in the pulley backend, so I'm mostly curious if anyone else knows how this might come about off the top of their head
clobbers are computed by looking at defs on all instructions; is the regalloc metadata correct on xconst8
?
I double-checked it was using reg_def
yeah
cool, and then the other piece is ensuring it's actually a callee-save; going to look at ABI code, one sec
it's listed in DEFAULT_CALLEE_SAVES
on the pulley backend -- I'll note there's a typo in this definition where the float registers are using px_reg
instead of pf_reg
, but that I don't think should affect this
I threw some debugging in OperandCollector::reg_def
and it looks like it's only ever called with virtual registers, not physical registers, so that seems a bit suspect
one thing I also thought was odd was that in compute_clobbers
it iterates over operand_ranges
but that set is basically empty
it only iterates over the Inst::Args
instruction which also seems odd
ah, so there isn't a separate collector pass to gather clobbers -- we collect once into the shared operand array, then regalloc works over that, then we iterate over that to gather clobbers (here: https://github.com/bytecodealliance/wasmtime/blob/5dcaa13ced14a4fe135036c82fdc9cb9170b1074/cranelift/codegen/src/machinst/vcode.rs#L661)
but: is included_in_clobbers
correct for the generated instructions?
oh you know
ok yep that's it
the return value of that is inverted
I looked at that earlier and glossed over this by accident
t hanks!
included_in_clobbers
, doing what it says on the tin (but ever sneaky in doing so)! no problem
yeah it's defined as is_args()
on pulley whereas x64 has !self.is_args()
(roughly)
all good now though, thanks!
yep yep
woohoo that got this batch of new tests down to only one failure which I already knew about
sweet!
Last updated: Jan 24 2025 at 00:11 UTC