X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Ffcntl%2Ffcntl.c;h=fb7806a3dd4848f11d9866d585c77578126b49a2;hp=464dbf00c18901a0d7640b147b1b6ab91bfe7712;hb=708c91f4e9be2cfd6d35e71361956e13f3201b85;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01 diff --git a/src/fcntl/fcntl.c b/src/fcntl/fcntl.c index 464dbf00..fb7806a3 100644 --- a/src/fcntl/fcntl.c +++ b/src/fcntl/fcntl.c @@ -1,22 +1,26 @@ +#define _GNU_SOURCE #include #include #include +#include #include "syscall.h" #include "libc.h" int fcntl(int fd, int cmd, ...) { - int r; long arg; va_list ap; va_start(ap, cmd); arg = va_arg(ap, long); va_end(ap); if (cmd == F_SETFL) arg |= O_LARGEFILE; - if (cmd == F_SETLKW) CANCELPT_BEGIN; - r = __syscall_fcntl(fd, cmd, arg); - if (cmd == F_SETLKW) CANCELPT_END; - return r; + if (cmd == F_SETLKW) return syscall_cp(SYS_fcntl, fd, cmd, arg); + if (cmd == F_GETOWN) { + struct f_owner_ex ex; + int ret = __syscall(SYS_fcntl, fd, F_GETOWN_EX, &ex); + if (ret == -EINVAL) return __syscall(SYS_fcntl, fd, cmd, arg); + if (ret) return __syscall_ret(ret); + return ex.type == F_OWNER_PGRP ? -ex.pid : ex.pid; + } + return syscall(SYS_fcntl, fd, cmd, arg); } - -LFS64(fcntl);