|
@@ -11,42 +11,16 @@
|
|
|
|
|
|
#ifdef __USE_POSIX
|
|
|
#include <signal.h>
|
|
|
+#include <cancel.h>
|
|
|
|
|
|
-#ifdef __UCLIBC_HAS_THREADS_NATIVE__
|
|
|
-# ifndef __NR_rt_sigsuspend
|
|
|
-# error break build, NPTL needs rt_sigsuspend syscall
|
|
|
-# endif
|
|
|
-# include <sysdep-cancel.h>
|
|
|
-#else
|
|
|
-# define SINGLE_THREAD_P 1
|
|
|
-#endif
|
|
|
-
|
|
|
-#ifdef __NR_rt_sigsuspend
|
|
|
-static _syscall2(int, rt_sigsuspend, const sigset_t *, set, size_t, size)
|
|
|
-
|
|
|
-
|
|
|
- wait until a signal arrives, and restore the set of blocked signals. */
|
|
|
-int sigsuspend(const sigset_t *set)
|
|
|
+int __NC(sigsuspend)(const sigset_t *set)
|
|
|
{
|
|
|
- if (SINGLE_THREAD_P)
|
|
|
- return rt_sigsuspend(set, _NSIG / 8);
|
|
|
-
|
|
|
-# ifdef __UCLIBC_HAS_THREADS_NATIVE__
|
|
|
- int oldtype = LIBC_CANCEL_ASYNC ();
|
|
|
- int result = rt_sigsuspend(set, _NSIG / 8);
|
|
|
- LIBC_CANCEL_RESET (oldtype);
|
|
|
- return result;
|
|
|
-# endif
|
|
|
-}
|
|
|
+#ifdef __NR_rt_sigsuspend
|
|
|
+ return INLINE_SYSCALL(rt_sigsuspend, 2, set, __SYSCALL_SIGSET_T_SIZE);
|
|
|
#else
|
|
|
-# define __NR___syscall_sigsuspend __NR_sigsuspend
|
|
|
-static __always_inline _syscall3(int, __syscall_sigsuspend, int, a, unsigned long int, b,
|
|
|
- unsigned long int, c)
|
|
|
-
|
|
|
-int sigsuspend(const sigset_t *set)
|
|
|
-{
|
|
|
- return __syscall_sigsuspend(0, 0, set->__val[0]);
|
|
|
-}
|
|
|
+ return INLINE_SYSCALL(sigsuspend, 3, 0, 0, set->__val[0]);
|
|
|
#endif
|
|
|
-libc_hidden_def(sigsuspend)
|
|
|
+}
|
|
|
+CANCELLABLE_SYSCALL(int, sigsuspend, (const sigset_t *set), (set))
|
|
|
+lt_libc_hidden(sigsuspend)
|
|
|
#endif
|