summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/common/msync.c
diff options
context:
space:
mode:
Diffstat (limited to 'libc/sysdeps/linux/common/msync.c')
-rw-r--r--libc/sysdeps/linux/common/msync.c38
1 files changed, 7 insertions, 31 deletions
diff --git a/libc/sysdeps/linux/common/msync.c b/libc/sysdeps/linux/common/msync.c
index 844dbaa89..e183fbff2 100644
--- a/libc/sysdeps/linux/common/msync.c
+++ b/libc/sysdeps/linux/common/msync.c
@@ -8,38 +8,14 @@
*/
#include <sys/syscall.h>
-#include <unistd.h>
-#include <sys/mman.h>
-#ifdef __NR_msync
+#if defined __NR_msync && defined __ARCH_USE_MMU__
+# include <sys/mman.h>
+# include <cancel.h>
-#ifdef __UCLIBC_HAS_THREADS_NATIVE__
-#include <sysdep-cancel.h>
-#else
-#define SINGLE_THREAD_P 1
-#endif
-
-#define __NR___syscall_msync __NR_msync
-static __always_inline _syscall3(int, __syscall_msync, void *, addr, size_t, length,
- int, flags)
-
-extern __typeof(msync) __libc_msync;
-int __libc_msync(void * addr, size_t length, int flags)
-{
-#ifdef __UCLIBC_HAS_THREADS_NATIVE__
- int oldtype, result;
-#endif
-
- if (SINGLE_THREAD_P)
- return __syscall_msync(addr, length, flags);
-
-#ifdef __UCLIBC_HAS_THREADS_NATIVE__
- oldtype = LIBC_CANCEL_ASYNC ();
- result = __syscall_msync(addr, length, flags);
- LIBC_CANCEL_RESET (oldtype);
- return result;
-#endif
-}
-weak_alias(__libc_msync,msync)
+# define __NR___msync_nocancel __NR_msync
+static _syscall3(int, __NC(msync), void *, addr, size_t, length, int, flags)
+CANCELLABLE_SYSCALL(int, msync, (void *addr, size_t length, int flags),
+ (addr, length, flags))
#endif