创建一个进程可以通过clone()
,fork()
,vfork()
这三个系统调用来完成。而这三个系统调用都是由do_fork()
函数来负责处理。在《深入理解Linux内核(第三版)》中写到,实现clone()
系统调用的是sys_clone()
服务例程,实现fork()
系统调用的是clone()
,实现vfork()
的也是clone()
。但是负责处理clone()
,fork()
和vfork()
的函数是do_fork()
。概括的流程就是:clone(),fork(),vfork()
——>
sys_clone()
——>
do_fork()
。
do_fork()
函数的关键是调用copy_process()
函数。copy_process()
函数的作用是创建进程描述符以及子进程执行所需要的所有其他数据结构。在copy_process()
函数中,比较关键的是调用dup_task_struct()
为子进程获取进程描述符;调用copy_thread()
用发出clone()
系统调用时CPU寄存器保存的值来初始化子进程的内核栈;调用sched_fork()
完成对新进程调度程序数据结构的初始化。copy_process()
函数结束后返回子进程描述符指针(tsk)。
当do_fork()