Linux内核分析(六)Linux新进程创建处理过程

Linux创建新进程使用fork系统调用,系统调用的前期和一般的系统调用并没有什么特别的区别,而区别在于fork处理过程do_fork的内部。do_fork的处理过程可总结为:

1. 复制父进程的程序控制块;

2. 修改复制过来的进程控制块,将控制块中的属性值改为子进程自己的值,比如,栈指针指向自己的栈地址,并初始化栈顶指针,打开的文件列表初始化等等,而EIP的值将被设置为ret_from_fork的地址,ret_from_fork过程会跳转到sys_call_exit去执行。

3. 转去子进程执行。

所以,在内核中,新创建的进程将从ret_from_fork处继续执行,然后跳转到sys_call_exit,这个过程中不会再调用进程切换检查的部分;而在用户程序看来,新创建的子进程将会从fork ()系统调用的下一条指令处开始执行,而这一般会是fork函数返回值的赋值和检测。

猜你喜欢

转载自blog.csdn.net/yubo112002/article/details/82527142
今日推荐