about summary refs log tree commit diff
path: root/src/unistd/pipe2.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2013-02-03 16:09:05 -0500
committerRich Felker <dalias@aerifal.cx>2013-02-03 16:09:05 -0500
commit89d3df6e5420878e35a93a481105017a94a02852 (patch)
tree5ab6a990689dcab0a8eb719993015c0f90fde098 /src/unistd/pipe2.c
parentd432b2c057fc64256645422382c2f7e32c45b3cc (diff)
downloadmusl-89d3df6e5420878e35a93a481105017a94a02852.tar.gz
musl-89d3df6e5420878e35a93a481105017a94a02852.tar.xz
musl-89d3df6e5420878e35a93a481105017a94a02852.zip
streamline old-kernel fallback path of pipe2 to use syscalls directly
also, don't waste code/time on F_GETFL since pipes always have blank
flags initially (at least on old kernels, which are all this fallback
code matters for).
Diffstat (limited to 'src/unistd/pipe2.c')
-rw-r--r--src/unistd/pipe2.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/unistd/pipe2.c b/src/unistd/pipe2.c
index 973e8ec3..bbeabcbf 100644
--- a/src/unistd/pipe2.c
+++ b/src/unistd/pipe2.c
@@ -11,12 +11,12 @@ int pipe2(int fd[2], int flag)
 	ret = __syscall(SYS_pipe, fd);
 	if (ret) return __syscall_ret(ret);
 	if (flag & O_CLOEXEC) {
-		fcntl(fd[0], F_SETFD, FD_CLOEXEC);
-		fcntl(fd[1], F_SETFD, FD_CLOEXEC);
+		__syscall(SYS_fcntl, fd[0], F_SETFD, FD_CLOEXEC);
+		__syscall(SYS_fcntl, fd[1], F_SETFD, FD_CLOEXEC);
 	}
 	if (flag & O_NONBLOCK) {
-		fcntl(fd[0], F_SETFL, fcntl(fd[0], F_GETFL) | O_NONBLOCK);
-		fcntl(fd[1], F_SETFL, fcntl(fd[1], F_GETFL) | O_NONBLOCK);
+		__syscall(SYS_fcntl, fd[0], F_SETFL, O_NONBLOCK);
+		__syscall(SYS_fcntl, fd[1], F_SETFL, O_NONBLOCK);
 	}
 	return 0;
 }