summaryrefslogtreecommitdiff
path: root/src/fcntl
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2014-06-06 15:42:42 -0400
committerRich Felker <dalias@aerifal.cx>2014-06-06 15:42:42 -0400
commit7765706c0584ed4a30e0b7a3ada742e490ef02b0 (patch)
tree786ba57bf840d5f5db48167284c55f9db6698e6e /src/fcntl
parent1cacc01dc0623ac6443e19580222331812bddbbc (diff)
downloadmusl-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.c7
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);