diff options
Diffstat (limited to 'libc/sysdeps/linux/common/fsync.c')
| -rw-r--r-- | libc/sysdeps/linux/common/fsync.c | 28 | 
1 files changed, 15 insertions, 13 deletions
diff --git a/libc/sysdeps/linux/common/fsync.c b/libc/sysdeps/linux/common/fsync.c index 7ca709887..ecc203c74 100644 --- a/libc/sysdeps/linux/common/fsync.c +++ b/libc/sysdeps/linux/common/fsync.c @@ -9,27 +9,29 @@  #include "syscalls.h"  #include <unistd.h> -#ifdef __UCLIBC__HAS_THREADS__ -# include <sysdep-cancel.h> + +#ifdef __UCLIBC_HAS_THREADS_NATIVE__ +#include "sysdep-cancel.h" +#else +#define SINGLE_THREAD_P 1  #endif +#define __NR___syscall_fsync __NR_fsync +static inline _syscall1(int, __syscall_fsync, int, fd); +  extern __typeof(fsync) __libc_fsync; -#ifdef __UCLIBC__HAS_THREADS__ -int __libc_fsync (int fd) + +int __libc_fsync(int fd)  {  	if (SINGLE_THREAD_P) -		return INLINE_SYSCALL (fsync, 1, fd); +		return __syscall_fsync(fd); +#ifdef __UCLIBC_HAS_THREADS_NATIVE__  	int oldtype = LIBC_CANCEL_ASYNC (); - -	int result = INLINE_SYSCALL (fsync, 1, fd); - +	int result = __syscall_fsync(fd);  	LIBC_CANCEL_RESET (oldtype); -  	return result; -} -#else -# define __NR___libc_fsync __NR_fsync -_syscall1(int, __libc_fsync, int, fd);  #endif +} +  weak_alias(__libc_fsync, fsync)  | 
