pchickey opened PR #6462 from bytecodealliance:pch/release-9-wasi-rights-read-write
to bytecodealliance:release-9.0.0
:
https://github.com/bytecodealliance/wasmtime/pull/6265 introduced a regression with programs using wasi-libc, reported at https://github.com/WebAssembly/wasi-libc/issues/415.
Wasi-libc read the rights of the base directory (using
fd_fdstat_get
) and used those to mask the rights requested topath_open
. In 6265, I changed the behavior of fdstat_get to always report and empty set of rights. This means that Wasi-libc will always pass an empty set of rights topath_open
, which is a problem because theFD_READ
andFD_WRITE
rights are how path_open determines if a descriptor is to be opened for reading, writing, or both.The fix is as follows:
- directories always return the full set of rights in
fd_fdstat_get
.- we record the access mode that a file is opened with, and use that to set the
FD_READ
andFD_WRITE
bits infs_rights_base
for a file'sfd_fdstat_get
.- A test demonstrates the behavior of the fdstat rights bits, and that opening for reading, writing, or reading and writing behaves correctly when calling
fd_read
andfd_write
pchickey requested wasmtime-core-reviewers for a review on PR #6462.
pchickey requested alexcrichton for a review on PR #6462.
pchickey edited PR #6462:
https://github.com/bytecodealliance/wasmtime/pull/6265 introduced a regression with programs using wasi-libc, reported at https://github.com/WebAssembly/wasi-libc/issues/415.
Wasi-libc read the rights of the base directory (using
fd_fdstat_get
) and used those to mask the rights requested topath_open
. In 6265, I changed the behavior of fdstat_get to always report and empty set of rights. This means that Wasi-libc will always pass an empty set of rights topath_open
, which is a problem because theFD_READ
andFD_WRITE
rights are how path_open determines if a descriptor is to be opened for reading, writing, or both.The fix is as follows:
- directories always return the full set of rights in
fd_fdstat_get
.- we record the access mode that a file is opened with, and use that to set the
FD_READ
andFD_WRITE
bits infs_rights_base
for a file'sfd_fdstat_get
.- A test demonstrates the behavior of the fdstat rights bits, and that opening for reading, writing, or reading and writing behaves correctly when calling
fd_read
andfd_write
This PR is just for the
release-9.0.0
branch, I will work on upstreaming it tomain
but the situation there is slightly more complex because the test also needs to pass under the preview 2 implementation.
pchickey updated PR #6462.
pchickey requested sunfishcode for a review on PR #6462.
pchickey updated PR #6462.
alexcrichton submitted PR review.
sunfishcode submitted PR review.
pchickey merged PR #6462.
squeek502 commented on PR #6462:
The bug that this fixed seems to have been reintroduced. With
wasmtime 23.0.1
andwasi-sdk 23.0
:
open-rw.c
:#include <stdio.h> #include <stdlib.h> int main() { // Note: using an `openat` call directly here with O_WRONLY or O_RDWR would have the same result FILE* file = fopen("testfile", "w"); if (!file) return 1; fclose(file); return 0; }
$ ls testfile testfile $ $WASI_SDK/bin/clang --sysroot=$WASI_SDK/share/wasi-sysroot open-rw.c -o open-rw-sdk.wasm $ strace -e trace=openat2 wasmtime --dir=. open-rw-sdk.wasm openat2(3, "testfile", {flags=O_RDONLY|O_CLOEXEC, resolve=RESOLVE_NO_MAGICLINKS|RESOLVE_BENEATH}, 24) = 5 +++ exited with 0 +++
wasmtime
is callingopenat2
withRDONLY
, but"w"
was passed as the access mode.
squeek502 edited a comment on PR #6462:
The bug that this fixed seems to have been reintroduced. With
wasmtime 23.0.1
andwasi-sdk 23.0
:
open-w.c
:#include <stdio.h> #include <stdlib.h> int main() { FILE* file = fopen("testfile", "w"); if (!file) return 1; fclose(file); return 0; }
$ ls testfile testfile $ $WASI_SDK/bin/clang --sysroot=$WASI_SDK/share/wasi-sysroot open-w.c -o open-w-sdk.wasm $ strace -e trace=openat2 wasmtime --dir=. open-w-sdk.wasm openat2(3, "testfile", {flags=O_RDONLY|O_LARGEFILE|O_CLOEXEC, resolve=RESOLVE_NO_MAGICLINKS|RESOLVE_BENEATH}, 24) = 11 +++ exited with 0 +++
wasmtime
is callingopenat2
withRDONLY
, but"w"
was passed as the access mode.
squeek502 deleted a comment on PR #6462:
The bug that this fixed seems to have been reintroduced. With
wasmtime 23.0.1
andwasi-sdk 23.0
:
open-w.c
:#include <stdio.h> #include <stdlib.h> int main() { FILE* file = fopen("testfile", "w"); if (!file) return 1; fclose(file); return 0; }
$ ls testfile testfile $ $WASI_SDK/bin/clang --sysroot=$WASI_SDK/share/wasi-sysroot open-w.c -o open-w-sdk.wasm $ strace -e trace=openat2 wasmtime --dir=. open-w-sdk.wasm openat2(3, "testfile", {flags=O_RDONLY|O_LARGEFILE|O_CLOEXEC, resolve=RESOLVE_NO_MAGICLINKS|RESOLVE_BENEATH}, 24) = 11 +++ exited with 0 +++
wasmtime
is callingopenat2
withRDONLY
, but"w"
was passed as the access mode.
Last updated: Jan 24 2025 at 00:11 UTC