diff options
Diffstat (limited to 'libc/sysdeps/linux/common/fdatasync.c')
-rw-r--r-- | libc/sysdeps/linux/common/fdatasync.c | 29 |
1 files changed, 5 insertions, 24 deletions
diff --git a/libc/sysdeps/linux/common/fdatasync.c b/libc/sysdeps/linux/common/fdatasync.c index e51c72365..6c2f4f9f3 100644 --- a/libc/sysdeps/linux/common/fdatasync.c +++ b/libc/sysdeps/linux/common/fdatasync.c @@ -8,36 +8,17 @@ */ #include <sys/syscall.h> -#include <unistd.h> #if !defined __NR_fdatasync && defined __NR_osf_fdatasync # define __NR_fdatasync __NR_osf_fdatasync #endif #ifdef __NR_fdatasync +# include <unistd.h> +# include <cancel.h> -# ifdef __UCLIBC_HAS_THREADS_NATIVE__ -# include <sysdep-cancel.h> -# else -# define SINGLE_THREAD_P 1 -# endif - -#define __NR___syscall_fdatasync __NR_fdatasync - -static __always_inline -_syscall1(int, __syscall_fdatasync, int, fd) - -int fdatasync(int fd) -{ - if (SINGLE_THREAD_P) - return __syscall_fdatasync(fd); - -# ifdef __UCLIBC_HAS_THREADS_NATIVE__ - int oldtype = LIBC_CANCEL_ASYNC (); - int result = __syscall_fdatasync(fd); - LIBC_CANCEL_RESET (oldtype); - return result; -# endif -} +# define __NR___fdatasync_nocancel __NR_fdatasync +static _syscall1(int, __NC(fdatasync), int, fd) +CANCELLABLE_SYSCALL(int, fdatasync, (int fd), (fd)) #endif |