Stream: git-wasmtime

Topic: wasmtime / issue #3064 Cranelift: ishl with i128 shift am...


view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:34):

bjorn3 opened issue #3064:

Steps to Reproduce

Try to compile an ishl instruction with an i128 rhs using the AArch64 backend.

Expected Results

It compiles

Actual Results

thread 'rustc' panicked at 'Multi-register value not expected', /home/runner/.cargo/git/checkouts/wasmtime-41807828cb3a7a7e/c71ad94/cranelift/codegen/src/isa/aarch64/lower.rs:297:10
stack backtrace:
[...]
   2: core::option::expect_failed
             at /rustc/6d820866a27b1949e237be79b9c8c0145fe728b7/library/core/src/option.rs:1243:5
   3: cranelift_codegen::isa::aarch64::lower_inst::lower_insn_to_regs
   4: cranelift_codegen::machinst::lower::Lower<I>::lower
   5: cranelift_codegen::machinst::compile::compile
   6: <cranelift_codegen::isa::aarch64::AArch64Backend as cranelift_codegen::machinst::MachBackend>::compile_function

Versions and Environment

Cranelift version or commit: c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8

Operating system: N/A

Architecture: AArch64

Extra Info

AArch64 counterpart to https://github.com/bytecodealliance/wasmtime/issues/2727

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:34):

bjorn3 labeled issue #3064:

Steps to Reproduce

Try to compile an ishl instruction with an i128 rhs using the AArch64 backend.

Expected Results

It compiles

Actual Results

thread 'rustc' panicked at 'Multi-register value not expected', /home/runner/.cargo/git/checkouts/wasmtime-41807828cb3a7a7e/c71ad94/cranelift/codegen/src/isa/aarch64/lower.rs:297:10
stack backtrace:
[...]
   2: core::option::expect_failed
             at /rustc/6d820866a27b1949e237be79b9c8c0145fe728b7/library/core/src/option.rs:1243:5
   3: cranelift_codegen::isa::aarch64::lower_inst::lower_insn_to_regs
   4: cranelift_codegen::machinst::lower::Lower<I>::lower
   5: cranelift_codegen::machinst::compile::compile
   6: <cranelift_codegen::isa::aarch64::AArch64Backend as cranelift_codegen::machinst::MachBackend>::compile_function

Versions and Environment

Cranelift version or commit: c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8

Operating system: N/A

Architecture: AArch64

Extra Info

AArch64 counterpart to https://github.com/bytecodealliance/wasmtime/issues/2727

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:34):

bjorn3 labeled issue #3064:

Steps to Reproduce

Try to compile an ishl instruction with an i128 rhs using the AArch64 backend.

Expected Results

It compiles

Actual Results

thread 'rustc' panicked at 'Multi-register value not expected', /home/runner/.cargo/git/checkouts/wasmtime-41807828cb3a7a7e/c71ad94/cranelift/codegen/src/isa/aarch64/lower.rs:297:10
stack backtrace:
[...]
   2: core::option::expect_failed
             at /rustc/6d820866a27b1949e237be79b9c8c0145fe728b7/library/core/src/option.rs:1243:5
   3: cranelift_codegen::isa::aarch64::lower_inst::lower_insn_to_regs
   4: cranelift_codegen::machinst::lower::Lower<I>::lower
   5: cranelift_codegen::machinst::compile::compile
   6: <cranelift_codegen::isa::aarch64::AArch64Backend as cranelift_codegen::machinst::MachBackend>::compile_function

Versions and Environment

Cranelift version or commit: c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8

Operating system: N/A

Architecture: AArch64

Extra Info

AArch64 counterpart to https://github.com/bytecodealliance/wasmtime/issues/2727

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:34):

bjorn3 commented on issue #3064:

Found by https://github.com/bjorn3/rustc_codegen_cranelift/commit/11584b52966cc71bdae39ac1733ea929201c517f.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:39):

cfallin commented on issue #3064:

cc @afonso360

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:42):

afonso360 commented on issue #3064:

This is interesting, because we have tests for this! https://github.com/bytecodealliance/wasmtime/blob/c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8/cranelift/filetests/filetests/runtests/i128-arithmetic.clif#L98

I need to look into this a bit more

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:43):

bjorn3 commented on issue #3064:

The lhs is i8 in this case. Maybe it only gets handled when the lhs and rhs are both i128?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:45):

afonso360 commented on issue #3064:

I think they are both i128, lhs is obtained from iconcat v0, v1, and rhs is iconcat v4, v4.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:51):

bjorn3 commented on issue #3064:

I mean in case of the bug the lhs is i8.

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:52):

afonso360 commented on issue #3064:

Oh, right, we also have test for those: https://github.com/bytecodealliance/wasmtime/blob/c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8/cranelift/filetests/filetests/runtests/i128-arithmetic.clif#L76

Are you able to get a clif file from cg_clif?

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:55):

bjorn3 commented on issue #3064:

That test is the opposite way around. There the lhs is i128 and the rhs is i8. In my case the lhs is i8 and the rhs is i128. I don't have a clif file at hand, but I would guess it did be:

function %ishl_i128_i8(i64, i64, i8) -> i8 {
block0(v0: i64, v1: i64, v2: i8):
    v3 = iconcat v0, v1

    v4 = ishl.i8 v2, v3

    return v4
}

view this post on Zulip Wasmtime GitHub notifications bot (Jul 05 2021 at 16:55):

afonso360 commented on issue #3064:

Oh, sorry, got it!

Yeah i'll have a look

view this post on Zulip Wasmtime GitHub notifications bot (Jul 16 2021 at 21:08):

akirilov-arm closed issue #3064:

Steps to Reproduce

Try to compile an ishl instruction with an i128 rhs using the AArch64 backend.

Expected Results

It compiles

Actual Results

thread 'rustc' panicked at 'Multi-register value not expected', /home/runner/.cargo/git/checkouts/wasmtime-41807828cb3a7a7e/c71ad94/cranelift/codegen/src/isa/aarch64/lower.rs:297:10
stack backtrace:
[...]
   2: core::option::expect_failed
             at /rustc/6d820866a27b1949e237be79b9c8c0145fe728b7/library/core/src/option.rs:1243:5
   3: cranelift_codegen::isa::aarch64::lower_inst::lower_insn_to_regs
   4: cranelift_codegen::machinst::lower::Lower<I>::lower
   5: cranelift_codegen::machinst::compile::compile
   6: <cranelift_codegen::isa::aarch64::AArch64Backend as cranelift_codegen::machinst::MachBackend>::compile_function

Versions and Environment

Cranelift version or commit: c71ad9490e7f3e19bbcae7e28bbe50f8a0b4a5d8

Operating system: N/A

Architecture: AArch64

Extra Info

AArch64 counterpart to https://github.com/bytecodealliance/wasmtime/issues/2727


Last updated: Jan 24 2025 at 00:11 UTC