第9章Linux系统.ppt
《第9章Linux系统.ppt》由会员分享,可在线阅读,更多相关《第9章Linux系统.ppt(132页珍藏版)》请在三一办公上搜索。
1、第9章 Linux系统,Linux系统,Linux系统概述Linux的特权级与中断处理Linux系统功能调用Linux系统的进程管理Linux系统的存储管理Linux系统的设备驱动Linux文件系统,1,Linux系统主要内容,Linux系统概述,Linux系统 Linux系统概述,1.Linux系统的定义 Linux系统是一个类UNIX的操作系统,与UNIX完全兼容,在操作系统功能、使用方法等方面极为相似。(1)什么是Linux操作系统 Linux是一个多用户、多任务操作系统(2)Linux与UNIX操作系统的不同点 源代码编写方式 商业模式 开发模式,2,Linux系统 Linux系统概述
2、,(4)Linux系统的特点 单体结构内核 可抢占式内核 多线程应用程序的支持 多处理机支持 支持多种文件系统,(3)Linux系统的组成 Linux操作系统包括Linux内核,还包括shell、带有多窗口 管理器的 X-Windows图形用户接口、文本编辑器、高级语 言编译器等应用软件。,3,Linux系统 Linux系统概述,2.Linux系统的内核结构(1)Linux内核的组成 Linux内核包含最基础、最核心的概念,提供系统其他部 分必须的服务支持。组成进程调度程序、主存管理程序负责网络、进程间通信的服务程序中断处理程序和设备驱动等核心服务程序,4,Linux系统 Linux系统概述,
3、5,(2)Linux系统的核心结构,Linux系统的核心结构示意图,Linux系统 Linux系统概述,Linux系统的特权级与中断处理,Linux系统 Linux系统的特权级与中断处理,6,1.Linux系统的特权级Linux系统使用两个级别(处理机提供四个特权级):特权级0 核态(内核模式)特权级3 用户态(用户模式)2.Linux系统中断处理的上半部和下半部(1)为什么要区分上半部和下半部,Linux系统 Linux系统的特权级与中断处理,为提高中断处理的效率,中断处理程序的执行必须快速、简洁。为此,Linux系统将中断处理程序分为两部分。将中断响应后必须立即处理的工作即刻执行,这就是中
4、断处理程序的上半部(tophalf)。将更多的处理工作向后推迟执行,这就是中断处理程序序的下半部(bottom half)。,7,(2)中断处理程序的上半部上半部是中断处理中有严格时间限制的工作,是关键而 紧迫的部分;上半部的工作是不可被打断的,即在屏蔽所有中断的情 况下进行的。例:与硬件设备应答或使硬件复位的工作。,(3)中断处理程序的下半部下半部处理那些可以稍后完成的工作;下半部的执行是可以打断的,即是在开中断的情况下执 行。,Linux系统 Linux系统的特权级与中断处理,8,3.中断处理下半部的实现机制 Linux系统中,用于实现实现将工作推后执行的内核机制称为“下半部机制”,下半部
5、机制主要有tasklet和工作队列两种。(1)tasklet tasklet通过软中断实现 一个软中断被标记后才能执行,称为触发软中断。待处理的软中断会在以下时机被检查和执行:从一个硬件中断返回时;在ksoftirqd内核线程中;在显示检查和执行待处理的软中断的代码中。,Linux系统 Linux系统的特权级与中断处理,9,Tasklet软中断 tasklet的软中断表示是TASKLET_SOFTIRQ;Taskle由结构体tasklet_struct结构表示,struct tasklet_struct struct tasklet_struct*next;/*链表中的下一个taskle*/u
6、nsignet long state;/*taskle的状态*/atomic_t count;/*引用计数器*/void(*func)(unsigned long);/*taskle的处理函数*/unsigned long data;/*给taskle处理函数的参数*/tasklet由tasklet_schedule()函数调度,Linux系统 Linux系统的特权级与中断处理,10,(2)工作队列 工作队列机制将中断处理程序的下半部交给一个内核线 程去执行。下半部是在进程上下文(用户地址空间)执行,可以睡眠和 被重新调度。注:这一点与上述的tasklet不同。如果下半部工作需要睡 眠(如需要
7、执行阻塞式I/O操作时,或要等待信号灯)时应 选择工作队列机制;否则可选择tasklet机制。,Linux系统 Linux系统的特权级与中断处理,11,工作者线程 该线程接收由各内核中断处理程序交给它的下半部。该线程内核线程实现的。执行的函数是 work_thread(),对应的数据结构是工作队列链表。工作队列链表 由若干个work_struct结构组成。work_struct结构,Linux系统 Linux系统的特权级与中断处理,12,work_struct结构 每个work_struct结构描述如下 struct work_struct unsigned long pending;/*该工
8、作正在等待处理?*/struct list_head entry;/*勾链字*/void(*func)(void*);/*该工作的处理函数*/void*data;/*传递该该处理函数的参数*/void*wq_data;/*内部使用*/struct timer_list timer;/*延迟的工作队列所用的定时器*/,Linux系统 Linux系统的特权级与中断处理,13,执行函数work_thread()执行一个死循环;若工作队列链表不空时,执行链表上的所有工作。工 作被执行完毕,它就将相应的work_struct对象从链表 上移走;当链表为空时,它进入睡眠状态;当有下半部插入到队列时,函数是
9、work_thread()被唤醒,将继续处理新加入的下半部。,Linux系统 Linux系统的特权级与中断处理,Linux系统的功能调用,Linux系统Linux系统功能调用,14,1.Linux系统功能调用的过程在Linux系统中,系统调用通过异常类型实现;当执行了int 0 x80指令而发生的软件中断;系统自动将用户态切换为核心态来处理该事件,执行自陷处理程序(系统调用处理程序)。,Linux系统Linux系统功能调用,15,(1)系统功能调用过程,Linux系统调用过程,Linux系统Linux系统功能调用,16,(2)例:getuid系统调用过程,getuid系统调用过程,Linux系
10、统Linux系统功能调用,17,2.Linux系统功能调用的实现机制(1)Linux系统调用的进入 Linux系统的软中断指令是int 0 x80汇编语言指令 该指令的执行会发生中断 处理机的状态由用户态自陷到内核态 从system_call()开始执行系统调用处理程序。当系统调用处理完毕后,通过iret汇编语言指令返回到用 户态。,Linux系统Linux系统功能调用,18,(2)系统调用号 linux中,每个系统调用被赋予一个唯一的系统调用号 系统调用号定义在include/asm-i386/unistd.h头文件中 系统调用号格式如下#define _NR_restart_syscall
11、 0#define _NR_exit 1#define _NR_fork 2#define _NR_read 3#define _NR_write 4#define _NR_open 5#define _NR_mq_getsetattr 282,Linux系统Linux系统功能调用,19,(3)系统调用表 系统调用表记录了内核中所有已注册过的系统调用,它是系统调用的跳转表。系统调用表是一个函数指针数组,表中依次保存所有 系统调用的函数指针 Linux系统调用表保存在arch/i386/kernel/下的entry.S中,Linux系统Linux系统功能调用,20,系统调用表格式如下 ENTRY
12、(sys_call_table).long sys_restart_syscall/*0*/.long sys_exit/*1*/.long sys_fork/*2*/.long sys_read/*3*/.long sys_write/*4*/.long sys_open/*5*/.long sys_mq_getsetattr/*282*/,Linux系统Linux系统功能调用,21,(4)系统调用处理程序 系统调用处理程序是system_call(),主要工作如下宏SAVE_ALL保护现场;正确性检查;依eax中所包含的系统调用号,调用其对应的服务例 程;系统服务例程结束时,通过宏REST
13、ORE_ALL恢复寄 存器;最后通过iret指令返回。,Linux系统Linux系统功能调用,22,3.增加一个新的系统功能调用的方法(1)添加新的服务例程 在/usr/src/linux/kernel/sys.c文件中增加一个新的函数,该函数的名字是sys_mysyscall 例:一个简单的系统调用,其功能是返回一个整型值 asmlinkage int sys_mycall(int number)return number;,Linux系统Linux系统功能调用,23,(2)增加新的系统功能调用号 在文件include/asm-i386/unistd.h中添加一项#define _NR_my
14、syscall XX XX为新增加的系统调用号,此数字选一未用值。例#define _NR_restart_syscall 0#define _NR_exit1#define _NR_mq_getsetattr 282#define _NR_mysyscall 283,Linux系统Linux系统功能调用,24,(3)修改系统调用表 在文件/arch/i386/kernel/entry.S中的系统调用表sys_call_table中添加新增的系统调用sys_call_table数组包含指向内核中每个系统调用的指针 例 ENTRY(sys_call_table).long sys_restart
15、_syscall/*0*/.long sys_exit/*1*/.long sys_mq_getsetattr/*282*/.long sys_mysyscall/*283*/,Linux系统Linux系统功能调用,25,(4)重新编译内核并启动新内核 为使新的系统调用生效,需要重建Linux的内核。这需要以超级用户身份登录后重新编译内核。,(5)在用户程序中访问新的系统调用 在用户程序中,测试新增加的系统调用是否能正确使用。,Linux系统Linux系统功能调用,Linux系统的进程管理,Linux系统Linux系统的进程管理,26,1.Linux系统进程与线程(1)Linux系统中的进程
16、进程是程序在处理机上的一次执行过程。进程是处于执行 期的程序,它是分配系统资源和调度的实体。进程包括可执行的程序代码、打开的文件、挂起的信号、内核数据、地址空间、处理机状态、一个或多个可执行 的线程等。(2)Linux系统中的线程 Linux系统将线程看作是一种特殊的进程。线程被视为一 个与其他进程共享某些资源的进程。,Linux系统Linux系统的进程管理,27,2.Linux系统的进程描述符 Linux内核使用进程描述符(又称为进程控制块)来描述一个 进程的完整信息。,(1)进程控制块的结构,Linux系统Linux系统的进程管理,28,进程控制块的结构,进程控制块结构,Linux系统Li
17、nux系统的进程管理,29,(2)进程控制块的主要内容,进程标识符 进程标识符process ID,进程描述符中的标识符字段,Linux系统Linux系统的进程管理,30,进程状态 反映进程当前状态,包括以下几种可能的状态,可运行状态 TASK_RUNNING 可中断的等待状态 TASK_INTERRUPTIBLE 不可中断的等待状态 TASK_UNINTERRUPTIBLE 暂停状态 TASK_STOPPED 终止状态 TXIT_ZOMBIE,Linux系统Linux系统的进程管理,31,进程基本信息 每个进程都有一个进程基本信息块。在进程描述符的thread_info字段中包含了指向该结构
18、的指针,与进程调度有关的信息 可运行进程链表(最多可有140个),进程的亲属关系,进程描述符中的亲属关系字段,Linux系统Linux系统的进程管理,32,其他字段 在进程描述符的thread_info字段中包含了指向各种结构的 指针。,fs 指向当前目录结构 fs_steuct files 指向文件描述符结构 files_struct mm 指向主存描述符结构 mm_struct signal 指向信号结构 signal_struct tty 指向进程相关的 tty_struct结构,Linux系统Linux系统的进程管理,33,(1)TASK_RUNNING(可运行状态)它或者正在执行,运
19、行状态 或者在运行队列中等待执行,就绪状态(2)TASK_INTERRUPTIBLE(可中断的等待状态)进程正在等待某一事件的发生(如某一硬件中断或一个信 号),它处于挂起或称睡眠状态。(3)TASK_UNINTERRUPTIBLE(不可中断的等待 状态)除了不会因为接收到信号而被唤醒从而投入运行外,这个 状态与可中断等待状态相同。,3.Linux系统进程状态及变迁,Linux系统Linux系统的进程管理,34,(4)TASK_ZOMBIE(僵死状态)表示进程已经结束,但其父进程还没有调用wait4()系统 调用。子进程的进程描述符在此之前仍然被保留(5)TASK_STOPPED(停止)表示进
20、程停止执行,进程没有投入运行也不能投入运行。通常这种状态发生在接收到SIGSTOP、SIGTSTP、SIGTTIN、SIGTTOU等信号的时候。,Linux系统Linux系统的进程管理,35,(6)Linux系统进程状态的变迁,Linux系统进程状态变迁图,Linux系统Linux系统的进程管理,36,(1)进程创建 Linux系统用fork()系统调用创建一个进程。写时拷贝 在创建新进程时内核不复制父进程的整个地址空间,而是让父进程和子进程以读方式共享同一拷贝 只有当一方真正需要写入时,数据才被复制,这时,父、子进程才拥有各自的拷贝,4.Linux系统进程创建与终止,系统提供fork()和c
21、lone()系统调用 fork()用来创建一般进程 clone()用来创建轻量级进程(线程),Linux系统Linux系统的进程管理,37,(2)进程终止 Linux系统提供exit()系统调用以终止某一个进程。其主要 功能由do_exec()函数完成。进程终止后,此进程处于僵死状态,但系统还保留了它的 进程描述符。只有父进程发出了与被终止进程相关的 wait()系统调用后,子进程的task_struct结构才能释放。,Linux系统Linux系统的进程管理,38,(1)进程等待 两种等待状态 TASK_INTERRUPTIBLE 和 TASK_UNINTERRUPTIBLE 区别:处于TAS
22、K_UNINTERRUPTIBLE状态的进程如果接收到一个信 号会被提前唤醒并响应该信号,而处于TASK_INTERRUPTIBLE状态 的进程会忽略信号。,5.Linux系统的进程等待与唤醒,进程等待的主要步骤 调用declare_waitqueue()创建一个等待队列的元素。调用add_wait_queue()将该元素加入到等待队列。进程的状态设置为TASK_INTERRUPTIBLE状态 TASK_UNINTERRUPTIBLE状态。转进程调度程序schedule()。,Linux系统Linux系统的进程管理,39,(2)进程唤醒,进程唤醒的主要步骤 当进程状态设置为TASK_INTER
23、RUPTIBLE,则由信号唤醒进程,这是所谓的伪唤醒(不是直接由所等待的事件唤醒),因此需要检 查并处理信号。若检查条件为真(所等待的事件发生),转;若条件不为真,转进 程调度schdule()。当进程被唤醒时(因事件发生),检查条件是否为真,若为真转;否则转进程调度schdule()。当条件满足时,进程状态设置为 TASK_RUNNING,并将该进程 移出等待队列。该函数将进程状态设置为TASK_RUNNING,再将此进程加入到 可执行队列。若被唤醒进程的优先级比当前正在运行的进程的优 先级高,设置need_resched标志。,Linux系统Linux系统的进程管理,Linux系统的进程调
24、度,Linux系统Linux系统的进程调度,40,1.Linux进程调度目标和特点,进程调度程序是内核的组成部分,负责选择下一个要运 行的进程。进程调度可看作在可运行态进程之间分配有限的处理器 时间资源的内核子系统。进程调度程序是如Linux这样的多任务操作系统的基础。(1)Linux进程调度策略 基于动态优先级和可变时间的调度 调度方式为可抢占式调度,Linux系统Linux系统的进程调度,41,(2)调度目标 实现算法复杂度为O(1)级的调度 进程调度算法保证在恒定的时间内完成 算法执行时间与系统中处于就绪(可运行)状态的进程个 数无关 提高交互性能提高交互性能,保证系统能快速响应 保证公
25、平 在合理设定的时间范围内,没有进程会出现饥饿状态 也不会有进程获得大量的时间片 实现SMP可扩展性,Linux系统Linux系统的进程调度,42,(3)I/O消耗型和处理器消耗型的进程 I/O消耗型进程 大部分时间是使用外部设备,交互式进程具有此特征。处理器消耗型进程 大部分时间是使用CPU,计算进程具有此特征。,交互式的程序都是I/O消耗型的。Linux为了保证交互式应用,优化了进程的响应,更倾向 于优先调度I/O消耗型进程,但并未忽略处理器消耗型程 序。,Linux系统Linux系统的进程调度,43,(4)进程调度的特点 Linux系统实现了基于进程过去行为的启发式算法;Linux系统选
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Linux 系统
链接地址:https://www.31ppt.com/p-5311049.html