candymate opened issue #6787:
Test Case
Cases with
i64.trunc_sat_f32_u
,i64.trunc_sat_f64_u
,i32.trunc_sat_f32_u
,i32.trunc_sat_f64_u
workOne example
(module (type (;0;) (func (param f32) (result i64))) (func (;0;) (type 0) (param f32) (result i64) local.get 0 i64.trunc_sat_f32_u ) (export "main" (func 0)) )
use wasmtime::*; fn main() -> Result<()> { let engine = Engine::default(); let module = Module::from_file(&engine, "test.wat")?; let mut store = Store::new(&engine, ()); let instance = Instance::new(&mut store, &module, &[])?; let main = instance.get_typed_func::<f32, i64>(&mut store, "main")?; println!("main(NaN) = {}", main.call(&mut store, f32::NAN)?); Ok(()) }
Steps to Reproduce
Run the following code with s390x
cargo run --release --target=s390x-unknown-linux-gnu
Expected Results
ixx.trunc_sat_fxx_u
with NaN should result in 0. (https://webassembly.github.io/spec/core/exec/numerics.html#op-trunc-sat-u)
main(NaN) = 0
Actual Results
main(NaN) = -1
Versions and Environment
Wasmtime version or commit: v11.0.1 Release
Operating system: Ubuntu 20.04.6
Architecture: s390x
candymate added the bug label to Issue #6787.
cfallin commented on issue #6787:
cc @uweigand, can you take a look?
uweigand commented on issue #6787:
Unfortunately I'm unable to reproduce the problem, the provided test case gives the correct output for me:
main(NaN) = 0
Not sure what exactly is different in your situation, it must be some environment issue. Which Rust version are you using? Which s390x processor version?
Note that there is a spec conformance test in the wasmtime testsuite that verifies these specific corner cases:
https://github.com/WebAssembly/testsuite/blob/7ef86ddeed81458f9031a49a40b3a3f99c1c6a8a/conversions.wast#L399
This test is continually passing in CI on s390x, so the core implementation should be correct.
candymate commented on issue #6787:
Thanks for the response.
I was using an old QEMU, and it seemed to be the cause of the problem. After updating QEMU, it now gives me the correct output.
candymate closed issue #6787:
Test Case
Cases with
i64.trunc_sat_f32_u
,i64.trunc_sat_f64_u
,i32.trunc_sat_f32_u
,i32.trunc_sat_f64_u
workOne example
(module (type (;0;) (func (param f32) (result i64))) (func (;0;) (type 0) (param f32) (result i64) local.get 0 i64.trunc_sat_f32_u ) (export "main" (func 0)) )
use wasmtime::*; fn main() -> Result<()> { let engine = Engine::default(); let module = Module::from_file(&engine, "test.wat")?; let mut store = Store::new(&engine, ()); let instance = Instance::new(&mut store, &module, &[])?; let main = instance.get_typed_func::<f32, i64>(&mut store, "main")?; println!("main(NaN) = {}", main.call(&mut store, f32::NAN)?); Ok(()) }
Steps to Reproduce
Run the following code with s390x
cargo run --release --target=s390x-unknown-linux-gnu
Expected Results
ixx.trunc_sat_fxx_u
with NaN should result in 0. (https://webassembly.github.io/spec/core/exec/numerics.html#op-trunc-sat-u)
main(NaN) = 0
Actual Results
main(NaN) = -1
Versions and Environment
Wasmtime version or commit: v11.0.1 Release
Operating system: Ubuntu 20.04.6
Architecture: s390x
uweigand commented on issue #6787:
I was using an old QEMU, and it seemed to be the cause of the problem.
Ah yes, some older QEMU versions had a bug in the emulation of the float-to-int conversion instructions - that would explain it.
Last updated: Jan 24 2025 at 00:11 UTC