do_getksig.c

来自「Minix3.11的源码。[MINIX 3是一个为高可靠性应用而设计的自由且简洁」· C语言 代码 · 共 46 行

C
46
字号
/* The kernel call that is implemented in this file: *   m_type:	SYS_GETKSIG * * The parameters for this kernel call are: *     m2_i1:	SIG_PROC  	# process with pending signals *     m2_l1:	SIG_MAP		# bit map with pending signals */#include "../system.h"#include <signal.h>#include <sys/sigcontext.h>#if USE_GETKSIG/*===========================================================================* *			      do_getksig				     * *===========================================================================*/PUBLIC int do_getksig(m_ptr)message *m_ptr;			/* pointer to request message */{/* PM is ready to accept signals and repeatedly does a kernel call to get  * one. Find a process with pending signals. If no signals are available,  * return NONE in the process number field. * It is not sufficient to ready the process when PM is informed, because  * PM can block waiting for FS to do a core dump. */  register struct proc *rp;  /* Find the next process with pending signals. */  for (rp = BEG_USER_ADDR; rp < END_PROC_ADDR; rp++) {      if (rp->p_rts_flags & SIGNALED) {          m_ptr->SIG_PROC = rp->p_nr;		/* store signaled process */          m_ptr->SIG_MAP = rp->p_pending;	/* pending signals map */          sigemptyset(&rp->p_pending); 		/* ball is in PM's court */          rp->p_rts_flags &= ~SIGNALED;		/* blocked by SIG_PENDING */          return(OK);      }  }  /* No process with pending signals was found. */  m_ptr->SIG_PROC = NONE;   return(OK);}#endif /* USE_GETKSIG */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?