198c976f7e
that passes signal map along. This mechanisms is also used for nonuser signals like SIGKMESS, SIGKSTOP, SIGKSIG. Revised comments of many system call handlers. Renamed setpriority to nice.
37 lines
1.1 KiB
C
37 lines
1.1 KiB
C
/* The system call that is implemented in this file:
|
|
* m_type: SYS_ENDKSIG
|
|
*
|
|
* The parameters for this system call are:
|
|
* m2_i1: SIG_PROC # process for which PM is done
|
|
*/
|
|
|
|
#include "../system.h"
|
|
#include <signal.h>
|
|
#include <sys/sigcontext.h>
|
|
|
|
#if USE_ENDKSIG
|
|
|
|
/*===========================================================================*
|
|
* do_endksig *
|
|
*===========================================================================*/
|
|
PUBLIC int do_endksig(m_ptr)
|
|
message *m_ptr; /* pointer to request message */
|
|
{
|
|
/* Finish up after a kernel type signal, caused by a SYS_KILL message or a
|
|
* call to cause_sig by a task. This is called by the PM after processing a
|
|
* signal it got with SYS_GETKSIG.
|
|
*/
|
|
register struct proc *rp;
|
|
|
|
rp = proc_addr(m_ptr->SIG_PROC);
|
|
if (isemptyp(rp)) return(EINVAL); /* process already dead? */
|
|
|
|
/* PM has finished one kernel signal. Perhaps process is ready now? */
|
|
if (! (rp->p_rts_flags & SIGNALED)) /* new signal arrived */
|
|
if ((rp->p_rts_flags &= ~SIG_PENDING)==0) /* remove pending flag */
|
|
lock_ready(rp); /* ready if no flags */
|
|
return(OK);
|
|
}
|
|
|
|
#endif /* USE_ENDKSIG */
|
|
|