orangeC23 added the bug label to Issue #7331.
orangeC23 opened issue #7331:
Steps to Reproduce
(1) The cfile is :
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <sys/stat.h> //#include <sys/uio.h> //#include <unistd.h> #include <fcntl.h> int main() { const char *dirPath = "Data/mydir"; int open_style= O_RDONLY; int fd = get_fd(dirPath, open_style); readdirQ6TwcRnVK4(dirPath); return 0; } int readdirQ6TwcRnVK4 (const char *path) { return fd_readdir(path); } int get_fd(const char* file_name, int open_style){ int fd = open(file_name, open_style); if (fd == -1) { perror("Failed to open the file"); return 1; } return fd; } int fd_readdir(const char *path) { printf("Enter fd_readdir.\n"); DIR *directory; struct dirent *entry; directory = opendir(path); if (directory == NULL) { perror("opendir"); return 1; } while ((entry = readdir(directory)) != NULL) { printf("%s\n", entry->d_name); } closedir(directory); printf("Leave fd_readdir.\n"); return 0; }
(2)compile the c file into wasm:
./wasi-sdk-16.0/bin/clang --target=wasm32-unkown-wasi --sysroot=./wasi-sdk-16.0/share/wasi-sysroot readdir.c -o readdir.wasm
(3)exeute open.wasm
wasmtime run --dir=./Data test1.wasm
The permission of Data/mydir is 0400 or 0500 or 0600, user1 create the Data/mydir directory before and user1 execute the Wasm file.Expected Results
Using
gcc test1.c -o test1
and./test1
to execute get the following result:Enter fd_readdir. . .. test.txt Leave fd_readdir.
And wamr, wasmedge also print the above message.
Actual Results
wasmtime prints:
Enter fd_readdir. opendir: Permission denied
I'm not sure whether wasmtime and native ubuntu and other runtimes get different could be a bug or only difference ? Maybe something error about the permission?
0400 r--
0500 r-x
0600 rw-0400, 0500, and 0600 has the read permission
Versions and Environment
wasmtime 13.0.0
Operating system: Ubuntu 20.04Architecture: x86_64
orangeC23 edited issue #7331:
Steps to Reproduce
(1) The cfile is :
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <sys/stat.h> #include <fcntl.h> int main() { const char *dirPath = "Data/mydir"; int open_style= O_RDONLY; int fd = get_fd(dirPath, open_style); readdirQ6TwcRnVK4(dirPath); return 0; } int readdirQ6TwcRnVK4 (const char *path) { return fd_readdir(path); } int get_fd(const char* file_name, int open_style){ int fd = open(file_name, open_style); if (fd == -1) { perror("Failed to open the file"); return 1; } return fd; } int fd_readdir(const char *path) { printf("Enter fd_readdir.\n"); DIR *directory; struct dirent *entry; directory = opendir(path); if (directory == NULL) { perror("opendir"); return 1; } while ((entry = readdir(directory)) != NULL) { printf("%s\n", entry->d_name); } closedir(directory); printf("Leave fd_readdir.\n"); return 0; }
(2)compile the c file into wasm:
./wasi-sdk-16.0/bin/clang --target=wasm32-unkown-wasi --sysroot=./wasi-sdk-16.0/share/wasi-sysroot readdir.c -o readdir.wasm
(3)exeute open.wasm
wasmtime run --dir=./Data test1.wasm
The permission of Data/mydir is 0400 or 0500 or 0600, user1 create the Data/mydir directory before and user1 execute the Wasm file.Expected Results
Using
gcc test1.c -o test1
and./test1
to execute get the following result:Enter fd_readdir. . .. test.txt Leave fd_readdir.
And wamr, wasmedge also print the above message.
Actual Results
wasmtime prints:
Enter fd_readdir. opendir: Permission denied
I'm not sure whether wasmtime and native ubuntu and other runtimes get different could be a bug or only difference ? Maybe something error about the permission?
0400 r--
0500 r-x
0600 rw-0400, 0500, and 0600 has the read permission
Versions and Environment
wasmtime 13.0.0
Operating system: Ubuntu 20.04Architecture: x86_64
orangeC23 edited issue #7331:
Steps to Reproduce
(1) The cfile is :
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <sys/stat.h> #include <fcntl.h> int main() { const char *dirPath = "Data/mydir"; int open_style= O_RDONLY; int fd = get_fd(dirPath, open_style); readdirQ6TwcRnVK4(dirPath); return 0; } int readdirQ6TwcRnVK4 (const char *path) { return fd_readdir(path); } int get_fd(const char* file_name, int open_style){ int fd = open(file_name, open_style); if (fd == -1) { perror("Failed to open the file"); return 1; } return fd; } int fd_readdir(const char *path) { printf("Enter fd_readdir.\n"); DIR *directory; struct dirent *entry; directory = opendir(path); if (directory == NULL) { perror("opendir"); return 1; } while ((entry = readdir(directory)) != NULL) { printf("%s\n", entry->d_name); } closedir(directory); printf("Leave fd_readdir.\n"); return 0; }
(2)compile the c file into wasm:
./wasi-sdk-16.0/bin/clang --target=wasm32-unkown-wasi --sysroot=./wasi-sdk-16.0/share/wasi-sysroot readdir.c -o readdir.wasm
(3)exeute open.wasm
wasmtime run --dir=./Data readdir.wasm
The permission of Data/mydir is 0400 or 0500 or 0600, user1 create the Data/mydir directory before and user1 execute the Wasm file.Expected Results
Using
gcc readdir.c -o readdir
and./readdir
to execute get the following result:Enter fd_readdir. . .. test.txt Leave fd_readdir.
And wamr, wasmedge also print the above message.
Actual Results
wasmtime prints:
Enter fd_readdir. opendir: Permission denied
I'm not sure whether wasmtime and native ubuntu and other runtimes get different could be a bug or only difference ? Maybe something error about the permission?
0400 r--
0500 r-x
0600 rw-0400, 0500, and 0600 has the read permission
Versions and Environment
wasmtime 13.0.0
Operating system: Ubuntu 20.04Architecture: x86_64
orangeC23 edited issue #7331:
Steps to Reproduce
(1) The cfile is :
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <sys/stat.h> #include <fcntl.h> int main() { const char *dirPath = "Data/mydir"; int open_style= O_RDONLY; int fd = get_fd(dirPath, open_style); readdirQ6TwcRnVK4(dirPath); return 0; } int readdirQ6TwcRnVK4 (const char *path) { return fd_readdir(path); } int get_fd(const char* file_name, int open_style){ int fd = open(file_name, open_style); if (fd == -1) { perror("Failed to open the file"); return 1; } return fd; } int fd_readdir(const char *path) { printf("Enter fd_readdir.\n"); DIR *directory; struct dirent *entry; directory = opendir(path); if (directory == NULL) { perror("opendir"); return 1; } while ((entry = readdir(directory)) != NULL) { printf("%s\n", entry->d_name); } closedir(directory); printf("Leave fd_readdir.\n"); return 0; }
(2)compile the c file into wasm:
./wasi-sdk-16.0/bin/clang --target=wasm32-unkown-wasi --sysroot=./wasi-sdk-16.0/share/wasi-sysroot readdir.c -o readdir.wasm
(3)exeute open.wasm
wasmtime run --dir=./Data readdir.wasm
The permission of Data/mydir is 0400 or 0500 or 0600, user1 create the Data/mydir directory before and user1 execute the Wasm file.Expected Results
Using
gcc readdir.c -o readdir
and./readdir
to execute get the following result:Enter fd_readdir. . .. test.txt Leave fd_readdir.
And wamr, wasmedge also print the above message.
Actual Results
wasmtime prints:
Enter fd_readdir. opendir: Permission denied
I'm not sure whether wasmtime and native ubuntu and other runtimes get different could be a bug or only difference ? Maybe something error about the permission?
0400 r--
0500 r-x
0600 rw-0400, 0500, and 0600 has the read permission
Sorry for bothering you. Thanks a lot !
Versions and Environment
wasmtime 13.0.0
Operating system: Ubuntu 20.04Architecture: x86_64
alexcrichton commented on issue #7331:
Thanks for the report, although I can ask a few clarify questions. Your C code as-provided does not compile for me because the functions are in the wrong order. Are you transforming the code to post in this issue report vs what you're running locally?
I can reproduce this behavior for 0400 and 0600 permissions but with 0500 permissions it seems to read the directory ok. Can you confirm whether 0500 works or not for you?
Locally this seems to be related to the 'x' permisison bit. Interestingly I also get different behavior on various platforms. The
ls
command for example can read an 0600 directory on Linux but not on macOS. A native Rust executable usingstd::fs::read_dir
can seem to open it on both platforms.I don't know what the "right" behavior is, or even if there is one. I'll cc @sunfishcode as this is related to what
cap-std
does. On Linux at least cap-std for theentries
method on directories issues:[pid 534964] openat2(3, "mydir", {flags=O_RDONLY|O_LARGEFILE|O_CLOEXEC, resolve=RESOLVE_NO_MAGICLINKS|RESOLVE_BENEATH}, 24) = 6 [pid 534964] statx(6, "", AT_STATX_SYNC_AS_STAT|AT_EMPTY_PATH, STATX_ALL, {stx_mask=STATX_ALL|STATX_MNT_ID, stx_attributes=0, stx_mode=S_IFDIR|0600, stx_size=4096, ...}) = 0 [pid 534964] statx(6, "", AT_STATX_SYNC_AS_STAT|AT_EMPTY_PATH, STATX_ALL, {stx_mask=STATX_ALL|STATX_MNT_ID, stx_attributes=0, stx_mode=S_IFDIR|0600, stx_size=4096, ...}) = 0 [pid 534964] openat(6, ".", O_RDONLY|O_LARGEFILE|O_NOFOLLOW|O_CLOEXEC|O_DIRECTORY) = -1 EACCES (Permission denied)
as compared to the Rust standard library which issues:
openat(AT_FDCWD, "./Data/mydir", O_RDONLY|O_NONBLOCK|O_CLOEXEC|O_DIRECTORY) = 3 newfstatat(3, "", {st_mode=S_IFDIR|0600, st_size=4096, ...}, AT_EMPTY_PATH) = 0
That's at least what I've found, but this is also assuming a lot about the original program and @orangeC23's issue, so this could also perhaps be "simply resolved" with more clarifications in the above issue.
orangeC23 edited issue #7331:
Steps to Reproduce
(1) The cfile is :
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <sys/stat.h> #include <fcntl.h> int get_fd(const char* file_name, int open_style){ int fd = open(file_name, open_style); if (fd == -1) { perror("Failed to open the file"); return 1; } return fd; } int fd_readdir(const char *path) { printf("Enter fd_readdir.\n"); DIR *directory; struct dirent *entry; directory = opendir(path); if (directory == NULL) { perror("opendir"); return 1; } while ((entry = readdir(directory)) != NULL) { printf("%s\n", entry->d_name); } closedir(directory); printf("Leave fd_readdir.\n"); return 0; } int readdirQ6TwcRnVK4 (const char *path) { return fd_readdir(path); } int main() { const char *dirPath = "Data/mydir"; int open_style= O_RDONLY; int fd = get_fd(dirPath, open_style); readdirQ6TwcRnVK4(dirPath); return 0; }
(2)compile the c file into wasm:
./wasi-sdk-16.0/bin/clang --target=wasm32-unkown-wasi --sysroot=./wasi-sdk-16.0/share/wasi-sysroot readdir.c -o readdir.wasm
(3)exeute open.wasm
wasmtime run --dir=./Data readdir.wasm
The permission of Data/mydir is 0400 or 0500 or 0600, user1 create the Data/mydir directory before and user1 execute the Wasm file.Expected Results
Using
gcc readdir.c -o readdir
and./readdir
to execute get the following result:Enter fd_readdir. . .. test.txt Leave fd_readdir.
And wamr, wasmedge also print the above message.
Actual Results
wasmtime prints:
Enter fd_readdir. opendir: Permission denied
I'm not sure whether wasmtime and native ubuntu and other runtimes get different could be a bug or only difference ? Maybe something error about the permission?
0400 r--
0500 r-x
0600 rw-0400, 0500, and 0600 has the read permission
Sorry for bothering you. Thanks a lot !
Versions and Environment
wasmtime 13.0.0
Operating system: Ubuntu 20.04Architecture: x86_64
orangeC23 commented on issue #7331:
Sorry. I updated the C program.
orangeC23 edited a comment on issue #7331:
Sorry. I updated the C program. I'll check the other information your provided. Thanks for your reply !
Last updated: Jan 24 2025 at 00:11 UTC