jan-justin opened PR #6379 from jan-justin:cranelift-interpreter-bitcast-simd-panic
to bytecodealliance:main
:
Fixes panic caused due to exceeding expected bounds when creating vector values, as mentioned over at #5915
<!--
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
-->
jan-justin requested abrown for a review on PR #6379.
jan-justin requested wasmtime-compiler-reviewers for a review on PR #6379.
jan-justin edited PR #6379:
Fixes panic caused due to exceeding expected bounds when creating vector values, as mentioned over at #5915
<!--
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
-->
jan-justin updated PR #6379.
afonso360 submitted PR review:
LGTM! Thanks! Just a small note.
afonso360 submitted PR review:
LGTM! Thanks! Just a small note.
afonso360 created PR review comment:
This seems to not handle big endian bitcasts. Can we add an assert somewhere here to ensure that we panic in that case? Something along these lines:
assert_eq!( mem_flags.endianness(Endianness::Little), Endianness::Little, "Only little endian bitcasts are supported" );
afonso360 edited PR review comment.
jan-justin created PR review comment:
Sure, I could certainly do that.
I would, however, like to know where it seems to indicate that the bitcasts on s390x are not handled? It might be useful for me in future since the CI run is indicating green for s390x. It failed on a previous run when I used
DataValue::read_from_slice_ne
variant.
afonso360 created PR review comment:
Well, I adapted the testcases into big endian and tried it out in s390x, and they are pointing out different results.
;; cargo run --target=s390x-unknown-linux-gnu -- test ./filetests/filetests/runtests/simd-bitcast.clif test interpret test run target s390x function %bitcast_more_lanes_big(i64x2) -> i32x4 { block0(v0: i64x2): v1 = bitcast.i32x4 big v0 return v1 } ; run: %bitcast_more_lanes_big(0x00000000000000000000000000000000) == 0x00000000000000000000000000000000 ; run: %bitcast_more_lanes_big(0x00000000000000ff00000000000000ff) == 0x000000ff00000000000000ff00000000 function %bitcast_fewer_lanes_big(i16x8) -> i64x2 { block0(v0: i16x8): v1 = bitcast.i64x2 big v0 return v1 } ; run: %bitcast_fewer_lanes_big(0x00000000000000000000000000000000) == 0x00000000000000000000000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff0000000000000000000000000000) == 0x00000000000000ff0000000000000000
Those would be good tests to add though! I don't think we have many big endian bitcast runtests. Although it should be noted that only s390x really supports this, I don't think any of the other backends do.
I don't think using
ne
here is the right solution since we explicitly pick one of the two. I think to make this work with big endian we would have to map each lane, apply ato_be/to_le
depending on memflags.
jan-justin created PR review comment:
I see, thank you for the clarification!
So then is your preference for me to include a panic on big endian bitcasts, or to spend some additional time ensuring that it is correctly handled?
afonso360 created PR review comment:
Up to you! I'm happy either way.
jan-justin created PR review comment:
I will give it a whirl. I need to set up qemu to test it and get back to you.
jan-justin created PR review comment:
Hey, sorry for the delay but I was unable to setup an s390x environment on my M1 MacBook.
At this point it would seem that I would go the assert route, however, I have a question regarding your comment containing the CLIF. Is your comment stating the assertions you expect to be true, or was that simply the output you received when running on a s390x machine?
I ask because have been wrapping myself around an axle over it.
afonso360 created PR review comment:
I mostly took that test ran it in QEMU s390x and recorded the output. I didn't look at it particularly hard, however I have some faith that the s390x backend would be correct in this regard. If you'd like to look further into this there is a very long thread where we nailed down the bitcast semantics
jan-justin created PR review comment:
Thank you, the thread definitely helped me understand the semantics.
I am subsequently able to get the expected output for
bitcast_more_lanes_big
, however, I am not quite as successful withbitcast_fewer_lanes_big
. If you have the time, could you kindly confirm the expected output forbitcast_fewer_lanes_big
since I am getting:Failed test: run: %bitcast_fewer_lanes_big(0x00ff0000000000000000000000000000) == 0x00000000000000ff0000000000000000, actual: 0x000000000000000000ff000000000000
afonso360 created PR review comment:
That test does pass on s390x, and at least at a first glance it makes some sense to me, since the first lane glance it appears that that lane gets mirrored in the i64? This at least seems consistent with the behavior described in page 12 of the Vector Bitcast Presentation which essentially makes bitcast a permute? Sorry if I can't help too much here, this stuff really confuses me.
I've tested a few more cases to try and explore this a bit more:
; run: %bitcast_fewer_lanes_big(0x00000000000000000000000000000000) == 0x00000000000000000000000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff0000000000000000000000000000) == 0x00000000000000ff0000000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff00ff000000000000000000000000) == 0x0000000000ff00ff0000000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff00ff000000ff0000000000000000) == 0x00ff000000ff00ff0000000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff00ff000000ff00000000000000ff) == 0x00ff000000ff00ff00ff000000000000 ; run: %bitcast_fewer_lanes_big(0x00ff00ff000000ff00ff0000000000ff) == 0x00ff000000ff00ff00ff0000000000ff
afonso360 edited PR review comment.
afonso360 edited PR review comment.
afonso360 edited PR review comment.
afonso360 edited PR review comment.
afonso360 edited PR review comment.
jan-justin created PR review comment:
That is indeed interesting!
I will try to dig a little deeper to see if I can shed some light on this.
Thank you for the additional information, it is really appreciated!
jan-justin updated PR #6379.
jan-justin updated PR #6379.
jan-justin created PR review comment:
Hey,
So I removed the explicit calls to
DataValue::read_from_slice
since it was superfluous. Nevertheless, it seems the output when running the Big endian tests through the interpreter still does not yield the expected results you showed.I won't hold the fix hostage any longer than I already have, so I have added a panic when attempting to bitcast on vectors when the big endian mem flag is set.
afonso360 created PR review comment:
I think disabling big endian for now seems like a reasonable solutions. I'm not entirely sure what is up with filetest infrastructure. Thanks for looking into this!
jan-justin created PR review comment:
No problem at all. Thank you for your patience!
afonso360 merged PR #6379.
Last updated: Jan 24 2025 at 00:11 UTC