diff options
| author | David Xu <davidxu@FreeBSD.org> | 2003-07-07 04:28:23 +0000 |
|---|---|---|
| committer | David Xu <davidxu@FreeBSD.org> | 2003-07-07 04:28:23 +0000 |
| commit | 91f7616affad4527d0f1b0f39c5b330d3cda68e2 (patch) | |
| tree | 6539674ba4c0ff3018faf64006ac81eb9090ec5f /lib/libpthread/thread/thr_sigsuspend.c | |
| parent | dce6e6518b85561495cff38a3074a69d29d58a55 (diff) | |
Notes
Diffstat (limited to 'lib/libpthread/thread/thr_sigsuspend.c')
| -rw-r--r-- | lib/libpthread/thread/thr_sigsuspend.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/lib/libpthread/thread/thr_sigsuspend.c b/lib/libpthread/thread/thr_sigsuspend.c index 8d087f57c6e3..869e3d919bab 100644 --- a/lib/libpthread/thread/thr_sigsuspend.c +++ b/lib/libpthread/thread/thr_sigsuspend.c @@ -43,20 +43,23 @@ int _sigsuspend(const sigset_t *set) { struct pthread *curthread = _get_curthread(); + sigset_t oldmask, newmask; int ret = -1; - sigset_t osigmask; if (!_kse_isthreaded()) return __sys_sigsuspend(set); /* Check if a new signal set was provided by the caller: */ if (set != NULL) { + newmask = *set; + THR_LOCK_SWITCH(curthread); /* Save current sigmask */ - memcpy(&osigmask, &curthread->sigmask, sizeof(osigmask)); + memcpy(&oldmask, &curthread->sigmask, sizeof(sigset_t)); + /* Change the caller's mask: */ - memcpy(&curthread->sigmask, set, sizeof(sigset_t)); + memcpy(&curthread->sigmask, &newmask, sizeof(sigset_t)); THR_SET_STATE(curthread, PS_SIGSUSPEND); @@ -68,7 +71,7 @@ _sigsuspend(const sigset_t *set) THR_SCHED_LOCK(curthread, curthread); /* Restore the signal mask: */ - memcpy(&curthread->sigmask, &osigmask, sizeof(sigset_t)); + memcpy(&curthread->sigmask, &oldmask, sizeof(sigset_t)); THR_SCHED_UNLOCK(curthread, curthread); /* * signal mask is reloaded, need to check if there is |
