diff options
author | bde <bde@FreeBSD.org> | 2002-04-04 17:49:48 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 2002-04-04 17:49:48 +0000 |
commit | 14ae95f735978b62fd4a040a2f05a7d5c5a30712 (patch) | |
tree | 27b9df7330c17460156c8810b34fef449a2d1764 /sys/i386/ibcs2/ibcs2_signal.c | |
parent | 2a571683e0a57e785364a0bccbf360ed24409bd1 (diff) | |
download | FreeBSD-src-14ae95f735978b62fd4a040a2f05a7d5c5a30712.zip FreeBSD-src-14ae95f735978b62fd4a040a2f05a7d5c5a30712.tar.gz |
Moved signal handling and rescheduling from userret() to ast() so that
they aren't in the usual path of execution for syscalls and traps.
The main complication for this is that we have to set flags to control
ast() everywhere that changes the signal mask.
Avoid locking in userret() in most of the remaining cases.
Submitted by: luoqi (first part only, long ago, reorganized by me)
Reminded by: dillon
Diffstat (limited to 'sys/i386/ibcs2/ibcs2_signal.c')
-rw-r--r-- | sys/i386/ibcs2/ibcs2_signal.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/sys/i386/ibcs2/ibcs2_signal.c b/sys/i386/ibcs2/ibcs2_signal.c index fd32aaf..12bd038 100644 --- a/sys/i386/ibcs2/ibcs2_signal.c +++ b/sys/i386/ibcs2/ibcs2_signal.c @@ -328,6 +328,7 @@ ibcs2_sigsys(td, uap) /* return SIG_HOLD and unblock signal*/ td->td_retval[0] = (int)IBCS2_SIG_HOLD; SIGDELSET(p->p_sigmask, signum); + signotify(p); } PROC_UNLOCK(p); } @@ -426,11 +427,13 @@ ibcs2_sigprocmask(td, uap) case IBCS2_SIG_UNBLOCK: SIGSETNAND(p->p_sigmask, bss); + signotify(p); break; case IBCS2_SIG_SETMASK: p->p_sigmask = bss; SIG_CANTMASK(p->p_sigmask); + signotify(p); break; default: |