static struct chain {
struct chain *next;
sem_t sem, sem2;
-} *head;
+} *head, *cur;
static void (*callback)(void *), *context;
static int chainlen;
{
pthread_t self;
struct sigaction sa;
- struct chain *cur, *next;
+ struct chain *next;
uint64_t oldmask;
if (!libc.threads_minus_1) {
pthread_rwlock_wrlock(&lock);
- __syscall(SYS_rt_sigprocmask, SIG_BLOCK, (uint64_t[]){-1}, &oldmask, 8);
+ __syscall(SYS_rt_sigprocmask, SIG_BLOCK, SIGALL_SET,
+ &oldmask, __SYSCALL_SSLEN);
sem_init(&chaindone, 0, 0);
sem_init(&chainlock, 0, 1);
sa.sa_handler = SIG_IGN;
__libc_sigaction(SIGSYNCCALL, &sa, 0);
- __syscall(SYS_rt_sigprocmask, SIG_SETMASK, &oldmask, 0, 8);
+ __syscall(SYS_rt_sigprocmask, SIG_SETMASK,
+ &oldmask, 0, __SYSCALL_SSLEN);
pthread_rwlock_unlock(&lock);
}