alexcrichton opened issue #5417:
Given this input as
foo.clif
:;; Fuzzgen test case test compile set opt_level=speed set enable_alias_analysis=false set use_egraphs=true set enable_simd=true set enable_safepoints=true set enable_llvm_abi_extensions=true set unwind_info=false set preserve_frame_pointers=true set machine_code_cfg_info=true set enable_jump_tables=false set enable_incremental_compilation_cache_checks=true target x86_64 function %my_fn(i16 uext, i32, i32, i64 uext, f32 uext, i32 sext, i128 uext, i16 uext, i8, i8) system_v { ss0 = explicit_slot 99 ss1 = explicit_slot 19 block0(v0: i16, v1: i32, v2: i32, v3: i64, v4: f32, v5: i32, v6: i128, v7: i16, v8: i8, v9: i8): v10 = iconst.i8 97 v11 = iconst.i16 0 v12 = iconst.i8 0 v13 = iconst.i8 0 v14 = iconst.i8 0 v15 = iconst.i8 0 v16 = iconst.i8 0 v17 = iconst.i8 -113 v18 = iconst.i8 0 v19 = iconst.i16 0 v20 = iconst.i32 0 v21 = iconst.i64 0 v22 = uextend.i128 v21 ; v21 = 0 stack_store v22, ss1 stack_store v19, ss1+16 ; v19 = 0 stack_store v18, ss1+18 ; v18 = 0 stack_store v22, ss0 stack_store v22, ss0+16 stack_store v22, ss0+32 stack_store v22, ss0+48 stack_store v22, ss0+64 stack_store v22, ss0+80 stack_store v19, ss0+96 ; v19 = 0 stack_store v18, ss0+98 ; v18 = 0 v23 = ireduce.i8 v3 v24 = rotl v14, v17 ; v14 = 0, v17 = -113 v25 = rotr v8, v3 nop nop nop v26 = sshr v16, v3 ; v16 = 0 v27 = stack_addr.i64 ss1+8 v28 = uload8.i32 v27 v29 = uextend.i64 v13 ; v13 = 0 v30 = rotr v6, v29 v31 = uextend.i128 v0 v32 = stack_addr.i64 ss0+4 v33 = sload8.i32 v32 v34 = icmp eq v31, v31 v35 = select_spectre_guard v34, v11, v7 ; v11 = 0 return } ; Note: the results in the below test cases are simply a placeholder and probably will be wrong ; run: %my_fn(6330, 786432, 0, 0, 0.0, 0, 0, 0, 0, 0) ; run: %my_fn(0, 0, 0, 0, 0.0, 0, 0, 0, 0, 0)
The
main
branch fails with:$ cargo run -p cranelift-tools -- test ./foo.clif ... thread 'worker #0' panicked at 'internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)`', cranelift/codegen/src/isa/x64/lower.rs:477:13 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: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` FAIL ./foo.clif: panicked in worker #0: internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` 1 tests Error: 1 failure
Bisection points to #5409 as the culprit here (cc @jameysharp and @cfallin)
alexcrichton labeled issue #5417:
Given this input as
foo.clif
:;; Fuzzgen test case test compile set opt_level=speed set enable_alias_analysis=false set use_egraphs=true set enable_simd=true set enable_safepoints=true set enable_llvm_abi_extensions=true set unwind_info=false set preserve_frame_pointers=true set machine_code_cfg_info=true set enable_jump_tables=false set enable_incremental_compilation_cache_checks=true target x86_64 function %my_fn(i16 uext, i32, i32, i64 uext, f32 uext, i32 sext, i128 uext, i16 uext, i8, i8) system_v { ss0 = explicit_slot 99 ss1 = explicit_slot 19 block0(v0: i16, v1: i32, v2: i32, v3: i64, v4: f32, v5: i32, v6: i128, v7: i16, v8: i8, v9: i8): v10 = iconst.i8 97 v11 = iconst.i16 0 v12 = iconst.i8 0 v13 = iconst.i8 0 v14 = iconst.i8 0 v15 = iconst.i8 0 v16 = iconst.i8 0 v17 = iconst.i8 -113 v18 = iconst.i8 0 v19 = iconst.i16 0 v20 = iconst.i32 0 v21 = iconst.i64 0 v22 = uextend.i128 v21 ; v21 = 0 stack_store v22, ss1 stack_store v19, ss1+16 ; v19 = 0 stack_store v18, ss1+18 ; v18 = 0 stack_store v22, ss0 stack_store v22, ss0+16 stack_store v22, ss0+32 stack_store v22, ss0+48 stack_store v22, ss0+64 stack_store v22, ss0+80 stack_store v19, ss0+96 ; v19 = 0 stack_store v18, ss0+98 ; v18 = 0 v23 = ireduce.i8 v3 v24 = rotl v14, v17 ; v14 = 0, v17 = -113 v25 = rotr v8, v3 nop nop nop v26 = sshr v16, v3 ; v16 = 0 v27 = stack_addr.i64 ss1+8 v28 = uload8.i32 v27 v29 = uextend.i64 v13 ; v13 = 0 v30 = rotr v6, v29 v31 = uextend.i128 v0 v32 = stack_addr.i64 ss0+4 v33 = sload8.i32 v32 v34 = icmp eq v31, v31 v35 = select_spectre_guard v34, v11, v7 ; v11 = 0 return } ; Note: the results in the below test cases are simply a placeholder and probably will be wrong ; run: %my_fn(6330, 786432, 0, 0, 0.0, 0, 0, 0, 0, 0) ; run: %my_fn(0, 0, 0, 0, 0.0, 0, 0, 0, 0, 0)
The
main
branch fails with:$ cargo run -p cranelift-tools -- test ./foo.clif ... thread 'worker #0' panicked at 'internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)`', cranelift/codegen/src/isa/x64/lower.rs:477:13 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: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` FAIL ./foo.clif: panicked in worker #0: internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` 1 tests Error: 1 failure
Bisection points to #5409 as the culprit here (cc @jameysharp and @cfallin)
afonso360 commented on issue #5417:
A minimized example:
test compile set opt_level=speed set use_egraphs=true target x86_64 function %my_fn(i16) system_v { block0(v0: i16): v1 = icmp eq v0, v0 v2 = select_spectre_guard v1, v1, v1 return } ; run: %my_fn(6330)
I think what's happening here is that the
icmp
is being optimized into aiconst.i16 1
due to the new egraph rules. And we don't have any rules in the backend to lower a genericselect_spectre_guard
. (see also #5206)
cfallin closed issue #5417:
Given this input as
foo.clif
:;; Fuzzgen test case test compile set opt_level=speed set enable_alias_analysis=false set use_egraphs=true set enable_simd=true set enable_safepoints=true set enable_llvm_abi_extensions=true set unwind_info=false set preserve_frame_pointers=true set machine_code_cfg_info=true set enable_jump_tables=false set enable_incremental_compilation_cache_checks=true target x86_64 function %my_fn(i16 uext, i32, i32, i64 uext, f32 uext, i32 sext, i128 uext, i16 uext, i8, i8) system_v { ss0 = explicit_slot 99 ss1 = explicit_slot 19 block0(v0: i16, v1: i32, v2: i32, v3: i64, v4: f32, v5: i32, v6: i128, v7: i16, v8: i8, v9: i8): v10 = iconst.i8 97 v11 = iconst.i16 0 v12 = iconst.i8 0 v13 = iconst.i8 0 v14 = iconst.i8 0 v15 = iconst.i8 0 v16 = iconst.i8 0 v17 = iconst.i8 -113 v18 = iconst.i8 0 v19 = iconst.i16 0 v20 = iconst.i32 0 v21 = iconst.i64 0 v22 = uextend.i128 v21 ; v21 = 0 stack_store v22, ss1 stack_store v19, ss1+16 ; v19 = 0 stack_store v18, ss1+18 ; v18 = 0 stack_store v22, ss0 stack_store v22, ss0+16 stack_store v22, ss0+32 stack_store v22, ss0+48 stack_store v22, ss0+64 stack_store v22, ss0+80 stack_store v19, ss0+96 ; v19 = 0 stack_store v18, ss0+98 ; v18 = 0 v23 = ireduce.i8 v3 v24 = rotl v14, v17 ; v14 = 0, v17 = -113 v25 = rotr v8, v3 nop nop nop v26 = sshr v16, v3 ; v16 = 0 v27 = stack_addr.i64 ss1+8 v28 = uload8.i32 v27 v29 = uextend.i64 v13 ; v13 = 0 v30 = rotr v6, v29 v31 = uextend.i128 v0 v32 = stack_addr.i64 ss0+4 v33 = sload8.i32 v32 v34 = icmp eq v31, v31 v35 = select_spectre_guard v34, v11, v7 ; v11 = 0 return } ; Note: the results in the below test cases are simply a placeholder and probably will be wrong ; run: %my_fn(6330, 786432, 0, 0, 0.0, 0, 0, 0, 0, 0) ; run: %my_fn(0, 0, 0, 0, 0.0, 0, 0, 0, 0, 0)
The
main
branch fails with:$ cargo run -p cranelift-tools -- test ./foo.clif ... thread 'worker #0' panicked at 'internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)`', cranelift/codegen/src/isa/x64/lower.rs:477:13 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: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` FAIL ./foo.clif: panicked in worker #0: internal error: entered unreachable code: implemented in ISLE: inst = `v35 = select_spectre_guard.i16 v47, v11, v7 ; v47 = 1, v11 = 0`, type = `Some(types::I16)` 1 tests Error: 1 failure
Bisection points to #5409 as the culprit here (cc @jameysharp and @cfallin)
Last updated: Jan 24 2025 at 00:11 UTC