afonso360 opened issue #5979:
:wave: Hey,
I'm working on adding ISA extensions to the fuzzer (cc: #5816) and this popped out.
This compiles without
has_vxrs_ext2
, so perhaps we might just need to ensurehas_mie2
on that particular lowering?I'm also not 100% sure if this is a valid configuration of ISA flags, are these two independent or does
vxrs_ext2
always implymie2
?
.clif
Test Casetest compile target s390x has_vxrs_ext2=true function u1:0() system_v { block0: v37 = f32const 0.0 v21 = fcvt_to_uint.i16 v37 ; v37 = 0.0 return }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
thread 'worker #0' panicked at 'Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2', cranelift/codegen/src/isa/s390x/inst/emit.rs:1436:13 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 FAIL ./lmao.clif: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: s390x
cc: @uweigand
afonso360 labeled issue #5979:
:wave: Hey,
I'm working on adding ISA extensions to the fuzzer (cc: #5816) and this popped out.
This compiles without
has_vxrs_ext2
, so perhaps we might just need to ensurehas_mie2
on that particular lowering?I'm also not 100% sure if this is a valid configuration of ISA flags, are these two independent or does
vxrs_ext2
always implymie2
?
.clif
Test Casetest compile target s390x has_vxrs_ext2=true function u1:0() system_v { block0: v37 = f32const 0.0 v21 = fcvt_to_uint.i16 v37 ; v37 = 0.0 return }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
thread 'worker #0' panicked at 'Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2', cranelift/codegen/src/isa/s390x/inst/emit.rs:1436:13 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 FAIL ./lmao.clif: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: s390x
cc: @uweigand
afonso360 labeled issue #5979:
:wave: Hey,
I'm working on adding ISA extensions to the fuzzer (cc: #5816) and this popped out.
This compiles without
has_vxrs_ext2
, so perhaps we might just need to ensurehas_mie2
on that particular lowering?I'm also not 100% sure if this is a valid configuration of ISA flags, are these two independent or does
vxrs_ext2
always implymie2
?
.clif
Test Casetest compile target s390x has_vxrs_ext2=true function u1:0() system_v { block0: v37 = f32const 0.0 v21 = fcvt_to_uint.i16 v37 ; v37 = 0.0 return }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
thread 'worker #0' panicked at 'Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2', cranelift/codegen/src/isa/s390x/inst/emit.rs:1436:13 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 FAIL ./lmao.clif: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: s390x
cc: @uweigand
afonso360 labeled issue #5979:
:wave: Hey,
I'm working on adding ISA extensions to the fuzzer (cc: #5816) and this popped out.
This compiles without
has_vxrs_ext2
, so perhaps we might just need to ensurehas_mie2
on that particular lowering?I'm also not 100% sure if this is a valid configuration of ISA flags, are these two independent or does
vxrs_ext2
always implymie2
?
.clif
Test Casetest compile target s390x has_vxrs_ext2=true function u1:0() system_v { block0: v37 = f32const 0.0 v21 = fcvt_to_uint.i16 v37 ; v37 = 0.0 return }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
thread 'worker #0' panicked at 'Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2', cranelift/codegen/src/isa/s390x/inst/emit.rs:1436:13 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 FAIL ./lmao.clif: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: s390x
cc: @uweigand
uweigand commented on issue #5979:
These instructions are part of VXRS_EXT2, it seems the sanity check in inst/mod.rs is just wrong here. I'll post a fix.
Generally speaking, VXRS_EXT2 and MIE2 are specified as two separate optional facilities in the ISA docs, so in theory it would be possible to build a s390x processor that supports just one of them. However, all s390x processors that actually exist support either both of them or none of them - that's probably why this error wasn't noticed previously.
As an aside, while looking at the ISA docs to verify, I noticed that MIE2 is actually a misnomer - these instruction are part of the "Miscellaneous-Instruction-Extension Facility 3", not 2, so this probably should be renamed to MIE3 everywhere. I'll submit a separate PR for that as well.
cfallin closed issue #5979:
:wave: Hey,
I'm working on adding ISA extensions to the fuzzer (cc: #5816) and this popped out.
This compiles without
has_vxrs_ext2
, so perhaps we might just need to ensurehas_mie2
on that particular lowering?I'm also not 100% sure if this is a valid configuration of ISA flags, are these two independent or does
vxrs_ext2
always implymie2
?
.clif
Test Casetest compile target s390x has_vxrs_ext2=true function u1:0() system_v { block0: v37 = f32const 0.0 v21 = fcvt_to_uint.i16 v37 ; v37 = 0.0 return }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
thread 'worker #0' panicked at 'Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2', cranelift/codegen/src/isa/s390x/inst/emit.rs:1436:13 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 FAIL ./lmao.clif: panicked in worker #0: Cannot emit inst 'FpuRound { op: ToUInt32, mode: ToZero, rd: Writable { reg: v133 }, rn: v130 }' for target; failed to match ISA requirements: MIE2 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: s390x
cc: @uweigand
Last updated: Jan 24 2025 at 00:11 UTC