- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
MINIX中的进程创建v2
MINIX中的进程创建
MINIX的系统中是由PM管理进程创建,但是具体创建操作由PM、内核、FS三部分完成。创建首先是用户调用 lib/posix/_fork.c中的fork()要求创建进程,这条调用最终转化成调用src/kernel/proc.c中的sys_call(),并构建一条消息 HYPERLINK \l Message message,其中写明m-m_source为当前调用者进程号,消息类型m-m_type为FORK。消息(即图中的m)的地址这时已经作为参数被传递进来,sys_call()可以据此得知m的内容,并在适当的时候将内容传递给PM(即图中MM)。
PM的工作就是不断地获取并处理消息,所以它能够得到用户进程发送的m,并将其存放在 HYPERLINK \l PM_global_variables m_in中。当PM分析m_in-m_type为FORK,得知了消息的内容是要进行fork操作,它就进一步调用其do_fork()完成整个过程。
PM进行FORK操作后,以发消息的形式通知内核中的系统任务SYSTEM和文件系统FS进行各自的Fork操作,最后由PM设置消息 HYPERLINK \l PM_global_variables m_out向调用者进程进行回复和提供返回值。
下图1说明了用户要求进程创建时,消息的传递过程。图中使用了三种箭头,实线表示消息的发送过程,点线表示消息的获取过程,虚线表示发送和接收消息都会经历的过程。
图1 Minix的fork调用消息传递过程
FORK所操作的数据对象
PM对数据对象的操作
PM为子进程分配内存空间
在执行fork调用时,如果中途停止,是很困难的事情。所以PM担心两件事情会导致进程创建失败,一是没有空闲的进程表项,二是当前内存不足,不能为子进程分配足够内存。为此,首先PM维护一个计数器procs_in_use,记录当前的进程个数,以方便知道是否有空闲进程表项。其次,PM调用 HYPERLINK \l alloc_mem alloc_mem(total_size)尝试为子进程分配内存,如果返回值为NO_MEM则直接退出并反馈内存不足,如果分配内存成功,那么这次fork就一定能成功。
PM查看父进程的内存映射表 HYPERLINK \l mem_map mp_seg,计算其数据段长度、栈段长度和两段的间隔gap的大小,以确定应该为子进程申请的内存大小,随后为子进程申请内存空间。成功申请之后将父进程的内存数据段、栈段和两段的中间间隔gap(也就是堆)完整的复制到子进程刚申请的内存页面中。
PM复制的内存是从数据段的开始一直到栈段的栈底部,至于代码段有两种情况,一是检查父进程rmp- HYPERLINK \l mp_flags mp_flags SEPARATE是否成立(附录中有所有 HYPERLINK \l mp_flags 状态定义),成立说明父进程是分离的ID空间,那么父子进程可以共享代码段,代码段就不用复制,并且内存映射表mp_seg中代码段映射mp_seg[T]不用修改,二是父进程是不分离的ID空间,就是代码段和数据段是在一起的,即代码在数据段中,那么上述内存拷贝从数据段的开始一直到栈段的栈底部,代码段也就一同被拷贝到子进程内存空间中了。
PM创建子进程的进程控制块
PM根据procs_in_use确定有空闲表项后。以遍历的方式检查每个表项的 HYPERLINK \l mp_flags mp_flags,直到找到一个 HYPERLINK \l mp_flags mp_flags的IN_USE位没被置位的表项。通过复制的形式,将父进程进程控制块复制到这个进程控制块表项中,因为子进程内存的物理地址改变了,所以要修改子进程控制块中的内存映射表 HYPERLINK \l mem_map mp_seg,将其代码段、数据段和栈段的物理地址 HYPERLINK \l mem_phys mem_phys进行更新,其次PM为子进程控制块(记做rmc)做其他修改:1、修改其父进程rmc-parent为当前执行fork调用的进程,2、修改子进程的进程状态mp_flag、退出状态mp_exitstatus、信号状态mp_sigstatus和子进程运行时间mp_child_utime为默认,3、分配给子进程一个pid号。
PM进程控制块定义可见附录中 HYPERLINK \l mproc mproc。
内核对数据对象的操作
内核负责在为子进程创建内核中的进程控制块,在复制控制块前,内核先保存子进程控制块中的LDT表选择子p_ldt_sel。在复制了父进程控制块后将子进程的LDT表选择子重设为它原来的选择子,这个选择子内有LDT表描述符的索引并指示要从GDT表查找这
文档评论(0)