in pipe2, use pipe() rather than __syscall(SYS_pipe, ...) for fallback
authorRich Felker <dalias@aerifal.cx>
Mon, 25 Mar 2013 15:34:22 +0000 (11:34 -0400)
committerRich Felker <dalias@aerifal.cx>
Mon, 25 Mar 2013 15:34:22 +0000 (11:34 -0400)
SYS_pipe is not usable directly in general, since mips has a very
broken calling convention for the pipe syscall. instead, just call the
function, so that the mips-specific ugliness is isolated in
mips/pipe.s and not copied elsewhere.

src/unistd/pipe2.c

index bbeabcbf27ece1205e0b1adc769f6cfecf60e845..f24f74fb0300d0d1cfe40e93d1da24b63be081f4 100644 (file)
@@ -5,11 +5,11 @@
 
 int pipe2(int fd[2], int flag)
 {
-       if (!flag) return syscall(SYS_pipe, fd);
+       if (!flag) return pipe(fd);
        int ret = __syscall(SYS_pipe2, fd, flag);
        if (ret != -ENOSYS) return __syscall_ret(ret);
-       ret = __syscall(SYS_pipe, fd);
-       if (ret) return __syscall_ret(ret);
+       ret = pipe(fd);
+       if (ret) return ret;
        if (flag & O_CLOEXEC) {
                __syscall(SYS_fcntl, fd[0], F_SETFD, FD_CLOEXEC);
                __syscall(SYS_fcntl, fd[1], F_SETFD, FD_CLOEXEC);