fitzgen opened PR #9003 from fitzgen:fix-rmw-and-floats-on-x64
to bytecodealliance:main
:
x86-64 allows us to do these kinds of read-modify-write operations in one instruction in general, however we also need to ensure that the non-memory operand is in a GPR. Because Cranelift allows
b{and,or,xor}
s on floating point types, that means we might need to insert a move from an XMM to a GPR.Found in https://github.com/bytecodealliance/wasmtime/pull/8941 but is actually unrelated to safepoints and stack maps, they just made this pattern more likely to occur. AFAICT, Wasm can't ever trigger this bug, and would only be something of concern for other CLIF producers.
<!--
Please make sure you include the following information:
If this work has been discussed elsewhere, please include a link to that
conversation. If it was discussed in an issue, just mention "issue #...".Explain why this change is needed. If the details are in an issue already,
this can be brief.Our development process is documented in the Wasmtime book:
https://docs.wasmtime.dev/contributing-development-process.htmlPlease ensure all communication follows the code of conduct:
https://github.com/bytecodealliance/wasmtime/blob/main/CODE_OF_CONDUCT.md
-->
fitzgen requested cfallin for a review on PR #9003.
fitzgen requested wasmtime-compiler-reviewers for a review on PR #9003.
elliottt submitted PR review.
elliottt created PR review comment:
Should this match against
(RegisterClass.Gpr _)
instead, to avoid potentially backtracking here instead of forcing the assertion failure input_in_reg
like before?
fitzgen updated PR #9003.
fitzgen submitted PR review.
fitzgen created PR review comment:
Good idea.
fitzgen has enabled auto merge for PR #9003.
elliottt submitted PR review.
fitzgen merged PR #9003.
Last updated: Jan 24 2025 at 00:11 UTC