diff options
author | David Xu <davidxu@FreeBSD.org> | 2013-04-18 05:56:00 +0000 |
---|---|---|
committer | David Xu <davidxu@FreeBSD.org> | 2013-04-18 05:56:00 +0000 |
commit | 8bbeb7e9e0733a2eb86ea159ac4ba35d5d410dc9 (patch) | |
tree | e4b6f6fc2374b0bd8c25966532484f8527e565ac /lib/libthr | |
parent | 880659fe819832bf064cf63dba0aae34f83a659e (diff) | |
download | src-8bbeb7e9e0733a2eb86ea159ac4ba35d5d410dc9.tar.gz src-8bbeb7e9e0733a2eb86ea159ac4ba35d5d410dc9.zip |
Avoid copying memory if SIGCANCEL is not masked.
Notes
Notes:
svn path=/head/; revision=249606
Diffstat (limited to 'lib/libthr')
-rw-r--r-- | lib/libthr/thread/thr_sig.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/lib/libthr/thread/thr_sig.c b/lib/libthr/thread/thr_sig.c index d2be9947ac12..420d99b402af 100644 --- a/lib/libthr/thread/thr_sig.c +++ b/lib/libthr/thread/thr_sig.c @@ -732,8 +732,12 @@ _setcontext(const ucontext_t *ucp) { ucontext_t uc; + if (ucp == NULL) + return (EINVAL); + if (!SIGISMEMBER(uc.uc_sigmask, SIGCANCEL)) + return __sys_setcontext(ucp); (void) memcpy(&uc, ucp, sizeof(uc)); - remove_thr_signals(&uc.uc_sigmask); + SIGDELSET(uc.uc_sigmask, SIGCANCEL); return __sys_setcontext(&uc); } @@ -743,7 +747,13 @@ _swapcontext(ucontext_t *oucp, const ucontext_t *ucp) { ucontext_t uc; - (void) memcpy(&uc, ucp, sizeof(uc)); - remove_thr_signals(&uc.uc_sigmask); - return __sys_swapcontext(oucp, &uc); + if (oucp == NULL || ucp == NULL) + return (EINVAL); + if (SIGISMEMBER(ucp->uc_sigmask, SIGCANCEL)) { + stdout_debug("remove SIGCANCEL\n"); + (void) memcpy(&uc, ucp, sizeof(uc)); + SIGDELSET(uc.uc_sigmask, SIGCANCEL); + ucp = &uc; + } + return __sys_swapcontext(oucp, ucp); } |