diff options
Diffstat (limited to 'libc/sysdeps/linux')
| -rw-r--r-- | libc/sysdeps/linux/common/sigsuspend.c | 43 | 
1 files changed, 18 insertions, 25 deletions
| diff --git a/libc/sysdeps/linux/common/sigsuspend.c b/libc/sysdeps/linux/common/sigsuspend.c index ded2aad5b..c26ad16ee 100644 --- a/libc/sysdeps/linux/common/sigsuspend.c +++ b/libc/sysdeps/linux/common/sigsuspend.c @@ -9,48 +9,41 @@  #include <sys/syscall.h> -#if defined __USE_POSIX +#ifdef __USE_POSIX  #include <signal.h> -#undef sigsuspend -libc_hidden_proto(sigsuspend) +#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 -# define __NR___rt_sigsuspend __NR_rt_sigsuspend - -# ifdef __UCLIBC_HAS_THREADS_NATIVE__ -#  include <errno.h> -#  include <sysdep-cancel.h> +static _syscall2(int, rt_sigsuspend, const sigset_t *, set, size_t, size)  /* Change the set of blocked signals to SET,     wait until a signal arrives, and restore the set of blocked signals.  */ -int sigsuspend (const sigset_t *set) +int sigsuspend(const sigset_t *set)  {  	if (SINGLE_THREAD_P) -		return INLINE_SYSCALL (rt_sigsuspend, 2, set, _NSIG / 8); +		return rt_sigsuspend(set, _NSIG / 8); +# ifdef __UCLIBC_HAS_THREADS_NATIVE__  	int oldtype = LIBC_CANCEL_ASYNC (); - -	int result = INLINE_SYSCALL (rt_sigsuspend, 2, set, _NSIG / 8); - +	int result = rt_sigsuspend(set, _NSIG / 8);  	LIBC_CANCEL_RESET (oldtype); -  	return result; -} -# else -static inline _syscall2(int, __rt_sigsuspend, const sigset_t *, mask, size_t, size) - -int sigsuspend(const sigset_t * mask) -{ -	return __rt_sigsuspend(mask, _NSIG / 8); -}  # endif +}  #else  # define __NR___syscall_sigsuspend __NR_sigsuspend -static __inline__ _syscall3(int, __syscall_sigsuspend, int, a, unsigned long int, b, -		  unsigned long int, c) +static __always_inline _syscall3(int, __syscall_sigsuspend, int, a, unsigned long int, b, +				 unsigned long int, c) -int sigsuspend(const sigset_t * set) +int sigsuspend(const sigset_t *set)  {  	return __syscall_sigsuspend(0, 0, set->__val[0]);  } | 
