实验六:分析 Linux内核创建一个新进程的过程
实验内容 :
- 阅读理解task_struct数据结构http://codelab.shiyanlou.com/xref/linux-3.18.6/include/linux/sched.h#1235;
- 分析fork函数对应的内核处理过程sys_clone,理解创建一个新进程如何创建和修改task_struct 的数据结构;
- 使用gdb跟踪分析一个fork系统调用内核处理函数sys_clone ,验证您对Linux系统创建一个新进程的理解,推荐在实验楼Linux虚拟机环境下完成实验。
- 特别关注新进程是从哪里开始执行的?为什么从哪里能顺利执行下去?即执行起点与内核堆栈如何保证一致。
fork:
fork ()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是子进程,原来的成为父进程。
返回值问题:在父进程中,fork返回创建子进程的进程ID,在子进程中,fork返回0;也就是执行一次返回两个值。
getpid():获得当前进程的PID。
getppid()获得一个进程的父进程PID。
实验步骤:
1、打开虚拟机,进入LinuxKernrl
2、删除原来的menu文件,克隆一个新的menu。
在已经完成MenuOS里面增加一个命令fork,覆盖test.c文件。
4、使用make roofts进行编译,发现menu中多了一个fork命令。
5、打开另外一个终端,进行gdb调试
6、分别在sys_clone、do_fork、dup_task_struct、copy_process、copy_thread、ret_from_fork处设置断点。
7、使用“c”使断点执行,使其停在do_fork、dup_task_struct,最后进入dup_task_struct,停在copy_thread和ret_from_fork上。