afonso360 opened issue #3288:
Running the test case introduced by @dheaton-arm in #3283 on the s390x QEMU emulator shows wrong results, only for
i16
,i32
andi64
types.i8
passes these tests.
.clif
Test Casetest run target s390x function %umulhi_i8(i8, i8) -> i8 { block0(v0: i8, v1: i8): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i8(2, 4) == 0 ; run: %umulhi_i8(255, 255) == 254 function %umulhi_i16(i16, i16) -> i16 { block0(v0: i16, v1: i16): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i16(2, 4) == 0 ; run: %umulhi_i16(65535, 65535) == 65534 function %umulhi_i32(i32, i32) -> i32 { block0(v0: i32, v1: i32): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i32(500, 700) == 0 ; run: %umulhi_i32(4294967295, 4294967295) == 4294967294 function %umulhi_i64(i64, i64) -> i64 { block0(v0: i64, v1: i64): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i64(4294967295, 4294967295) == 0 ; run: %umulhi_i64(18446744073709551615, 18446744073709551615) == 18446744073709551614
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass
Actual Results
Versions and Environment
Cranelift version or commit: main
Operating system: linux
Architecture: s390x QEMUExtra Info
A file with this test was added in #3283.
afonso360 labeled issue #3288:
Running the test case introduced by @dheaton-arm in #3283 on the s390x QEMU emulator shows wrong results, only for
i16
,i32
andi64
types.i8
passes these tests.
.clif
Test Casetest run target s390x function %umulhi_i8(i8, i8) -> i8 { block0(v0: i8, v1: i8): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i8(2, 4) == 0 ; run: %umulhi_i8(255, 255) == 254 function %umulhi_i16(i16, i16) -> i16 { block0(v0: i16, v1: i16): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i16(2, 4) == 0 ; run: %umulhi_i16(65535, 65535) == 65534 function %umulhi_i32(i32, i32) -> i32 { block0(v0: i32, v1: i32): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i32(500, 700) == 0 ; run: %umulhi_i32(4294967295, 4294967295) == 4294967294 function %umulhi_i64(i64, i64) -> i64 { block0(v0: i64, v1: i64): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i64(4294967295, 4294967295) == 0 ; run: %umulhi_i64(18446744073709551615, 18446744073709551615) == 18446744073709551614
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass
Actual Results
Versions and Environment
Cranelift version or commit: main
Operating system: linux
Architecture: s390x QEMUExtra Info
A file with this test was added in #3283.
afonso360 labeled issue #3288:
Running the test case introduced by @dheaton-arm in #3283 on the s390x QEMU emulator shows wrong results, only for
i16
,i32
andi64
types.i8
passes these tests.
.clif
Test Casetest run target s390x function %umulhi_i8(i8, i8) -> i8 { block0(v0: i8, v1: i8): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i8(2, 4) == 0 ; run: %umulhi_i8(255, 255) == 254 function %umulhi_i16(i16, i16) -> i16 { block0(v0: i16, v1: i16): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i16(2, 4) == 0 ; run: %umulhi_i16(65535, 65535) == 65534 function %umulhi_i32(i32, i32) -> i32 { block0(v0: i32, v1: i32): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i32(500, 700) == 0 ; run: %umulhi_i32(4294967295, 4294967295) == 4294967294 function %umulhi_i64(i64, i64) -> i64 { block0(v0: i64, v1: i64): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i64(4294967295, 4294967295) == 0 ; run: %umulhi_i64(18446744073709551615, 18446744073709551615) == 18446744073709551614
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass
Actual Results
Versions and Environment
Cranelift version or commit: main
Operating system: linux
Architecture: s390x QEMUExtra Info
A file with this test was added in #3283.
afonso360 edited issue #3288:
Running the test case introduced by @dheaton-arm in #3283 on the s390x QEMU emulator shows wrong results, only for
i16
,i32
andi64
types.i8
passes these tests.
.clif
Test Casetest run target s390x function %umulhi_i8(i8, i8) -> i8 { block0(v0: i8, v1: i8): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i8(2, 4) == 0 ; run: %umulhi_i8(255, 255) == 254 function %umulhi_i16(i16, i16) -> i16 { block0(v0: i16, v1: i16): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i16(2, 4) == 0 ; run: %umulhi_i16(65535, 65535) == 65534 function %umulhi_i32(i32, i32) -> i32 { block0(v0: i32, v1: i32): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i32(500, 700) == 0 ; run: %umulhi_i32(4294967295, 4294967295) == 4294967294 function %umulhi_i64(i64, i64) -> i64 { block0(v0: i64, v1: i64): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i64(4294967295, 4294967295) == 0 ; run: %umulhi_i64(18446744073709551615, 18446744073709551615) == 18446744073709551614
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass
Actual Results
FAIL ./filetests/filetests/runtests/test.clif: run Caused by: Failed test: run: %umulhi_i16(2, 4) == 0, actual: 2048 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: linux
Architecture: s390x QEMUExtra Info
A file with this test was added in #3283.
akirilov-arm commented on issue #3288:
cc @uweigand
uweigand commented on issue #3288:
Hmm. The above clif test case just passes for me, running on s390x natively. I guess I'll need to try under qemu to see if this might be a problem there ...
uweigand commented on issue #3288:
Just re-ran the test under qemu and it also passes for me. Where exactly did you see the failure (cranelift / qemu versions)?
afonso360 commented on issue #3288:
The commit where I tested this was 16b6a404e419498e6204e6c4855b50105370c7b0, with qemu-s390x 4.2.1.
I tried to reproduce this with the current main, and it looks like it got fixed. (still fails if I go back to 16b6a404e419498e6204e6c4855b50105370c7b0).
I've opened #3418 to enable the
umulhi
testsuite to prevent regressions. Otherwise we can close this.
afonso360 edited a comment on issue #3288:
The commit where I originally tested this was 16b6a404e419498e6204e6c4855b50105370c7b0, with qemu-s390x 4.2.1.
I tried to reproduce this with the current main, and it looks like it got fixed. (still fails if I go back to 16b6a404e419498e6204e6c4855b50105370c7b0).
I've opened #3418 to enable the
umulhi
testsuite to prevent regressions. Otherwise we can close this.
uweigand commented on issue #3288:
The commit where I originally tested this was 16b6a40, with qemu-s390x 4.2.1.
I tried to reproduce this with the current main, and it looks like it got fixed. (still fails if I go back to 16b6a40).
Ah, right, that likely got fixed by this: https://github.com/bytecodealliance/wasmtime/pull/3329
I've opened #3418 to enable the
umulhi
testsuite to prevent regressions. Otherwise we can close this.Thanks!
akirilov-arm closed issue #3288:
Running the test case introduced by @dheaton-arm in #3283 on the s390x QEMU emulator shows wrong results, only for
i16
,i32
andi64
types.i8
passes these tests.
.clif
Test Casetest run target s390x function %umulhi_i8(i8, i8) -> i8 { block0(v0: i8, v1: i8): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i8(2, 4) == 0 ; run: %umulhi_i8(255, 255) == 254 function %umulhi_i16(i16, i16) -> i16 { block0(v0: i16, v1: i16): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i16(2, 4) == 0 ; run: %umulhi_i16(65535, 65535) == 65534 function %umulhi_i32(i32, i32) -> i32 { block0(v0: i32, v1: i32): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i32(500, 700) == 0 ; run: %umulhi_i32(4294967295, 4294967295) == 4294967294 function %umulhi_i64(i64, i64) -> i64 { block0(v0: i64, v1: i64): v2 = umulhi v0, v1 return v2 } ; run: %umulhi_i64(4294967295, 4294967295) == 0 ; run: %umulhi_i64(18446744073709551615, 18446744073709551615) == 18446744073709551614
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass
Actual Results
FAIL ./filetests/filetests/runtests/test.clif: run Caused by: Failed test: run: %umulhi_i16(2, 4) == 0, actual: 2048 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: linux
Architecture: s390x QEMUExtra Info
A file with this test was added in #3283.
Last updated: Jan 24 2025 at 00:11 UTC