一、实验楼 实验七
1. task_struct数据结构:
struct task_struct {
volatile long state;
void *stack;
pid_t pid;
unsigned int rt_priority;
unsigned int policy;
struct files_struct *files;
}
2. fork 函数对应的内核处理过程 sys_clone:
do_fork函数原型位于linux-3.18.6/kernel/fork.c。
fork函数可以创建进程,创建一个进程是复制当前进程的信息,被复制的进程成为父进程,被创建的新进程成为子进程。父进程和子进程的绝大部分信息是完全一样的,但是有些信息不能一样,比如pid的值和内核堆栈。还有将新进程链接到各种链表中,要保存进程执行到哪个位置,有一个thread数据结构记录ip和sp等信息也不能一样。所以,父进程创建子进程时,会有一个地方复制父进程的进程描述符task_struct结构体变量,并有很多地方来修改复制的进程描述符task_struct结构体变量。
3. gdb 跟踪分析 sys_clone:
在MenuOS中添加fork函数,进入gdb进行调试,在sys_clone、do_fork、dup_task_struct、copy_process、copy_thread、ret_from_fork等处各设置断点,然后不断执行。