Lordworms opened PR #9878 from Lordworms:canonicalize
to bytecodealliance:main
:
<!--
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
-->
Lordworms requested cfallin for a review on PR #9878.
Lordworms requested wasmtime-compiler-reviewers for a review on PR #9878.
Lordworms requested fitzgen for a review on PR #9878.
Lordworms requested wasmtime-core-reviewers for a review on PR #9878.
Lordworms requested wasmtime-default-reviewers for a review on PR #9878.
Lordworms edited PR #9878:
<!--
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
-->part of https://github.com/bytecodealliance/wasmtime/issues/9783
github-actions[bot] commented on PR #9878:
Subscribe to Label Action
cc @fitzgen
<details>
This issue or pull request has been labeled: "cranelift", "pulley"Thus the following users have been cc'd because of the following labels:
- fitzgen: pulley
To subscribe or unsubscribe from this label, edit the <code>.github/subscribe-to-label.json</code> configuration file.
Learn more.
</details>
cfallin submitted PR review.
cfallin created PR review comment:
I'm surprised this is necessary: the intent of
canonicalize-nan.wast
is to test Cranelift's NaN-canonicalization pass, and this pass operates on the machine-independent IR (CLIF) so it should work for compilation to Pulley as well as any other target. The Pulley virtual machine shouldn't have to unconditionally canonicalize NaNs.Could you check whether the pass is producing NaN-canonicalization sequences (which look like compares to test for NaN, then a select operator)?
I'm wondering whether this might have something to do with the
has_vector_support
boolean inContext::canonicalize_nans()
; the comment there (that riscv64 is the only architecture without vector support) is no longer accurate now that we have Pulley in-tree; I'm not sure but perhaps that's related?
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Oh I think this might be my fault, in the contribution docs for pulley it recommends running the test suite directly via
wasmtime wast .../*.wast
. Whentests/misc_testsuite/simd/canonicalize-nan.wast
is executed that's actually expected to fail (it even fails on native) and it requires an extra-W nan-canonicalization
flag.Chris is right though in that the manual canonicalization here shouldn't be necessary. @Lordworms you'll find though that
-W nan-canonicalization
isn't fully supported just yet:Error: failed to run script file './tests/misc_testsuite/simd/canonicalize-nan.wast' Caused by: 0: failed directive on ./tests/misc_testsuite/simd/canonicalize-nan.wast:7:1 1: Compilation error: Unsupported feature: should be implemented in ISLE: inst = `v10 = fcmp.f32x4 uno v7, v7`, type = `Some(types::I32X4)`
That being said this PR still gets the
simd_f32x4_rounding.wast
test passing, so with the canonicalization removed it should still be good to flag that test as passing
alexcrichton submitted PR review.
alexcrichton created PR review comment:
As a minor stylistic note, mind prefixing these instructions with
v
(e.g.vtrunc32x4
) instead? I've been trying to use thev
prefix for all simd/vector-related instructions so far
Lordworms submitted PR review.
Lordworms created PR review comment:
yep
Lordworms created PR review comment:
I am new to this project and didn't find it. Sorry for that.
Lordworms submitted PR review.
Lordworms updated PR #9878.
Lordworms updated PR #9878.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Oh this'll want to stay as these are test exemptions for a different compiler, Winch, unrelated to Pulley. Only the ones above are the ones affecting Pulley.
Also it looks like a merge conflict has creeped in due to this file, so if you want to rebase that should help resolve the conflict.
Lordworms updated PR #9878.
Lordworms submitted PR review.
Lordworms created PR review comment:
resolved it.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Oh I think this test popped back in by accident during the rebase
Lordworms updated PR #9878.
alexcrichton submitted PR review.
alexcrichton has enabled auto merge for PR #9878.
alexcrichton merged PR #9878.
Last updated: Jan 24 2025 at 00:11 UTC