Stream: git-wasmtime

Topic: wasmtime / issue #6545 Failed to print to stdout when ena...


view this post on Zulip Wasmtime GitHub notifications bot (Jun 09 2023 at 09:39):

hurae opened issue #6545:

Test Case

Simple hello world example, works fine with wasi preview1, but panic for component model.

seesee.zip

// wit/see.wit
package plugin:see

world see {
  export run: func() -> result
}
// seesee/src/lib.rs
wit_bindgen::generate!({
    path: "../wit/see.wit",
    world: "see",
});

struct Checks;

impl See for Checks {
    fn run() -> Result<(), ()> {
        println!("Hello, world!");

        Ok(())
    }
}

export_see!(Checks);
// part of Cargo.toml
wasmtime = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0", default-features = false, features = [
  "cranelift",
  "component-model",
  "async",
] }
wasmtime-wasi = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0"}

Steps to Reproduce

The last step is just a copy of src/commands/run.rs which replaced all related things to component version.

Expected Results

Print the string to stdout.

Actual Results

└─>   cargo run ../rskyeye/seesee/seesee.component.wasm
    Finished dev [unoptimized + debuginfo] target(s) in 0.18s
     Running `target/debug/runner ../rskyeye/seesee/seesee.component.wasm`
Error: error while executing at wasm backtrace:
    0: 0x9792 - <unknown>!rust_panic
    1: 0x9780 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0x8728 - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0x865e - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0x8eae - <unknown>!rust_begin_unwind
    5: 0x231a - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x7c20 - <unknown>!std::io::stdio::_print::hc2f2653d6b9a5348
    7: 0x578a - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

Versions and Environment

Wasmtime version or commit:

Tried both branch "release-10.0.0" and commit "92024ad11728efa9b3b59b426ebc7cc817cebf6b" which is the last component type version 2 version.

component adapter:

Tried both commit 92024ad (component type version 2, with wasm-tools 1.0.34) and f7ae056 (component type version 3, with wasm-tools 1.0.35) with exactly the same commit of wasmtime and wasmtime_wasi.

Operating system: Linux fedora 6.2.14-300.fc38.x86_64

Architecture: AMD64

Extra Info

The same wasm file works before composing to component with adapter when run following command on all of version 8.0.0, 9.0.0, 9.0.3 and commit 92024ad11728efa9b3b59b426ebc7cc817cebf6b:

wasmtime run seesee.wasi.wasm --invoke run

view this post on Zulip Wasmtime GitHub notifications bot (Jun 09 2023 at 09:39):

hurae labeled issue #6545:

Test Case

Simple hello world example, works fine with wasi preview1, but panic for component model.

seesee.zip

// wit/see.wit
package plugin:see

world see {
  export run: func() -> result
}
// seesee/src/lib.rs
wit_bindgen::generate!({
    path: "../wit/see.wit",
    world: "see",
});

struct Checks;

impl See for Checks {
    fn run() -> Result<(), ()> {
        println!("Hello, world!");

        Ok(())
    }
}

export_see!(Checks);
// part of Cargo.toml
wasmtime = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0", default-features = false, features = [
  "cranelift",
  "component-model",
  "async",
] }
wasmtime-wasi = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0"}

Steps to Reproduce

The last step is just a copy of src/commands/run.rs which replaced all related things to component version.

Expected Results

Print the string to stdout.

Actual Results

└─>   cargo run ../rskyeye/seesee/seesee.component.wasm
    Finished dev [unoptimized + debuginfo] target(s) in 0.18s
     Running `target/debug/runner ../rskyeye/seesee/seesee.component.wasm`
Error: error while executing at wasm backtrace:
    0: 0x9792 - <unknown>!rust_panic
    1: 0x9780 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0x8728 - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0x865e - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0x8eae - <unknown>!rust_begin_unwind
    5: 0x231a - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x7c20 - <unknown>!std::io::stdio::_print::hc2f2653d6b9a5348
    7: 0x578a - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

Versions and Environment

Wasmtime version or commit:

Tried both branch "release-10.0.0" and commit "92024ad11728efa9b3b59b426ebc7cc817cebf6b" which is the last component type version 2 version.

component adapter:

Tried both commit 92024ad (component type version 2, with wasm-tools 1.0.34) and f7ae056 (component type version 3, with wasm-tools 1.0.35) with exactly the same commit of wasmtime and wasmtime_wasi.

Operating system: Linux fedora 6.2.14-300.fc38.x86_64

Architecture: AMD64

Extra Info

