操作系统原理设备管理(1).ppt
《操作系统原理设备管理(1).ppt》由会员分享,可在线阅读,更多相关《操作系统原理设备管理(1).ppt(83页珍藏版)》请在三一办公上搜索。
1、Unit 9,设备管理,操作系统原理冯耀霖,设备,也称外部设备或I/O设备,是指那些由于原理、结构、数据格式等原因不能与系统总线直接连接的装置。它们也是计算机系统不可或缺的重要组成部分,是计算机主机(CPU+内存)与外部环境进行交互和沟通的通道。显然,I/O设备的存在才使得计算机的存在有了意义,就像一个人,如果没有与人交际和沟通的能力,则这个人通常被认为是痴呆或白痴,即使他实际上是一个天才。同样,一台没有I/O设备的计算机,不管其计算功能多么强大,也是废铁一堆。所以,设备管理也是操作系统的重要组成部分,是操作系统的基本功能之一,而且由于I/O设备的种类繁多,各自的特性和使用方式有很大差异,因此
2、,设备管理软件可以说是操作系统中最繁杂的部分。,内容,设备设备管理概述设备驱动程序独立于设备的I/O软件用户级I/O软件,1 设备,设备分类设备的差异性设备控制器I/O控制方式,1.1 设备分类,可以说,外部设备(简称外设或设备)是计算机系统中最多样、差异最大的组成部分,不同的计算机系统所配置的外设也不同。对外设的分类方法有许多种,主要有以下三种:基本分类法功能分类法管理分类法,1.基本分类法它把外设大致分为三类:(1)外存:磁盘、光盘、U盘。(2)人机通信设备:输入设备有:键盘、鼠标、话筒、光笔、扫描仪、数码相机等;输出设备有:显示器、打印机、绘图仪、扬声器等。(3)机机通信设备:输入设备有
3、:传感器、仪器仪表等;输出设备有:执行器、仪器仪表等;输入输出设备有:网卡、Modem等。,2.功能分类法如果从外设的功能上来分,只有两种:存储设备和通信设备。(1)存储设备即外存,外存的共同特点是都对存储区进行分块管理,也就是说,这些设备在逻辑上可以看成是有若干存储块组成的存储空间,所以传统上也被称作块设备。另外,为了进行大块数据的传输,通常需要在内存为它们创建比较大的数据缓冲区。(2)通信设备除了外存之外的那些外设通常都是通信设备,它们是计算机与外部环境进行交互的主要手段。这些设备的数据量往往不是很大,也不是很集中,因此这类设备在内存中不需要较大的缓冲区,或者就根本没有缓,冲区,例如键盘、
4、鼠标等。这些设备传统上也被称作字符设备。3.管理分类法按设备的管理性质可把外设分为两类:(1)系统设备是指操作系统生成时就纳入系统管理范围的各种标准设备(基本配置),操作系统提供有相应的数据结构和设备驱动程序等。如键盘、鼠标、显示器、磁盘驱动器等。(2)用户设备是指系统设备之外的非标准设备,在安装操作系统时没有配置,而由用户根据需要自己安装配置。如扫描仪、绘图仪等。,1.2 设备的差异性,外部设备由于种类不同,制造商不同,技术标准不同,其特性可以有巨大的不同。而这种不同越是明显,对操作系统的设计的挑战就越大。因为屏蔽这些巨大的不同,使得不同的设备相互共存并不是一件容易的事情。其中最为明显的一种
5、差异是数据传输的速度,它涵盖的范围从每秒十个字节到几兆个字节。表9-1给出的是较为常见的一些设备的数据传输率。,表9-1 外设的数据传输率,1.3 设备控制器,从设备的物理结构上来看,外设可能是电器的或机械的,甚至是机、电、光多种技术结合的。但不管其主体是哪种构成,只要它要与电子计算机相连接,那它就必须有电子器件部分。这也就是说,计算机的外设必须由两部分组成:一是外设的执行部分(电气的、机械或机、电、光多种技术结合的),也称设备主体;二是外设与系统的接口部分,而且这部分一定是电子部分,因为计算机系统必须通过这些接口来对外设进行控制和数据传输。设备控制器(也称适配器)是外设与总线之间的一组电子器
6、件。例如,串行口控制器就是一种简单的设备控制器,它是计算机上用来控制串行信号的一块芯片或一个芯片组。再如贴在磁盘侧面的电子线路板也是一种设备控制,器磁盘控制器,CPU就是通过这个控制器来对磁盘进行各种操作的。为使处理器可以像访问内存那样来访问外设,计算机系统必须提供一些互不冲突、能按地址访问、并能以数字信号进行数据传送的设备寄存器。通常每个设备都有三类设备寄存器:状态寄存器、控制寄存器、数据寄存器。这些寄存器都有自己的专有地址,称做端口(port)。这些寄存器的作用分别为:状态寄存器用来由控制器向处理器提供设备的当前工作状态。例如,设备的当前操作是否执行完毕,数据是否可以被读出或写入,以及各种
7、错误提示等。这些信息通常都用字位(bit)来表示。,控制寄存器主要用来由处理器向控制器传送操作命令。还用来管理外设工作模式,即在设备初始化时或运行时,处理器可以通过向控制寄存器写入命令来改变设备工作模式或设备状态。例如,在串口寄存器中专有一位信息是用来选择通信方式的(全工或半工),还有一位信息是用来设置数据字长的,以及其他用来设置通信波特率等的各个控制位。数据寄存器(有些设备控制器又进一步设置为输入数据寄存器和输出数据寄存器)则是输入输出数据的暂存寄存器,用来实现设备与处理器之间的数据交换。除了设备寄存器外,有些设备控制器还设有I/O数据缓冲区,以提高与CPU交互数据的效率。块设备控制器都,设
8、有I/O数据缓冲区,而有些字符设备控制器也设有I/O数据缓冲区,如视频控制器。所有设备控制器的寄存器和I/O数据缓冲区构成的地址空间称作I/O地址空间(I/O空间),对于I/O地址空间的处理有三种方式:(1)独立编址的I/O空间在这种方式下,I/O空间与内存是完全脱离的。每个设备寄存器被赋予一个I/O端口,这个端口就是一个9位或16位的一个整数,它与内存地址没有任何关系。而正是由于端口与内存地址没有任何关系,或者说端口不是内存地址,操作系统必须使用专门的输入输出特殊指令来进行数据的读写。例如,许多指令集使用IN REG,PORT,指令用来从设备读数据,而指令OUT PORT,REG则用来将数据
9、写入设备。这种方式的优点是I/O空间与内存分离,输入输出操作不会影响或干扰内存操作,尤其是输入输出软件的可靠性通常不如内存管理软件,这种分离就显得更有价值。但俗话说,成也萧何,败也萧何。这个优点恰恰也是其缺点。由于I/O空间与内存分离,输入输出指令与内存访问指令自然也不相同,输入输出所使用的IN/OUT等指令都是低级的汇编指令。由于高级编程语言不支持这种低级指令,从而形成高级语言屏蔽的一个漏洞。程序员如果想要进行I/O,则必须使用低级语言,这将增大程序设计的难度和可靠性。,(2)内存映射I/O空间顾名思义,就是将I/O空间映射到内存里面,与内存统一编址。具体来说,就是系统在内存空间中划出一部分
10、来作为I/O空间,即所有设备寄存器的端口和I/O数据缓冲区都是正规的内存地址空间的一部分,CPU对这些空间的读写与对普通内存的读写使用同样的指令,但引起的是与外部设备间的数据传送。RISC(精简指令集)类CPU计算机都使用这种方式。这种方式虽然具有I/O与内存访问统一的优点,但是也存在一些问题。例如总线竞争,在单总线系统里,内存和外设都需要对总线上的数据进行监听,以确认命令是否针对自己。这样将产生总线竞争而降低系统效率。,(3)混合I/O空间这是上述两种方式的组合:I/O数据缓冲区为内存映射,而设备寄存器则独立于内存。例如采用Intel奔腾处理器的计算机系统,将640K到1M的主存地址留给I/
11、O数据缓冲区,而0到64K的地址留给I/O端口。设备控制器与CPU通过总线来连接。总线是一种严格定义的描述了线上传输数据的协议,凡是符合总线协议的各种设备都可以共同使用总线与CPU进行数据通信。,CPU,内存,字符设备控制器,字符设备控制器,DMA控制器,总线,图9-1 单总线型I/O系统结构,1.4 I/O控制方式,I/O控制方式,即为实现数据的输入输出,CPU与外设之间的交互方式。有三种基本的I/O控制方式:轮询(polling)方式中断驱动方式DMA方式采用何种I/O控制方式将直接影响设备管理的实施方法及效率。1.轮询方式 也称程序控制方式。它要求在程序中的I/O指令后紧接着安排循环查询
12、指令,即在CPU启动了设备控制器进,行数据的输入输出后便以循环查询设备状态的方式来等待I/O的完成。这种方式的特点是:CPU处于主动地位,涉入I/O过程的程度很深,而外设则处于被动地位,是一种同步工作方式。2.中断驱动方式使用轮询方式时,CPU需要读取设备状态寄存器以检测设备的当前状态,如果设备还未完成此次的I/O,则需要CPU不断地查询,由于CPU与外设的速度差距巨大,因此在I/O过程中,CPU绝大部分时间都处于繁忙等待状,态,CPU的效率十分低下。一种更为有效的方式是让设备处于某种主动地位,而将CPU从忙等待中解脱出来。在启动了某个外设后,立即阻塞现行进程,CPU就可被调度转去执行其他进程
13、而不是在原地踏步等待。当某个数据I/O任务完成后,由设备控制器向CPU发出一个I/O中断,驱动CPU中止现行进程的执行而转去执行相应的中断处理程序,并唤醒等待该I/O的进程。显然,这种I/O控制方式可以大大提高CPU的效率,因此是设备与CPU进行交互的基本手段。3.DMA方式,虽然中断驱动方式避免了轮询方式的忙等待现象,从而大大提高了CPU的效率,但这主要是对慢速的字符设备而言的。而对于一次需要传输大量数据的高速块设备来说,仍然不能令人满意。因为设备的数据寄存器的容量是有限的,故一个I/O任务中待传输的数据需要多次送往数据寄存器,而每当设备传送完一次数据寄存器中的数据时,就会触发一次I/O中断
14、,因此在块设备的一次I/O任务的完成过程中,CPU需要响应和处理许多次I/O中断,而每一次I/O中断的响应和处理都需要付出不小的额外CPU开销,CPU的效率并未获得太多改善。人们发现,在设备与主机交换大量数据时,CPU只是数据传输的一个中介,用功能强大的CPU长时间去充当,一个传输数据的中介角色显然得不偿失。于是就设计出一种专门负责执行数据I/O事务的处理器I/O处理器,它比CPU要简单得多,但也便宜很多,它只能执行少量的指令,主要是数据I/O指令。I/O处理器既可以构建在设备控制器里面(这样的控制器称为DMA控制器),也可以作为独立的实体挂在计算机主板上。最简单的I/O处理器在一个时间只能处
15、理一个I/O,即不能并发,而复杂的I/O处理器可以同时处理多个I/O,即它能够提供多个I/O通道,每个通道可以对应一个I/O设备。有了I/O处理器,就可以将CPU从繁杂的I/O事务中解脱出来。DMA(Direct Memory Access,直接内存访问)方式就是使用I/O处理器的I/O控制方式,主要是针对块,设备的。DMA方式的目的当然是降低CPU响应中断的频率,使得一个传输大量数据的I/O任务中需要响应许多次中断变为只响应一次中断。DMA方式在设备和内存之间建立了直接数据通路,即设备和内存之间可直接读写数据,且数据传输的基本单位是数据块。一个I/O任务中的所有数据是在一个DMA控制器的控制
16、下完成传输的,且在整个传输过程中无需CPU的直接干预,直到该任务中的所有数据都传输完后,DMA控制器才向CPU发出一个I/O中断。DMA控制器在普通设备控制器的基础上又增设了两个寄存器:内存地址寄存器和数据计数寄存器。,DMA方式的I/O过程如下:CPU对DMA控制器进行设置,告诉其存放I/O数据的主存区地址和传输长度(分别送入内存地址寄存器和数据计数寄存器);启动DMA过程,将系统总线的使用权暂时移交给DMA控制器;DMA控制器进行数据传输,即接管对系统总线的使用权(总线周期窃用),启动设备进行数据的I/O,并进行数据传送个数的计数以及内存区地址的增量;当数据传送完毕,DMA控制器向CPU发
17、出一个I/O中断,同时向CPU移交总线使用权。CPU响应中断,处理善后事宜。,DMA方式的优点是显著减少了中断次数和CPU的I/O操作次数,从而大大减轻了CPU的I/O负担,加快了I/O的速度,不仅有利于CPU效率的发挥,而且能满足高速I/O设备对成组数据的高速传送要求。缺点自然是增加了成本和复杂性,而且由于DMA控制器需要与CPU竞争系统总线,其效率的提高不如理论上的期望。,2 设备管理概述,设备管理的目标和功能 设备控制块I/O软件的分层结构,2.1 设备管理的目标和功能,1.设备管理的目标设备管理是操作系统的重要组成部分,现代操作系统的设备管理的基本目标除了公平和有效之外,另一目标是把所
18、有外设都抽象成文件,使得对物理特征各异的各种设备都可以以统一的文件方式进行操作。具体地说,它必须满足下述设计要求:为用户提供方便、统一的设备使用界面。将复杂的具体设备操作控制过程隐藏起来,通过统一的文件操作界面进行I/O操作,既方便了用户对设备的使用和满足用户使用外设的各种要求,又有利于将不同类型的设备配置在系统中。提高外设的利用率,尽量提高并行程度。一方面,,用户使用外设常有很大的随机性,设备管理应能根据当时设备的忙闲状况进行分配,实现资源共享。另一方面,充分发挥设备和主机的效率,有效地解决CPU与外设之间传输速率不协调的问题。另外,将独享设备尽量虚拟成共享设备,以增大资源利用率和降低死锁发
19、生的概率。例如,将一台打印机虚拟成多台可共享的逻辑打印机。用户程序独立于设备,即实现程序与设备的无关性。程序中可使用逻辑设备名或设备文件名来使用设备,它们与实际使用的物理设备无关。当物理设备发生故障或有更换时,用户程序不必修改,就可使用系统分配的其他相关设备。,2.设备管理的功能为了达到设备管理的目标,设备管理系统通常需要实现如下基本功能:设备驱动和错误处理。主要是按照I/O控制方式,对不同的设备完成相应的I/O中断、设备控制器操作、读写操作等物理I/O过程。针对不同的设备请求,通过设备驱动程序完成对设备的直接控制。错误处理指的是对输入输出过程中产生的错误进行侦测与纠正,而且纠错应该在最靠近硬
20、件的层面上进行。系统与设备间的协调。主要是速度上的协调,要解决快速的CPU与慢速的I/O设备之间的操作不匹配的问题,通常采用I/O缓冲区的方式来解决这个矛盾。设备管,理要实现I/O缓冲区的建立、分配及回收。设备调度与分配。即对等待共享设备I/O操作的进程进行调度,而对多个进程争用独占设备进行分配。,2.2 设备控制块与设备文件,就如用进程控制块(PCB)来表示一个进程,用文件控制块(FCB)来表示一个文件一样,操作系统用设备控制块(DCB)来抽象表示一个外部设备。操作系统在内核空间中为每个设备建立一个设备控制块,用于描述本设备的各种抽象属性及控制信息。DCB包含的内容如:设备名(即设备文件名)
21、设备ID设备工作状态控制器端口I/O缓冲区端口I/O请求队列指针设备驱动程序指针设备中断处理程序指针,设备ID由主设备号和次设备号构成。主设备号用于标识设备类型,如IDE硬盘、SCSI硬盘、显示器、打印机等,同一类设备使用的是同一个设备驱动程序。次设备号用于标识同类设备中的某个具体设备及其控制器,即同类设备的序号。这里的设备驱动程序指针实际上是一个指针组,其中的每个指针指向一个设备操作函数。设备驱动程序容易被人误认为是一个完整的、能够独立运行的程序,其实不然,它只是一组进程可调用的、能对设备实施I/O操作及控制操作的内核功能函数,如open();/打开close();/关闭,read();/读
22、数据write();/写数据llseek();/移动读写指针readdir();/读目录ioclt();/输入输出控制release();/释放缓存当然,对于块设备和字符设备以及不同的块设备和不同的字符设备,各自所含的功能函数的个数有所不同,同名函数具体执行的算法也是不同的,从而构成了不同设备的驱动程序。设备驱动程序就是操作系统对设备的物理抽象(最底层抽象)。,至于如何管理DCB则可以有不同的方法。自UNIX后,现代操作系统普遍将DCB抽象成特殊文件(即设备文件)。与数据文件一样,系统为每个设备文件建立一个 FCB,但设备文件的特殊之处在于,它并没有数据文件意义上的文件体,即它并不在磁盘空间中
23、占有一席之地,换言之,操作系统并不给设备文件分配磁盘空间单元。那么,设备文件的文件体是什么呢?就是DCB!例如,Linux是按如下方式处理的。Linux支持三种类型的硬件设备:字符设备、块设备及网络设备。字符设备能够存储或传输不定长数据。某些字符设备可以每次传送一个字节,可以不经过缓冲区直接进行读,写,如系统中的串行口/dev/dnao和/dev/cnal,传送完一个字节后产生一个I/O中断;另一些字符设备可以在设备内缓存数据,因此可以一次传送完多个字节后产生一个I/O中断。块设备以块为单位传输数据。每个块设备都可建有一个I/O数据缓冲区队列,缓冲区的大小与块相等,因此,块设备一次可传输一块或
24、多块数据。网络设备也称包设备(如以太网卡),是通过BSDsocket和网络子系统访问,它负责数据包的发送和接收。网络协议(如TCP/IP)就建立在网络设备驱动程序之上。与字符设备和块设备不同的是,网络设备传输的不是无结构的流式数据,而是有结构的数据包。,针对这三类设备,Linux在内核空间中建立了三个设备注册表(也称设备开关表),分别是:块设备注册表、字符设备注册表、以及网络设备注册表,它们均为线性表(数组)。每个已配置在系统中的外设都在相应的设备注册表中占有一个表项。表项中包含了DCB中的核心内容,主要有:设备名(即设备文件名)、主设备号、驱动程序指针。DCB中的其他内容则被记录在 i 节点
25、中。i 节点中也设置有主设备号,通过它与相应的注册表表项连接了起来。从而在设备文件名与设备驱动程序之间建立起了一条通路。见图9-2。,i节点号,外设,主设备号,fops,*read(),*write(),write(),read(),驱动程序,中处程序,设备文件名,设备目录,i 节点,设备注册表,图9-2 设备文件名到设备驱动程序的通路,*intrrpt(),2.3 I/O软件的分层结构,设备管理软件,也称作I/O控制系统(IOCS)或I/O软件,是操作系统中非常繁杂的部分,通常按照I/O功能进行分层,每一层提供独特的功能,并与相邻的层面间设计有标准界面。当然,不同的操作系统这种分层是不同的,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 原理 设备管理
链接地址:https://www.31ppt.com/p-2576716.html