diff options
author | jmallett <jmallett@FreeBSD.org> | 2002-09-30 20:20:22 +0000 |
---|---|---|
committer | jmallett <jmallett@FreeBSD.org> | 2002-09-30 20:20:22 +0000 |
commit | 0341f71df178fd346332ced28efb677a6ef39414 (patch) | |
tree | 44cc85d6d7a465b4410e0fa06f9f5a1b21bc40b6 /sys/kern/subr_trap.c | |
parent | e70c6b99c8b8b510eaef402242dd8cb86e300c6f (diff) | |
download | FreeBSD-src-0341f71df178fd346332ced28efb677a6ef39414.zip FreeBSD-src-0341f71df178fd346332ced28efb677a6ef39414.tar.gz |
First half of implementation of ksiginfo, signal queues, and such. This
gets signals operating based on a TailQ, and is good enough to run X11,
GNOME, and do job control. There are some intricate parts which could be
more refined to match the sigset_t versions, but those require further
evaluation of directions in which our signal system can expand and contract
to fit our needs.
After this has been in the tree for a while, I will make in kernel API
changes, most notably to trapsignal(9) and sendsig(9), to use ksiginfo
more robustly, such that we can actually pass information with our
(queued) signals to the userland. That will also result in using a
struct ksiginfo pointer, rather than a signal number, in a lot of
kern_sig.c, to refer to an individual pending signal queue member, but
right now there is no defined behaviour for such.
CODAFS is unfinished in this regard because the logic is unclear in
some places.
Sponsored by: New Gold Technology
Reviewed by: bde, tjr, jake [an older version, logic similar]
Diffstat (limited to 'sys/kern/subr_trap.c')
-rw-r--r-- | sys/kern/subr_trap.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/kern/subr_trap.c b/sys/kern/subr_trap.c index f120141..0a165e9 100644 --- a/sys/kern/subr_trap.c +++ b/sys/kern/subr_trap.c @@ -54,6 +54,8 @@ #include <sys/signalvar.h> #include <sys/systm.h> #include <sys/vmmeter.h> +#include <sys/malloc.h> +#include <sys/ksiginfo.h> #include <machine/cpu.h> #include <machine/pcb.h> @@ -80,7 +82,7 @@ userret(td, frame, oticks) mtx_lock(&Giant); PROC_LOCK(p); mtx_lock_spin(&sched_lock); - if (SIGPENDING(p) && ((p->p_sflag & PS_NEEDSIGCHK) == 0 || + if (signal_pending(p) && ((p->p_sflag & PS_NEEDSIGCHK) == 0 || (td->td_kse->ke_flags & KEF_ASTPENDING) == 0)) printf("failed to set signal flags properly for ast()\n"); mtx_unlock_spin(&sched_lock); |