summaryrefslogtreecommitdiff
path: root/lib/libpthread/thread/thr_sigpending.c
diff options
context:
space:
mode:
authorDavid Xu <davidxu@FreeBSD.org>2003-07-07 04:28:23 +0000
committerDavid Xu <davidxu@FreeBSD.org>2003-07-07 04:28:23 +0000
commit91f7616affad4527d0f1b0f39c5b330d3cda68e2 (patch)
tree6539674ba4c0ff3018faf64006ac81eb9090ec5f /lib/libpthread/thread/thr_sigpending.c
parentdce6e6518b85561495cff38a3074a69d29d58a55 (diff)
Notes
Diffstat (limited to 'lib/libpthread/thread/thr_sigpending.c')
-rw-r--r--lib/libpthread/thread/thr_sigpending.c6
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);