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_sigpending.c | |
| parent | dce6e6518b85561495cff38a3074a69d29d58a55 (diff) | |
Notes
Diffstat (limited to 'lib/libpthread/thread/thr_sigpending.c')
| -rw-r--r-- | lib/libpthread/thread/thr_sigpending.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/libpthread/thread/thr_sigpending.c b/lib/libpthread/thread/thr_sigpending.c index 1b9b502c880c..1edf01f535e0 100644 --- a/lib/libpthread/thread/thr_sigpending.c +++ b/lib/libpthread/thread/thr_sigpending.c @@ -46,6 +46,7 @@ _sigpending(sigset_t *set) { struct pthread *curthread = _get_curthread(); kse_critical_t crit; + sigset_t sigset; int ret = 0; /* Check for a null signal set pointer: */ @@ -59,12 +60,13 @@ _sigpending(sigset_t *set) crit = _kse_critical_enter(); KSE_SCHED_LOCK(curthread->kse, curthread->kseg); - *set = curthread->sigpend; + sigset = curthread->sigpend; KSE_SCHED_UNLOCK(curthread->kse, curthread->kseg); KSE_LOCK_ACQUIRE(curthread->kse, &_thread_signal_lock); - SIGSETOR(*set, _thr_proc_sigpending); + SIGSETOR(sigset, _thr_proc_sigpending); KSE_LOCK_RELEASE(curthread->kse, &_thread_signal_lock); _kse_critical_leave(crit); + *set = sigset; } /* Return the completion status: */ return (ret); |
