pchickey opened PR #7876 from bytecodealliance:pch/preview2_fs_dont_mask_perms
to bytecodealliance:main
:
First update the fd_filestat_set test to assert that the filestat_set operations on a file descriptor behaves the same whether opened readonly or readwrite. This test now reproduces the behavior reported in https://github.com/bytecodealliance/wasmtime/issues/7829. wasi-common passes this changed test, but wasmtime-wasi::preview2 does not, showing that this is a regression between the two implementations.
Then, in preview2 implementation, track open_mode for a File and Dir, and use that instead of reporting permissions in DescriptorFlags.
FilePerms/DirPerms is a way of having wasmtime-wasi, instead of the operating system, mediate permissions on a preview2 Descriptor. This was conflated with the open mode, which should determine whether DescriptorFlags contains READ or WRITE or MUTATE_DIRECTORY.
- don't mask FilePerms with the DescriptorFlags (oflags) in path_open
- File and Dir now track their open_mode (represented using FilePerms)
and report them in DescriptorFlags
pchickey requested alexcrichton for a review on PR #7876.
pchickey requested wasmtime-core-reviewers for a review on PR #7876.
pchickey requested sunfishcode for a review on PR #7876.
sunfishcode submitted PR review.
sunfishcode created PR review comment:
This doesn't seem right. If we open the file with just
RIGHTS_FD_READ
, we shuldn't be able to dofd_filestat_set_size
on it. That would be analogous in POSIX to opening a file withFD_READ
and callingftruncate
, which is defined to fail.
pchickey submitted PR review.
pchickey created PR review comment:
That was what I thought too but I didnt chase it down in the ftruncate case. From the python test suite I found that futime is expected to succeed even when a file is read-only. So, I'll have to change this test, as well as set-len to check the open mode and reject size changes when not open for writing (fail with EINVAL, which I prefer here to EBADF) but permit set-times.
sunfishcode edited PR review comment.
pchickey edited PR review comment.
pchickey updated PR #7876.
pchickey submitted PR review.
pchickey created PR review comment:
This problem ended up being down to how the test was written. wasi::OFLAGS_CREAT implies that the WASI impl open the file with the O_RRONLY or O_RDWR in posix, so we were never actually opening a file just for reading in this test. I changed the test to create the file, then open it under the requested mode, and it behaves as expected.
pchickey commented on PR #7876:
I believe the test now shows that the implementations all behave as expected.
pchickey edited a comment on PR #7876:
I believe the test now shows that the implementations all behave as desired.
pchickey requested sunfishcode for a review on PR #7876.
alexcrichton submitted PR review:
Seems reasonable to me but I'm finding it difficult to follow what each of the sets of permissions are so I'm not 100% sure. Could you expand a bit on how this fixes https://github.com/bytecodealliance/wasmtime/issues/7829? I'm having a tough time connecting permissions and how that'd fail something fd-based vs path-based.
Also https://github.com/bytecodealliance/wasmtime/issues/7829 mentions errno 63 and ENOSR but I suspect that was something Python-specific or something like that?
alexcrichton submitted PR review:
Seems reasonable to me but I'm finding it difficult to follow what each of the sets of permissions are so I'm not 100% sure. Could you expand a bit on how this fixes https://github.com/bytecodealliance/wasmtime/issues/7829? I'm having a tough time connecting permissions and how that'd fail something fd-based vs path-based.
Also https://github.com/bytecodealliance/wasmtime/issues/7829 mentions errno 63 and ENOSR but I suspect that was something Python-specific or something like that?
alexcrichton created PR review comment:
While you're here mind adding documentation to this method? I forget how
perms
relates tofile_perms
myself
alexcrichton created PR review comment:
Mind adding some brief comments here about what these fields are? Three sets of permissions seems like a good threshold for needing disambiguation
pchickey updated PR #7876.
pchickey submitted PR review.
pchickey created PR review comment:
Yep improved and documented this :)
brettcannon commented on PR #7876:
I just finished running CPython's test suite and this fixed the issue I found and didn't cause any new ones!
pchickey updated PR #7876.
pchickey updated PR #7876.
pchickey updated PR #7876.
pchickey updated PR #7876.
pchickey updated PR #7876.
pchickey updated PR #7876.
pchickey merged PR #7876.
Last updated: Jan 24 2025 at 00:11 UTC