afonso360 added the bug label to Issue #7229.
afonso360 added the cranelift label to Issue #7229.
afonso360 opened issue #7229:
:wave: Hey,
This showed up in fuzzgen while I was fuzzing a unrelated branch, but it reproduces on main.
.clif
Test Casetest compile set opt_level=speed_and_size target x86_64 function %a() -> i8 { block0: v21 = iconst.i64 0x6350_5050_5050_3750 v22 = iconst.i64 0x5050_5055_5050_3838 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v39 = iconst.i8 0 v51 = bmask.i8 v23 v56 = select v51, v51, v51 v65 = popcnt v56 v67 = icmp ugt v65, v39 ; v39 = 0 return v67 }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
afonso@DESKTOP-1AHKMV2:~/git/wasmtime/cranelift$ cargo run -- test ./lmao.clif Finished dev [unoptimized + debuginfo] target(s) in 0.20s Running `/home/afonso/git/wasmtime/target/debug/clif-util test ./lmao.clif` thread 'worker #0' panicked at 'internal error: entered unreachable code', cranelift/codegen/src/verifier/mod.rs:1731:22 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: internal error: entered unreachable code FAIL ./lmao.clif: panicked in worker #0: internal error: entered unreachable code 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: X64
Extra Info
The function looks like this after egraph optimizations:
function %a() -> i8 fast { block0: v22 = iconst.i64 0x5050_5055_5050_3838 v21 = iconst.i64 0x6350_5050_5050_3750 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v74 = iconst.i128 0 v75 = icmp ne v23, v74 ; v74 = 0 v76 -> v75 v77 -> v76 v78 -> v77 return v75 }
One of the rules is incorrectly producing a
iconst.i128
. Eventually the code ends up crashing during bounds checking in the verifier, but the root cause is a wrong rule in egraphs.As an aside, how cool is it that we are able to reason through a
popcnt
,select
andbmask
and arrive aticmp ne, 0
!
afonso360 edited issue #7229:
:wave: Hey,
This showed up in fuzzgen while I was fuzzing a unrelated branch, but it reproduces on main.
.clif
Test Casetest compile set opt_level=speed_and_size target x86_64 function %a() -> i8 { block0: v21 = iconst.i64 0x6350_5050_5050_3750 v22 = iconst.i64 0x5050_5055_5050_3838 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v39 = iconst.i8 0 v51 = bmask.i8 v23 v56 = select v51, v51, v51 v65 = popcnt v56 v67 = icmp ugt v65, v39 ; v39 = 0 return v67 }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
afonso@DESKTOP-1AHKMV2:~/git/wasmtime/cranelift$ cargo run -- test ./lmao.clif Finished dev [unoptimized + debuginfo] target(s) in 0.20s Running `/home/afonso/git/wasmtime/target/debug/clif-util test ./lmao.clif` thread 'worker #0' panicked at 'internal error: entered unreachable code', cranelift/codegen/src/verifier/mod.rs:1731:22 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: internal error: entered unreachable code FAIL ./lmao.clif: panicked in worker #0: internal error: entered unreachable code 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: X64
Extra Info
The function looks like this after egraph optimizations:
function %a() -> i8 fast { block0: v22 = iconst.i64 0x5050_5055_5050_3838 v21 = iconst.i64 0x6350_5050_5050_3750 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v74 = iconst.i128 0 v75 = icmp ne v23, v74 ; v74 = 0 v76 -> v75 v77 -> v76 v78 -> v77 return v75 }
One of the rules is incorrectly producing a
iconst.i128
. Eventually the code ends up crashing during bounds checking in the verifier, but the root cause is a wrong rule in egraphs.I'm opening this issue because I might not have time to look into it in the next few days.
As an aside, how cool is it that we are able to reason through a
popcnt
,select
andbmask
and arrive aticmp ne, 0
!
alexcrichton closed issue #7229:
:wave: Hey,
This showed up in fuzzgen while I was fuzzing a unrelated branch, but it reproduces on main.
.clif
Test Casetest compile set opt_level=speed_and_size target x86_64 function %a() -> i8 { block0: v21 = iconst.i64 0x6350_5050_5050_3750 v22 = iconst.i64 0x5050_5055_5050_3838 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v39 = iconst.i8 0 v51 = bmask.i8 v23 v56 = select v51, v51, v51 v65 = popcnt v56 v67 = icmp ugt v65, v39 ; v39 = 0 return v67 }
Steps to Reproduce
clif-util test ./the-above.clif
Expected Results
The test to pass.
Actual Results
afonso@DESKTOP-1AHKMV2:~/git/wasmtime/cranelift$ cargo run -- test ./lmao.clif Finished dev [unoptimized + debuginfo] target(s) in 0.20s Running `/home/afonso/git/wasmtime/target/debug/clif-util test ./lmao.clif` thread 'worker #0' panicked at 'internal error: entered unreachable code', cranelift/codegen/src/verifier/mod.rs:1731:22 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ERROR cranelift_filetests::concurrent > FAIL: panicked in worker #0: internal error: entered unreachable code FAIL ./lmao.clif: panicked in worker #0: internal error: entered unreachable code 1 tests Error: 1 failure
Versions and Environment
Cranelift version or commit: main
Operating system: Linux
Architecture: X64
Extra Info
The function looks like this after egraph optimizations:
function %a() -> i8 fast { block0: v22 = iconst.i64 0x5050_5055_5050_3838 v21 = iconst.i64 0x6350_5050_5050_3750 v23 = iconcat v22, v21 ; v22 = 0x5050_5055_5050_3838, v21 = 0x6350_5050_5050_3750 v74 = iconst.i128 0 v75 = icmp ne v23, v74 ; v74 = 0 v76 -> v75 v77 -> v76 v78 -> v77 return v75 }
One of the rules is incorrectly producing a
iconst.i128
. Eventually the code ends up crashing during bounds checking in the verifier, but the root cause is a wrong rule in egraphs.I'm opening this issue because I might not have time to look into it in the next few days.
As an aside, how cool is it that we are able to reason through a
popcnt
,select
andbmask
and arrive aticmp ne, 0
!
Last updated: Jan 24 2025 at 00:11 UTC