- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux
一、实验内容:
1. 利用bochs观测linux0.11
2. 利用bochs观测linux0.11
进程管理实验
下的 PCB进程控制结构。
下的fork.c 源代码文件,简单分析其中
的重要函数。
3. 在fork.c 适当位置添加代码,以验证 fork 函数的工作原理。 二、 Linux 进程管理机制分析
Linux 有两类进程:一类是普通用户进程,一类是系统进程,它
既可以在用户空间运行, 又可以通过系统调用进入内核空间, 并在内
核空间运行;另一类叫做内核进程,这种进程只能在内核空间运行。
在以 i386 为平台的 Linux 系统中,进程由进程控制块,系统堆栈,用
户堆栈,程序代码及数据段组成。 Linux 系统中的每一个用户进程有
两个堆栈: 一个叫做用户堆栈, 它是进程运行在用户空间时使用的堆 栈; 另一个叫做系统堆栈, 它是用户进程运行在系统空间时使用的堆
栈。
1.Linux 进程的状态:
Linux 进程用进程控制块的 state域记录了进程的当前状态, 一个 Linux 进程在它的生存期中,可以有下面 6种 状态。
1.就绪状态 (TASK_RUNNING) :在此状态下, 进程已挂入就绪队列,
进入准备运行状态。
2.运行状态 (TASK_RUNNING) :当进程正在运行时,它的 state域中 的值不改变。但是 Linux 会用一个专门指针 (current) 指向当前运行的
任务。
3.可中断等待状态 (TASK_INTERRUPTIBLE) :进程由于未获得它所
申请的资源而处在等待状态。 不管是资源有效或者中断唤醒信号都能
使等待的进程脱离等待而进入就绪状态。即 ”浅睡眠状态 ”。
4.不可中断等待状态 (TASK_UNINTERRUPTIBLE) :这个等待状态与
上面等待状态的区别在于只有当它申请的资源有效时才能被唤醒, 而
其它信号不能。即 睡眠状态 ”。
5.停止状态( TASK_STOPPED) :当进程收到一个 SIGSTOP 信号后
就由运行状态进入停止状态,当收到一个 SINCONT 信号时,又会恢
复运行状态。挂起状态。
6.终止状态( TASK_ZOMBIE:)进程因某种原因终止运行,但进程控制
块尚未注销。即 死状态 ”。
状态图如下所示:
2.Linux 进程控制块:
在Linux 中,进程控制块为数据结构 task_struct, 它包含了大量该进程 的信息,这些信息大致为以下几类:
1) .进程的当前状态
2) .调度信息
3) .进程标识
4) .进程的通信信息
5) .进程与其它进程之间关系的信息
6) .使用文件的信息
7) .虚拟内存与物理内存的关系
8) .计时器
9) .处理器与进程的有关信息
3. Fork 函数:
父进程创建一个子进程最方便快捷的方式就是把父进程的控制
块照原样复制一个, 然后再根据子进程的修改特点对它进行必要的修
改,形成子进程的控制块。
系统调用 fork() 通过调用 find_empty_process 及copy_process 等函数复制一个当前进程的进程控制块, 然后用新进程标识修改旧标
识,填写子进程与父进程关系,创建子进程堆栈和数据区。
因此, fork() 执行后,父子进程共享同一个存储空间,父进程的所有 可共享资源都被子进程通过数据结构的复制继承了过来。
在父进程调用 fork()与在子进程中调用 fork(), fork()的返回值不同! 如果是在父进程调用 fork(), 则 fork()就复制出一个子进程, 并返回子
进程的标识 ID,如果创建子进程失败,则 fork()的返回值为 -1;而如果
在子进程调用 fork(),则它返回的是 0。
三、实验步骤及结果
在安装目录下双击 bochs.exe,选择提供好的 linux0.11 配置文件, 点击start ,启动虚拟机,如下图所示:
一、 利用 bochs观测 linux0.11 下的 PCB进程控制结构
1. 切换工作目录到 /usr/src/linux/include/linux 文件夹,如下所
示:
2. 利用vi 编辑器打开 sched.h 头文件, 寻找struct task_struct 结构
体的定义,如下:
观察进程控制块的内容,对里面的一些变量分析:
Longstate : 表示当前进程所
文档评论(0)