diff options
author | Rich Felker <dalias@aerifal.cx> | 2013-08-02 13:33:31 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2013-08-02 13:33:31 -0400 |
commit | 9ca1f62b0c0d3e50480eb654ac941ff943ce0558 (patch) | |
tree | 3920a0d5db41c52b13b8a70efdb2c039aa4e4f9c /src/stat | |
parent | c8c0844f7fbcb955848ca84432e5ffcf71f1cef1 (diff) | |
download | musl-9ca1f62b0c0d3e50480eb654ac941ff943ce0558.tar.gz musl-9ca1f62b0c0d3e50480eb654ac941ff943ce0558.tar.xz musl-9ca1f62b0c0d3e50480eb654ac941ff943ce0558.zip |
make fchdir, fchmod, fchown, and fstat support O_PATH file descriptors
on newer kernels, fchdir and fstat work anyway. this same fix should be applied to any other syscalls that are similarly affected. with this change, the current definitions of O_SEARCH and O_EXEC as O_PATH are mostly conforming to POSIX requirements. the main remaining issue is that O_NOFOLLOW has different semantics.
Diffstat (limited to 'src/stat')
-rw-r--r-- | src/stat/fchmod.c | 10 | ||||
-rw-r--r-- | src/stat/fstat.c | 12 |
2 files changed, 19 insertions, 3 deletions
diff --git a/src/stat/fchmod.c b/src/stat/fchmod.c index f9b99366..1b943d44 100644 --- a/src/stat/fchmod.c +++ b/src/stat/fchmod.c @@ -1,7 +1,15 @@ #include <sys/stat.h> +#include <errno.h> #include "syscall.h" +void __procfdname(char *, unsigned); + int fchmod(int fd, mode_t mode) { - return syscall(SYS_fchmod, fd, mode); + int ret = __syscall(SYS_fchmod, fd, mode); + if (ret != -EBADF || fd < 0) return __syscall_ret(ret); + + char buf[15+3*sizeof(int)]; + __procfdname(buf, fd); + return syscall(SYS_chmod, buf, mode); } diff --git a/src/stat/fstat.c b/src/stat/fstat.c index 10228f75..29b4243d 100644 --- a/src/stat/fstat.c +++ b/src/stat/fstat.c @@ -1,10 +1,18 @@ #include <sys/stat.h> +#include <errno.h> #include "syscall.h" #include "libc.h" -int fstat(int fd, struct stat *buf) +void __procfdname(char *, unsigned); + +int fstat(int fd, struct stat *st) { - return syscall(SYS_fstat, fd, buf); + int ret = __syscall(SYS_fstat, fd, st); + if (ret != -EBADF || fd < 0) return __syscall_ret(ret); + + char buf[15+3*sizeof(int)]; + __procfdname(buf, fd); + return syscall(SYS_stat, buf, st); } LFS64(fstat); |