The same wasm file works before composing to component with adapter when run following command on all of version 8.0.0, 9.0.0, 9.0.3 and commit 92024ad11728efa9b3b59b426ebc7cc817cebf6b:

wasmtime run seesee.wasi.wasm --invoke run

view this post on Zulip Wasmtime GitHub notifications bot (Jun 09 2023 at 09:48):

hurae edited issue #6545:

Test Case

Simple hello world example, works fine with wasi preview1, but panic for component model.

// wit/see.wit
package plugin:see

world see {
  export run: func() -> result
}
// seesee/src/lib.rs
wit_bindgen::generate!({
    path: "../wit/see.wit",
    world: "see",
});

struct Checks;

impl See for Checks {
    fn run() -> Result<(), ()> {
        println!("Hello, world!");

        Ok(())
    }
}

export_see!(Checks);
// part of Cargo.toml
wasmtime = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0", default-features = false, features = [
  "cranelift",
  "component-model",
  "async",
] }
wasmtime-wasi = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0"}

Steps to Reproduce

The last step is just a copy of src/commands/run.rs which replaced all related things to component version.

Expected Results

Print the string to stdout.

Actual Results

└─>   cargo run ../rskyeye/seesee/seesee.component.wasm
    Finished dev [unoptimized + debuginfo] target(s) in 0.18s
     Running `target/debug/runner ../rskyeye/seesee/seesee.component.wasm`
Error: error while executing at wasm backtrace:
    0: 0x9792 - <unknown>!rust_panic
    1: 0x9780 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0x8728 - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0x865e - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0x8eae - <unknown>!rust_begin_unwind
    5: 0x231a - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x7c20 - <unknown>!std::io::stdio::_print::hc2f2653d6b9a5348
    7: 0x578a - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

Versions and Environment

Wasmtime version or commit:

Tried both branch "release-10.0.0" and commit "92024ad11728efa9b3b59b426ebc7cc817cebf6b" which is the last component type version 2 version.

component adapter:

Tried both commit 92024ad (component type version 2, with wasm-tools 1.0.34) and f7ae056 (component type version 3, with wasm-tools 1.0.35) with exactly the same commit of wasmtime and wasmtime_wasi.

Operating system: Linux fedora 6.2.14-300.fc38.x86_64

Architecture: AMD64

Extra Info

The same wasm file works before composing to component with adapter when run following command on all of version 8.0.0, 9.0.0, 9.0.3 and commit 92024ad11728efa9b3b59b426ebc7cc817cebf6b:

wasmtime run seesee.wasi.wasm --invoke run

view this post on Zulip Wasmtime GitHub notifications bot (Jun 09 2023 at 15:01):

pchickey commented on issue #6545:

Log would be helpful here as well

view this post on Zulip Wasmtime GitHub notifications bot (Jun 12 2023 at 03:08):

hurae commented on issue #6545:

wasmtime_wasi didn't produce any log. Here is the best result I can get:

set this: RUST_LOG=trace,cranelift_codegen=info,wasmtime_cranelift::compiler=info,cranelift_wasm::func_translator=info

[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(3)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .wasmtime.engine
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .symtab
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .strtab
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .shstrtab
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] ====== Capturing Backtrace ======
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] === Tracing through contiguous sequence of Wasm frames ===
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] trampoline_sp = 0x00007f24f3205220
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace]    initial pc = 0x00007f24f321d9e4
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace]    initial fp = 0x00007f24f32050e0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321d9e4
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32050e0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321d01b
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205150
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321b56c
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205180
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321b3ff
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205190
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321c664
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051a0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f320a453
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051b0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f320ab80
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051d0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f3212908
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205210
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] === Done tracing contiguous sequence of Wasm frames ===
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] ====== Done Capturing Backtrace (reached end of activations) ======
Error: error while executing at wasm backtrace:
    0: 0xb237 - <unknown>!rust_panic
    1: 0xb225 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0xa1cd - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0xa103 - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0xa953 - <unknown>!rust_begin_unwind
    5: 0x236d - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x27ed - <unknown>!core::result::unwrap_failed::he6bfae7ea6f8795e
    7: 0x6281 - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

view this post on Zulip Wasmtime GitHub notifications bot (Jun 12 2023 at 03:19):

hurae edited a comment on issue #6545:

Reproduced in branch "release-10.0.0".

wasmtime_wasi didn't produce any log. Here is the best result I can get:

set this: RUST_LOG=trace,cranelift_codegen=info,wasmtime_cranelift::compiler=info,cranelift_wasm::func_translator=info

