do_fork() 源码剖析

Posted zhangtiezi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了do_fork() 源码剖析相关的知识,希望对你有一定的参考价值。

  分析一下do_fork()的源码的主要步骤

1.首次查找_pidmap位图,为新子进程分配新的pid

技术分享图片

2.复制进程描述符,返回的是新的进程描述符的地址(struct task_struct *p)

技术分享图片

3.初始化完成量,vfrok主要用excv,父进程的虚拟地址空间对其没有用处,所以实现方式为在子进程退出或者替换后父进程才开始执行

 

技术分享图片

4.如果设置了vfork,则调用wait(父进程)

5.free_pidmap(pid):

6.返回子进程pid。

 

对于第二步,是do_fork的关键

1.检查flag位的合法性

2.为子进程获取进程描述符

技术分享图片

  开辟内核栈+thread_info 一般大小为8k

  将current的值赋给子进程

 

  技术分享图片

3.检查线程数量,设置一些关键字,保存新的pid

4.用系统调用时cpu寄存器中的值初始化新线程,将exa置为0(fork和clone在子进程的返回值)

技术分享图片

 

 5.完成一些字段的设置,将新进程加入到链表,将新进程pid加入到散列表

 

技术分享图片

复制父进程每一个vm_area_struct,也复制它的页表,将私有的可写的页都标记为只读,为写时拷贝做准备。

 

技术分享图片

 

 1.判断是否为创建线程,如果是线程,直接使用mm = oldmm ,表示线程公用虚拟地址空间

2.对于非线程,为其创建虚拟地址空间,创建新的局部描述符加入到tsk地址空间,之后调用dup_mmap;

 

后续需要解决的问题:

1.current是什么

2.用户态fork()->内核态sys_fork()的过程是什么

3.copy_mm 在什么时候用的
 


以上是关于do_fork() 源码剖析的主要内容,如果未能解决你的问题,请参考以下文章

Spark Sql 源码剖析(二): TreeNode

java集合框架源码剖析系列java源码剖析之TreeMap

Mybatis源码剖析:二级缓存源码剖析

Mybatis源码剖析:延迟加载源码剖析

SpringBoot整合SSM三大框架源码剖析之SpringBoot源码剖析

转:Java集合源码剖析LinkedHashmap源码剖析