yuyang-ok opened issue #4256:
this segment fault seens only on riscv64 platform, and only with doing the test with
https://github.com/bytecodealliance/wasmtime/blob/main/cranelift/filetests/filetests/runtests/i128-load-store.clif.here are are gdb prompt
skipped cranelift/filetests/filetests/runtests/i128-load-store.clif: host can't run Aarch64(Aarch64) programs
Thread 3 "worker #0" received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff7c08cd0 (LWP 426)]
alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
224 /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs: No such file or directory.
(gdb) backtrace
#0 alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
#1 0x0000555556574d5a in alloc::vec::Vec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::as_ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:1140
#2 0x000055555657a9d0 in alloc::vec::{impl#10}::deref<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2497
#3 0x0000555556579ad4 in alloc::vec::{impl#14}::clone<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2543
#4 0x0000555555c8553a in cranelift_codegen::ir::extfunc::{impl#8}::clone (self=0xf7fc23a00000800f) at cranelift/codegen/src/ir/extfunc.rs:28
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
#6 0x0000555555cb346e in cranelift_filetests::function_runner::CompiledFunction::call (self=0x7fff, arguments=...)
at cranelift/filetests/src/function_runner.rs:176
#7 0x0100000000000000 in ?? ()
(gdb) frame 5
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
221 let _signature = signature.clone();
![image](https://user-images.githubusercontent.com/96557710/173004027-e3e5f977-737a-4d3a-bae1-39c26950a09f.png)
there is noway I can't clone signature, bu it just happend.
looks like signature.returns has a wrong pointer.
assert!(self.0.len() >= signature.returns.len()); will segment fault too.
yuyang-ok edited issue #4256:
this segment fault seens only on riscv64 platform, and only with doing the test with
https://github.com/bytecodealliance/wasmtime/blob/main/cranelift/filetests/filetests/runtests/i128-load-store.clif.here are are gdb prompt
skipped cranelift/filetests/filetests/runtests/i128-load-store.clif: host can't run Aarch64(Aarch64) programs
Thread 3 "worker #0" received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff7c08cd0 (LWP 426)]
alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
224 /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs: No such file or directory.
(gdb) backtrace
#0 alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
#1 0x0000555556574d5a in alloc::vec::Vec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::as_ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:1140
#2 0x000055555657a9d0 in alloc::vec::{impl#10}::deref<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2497
#3 0x0000555556579ad4 in alloc::vec::{impl#14}::clone<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2543
#4 0x0000555555c8553a in cranelift_codegen::ir::extfunc::{impl#8}::clone (self=0xf7fc23a00000800f) at cranelift/codegen/src/ir/extfunc.rs:28
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
#6 0x0000555555cb346e in cranelift_filetests::function_runner::CompiledFunction::call (self=0x7fff, arguments=...)
at cranelift/filetests/src/function_runner.rs:176
#7 0x0100000000000000 in ?? ()
(gdb) frame 5
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
221 let _signature = signature.clone();
![image](https://user-images.githubusercontent.com/96557710/173004027-e3e5f977-737a-4d3a-bae1-39c26950a09f.png)
there is noway I can't clone signature, but it just happend.
looks like signature.returns has a wrong pointer.
assert!(self.0.len() >= signature.returns.len()); will segment fault too.
yuyang-ok edited issue #4256:
this segment fault seens only on riscv64 platform, and only with doing the test with
https://github.com/bytecodealliance/wasmtime/blob/main/cranelift/filetests/filetests/runtests/i128-load-store.clif.here are are gdb prompt
skipped cranelift/filetests/filetests/runtests/i128-load-store.clif: host can't run Aarch64(Aarch64) programs
Thread 3 "worker #0" received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff7c08cd0 (LWP 426)]
alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
224 /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs: No such file or directory.
(gdb) backtrace
#0 alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
#1 0x0000555556574d5a in alloc::vec::Vec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::as_ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:1140
#2 0x000055555657a9d0 in alloc::vec::{impl#10}::deref<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2497
#3 0x0000555556579ad4 in alloc::vec::{impl#14}::clone<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2543
#4 0x0000555555c8553a in cranelift_codegen::ir::extfunc::{impl#8}::clone (self=0xf7fc23a00000800f) at cranelift/codegen/src/ir/extfunc.rs:28
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
#6 0x0000555555cb346e in cranelift_filetests::function_runner::CompiledFunction::call (self=0x7fff, arguments=...)
at cranelift/filetests/src/function_runner.rs:176
#7 0x0100000000000000 in ?? ()
(gdb) frame 5
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
221 let _signature = signature.clone();
![image](https://user-images.githubusercontent.com/96557710/173004027-e3e5f977-737a-4d3a-bae1-39c26950a09f.png)
there is noway I can't clone signature, but it just happend.
looks like signature.returns has a wrong pointer.
assert!(self.0.len() >= signature.returns.len() /* will segment fault too. */ );
bjorn3 commented on issue #4256:
What does
p *signature
show?
yuyang-ok commented on issue #4256:
(gdb) backtrace
#0 alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
#1 0x0000555556574d5a in alloc::vec::Vec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::as_ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:1140
#2 0x000055555657a9d0 in alloc::vec::{impl#10}::deref<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2497
#3 0x0000555556579ad4 in alloc::vec::{impl#14}::clone<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2543
#4 0x0000555555c8553a in cranelift_codegen::ir::extfunc::{impl#8}::clone (self=0xf7fc23a00000800f) at cranelift/codegen/src/ir/extfunc.rs:28
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
#6 0x0000555555cb346e in cranelift_filetests::function_runner::CompiledFunction::call (self=0x7fff, arguments=...)
at cranelift/filetests/src/function_runner.rs:176
#7 0x0100000000000000 in ?? ()
(gdb) frame 5
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
221 let _signature = signature.clone();
(gdb) p *signature
Cannot access memory at address 0xf7fc23a00000800f
bjorn3 commented on issue #4256:
And what does
info proc maps
show?
yuyang-ok commented on issue #4256:
(gdb) info proc maps
Too many parameters: maps
bjorn3 commented on issue #4256:
I meant
info proc map
without thes
. My bad.
yuyang-ok commented on issue #4256:
Mapped address spaces:
Start Addr End Addr Size Offset objfile 0x555555555000 0x555556ffc000 0x1aa7000 0x0 /root/share/wasmtime/target/riscv64gc-unknown-linux-gnu/debug/clif-util 0x555556ffc000 0x5555571c9000 0x1cd000 0x1aa6000 /root/share/wasmtime/target/riscv64gc-unknown-linux-gnu/debug/clif-util 0x5555571c9000 0x5555571cd000 0x4000 0x1c73000 /root/share/wasmtime/target/riscv64gc-unknown-linux-gnu/debug/clif-util 0x5555571cd000 0x5555571ef000 0x22000 0x0 [heap] 0x7fffd0000000 0x7fffd0021000 0x21000 0x0 0x7fffd0021000 0x7fffd4000000 0x3fdf000 0x0 0x7fffd4000000 0x7fffd4021000 0x21000 0x0 0x7fffd4021000 0x7fffd8000000 0x3fdf000 0x0 0x7fffd8000000 0x7fffd8021000 0x21000 0x0 0x7fffd8021000 0x7fffdc000000 0x3fdf000 0x0 0x7fffdc000000 0x7fffdc021000 0x21000 0x0 0x7fffdc021000 0x7fffe0000000 0x3fdf000 0x0 0x7fffe0000000 0x7fffe0021000 0x21000 0x0 0x7fffe0021000 0x7fffe4000000 0x3fdf000 0x0 0x7fffe4000000 0x7fffe4021000 0x21000 0x0 0x7fffe4021000 0x7fffe8000000 0x3fdf000 0x0 0x7fffe8000000 0x7fffe8021000 0x21000 0x0 0x7fffe8021000 0x7fffec000000 0x3fdf000 0x0 0x7fffec000000 0x7fffec021000 0x21000 0x0 0x7fffec021000 0x7ffff0000000 0x3fdf000 0x0 0x7ffff0000000 0x7ffff0021000 0x21000 0x0 0x7ffff0021000 0x7ffff4000000 0x3fdf000 0x0 0x7ffff6bed000 0x7ffff6bee000 0x1000 0x0 0x7ffff6bee000 0x7ffff6dee000 0x200000 0x0 0x7ffff6df1000 0x7ffff6df2000 0x1000 0x0 0x7ffff6df2000 0x7ffff6ff2000 0x200000 0x0 0x7ffff6ff8000 0x7ffff6ff9000 0x1000 0x0 0x7ffff6ff9000 0x7ffff71f9000 0x200000 0x0 0x7ffff71f9000 0x7ffff71fa000 0x1000 0x0 0x7ffff71fa000 0x7ffff73fa000 0x200000 0x0 0x7ffff73fd000 0x7ffff73fe000 0x1000 0x0 0x7ffff73fe000 0x7ffff75fe000 0x200000 0x0 0x7ffff7601000 0x7ffff7602000 0x1000 0x0
yuyang-ok commented on issue #4256:
0x7ffff7602000 0x7ffff7802000 0x200000 0x0
0x7ffff7805000 0x7ffff7806000 0x1000 0x0
0x7ffff7806000 0x7ffff7a06000 0x200000 0x0
0x7ffff7a06000 0x7ffff7a07000 0x1000 0x0
0x7ffff7a07000 0x7ffff7a09000 0x2000 0x0
0x7ffff7a09000 0x7ffff7a0a000 0x1000 0x0
0x7ffff7a0a000 0x7ffff7c0a000 0x200000 0x0
0x7ffff7c0a000 0x7ffff7c0b000 0x1000 0x0
0x7ffff7c0b000 0x7ffff7c0d000 0x2000 0x0
0x7ffff7c0d000 0x7ffff7c0e000 0x1000 0x0
0x7ffff7c0e000 0x7ffff7e10000 0x202000 0x0
0x7ffff7e10000 0x7ffff7f13000 0x103000 0x0 /lib/riscv64-linux-gnu/libc-2.33.so
0x7ffff7f13000 0x7ffff7f17000 0x4000 0x102000 /lib/riscv64-linux-gnu/libc-2.33.so
0x7ffff7f17000 0x7ffff7f19000 0x2000 0x106000 /lib/riscv64-linux-gnu/libc-2.33.so
0x7ffff7f19000 0x7ffff7f21000 0x8000 0x0
0x7ffff7f21000 0x7ffff7f23000 0x2000 0x0 /lib/riscv64-linux-gnu/libdl-2.33.so
0x7ffff7f23000 0x7ffff7f24000 0x1000 0x1000 /lib/riscv64-linux-gnu/libdl-2.33.so
0x7ffff7f24000 0x7ffff7f25000 0x1000 0x2000 /lib/riscv64-linux-gnu/libdl-2.33.so
0x7ffff7f25000 0x7ffff7fa6000 0x81000 0x0 /lib/riscv64-linux-gnu/libm-2.33.so
0x7ffff7fa6000 0x7ffff7fa7000 0x1000 0x81000 /lib/riscv64-linux-gnu/libm-2.33.so
0x7ffff7fa7000 0x7ffff7fa8000 0x1000 0x81000 /lib/riscv64-linux-gnu/libm-2.33.so
0x7ffff7fa8000 0x7ffff7fa9000 0x1000 0x82000 /lib/riscv64-linux-gnu/libm-2.33.so
0x7ffff7fa9000 0x7ffff7fbd000 0x14000 0x0 /lib/riscv64-linux-gnu/libpthread-2.33.so
0x7ffff7fbd000 0x7ffff7fbe000 0x1000 0x13000 /lib/riscv64-linux-gnu/libpthread-2.33.so
0x7ffff7fbe000 0x7ffff7fbf000 0x1000 0x14000 /lib/riscv64-linux-gnu/libpthread-2.33.so
0x7ffff7fbf000 0x7ffff7fc3000 0x4000 0x0
0x7ffff7fc3000 0x7ffff7fd5000 0x12000 0x0 /lib/riscv64-linux-gnu/libgcc_s.so.1
0x7ffff7fd5000 0x7ffff7fd6000 0x1000 0x11000 /lib/riscv64-linux-gnu/libgcc_s.so.1
0x7ffff7fd6000 0x7ffff7fd7000 0x1000 0x12000 /lib/riscv64-linux-gnu/libgcc_s.so.1
0x7ffff7fd7000 0x7ffff7fd9000 0x2000 0x0
0x7ffff7fd9000 0x7ffff7fda000 0x1000 0x0
0x7ffff7fda000 0x7ffff7fdb000 0x1000 0x0
0x7ffff7fdb000 0x7ffff7fdd000 0x2000 0x0
0x7ffff7fdd000 0x7ffff7fdf000 0x2000 0x0 [vvar]
0x7ffff7fdf000 0x7ffff7fe1000 0x2000 0x0 [vdso]
0x7ffff7fe1000 0x7ffff7ffc000 0x1b000 0x0 /lib/riscv64-linux-gnu/ld-2.33.so
0x7ffff7ffc000 0x7ffff7ffd000 0x1000 0x0
yuyang-ok commented on issue #4256:
0x7ffff7ffd000 0x7ffff7ffe000 0x1000 0x1b000 /lib/riscv64-linux-gnu/ld-2.33.so
0x7ffff7ffe000 0x7ffff8000000 0x2000 0x1c000 /lib/riscv64-linux-gnu/ld-2.33.so
0x7ffffffdf000 0x800000000000 0x21000 0x0 [stack]
bjorn3 commented on issue #4256:
Looks like that pointer is getting corrupted pretty badly. There is no memory mapped nearby. You may need to poke around in
CompiledFunction::call
and elsewhere to see where the bad pointer originated from.
yuyang-ok commented on issue #4256:
ok
yuyang-ok edited a comment on issue #4256:
ok,thanks.
yuyang-ok commented on issue #4256:
maybe My some other code corrupted the pointer,I need some time to figure out. close it for now.
yuyang-ok closed issue #4256:
this segment fault seens only on riscv64 platform, and only with doing the test with
https://github.com/bytecodealliance/wasmtime/blob/main/cranelift/filetests/filetests/runtests/i128-load-store.clif.here are are gdb prompt
skipped cranelift/filetests/filetests/runtests/i128-load-store.clif: host can't run Aarch64(Aarch64) programs
Thread 3 "worker #0" received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff7c08cd0 (LWP 426)]
alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
224 /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs: No such file or directory.
(gdb) backtrace
#0 alloc::raw_vec::RawVec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/raw_vec.rs:224
#1 0x0000555556574d5a in alloc::vec::Vec<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global>::as_ptr<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f) at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:1140
#2 0x000055555657a9d0 in alloc::vec::{impl#10}::deref<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2497
#3 0x0000555556579ad4 in alloc::vec::{impl#14}::clone<cranelift_codegen::ir::extfunc::AbiParam, alloc::alloc::Global> (self=0xf7fc23a00000800f)
at /rustc/c35035cefc709abddabfb28ecc6a326458d46ce2/library/alloc/src/vec/mod.rs:2543
#4 0x0000555555c8553a in cranelift_codegen::ir::extfunc::{impl#8}::clone (self=0xf7fc23a00000800f) at cranelift/codegen/src/ir/extfunc.rs:28
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
#6 0x0000555555cb346e in cranelift_filetests::function_runner::CompiledFunction::call (self=0x7fff, arguments=...)
at cranelift/filetests/src/function_runner.rs:176
#7 0x0100000000000000 in ?? ()
(gdb) frame 5
#5 0x0000555555cb3786 in cranelift_filetests::function_runner::UnboxedValues::collect_returns (self=0x7ffff7c01b08, signature=0xf7fc23a00000800f)
at cranelift/filetests/src/function_runner.rs:221
221 let _signature = signature.clone();
![image](https://user-images.githubusercontent.com/96557710/173004027-e3e5f977-737a-4d3a-bae1-39c26950a09f.png)
there is noway I can't clone signature, but it just happend.
looks like signature.returns has a wrong pointer.
assert!(self.0.len() >= signature.returns.len() /* will segment fault too. */ );
Last updated: Jan 24 2025 at 00:11 UTC