Linux系统fork执行过程

郑德伦 原创作品转载请注明出处 《Linux内核分析》MOOC课程
http://mooc.study.163.com/course/USTC-1000029000
一、配置环境:
首先我们把环境配置完成
在实验楼中输入

rm menu –rf
git clone https://github.com/mengning/menu.git
cd menu
mv test_fork.c test.c
make rootfs

启动MenuOS后发现fork已经被加入到了MenuOS中了

这里写图片描述
二、跟踪调试fork
输入qemu –kernel ../linux-3.18.6/arch/x86/boot/bzImage –initrd ../rootfs.img –s –S
然后在另一个终端输入

gdb
(gdb)file linux-3.18.6/vmlinux
(gdb)target remote:1234
(gdb)b sys_clone
(gdb)b do_fork
(gdb)b dup_task_struct
(gdb)b copy_process
(gdb)b copy_thread
(gdb)b ret_from_fork

设置好断点之后 我们进行跟踪fork的过程
首先会触发sys_clone的系统调用
这里写图片描述
然后进入do_fork函数
这里写图片描述
在do_fork函数中会调用copy_process
这里写图片描述
在copy_process中调用dup_task_struct和copy_thread
这里写图片描述
这里写图片描述
最后调用ret_from_fork()完成进程的fork
这里写图片描述
整个过程我们用流程图表示一下:
这里写图片描述
三、总结
Linux创建一个新进程时,可能会使用到sys_vfork sys_clone sys_fork系统调用,但是这三个系统调用都会调用do_fork函数,do_fork会调用copy_process来复制父进程的资源给子进程。在copy_process中有各种copy_xxx 函数来进行复制初始化工作。完成各项工作之后会执行ret_from_fork,这是子进程的起点。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章