操作系统第9章Linux系统课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《操作系统第9章Linux系统课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 Linux 系统 课件
- 资源描述:
-
1、Linux系统系统1Linux系统系统主要内容主要内容 Linux系统概述系统概述Linux系统系统 Linux系统概述系统概述 Linux系统是一个类系统是一个类UNIX的操作系统,与的操作系统,与UNIX完全兼容,完全兼容, 在操作系统功能、使用方法等方面极为相似。在操作系统功能、使用方法等方面极为相似。 Linux是一个多用户、多任务操作系统 源代码编写方式源代码编写方式 商业模式商业模式 开发模式开发模式 2Linux系统系统 Linux系统概述系统概述 单体结构内核单体结构内核 可抢占式内核可抢占式内核 多线程应用程序的支持多线程应用程序的支持 多处理机支持多处理机支持 支持多种文件
2、系统支持多种文件系统 Linux操作系统包括Linux内核,还包括shell、带有多窗口 管理器的 X-Windows图形用户接口、文本编辑器、高级语 言编译器等应用软件。 3Linux系统系统 Linux系统概述系统概述 Linux内核包含最基础、最核心的概念,提供系统其他部 分必须的服务支持。 组成组成进程调度程序、主存管理程序负责网络、进程间通信的服务程序中断处理程序和设备驱动等核心服务程序4Linux系统系统 Linux系统概述系统概述5系系 统统 调调 用用 界界 面面程程 序序 库库进程通信进程通信进程调度进程调度存储管理存储管理文件子系统文件子系统高速缓冲高速缓冲字符设备字符设备
3、 块设备块设备 设备驱动程序设备驱动程序用户程序用户程序 硬硬 件件 控控 制制 硬硬 件件 用户级用户级核心级核心级硬件层硬件层进程管理与存储管理进程管理与存储管理网络管理网络管理网络协议网络协议网络驱动网络驱动Linux系统的核心结构示意图Linux系统系统 Linux系统概述系统概述 Linux系统的特权级与中断处理系统的特权级与中断处理Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理6Linux系统使用两个级别 (处理机提供四个特权级) :特权级0 核态 (内核模式)特权级3 用户态 (用户模式)Linux系统系统 Linux系统的特权级与中断处理系统的特权级
4、与中断处理为提高中断处理的效率,中断处理程序的执行必须快速、简洁。为此,Linux系统将中断处理程序分为两部分。将中断响应后必须立即处理的工作即刻执行,这就是中断处理程序的上半部 (tophalf)。将更多的处理工作向后推迟执行,这就是中断处理程序序的下半部(bottom half)。7上半部是中断处理中有严格时间限制的工作,是关键而 紧迫的部分;上半部的工作是不可被打断的,即在屏蔽所有中断的情 况下进行的。例:与硬件设备应答或使硬件复位的工作。下半部处理那些可以稍后完成的工作; 下半部的执行是可以打断的,即是在开中断的情况下执 行。Linux系统系统 Linux系统的特权级与中断处理系统的特
5、权级与中断处理8 Linux系统中,用于实现实现将工作推后执行的内核机制称为 “下半部机制”,下半部机制主要有tasklet和工作队列两种。 tasklet通过软中断实现通过软中断实现 一个软中断被标记后才能执行,称为触发软中断。 待处理的软中断会在以下时机被检查和执行:从一个硬件中断返回时;在ksoftirqd内核线程中;在显示检查和执行待处理的软中断的代码中。Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理9 Tasklet软中断软中断 tasklet的软中断表示是的软中断表示是TASKLET_SOFTIRQ; Taskle由结构体由结构体tasklet_stru
6、ct结构表示结构表示 struct tasklet_struct struct tasklet_struct *next; /* 链表中的下一个taskle */ unsignet long state; /* taskle的状态 */ atomic_t count; /* 引用计数器 */ void (*func) (unsigned long); /* taskle的处理函数 */ unsigned long data; /* 给taskle处理函数的参数 */ tasklet由由tasklet_schedule()函数调度函数调度 Linux系统系统 Linux系统的特权级与中断处理系统
7、的特权级与中断处理10 工作队列机制将中断处理程序的下半部交给一个内核线 程去执行。 下半部是在进程上下文 (用户地址空间)执行,可以睡眠和 被重新调度。 注:这一点与上述的tasklet不同。如果下半部工作需要睡 眠 (如需要执行阻塞式I/O操作时,或要等待信号灯)时应 选择工作队列机制;否则可选择tasklet机制。Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理11 工作者线程工作者线程 该线程接收由各内核中断处理程序交给它的下半部。 该线程内核线程实现的。执行的函数是 work_thread(), 对应的数据结构是工作队列链表。 工作队列链表工作队列链表 由若
8、干个work_struct结构组成。 work_struct结构Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理12 work_struct结构 每个work_struct结构描述如下 struct work_struct unsigned long pending; /* 该工作正在等待处理?*/ struct list_head entry; /* 勾链字 */ void (*func) (void *); /* 该工作的处理函数 */ void *data; /* 传递该该处理函数的参数 */ void *wq_data; /* 内部使用 */ struct t
9、imer_list timer; /* 延迟的工作队列所用的定时器 */ Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理13 执行函数执行函数work_threadwork_thread()() 执行一个死循环; 若工作队列链表不空时,执行链表上的所有工作。工 作被执行完毕,它就将相应的work_struct对象从链表 上移走; 当链表为空时,它进入睡眠状态; 当有下半部插入到队列时,函数是work_thread() 被唤醒,将继续处理新加入的下半部 。Linux系统系统 Linux系统的特权级与中断处理系统的特权级与中断处理Linux系统的系统的功能调用功能调用L
10、inux系统系统Linux系统功能调用系统功能调用14在Linux系统中,系统调用通过异常类型实现;当执行了int 0 x80指令而发生的软件中断;系统自动将用户态切换为核心态来处理该事件,执行自陷处理程序 (系统调用处理程序)。 Linux系统系统Linux系统功能调用系统功能调用15 abc(); abc(); syscall; system_call: sys_abc SYSEXITsysabc() 用户态用户态核心态核心态用户程序系统调用 在libc标准库中的封装例程系统调用处理程序系统调用服务例程Linux系统调用过程Linux系统系统Linux系统功能调用系统功能调用16int m
11、ain() getuid(); int getuid(void) long_res; int $0 x80; ENTRY(system_call) pushl % esx SAVE_ALL GET_CURRENT(%ebx) call sys_getuid16 RESTORE_ALLasmlinkage longsys_getuid16(void) return high2lowuid (current_uid);用户程序用户程序系统调用处理程序系统调用处理程序标准标准C库库内核例程内核例程getuid系统调用过程Linux系统系统Linux系统功能调用系统功能调用17 Linux系统的软中断
12、指令是系统的软中断指令是int 0 x80汇编语言指令汇编语言指令 该指令的执行会发生中断该指令的执行会发生中断 处理机的状态由用户态自陷到内核态处理机的状态由用户态自陷到内核态 从从system_call()开始执行系统调用处理程序。开始执行系统调用处理程序。 当系统调用处理完毕后,通过当系统调用处理完毕后,通过iret汇编语言指令返回到用汇编语言指令返回到用 户态。户态。Linux系统系统Linux系统功能调用系统功能调用18 linux中,每个系统调用被赋予一个唯一的系统调用号 系统调用号定义在include/asm-i386/unistd.h头文件中 系统调用号格式如下 #define
13、 _NR_restart_syscall 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 系统调用表记录了内核中所有已注册过的系统调用, 它是系统调用的跳转表。 系统调用表是一个函数指针数组,表中依次保存所有 系统调用的函数指针 Linux系统调用表保存在arch/i386/kernel/下的entry.S中Linux系统系统Lin
14、ux系统功能调用系统功能调用20 系统调用表格式如下系统调用表格式如下 ENTRY(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系统调用处理程序是系统调用处理程序是system_call(
15、),主要工作如下,主要工作如下宏SAVE_ALL保护现场; 正确性检查 ;依eax中所包含的系统调用号,调用其对应的服务例 程;系统服务例程结束时,通过宏RESTORE_ALL恢复寄 存器;最后通过iret指令返回。 Linux系统系统Linux系统功能调用系统功能调用22 在/usr/src/linux/kernel/sys.c文件中增加一个新的函数, 该函数的名字是sys_mysyscall 例:例:一个简单的系统调用,其功能是返回一个整型值 asmlinkage int sys_mycall(int number) return number; Linux系统系统Linux系统功能调用系
16、统功能调用23 在文件在文件include/asm-i386/unistd.hinclude/asm-i386/unistd.h中添加一项中添加一项 #define _NR_mysyscall XX XX XX为新增加的系统调用号,此数字选一未用值为新增加的系统调用号,此数字选一未用值。 例例 #define _NR_restart_syscall 0 #define _NR_exit1 #define _NR_mq_getsetattr 282 #define _NR_mysyscall 283 Linux系统系统Linux系统功能调用系统功能调用24 在文件/arch/i386/kerne
17、l/entry.S中的系统调用表sys_call_table中添加新增的系统调用sys_call_table数组包含指向内核中每个系统调用的指针 例例 ENTRY(sys_call_table) .long sys_restart_syscall /* 0 */ .long sys_exit /* 1 */ .long sys_mq_getsetattr /* 282 */ .long sys_mysyscall /*283*/Linux系统系统Linux系统功能调用系统功能调用25 为使新的系统调用生效,需要重建Linux的内核。 这需要以超级用户身份登录后重新编译内核。 在用户程序中,测试
18、新增加的系统调用是否能正确使用。Linux系统系统Linux系统功能调用系统功能调用Linux系统的系统的进程管理进程管理Linux系统系统Linux系统的进程管理系统的进程管理26 进程是程序在处理机上的一次执行过程。进程是处于执行 期的程序,它是分配系统资源和调度的实体。 进程包括可执行的程序代码、打开的文件、挂起的信号、 内核数据、地址空间、处理机状态、一个或多个可执行 的线程等。 Linux系统将线程看作是一种特殊的进程。线程被视为一 个与其他进程共享某些资源的进程。 Linux系统系统Linux系统的进程管理系统的进程管理27Linux内核使用进程描述符 (又称为进程控制块)来描述一
19、个 进程的完整信息。Linux系统系统Linux系统的进程管理系统的进程管理28指向进程基本控制块的指针进程状态state进程标识进程调度有关的字段进程亲属关系的字段指向当前目录的指针指向文件描述符的指针指向主存描述符的指针指向信号结构的指针指向tty结构的指针task_structthread_info当前目录文件描述符主存描述符所接收的信号与进程相关的tty指向进程队列priopidtgidpgrpsessinthread_inforun_listttyreal_parentparentchildrensiblingfsfilesmmsignal进程控制块的结构进程控制块的结构进程控制块结
20、构29 进程标识符进程标识符 进程标识符process ID 进程描述符中的标识符字段字段名字段名说明说明pid进程的PIDtgid线程组领头进程的PIDpgrp进程组领头的进程PIDsession会话领头进程的PIDLinux系统系统Linux系统的进程管理系统的进程管理30 进程状态进程状态 反映进程当前状态,包括以下几种可能的状态 可运行状态 TASK_RUNNING 可中断的等待状态 TASK_INTERRUPTIBLE 不可中断的等待状态 TASK_UNINTERRUPTIBLE 暂停状态 TASK_STOPPED 终止状态 TXIT_ZOMBIELinux系统系统Linux系统的进
21、程管理系统的进程管理31 进程基本信息进程基本信息 每个进程都有一个进程基本信息块。在进程描述符的thread_info字段中包含了指向该结构的指针 与进程调度有关的信息与进程调度有关的信息 可运行进程链表 (最多可有140个) 进程的亲属关系进程的亲属关系 进程描述符中的亲属关系字段字段名字段名说明说明real_parent指向创建p进程的父进程的描述符,若该父进程不再存在,就指向1#进程parent指向p进程的当前父进程,它的值通常与real_parent一致,偶尔也可不同children链表的头部,链表中的所有进程都是p进程创建的子进程sibling指向兄弟进程链表中的下一个或前一个元素
22、的指针Linux系统系统Linux系统的进程管理系统的进程管理32 其他字段其他字段 在进程描述符的thread_info字段中包含了指向各种结构的 指针。 fs 指向当前目录结构 fs_steuct files 指向文件描述符结构 files_struct mm 指向主存描述符结构 mm_struct signal 指向信号结构 signal_struct tty 指向进程相关的 tty_struct结构Linux系统系统Linux系统的进程管理系统的进程管理33 它或者正在执行,运行状态它或者正在执行,运行状态 或者在运行队列中等待执行,就绪状态或者在运行队列中等待执行,就绪状态 进程正在
23、等待某一事件的发生(如某一硬件中断或一个信 号),它处于挂起或称睡眠状态。 除了不会因为接收到信号而被唤醒从而投入运行外,这个 状态与可中断等待状态相同。Linux系统系统Linux系统的进程管理系统的进程管理34 表示进程已经结束,但其父进程还没有调用wait4()系统 调用。子进程的进程描述符在此之前仍然被保留 表示进程停止执行,进程没有投入运行也不能投入运行。 通常这种状态发生在接收到SIGSTOP、SIGTSTP、 SIGTTIN、SIGTTOU等信号的时候。Linux系统系统Linux系统的进程管理系统的进程管理35 运行运行TASKUNNING进程调度等待某事件等待的事件发生 创建
24、创建新进程新进程 就绪就绪TASKUNNING 进程进程 终止终止 等待等待TASKINTERRUPTIBLETASKUNINTERRUPTIBLE被抢占创建进程完成Linux系统进程状态变迁图Linux系统系统Linux系统的进程管理系统的进程管理36 Linux系统用fork()系统调用创建一个进程。 写时拷贝写时拷贝 在创建新进程时内核不复制父进程的整个地址空间, 而是让父进程和子进程以读方式共享同一拷贝 只有当一方真正需要写入时,数据才被复制,这时, 父、子进程才拥有各自的拷贝 系统提供系统提供fork()和和clone()系统调用系统调用 fork()用来创建一般进程 clone()
25、用来创建轻量级进程 (线程) Linux系统系统Linux系统的进程管理系统的进程管理37 Linux系统提供exit()系统调用以终止某一个进程。其主要 功能由do_exec()函数完成。 进程终止后,此进程处于僵死状态,但系统还保留了它的 进程描述符。只有父进程发出了与被终止进程相关的 wait()系统调用后,子进程的task_struct结构才能释放。 Linux系统系统Linux系统的进程管理系统的进程管理38 两种等待状态两种等待状态 TASK_INTERRUPTIBLE 和 TASK_UNINTERRUPTIBLE 区别:处于TASK_UNINTERRUPTIBLE状态的进程如果接
展开阅读全文