github-actions[bot] commented on Issue #2223:
Subscribe to Label Action
cc @bnjbvr
<details>
This issue or pull request has been labeled: "cranelift", "cranelift:area:aarch64", "cranelift:meta"Thus the following users have been cc'd because of the following labels:
- bnjbvr: cranelift
To subscribe or unsubscribe from this label, edit the <code>.github/subscribe-to-label.json</code> configuration file.
Learn more.
</details>
cfallin commented on Issue #2223:
Updated for x64, thanks! I see a few failures on SpiderMonkey-x64 with e.g.
jit-test/tests/wasm/bigint/bigint.js
(and I have to test with--no-wasm-simd
to get Cranelift now on x64); I'm not sure if this is pre-existing, since we don't run the new x64 backend on CI there; but all of the basic functionality seems to work, so the basic stack-slot setup in this PR should be correct, I think.
cfallin commented on Issue #2223:
Updated -- that was a fun one to track down! (Ten points to
Gryffindorrr
...).The problem is that we weren't restoring the TLS register in the epilogue -- unlike IonMonkey, we do not treat the TLS register as an unallocatable fixed register, but rather we just copy its value to an ordinary SSA value on function entry. Apparently we were free to clobber it previously, but now we are not. Easy enough to handle in the clobber-restore sequences.
When vendored in, this passes SpiderMonkey's jit-tests on both x64 (
--wasm-compiler=cranelift --no-wasm-simd
) and aarch64 (--wasm-compiler=cranelift
).
Last updated: Jan 24 2025 at 00:11 UTC