yagehu opened issue #7116:
Test Case
(module (type (func)) (type (func (param i32 i64 i64 i32) (result i32))) (type (func (param i32))) (import "wasi_snapshot_preview1" "fd_advise" (func $fd_advise (type 1))) (import "wasi_snapshot_preview1" "proc_exit" (func $proc_exit (type 2))) (func $_start (type 0) (call $fd_advise i32.const 0 i64.const 0 i64.const 0 i32.const 6 ;; <-- ) (call $proc_exit) ) (memory (;0;) 2) (export "memory" (memory 0)) (export "_start" (func $_start)) )
Steps to Reproduce
Run the above WAT file with Wasmtime.
wasmtime run enum.wat
Expected Results
The
fd_advise
function should return an error code likeinval
. Theadvice
variant is specified to 6 cases, soi32.const
0 to 5 should be valid. But invalid ones shouldn't crash the runtime.Actual Results
Wasmtime prints a stacktrace:
Error: failed to run main module `enum.wat` Caused by: 0: failed to invoke command default 1: error while executing at wasm backtrace: 0: 0x8e - <unknown>!_start 2: In func wasi_snapshot_preview1::fd_advise at convert Advice: Invalid enum value Advice 3: Invalid enum value Advice
Versions and Environment
Wasmtime version or commit: 12.0.2
Operating system: macOS Sonoma 14.0
Architecture: amd64
Extra Info
Wasmer seems to do the correct thing here.
yagehu added the bug label to Issue #7116.
yagehu edited issue #7116:
Test Case
(module (type (func)) (type (func (param i32 i64 i64 i32) (result i32))) (type (func (param i32))) (import "wasi_snapshot_preview1" "fd_advise" (func $fd_advise (type 1))) (import "wasi_snapshot_preview1" "proc_exit" (func $proc_exit (type 2))) (func $_start (type 0) (call $fd_advise i32.const 0 i64.const 0 i64.const 0 i32.const 6 ;; <-- ) (call $proc_exit) ) (memory (;0;) 2) (export "memory" (memory 0)) (export "_start" (func $_start)) )
Steps to Reproduce
Run the above WAT file with Wasmtime.
wasmtime run enum.wat
Expected Results
The
fd_advise
function should return an error code likeinval
. Theadvice
variant is specified to 6 cases, soi32.const
0 to 5 should be valid. But invalid ones shouldn't crash the runtime.Actual Results
Wasmtime prints a stacktrace:
Error: failed to run main module `enum.wat` Caused by: 0: failed to invoke command default 1: error while executing at wasm backtrace: 0: 0x8e - <unknown>!_start 2: In func wasi_snapshot_preview1::fd_advise at convert Advice: Invalid enum value Advice 3: Invalid enum value Advice
Versions and Environment
Wasmtime version or commit: 12.0.2
Operating system: macOS Sonoma 14.0
Architecture: amd64
Extra Info
Wasmer seems to do the correct thing here.
pchickey commented on issue #7116:
We treat invalid enum tags the same way we treat invalid and misaligned pointers, by trapping. This behavior has not been captured by the witx abi spec https://github.com/WebAssembly/WASI/blob/main/legacy/tools/witx-docs.md. However, it is required by the component-model spec, and so it will be enforced that way from preview 2 forward.
In general, if you made a programming mistake that results in an out-of-bounds enum variant being passed across the wasi abstraction, that isn't a programming error that can be handled dynamically at runtime, but instead a bug that the programmer must fix for their program to execute correctly. So, I don't think we should change this behavior. If you'd like to argue for it to be specified otherwise, we can hear from other spec implementors over in the WASI repo, but preview 1 behavior is water under the bridge at this point and I'm most interested in specifying preview 2 at this time.
pchickey closed issue #7116:
Test Case
(module (type (func)) (type (func (param i32 i64 i64 i32) (result i32))) (type (func (param i32))) (import "wasi_snapshot_preview1" "fd_advise" (func $fd_advise (type 1))) (import "wasi_snapshot_preview1" "proc_exit" (func $proc_exit (type 2))) (func $_start (type 0) (call $fd_advise i32.const 0 i64.const 0 i64.const 0 i32.const 6 ;; <-- ) (call $proc_exit) ) (memory (;0;) 2) (export "memory" (memory 0)) (export "_start" (func $_start)) )
Steps to Reproduce
Run the above WAT file with Wasmtime.
wasmtime run enum.wat
Expected Results
The
fd_advise
function should return an error code likeinval
. Theadvice
variant is specified to 6 cases, soi32.const
0 to 5 should be valid. But invalid ones shouldn't crash the runtime.Actual Results
Wasmtime prints a stacktrace:
Error: failed to run main module `enum.wat` Caused by: 0: failed to invoke command default 1: error while executing at wasm backtrace: 0: 0x8e - <unknown>!_start 2: In func wasi_snapshot_preview1::fd_advise at convert Advice: Invalid enum value Advice 3: Invalid enum value Advice
Versions and Environment
Wasmtime version or commit: 12.0.2
Operating system: macOS Sonoma 14.0
Architecture: amd64
Extra Info
Wasmer seems to do the correct thing here.
Last updated: Jan 24 2025 at 00:11 UTC