exit.c程序中实现的大致实现的是进程终止和退出等方面如何处理的相关函数,包含kill()
函数系统调用的内部实现、exit()
函数系统调用的内部实现、waitpid()
函数的系统调用的实现,以及一些更底层的函数的实现。
要想看懂这些函数,需要对会话以及进程、进程组有一定的了解,并且对pcb里面的一些成员的了解。
主要包括有这八个函数:
void release(struct task_struct * p) //用来释放指定进程占用的内存以及删除其在任务数组的指针,并让内核重新调度。
static inline int send_sig(long sig, struct task_struct * p, int priv) //向指定进程发送信号,权限为priv
static void kill_session(void) //终止会话
int sys_kill(int pid, int sig) //向指定进程或进程组发送指定的进程组
static void tell_father(int pid) //子进程通知父进程(即向进程pid发送信号SIGCHLD)
int do_exit(long code) //程序退出处理程序
int sys_exit(int error_code) //系统调用exit(),终止进程
int sys_waitpid(pid_t pid, unsigned long * stat_addr, int options) //系统调用waitpid(),回收指定的子进程。
1.void release(struct task_struct * p)
参数:p代表要回收的任务数据结构中的指针
void release(struct task_struct * p)
{
int i;
if (!p) //如果p为NULL,直接返回
return;
for (i=1 ; i<NR_TASKS ; i++) //NR_TASKS代表进程并发的最大数值,即当前最多有多少个进程
if (task[i]==p) { //找到指定的任务
task[i]=NULL; //将该项置为空
free_page((long)p); //释放相关内存页
schedule(); //重新进行调度
return;
}
panic("trying to release non-existent task"); //指定任务不存在则死机
}
2.static inline int send_sig(long sig, struct task_struct * p, int priv)
参数:
sig代表发送的信号
p代表要发送的任务数据结构的指针
priv是否强制发送信号,无视特权级
static inline int send_sig(long sig,struct task_struct * p,int priv)
{
if (!p || sig<1 || sig>32) //p为NULL或者信号非法则返回
return -EINVAL;
if (priv || (current->euid==p->euid) || suser()) //如果强制发送标志置位或者当前进程的有效用户id等于指定进程的有效用户id或者当前进程是超级用户