[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] creating instance InstanceId(3)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(2)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(0)
[2023-06-12T03:04:46Z TRACE wasmtime_environ::component::dfg] referencing export of InstanceId(1)
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .wasmtime.engine
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .symtab
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .strtab
[2023-06-12T03:04:48Z DEBUG wasmtime_jit::code_memory] ignoring section .shstrtab
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] ====== Capturing Backtrace ======
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] === Tracing through contiguous sequence of Wasm frames ===
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] trampoline_sp = 0x00007f24f3205220
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace]    initial pc = 0x00007f24f321d9e4
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace]    initial fp = 0x00007f24f32050e0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321d9e4
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32050e0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321d01b
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205150
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321b56c
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205180
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321b3ff
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205190
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f321c664
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051a0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f320a453
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051b0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f320ab80
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f32051d0
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] --- Tracing through one Wasm frame ---
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] pc = 0x7f24f3212908
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] fp = 0x7f24f3205210
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] === Done tracing contiguous sequence of Wasm frames ===
[2023-06-12T03:04:48Z TRACE wasmtime_runtime::traphandlers::backtrace] ====== Done Capturing Backtrace (reached end of activations) ======
Error: error while executing at wasm backtrace:
    0: 0xb237 - <unknown>!rust_panic
    1: 0xb225 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0xa1cd - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0xa103 - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0xa953 - <unknown>!rust_begin_unwind
    5: 0x236d - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x27ed - <unknown>!core::result::unwrap_failed::he6bfae7ea6f8795e
    7: 0x6281 - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

view this post on Zulip Wasmtime GitHub notifications bot (Jun 26 2023 at 10:44):

hurae commented on issue #6545:

Fixed by https://github.com/bytecodealliance/wasmtime/issues/6546 , same reason.

view this post on Zulip Wasmtime GitHub notifications bot (Jun 26 2023 at 10:44):

hurae closed issue #6545:

Test Case

Simple hello world example, works fine with wasi preview1, but panic for component model.

// wit/see.wit
package plugin:see

world see {
  export run: func() -> result
}
// seesee/src/lib.rs
wit_bindgen::generate!({
    path: "../wit/see.wit",
    world: "see",
});

struct Checks;

impl See for Checks {
    fn run() -> Result<(), ()> {
        println!("Hello, world!");

        Ok(())
    }
}

export_see!(Checks);
// part of Cargo.toml
wasmtime = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0", default-features = false, features = [
  "cranelift",
  "component-model",
  "async",
] }
wasmtime-wasi = { git = "https://github.com/bytecodealliance/wasmtime", branch = "release-10.0.0"}

Steps to Reproduce

The last step is just a copy of src/commands/run.rs which replaced all related things to component version.

Expected Results

Print the string to stdout.

Actual Results

└─>   cargo run ../rskyeye/seesee/seesee.component.wasm
    Finished dev [unoptimized + debuginfo] target(s) in 0.18s
     Running `target/debug/runner ../rskyeye/seesee/seesee.component.wasm`
Error: error while executing at wasm backtrace:
    0: 0x9792 - <unknown>!rust_panic
    1: 0x9780 - <unknown>!std::panicking::rust_panic_with_hook::h1c67ce6bc4eb31b7
    2: 0x8728 - <unknown>!std::panicking::begin_panic_handler::{{closure}}::h749586aa4ef76f6f
    3: 0x865e - <unknown>!std::sys_common::backtrace::__rust_end_short_backtrace::h426b71926848cb31
    4: 0x8eae - <unknown>!rust_begin_unwind
    5: 0x231a - <unknown>!core::panicking::panic_fmt::hf4ce15c1b219b988
    6: 0x7c20 - <unknown>!std::io::stdio::_print::hc2f2653d6b9a5348
    7: 0x578a - <unknown>!run

Caused by:
    wasm trap: wasm `unreachable` instruction executed

Versions and Environment

Wasmtime version or commit:

Tried both branch "release-10.0.0" and commit "92024ad11728efa9b3b59b426ebc7cc817cebf6b" which is the last component type version 2 version.

component adapter:

Tried both commit 92024ad (component type version 2, with wasm-tools 1.0.34) and f7ae056 (component type version 3, with wasm-tools 1.0.35) with exactly the same commit of wasmtime and wasmtime_wasi.

Operating system: Linux fedora 6.2.14-300.fc38.x86_64

Architecture: AMD64

Extra Info

The same wasm file works before composing to component with adapter when run following command on all of version 8.0.0, 9.0.0, 9.0.3 and commit 92024ad11728efa9b3b59b426ebc7cc817cebf6b:

wasmtime run seesee.wasi.wasm --invoke run

Last updated: Nov 22 2024 at 16:03 UTC