gdb调试执行流程,首先设置断点b sys_clone,当在shell下输入fork命令后,系统执行至断点,接下来按步执行:
  1. 判断是否被跟踪
  2. 判断是否被创建为轻量级进程(vfork)
  3. 判断父进程是否被跟踪,
  4. 判断是否子进程获取新的PID或命名空间,如果是,则不允许其共享进程组、信号handler或父进程
  5. task_create在复制之前确认共享的权限
  6. 调用dup_task_struct复制task_struct(进程描述符)
  7. alloc_task_struct_node为task_struct分配内存
  8. alloc_thread_info_node为thread_info分配内存
  9. setup_thread_stack为进程新建一个内核栈
  10. copy_semundo
  11. copy_files
  12. copy_fs
  13. copy_sighand
  14. copy_signal
  15. copy_mm
  16. copy_namespaces
  17. copy_io
  18. 进入copy_thread
  19. struct pt_regs *childregs = task_pt_regs(p);给指针赋值,指向.thread.regs
  20. *childregs = *current_pt_regs();复制寄存器内容
  21. childregs->ax = 0; 给子进程pid返回值0;
  22. p->thread.ip = (unsigned long)ret_from_fork;子进程从ret_from_fork开始执行。
  23. ret_from_fork位于entry.S。子进程执行ret_from_fork后转到syscall_exit
  24. 父进程copy_thread完成,返回copy_process
  25. 给新进程分配新pid
  26. 设置子进程pid
  27. 子进程接下来进行关中断,检查信号(信号量不共享则不复制),继续restore_all最后恢复上下文,从内核态返回,继续执行程序中的代码。
  28. 父进程返回sys_clone,父进程执行fork()之后的代码。最后程序结束。
总结:
  • 进程(task)是处于执行期的程序,通常还包括打开的文件,挂起的信号,内核内部数据,处理器状态,一个或多个具有内存映射的内存地址空间及一个或多个执行线程,还有存放全局变量的数据段等。
  • 线程是在进程中活动的对象。linux:不特别区分进程线程,线程是特殊的进程。
  • 在现代Linux内核中,fork实际上是由clone系统调用实现的。
  • fork从内核返回两次,一个回到父进程,一次回到产生的新的子进程。
  • 程序通过exit()系统调用退出执行。此函数会终结进程并将其占用的资源释放掉。父进程可以通过wait4()系统调用查询子进程是否终结,这使进程拥有了等待特定进程执行完毕的能力。进程退出执行后被设置僵死状态。
  • Linux系统通过c库提供wait(),waitpid(),wait3(),wait4()等函数。
  • 内核把进程的列表存放在任务队列(task list)双向列表中,表中每项都是task_struct,被称为进程描述符,定义在<linux/sched.h>中。内核通过一个唯一的进程标示值PID来标记进程。PID为pid_t类型,实际为int。
  • 进程状态:
    • TASK_RUNNING表示进程可执行。
    • TASK_INTERRUPTIBLE可中断。进程正在睡眠(阻塞),等待信号。
    • TASK_UNINTERRUPTIBLE不可中断。处于此状态不受信号唤醒。其它同上。
    • _TASK_TRACED被其他进程跟踪的进程。
    • _TASK_STOPPED进程没有投入运行也不能投入运行。
  • Unix将产生机制分解为fork和exec。fork复制exec负责读取可执行文件并将其载入地址空间开始运行。
  • fork采用写时拷贝页实现。页的拷贝推迟到实际发生写入时。
  • 内核有意选择子进程先执行,因为一般子进程马上会调用exec()。以避免写时拷贝的开销。
  • 完成fork调用后存在两个进程,每个进程都会从fork()返回处继续执行。
  • fork,vfork,clone都调用do_fork,vfork不拷贝父进程的页表。clone带参数。

参考文献:

《Linux内核设计与实现》

By:昆仑雪狐

原创作品转载请注明出处

《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000

