diff options
author | Rich Felker <dalias@aerifal.cx> | 2014-06-06 15:42:42 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2014-06-06 15:42:42 -0400 |
commit | 7765706c0584ed4a30e0b7a3ada742e490ef02b0 (patch) | |
tree | 786ba57bf840d5f5db48167284c55f9db6698e6e /src/fcntl | |
parent | 1cacc01dc0623ac6443e19580222331812bddbbc (diff) | |
download | musl-7765706c0584ed4a30e0b7a3ada742e490ef02b0.tar.gz musl-7765706c0584ed4a30e0b7a3ada742e490ef02b0.tar.bz2 musl-7765706c0584ed4a30e0b7a3ada742e490ef02b0.tar.xz musl-7765706c0584ed4a30e0b7a3ada742e490ef02b0.zip |
add O_CLOEXEC fallback for open and related functions
since there is no easy way to detect whether open honored or ignored
the O_CLOEXEC flag, the optimal solution to providing a fallback is
simply to make the fcntl syscall to set the close-on-exec flag
immediately after open returns.
Diffstat (limited to 'src/fcntl')
-rw-r--r-- | src/fcntl/open.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/fcntl/open.c b/src/fcntl/open.c index 0594ed7e..088a28f7 100644 --- a/src/fcntl/open.c +++ b/src/fcntl/open.c @@ -10,7 +10,12 @@ int open(const char *filename, int flags, ...) va_start(ap, flags); mode = va_arg(ap, mode_t); va_end(ap); - return sys_open_cp(filename, flags, mode); + + int fd = __sys_open_cp(filename, flags, mode); + if (fd>=0 && (flags & O_CLOEXEC)) + __syscall(SYS_fcntl, fd, F_SETFD, FD_CLOEXEC); + + return __syscall_ret(fd); } LFS64(open); |