diff options
| -rw-r--r-- | libc/sysdeps/linux/common/not-cancel.h | 6 | ||||
| -rw-r--r-- | libc/sysdeps/linux/common/pause.c | 4 | 
2 files changed, 6 insertions, 4 deletions
| diff --git a/libc/sysdeps/linux/common/not-cancel.h b/libc/sysdeps/linux/common/not-cancel.h index 08dab8c9d..acf8e39e8 100644 --- a/libc/sysdeps/linux/common/not-cancel.h +++ b/libc/sysdeps/linux/common/not-cancel.h @@ -102,9 +102,11 @@ extern int __openat64_nocancel (int fd, const char *fname, int oflag,  #ifdef __NR_pause  # define pause_not_cancel() \    INLINE_SYSCALL (pause, 0) -/*#else +#else +# include <unistd.h> +extern __typeof(pause) __pause_nocancel;  # define pause_not_cancel() \ -  __pause_nocancel ()*/ +  __pause_nocancel ()  #endif  /* Uncancelable nanosleep.  */ diff --git a/libc/sysdeps/linux/common/pause.c b/libc/sysdeps/linux/common/pause.c index 32fe839c0..c35ecd5d5 100644 --- a/libc/sysdeps/linux/common/pause.c +++ b/libc/sysdeps/linux/common/pause.c @@ -25,7 +25,7 @@ int  # ifdef __LINUXTHREADS_OLD__  weak_function  # endif -pause(void) +__NC(pause)(void)  {  	sigset_t set; @@ -36,6 +36,6 @@ pause(void)  	   So no need for anything special here.  */  	return sigsuspend(&set);  } -lt_strong_alias(pause) +CANCELLABLE_SYSCALL(int, pause, (void), ())  LIBC_CANCEL_HANDLED ();		/* sigsuspend handles our cancellation.  */  #endif | 