fork函数创建新进程过程分析的更多相关文章

  1. 通过fork函数创建进程的跟踪,分析linux内核进程的创建

    作者:吴乐 山东师范大学 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.实验过程 1.打开gdb, ...

  2. Linux内核分析— —创建新进程的过程

    分析Linux内核创建一个新进程的过程 实验过程 要求:使用gdb跟踪分析一个fork系统调用内核处理函数sys_clone ,验证对Linux系统创建一个新进程的理解,推荐在实验楼Linux虚拟机环 ...

  3. linux进程学习-创建新进程

    init进程将系统启动后,init将成为此后所有进程的祖先,此后的进程都是直接或间接从init进程“复制”而来.完成该“复制”功能的函数有fork()和clone()等. 一个进程(父进程)调用for ...

  4. linux里面的fork函数创建一个新进程

    由fork创建的新进程成为子进程,fork函数被调用一次,但是返回两次,

  5. 创建新进程,就三个函数CreateProcessAsUser CreateProcessWithLogonW CreateProcessWithTokenW(附网友的流程)

    CreateProcessAsUser 怎么会还需要密码呢~~~ 先WTSGetActiveConsoleSessionId 得到当前的处理激活状态的SessionId OpenProcessToke ...

  6. Linux内核分析-创建新进程的过程

    分析Linux内核创建一个新进程的过程 task_struct结构体分析 struct task_struct{ volatile long state; //进程的状态 unsigned long ...

  7. Go:创建新进程(os.StartProcess源码解读)

    关于如何使用go语言实现新进程的创建和进程间通信,我在网上找了不少的资料,但是始终未能发现让自己满意的答案,因此我打算自己来分析这部分源代码,然后善加利用,并且分享给大家,期望大家能从中获得启发. 首 ...

  8. Win32 API编程:使用CreateProcess创建新进程

    #include <windows.h> #include <tchar.h> #include <stdio.h> int main(int argc, char ...

  9. 第八篇:文件共享和使用 dup 函数创建新描述符的区别

    前言 文件共享是指同时打开一个文件 用 dup 函数能对指定文件描述符再创建一个新的描述符,且这个新的描述符和旧的描述符指向的是同一个文件. 这两种行为有什么区别呢?下面给出的两张文件系统的图形象的解 ...

随机推荐

  1. maven webjar构建及使用

    这么做的目的想要把前端静态文件,css啊js啊一堆的放在一个maven工程下管理,需要的时候调用jar包直接引用. 1.把要打包文件放到另外的maven项目的/src/main/resources下 ...

  2. Codeforces Round #375 (Div. 2) F. st-Spanning Tree

    传送门 分析:构造题.可以这么想:先把s,t两个点去掉,把剩下的点先并查集合并.这样会出现个集合:, , 个剩余集合.那么个集合中先把只能与或中一个相连的连起来,如果这样已经超出了要求,那么就不能构造 ...

  3. Java—网络技术

    1  TCP Sockets基础 Sockets是一个编程抽象概念,它是网络上与另一个应用程序通信连接的句柄.Sockets编程将用户代码与TCP/IP协议堆栈的底层实现隔离开,允许用户灵活地实现自己 ...

  4. Mac OS 下 mysql 找不到 mysql.sock 的问题

    mysql.sock 无法找到一般存在两种问题,一是mysql服务未启动,mysql.sock没有生成,二是mysql.sock的指向位置出错,在指向位置加个mysql.sock的软链接就可以解决. ...

  5. thinkjs中自定义sql语句

    一直以为在使用thinkjs时,只能是它自带的sql语句查询,当遇到类似于这样的sql语句时,却不知道这该怎样来写程序,殊不知原来thinkjs可以执行自定义sql语句 SELECT * from a ...

  6. Windows Store App JavaScript 开发:选取文件和文件夹

    前面提到过,文件打开选取器由FileOpenPicker类表示,用于选取或打开文件,而文件夹选取器由FolderPicker类表示,用来选取文件夹.在FileOpenPicker类中,pickSing ...

  7. Windows Store App Image开发示例

    通过上面的介绍,读者已经了解了Image对象及ImageBrush对象的使用方法和常用属性,在实际的开发工作中,比较常用的是Image对象,下面以一个幼儿园识物识字卡应用为例,来帮助读者更好的理解Im ...

  8. js判断数组

    1.constructor 在W3C定义中的定义:constructor 属性返回对创建此对象的数组函数的引用 就是返回对象相对应的构造函数.从定义上来说跟instanceof不太一致,但效果都是一样 ...

  9. 虚拟化 模板制作 rhev笔记

    查看主机是否支持RHEV:一要支持vt-x, 一定是64位操作系统 cat /proc/cpuinfo 查看是否有lm(64位) 是否有, vmx(or svm)(vt-x) 虚拟化中制作Linux模 ...

  10. canvas 时钟+自由落体

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...