alexcrichton added the winch label to Issue #8632.
alexcrichton opened issue #8632:
Given this input:
(module (func (result i32 i32 i32) i32.const 1 i32.eqz f64.const 0 f64.const 1 f64.ne i32.const 1111 ) (export "d" (func 0)) )
I locally get:
$ ./target/release/wasmtime run -C compiler=cranelift --invoke d out.wat warning: using `--invoke` with a function that returns values is experimental and may break in the future 0 1 1111 $ ./target/release/wasmtime run -C compiler=winch --invoke d out.wat warning: using `--invoke` with a function that returns values is experimental and may break in the future 0 0 1111
Notably the second return value here, the
f64.ne
branch, differs in Winch and Cranelift. I believe that Cranelift is correct in this case, hence the bug report for winch.cc @saulecabrera
github-actions[bot] commented on issue #8632:
Subscribe to Label Action
cc @saulecabrera
<details>
This issue or pull request has been labeled: "winch"Thus the following users have been cc'd because of the following labels:
- saulecabrera: winch
To subscribe or unsubscribe from this label, edit the <code>.github/subscribe-to-label.json</code> configuration file.
Learn more.
</details>
alexcrichton added the fuzz-bug label to Issue #8632.
alexcrichton commented on issue #8632:
For reference the compiler outputs for this function are:
<details>
<summary>cranelift</summary>
0000000000000000 <wasm[0]::function[0]>: 0: 55 push %rbp 1: 48 89 e5 mov %rsp,%rbp 4: 31 c0 xor %eax,%eax 6: c5 c1 57 cf vxorpd %xmm7,%xmm7,%xmm1 a: c5 f9 2e 0d 1e 00 00 vucomisd 0x1e(%rip),%xmm1 # 30 <wasm[0]::function[0]+0x30> 11: 00 12: 40 0f 9a c6 setp %sil 16: 40 0f 95 c7 setne %dil 1a: 09 fe or %edi,%esi 1c: 40 0f b6 ce movzbl %sil,%ecx 20: ba 57 04 00 00 mov $0x457,%edx 25: 48 89 ec mov %rbp,%rsp 28: 5d pop %rbp 29: c3 ret ... 36: f0 3f lock (bad) ...
</details>
<details>
<summary>winch</summary>
0000000000000000 <wasm[0]::function[0]>: 0: 55 push %rbp 1: 48 89 e5 mov %rsp,%rbp 4: 4c 8b 5f 08 mov 0x8(%rdi),%r11 8: 4d 8b 1b mov (%r11),%r11 b: 49 81 c3 24 00 00 00 add $0x24,%r11 12: 49 39 e3 cmp %rsp,%r11 15: 0f 87 83 00 00 00 ja 9e <wasm[0]::function[0]+0x9e> 1b: 49 89 fe mov %rdi,%r14 1e: 48 83 ec 18 sub $0x18,%rsp 22: 48 89 7c 24 10 mov %rdi,0x10(%rsp) 27: 48 89 74 24 08 mov %rsi,0x8(%rsp) 2c: 48 89 14 24 mov %rdx,(%rsp) 30: b8 01 00 00 00 mov $0x1,%eax 35: 83 f8 00 cmp $0x0,%eax 38: b8 00 00 00 00 mov $0x0,%eax 3d: 40 0f 94 c0 rex sete %al 41: f2 0f 10 05 57 00 00 movsd 0x57(%rip),%xmm0 # a0 <wasm[0]::function[0]+0xa0> 48: 00 49: f2 0f 10 0d 57 00 00 movsd 0x57(%rip),%xmm1 # a8 <wasm[0]::function[0]+0xa8> 50: 00 51: 66 0f 2e c8 ucomisd %xmm0,%xmm1 55: b9 00 00 00 00 mov $0x0,%ecx 5a: 40 0f 95 c1 rex setne %cl 5e: 41 bb 00 00 00 00 mov $0x0,%r11d 64: 41 0f 9a c3 setp %r11b 68: 4c 09 d9 or %r11,%rcx 6b: 48 83 ec 04 sub $0x4,%rsp 6f: 89 04 24 mov %eax,(%rsp) 72: 51 push %rcx 73: b8 57 04 00 00 mov $0x457,%eax 78: 48 83 c4 04 add $0x4,%rsp 7c: 48 8b 4c 24 08 mov 0x8(%rsp),%rcx 81: 44 8b 1c 24 mov (%rsp),%r11d 85: 48 83 c4 04 add $0x4,%rsp 89: 44 89 19 mov %r11d,(%rcx) 8c: 44 8b 1c 24 mov (%rsp),%r11d 90: 48 83 c4 04 add $0x4,%rsp 94: 44 89 59 04 mov %r11d,0x4(%rcx) 98: 48 83 c4 18 add $0x18,%rsp 9c: 5d pop %rbp 9d: c3 ret 9e: 0f 0b ud2 a0: 00 00 add %al,(%rax) a2: 00 00 add %al,(%rax) a4: 00 00 add %al,(%rax) a6: f0 3f lock (bad) ...
</details>
saulecabrera assigned saulecabrera to issue #8632.
saulecabrera commented on issue #8632:
Thanks for catching this one, Alex! I'll take a look.
saulecabrera commented on issue #8632:
A quick update: I've identified the root cause and I'm working on fix. There's a bug in the stack shuffling algorithm which is causing truncation of values when handling multi-value returns.
saulecabrera commented on issue #8632:
The stack shuffling algorithm was a bit of a red herring. Here's a fix: https://github.com/bytecodealliance/wasmtime/pull/8685/files
saulecabrera closed issue #8632:
Given this input:
(module (func (result i32 i32 i32) i32.const 1 i32.eqz f64.const 0 f64.const 1 f64.ne i32.const 1111 ) (export "d" (func 0)) )
I locally get:
$ ./target/release/wasmtime run -C compiler=cranelift --invoke d out.wat warning: using `--invoke` with a function that returns values is experimental and may break in the future 0 1 1111 $ ./target/release/wasmtime run -C compiler=winch --invoke d out.wat warning: using `--invoke` with a function that returns values is experimental and may break in the future 0 0 1111
Notably the second return value here, the
f64.ne
branch, differs in Winch and Cranelift. I believe that Cranelift is correct in this case, hence the bug report for winch.cc @saulecabrera
Last updated: Jan 24 2025 at 00:11 UTC