linux0.11源码研究---exit.c

本文详细探讨了Linux0.11内核中exit.c文件的实现,主要涉及进程终止、资源回收及信号处理等核心功能。通过分析release()、send_signal()等关键函数,揭示了内核如何优雅地结束进程并管理进程状态。理解这些函数需要对进程、会话、信号和进程控制块有深入认识。
摘要由CSDN通过智能技术生成

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或者当前进程是超级用户࿰
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值