1 /* The kernel call that is implemented in this file:
4 * The parameters for this kernel call are:
5 * m2_i1: SIG_PROC # process with pending signals
6 * m2_l1: SIG_MAP # bit map with pending signals
11 #include <sys/sigcontext.h>
15 /*===========================================================================*
17 *===========================================================================*/
18 PUBLIC
int do_getksig(m_ptr
)
19 message
*m_ptr
; /* pointer to request message */
21 /* PM is ready to accept signals and repeatedly does a kernel call to get
22 * one. Find a process with pending signals. If no signals are available,
23 * return NONE in the process number field.
24 * It is not sufficient to ready the process when PM is informed, because
25 * PM can block waiting for FS to do a core dump.
27 register struct proc
*rp
;
29 /* Find the next process with pending signals. */
30 for (rp
= BEG_USER_ADDR
; rp
< END_PROC_ADDR
; rp
++) {
31 if (rp
->p_rts_flags
& SIGNALED
) {
32 m_ptr
->SIG_PROC
= rp
->p_nr
; /* store signaled process */
33 m_ptr
->SIG_MAP
= rp
->p_pending
; /* pending signals map */
34 sigemptyset(&rp
->p_pending
); /* ball is in PM's court */
35 rp
->p_rts_flags
&= ~SIGNALED
; /* blocked by SIG_PENDING */
40 /* No process with pending signals was found. */
41 m_ptr
->SIG_PROC
= NONE
;
44 #endif /* USE_GETKSIG */