在计算机系统中,除了处理器和内存之外,其他的大部分硬设备称为外部设备。它包括输入/输出设备,辅存设备及终端设备等。这些设备种类繁多,特性各异,操作方式的差异很大,从而使操作系统的设备管理变得十分繁杂。

设备管理程序一般要提供下述功能:

  1. 提供和进程管理系统的接口,当进程要求设备资源时,该接口将进程要求转达给设备管理程序 。
  2. 进行设备分配。按照设备类型和相应的分配算法把设备和其他有关的硬件分配给请求该设备的进程,并把未分配到所请求设备或其他有关硬件的进程放入等待队列 。
  3. 实现设备和设备 、 设备和 CPU 等之间的并行操作。
  4. 进行缓冲区管理。主要减少外部设备和内存与 CPU 之间的数据速度不匹配的问题,系统中一般设有缓冲区 ( 器 ) 来暂放数据。设备管理程序负责进行缓冲区分配 、 释放及有关的管理工作 。

1 数据传输控制方式

设备管理的主要任务之一是控制设备和内存或 CPU 之间的数据传送。

选择和衡量控制方式的原则如下: (1)数据传送速度足够高,能满足用户的需要但又不丢失数据。 (2)系统开销小,所需的处理控制程序少。 (3)能充分发挥硬件资源的能力,使得 I/O 设备尽量处于使用状态中,而 CPU 等待时间少。

外围设备和内存之间常用的数据传送控制方式:

(1)程序控制方式。处理器启动数据传输,然后等设备完成。此方式不能实现并发。 (2)中断方式。中断方式的数据传输过程是这样的,进程启动数据传输(如读)后,该进程放弃处理器,当数据传输完成,设备控制器产生中断请求,中断处理程序对数据传输工作处理之后,让相应进程成为就绪状态。以后,该进程就可以得到所需要的数据。 (3)直接存储访问(Direct Memory Access, DMA)方式。指外部设备和内存之间开辟直接的数据交换通路。除了控制状态寄存器和数据缓冲寄存器外, DMA 控制器中还包括传输字节计数器、内存地址寄存器等。 DMA 方式采用窃取(或挪用)处理器的工作周期和控制总线而实现辅助存储器和内存之间的数据交换。有的 DMA 方式也采用总线浮起方式传输 大批量数据。 (4)通道方式。通道又称为输入/输出处理器(Input/Output Processor, IOP),可以独立完成系统交付的输入/输出任务,通过执行自身的输入/输出专用程序(称通道程序)进行内存和外设之间的数据传输。主要有 3 种通道:字节多路通道、选择通道和成组多路通道。 (5)输入输出处理机。输入输出处理机也称为外围处理机,它是一个专用处理机,也可以是一个通用的处理机,具有丰富的指令系统和完善的中断系统。专用于大型 、 高效的计算机系统处理外围设备的输入输出,并利用共享存储器或其他共享手段与主机交换信息。从而使大型 、 高效的计算机系统更加高效地工作。与通道相比,输入输出处理机具有比较丰富的指令系统,结构接近于一般的处理机,有自己的局部存储器。

2 磁盘调度算法

访问磁盘的时间由3部分构成,它们是寻道 ( 査找数据所在的磁道 ) 时间 、 等待 ( 旋转等待扇区 ) 时间和数据传输时间,其中寻道时间 ( 査找时间 ) 是决定因素。

( 1 ) FCFS (first come first service)算法 : 有些文献称为 FIFO 算法 。FCFS 是一种最简单的磁盘调度算法,按先来先服务的次序,未作优化。这种算法的优点是公平 、 简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法未对寻道进行优化,致使平均寻道时间可能较长。

( 2 ) SSTF ( ShortestSeekTimeFirst,最短寻道时间优先 ) 算法 : 选择这样的进程,其要求访问的磁道距当前磁头所在的磁道距离最近,以使每次寻道的时间最短 。FCFS 会引起读写头在盘面上的大范围移动, SSTF 査找距离磁头最短 ( 也就是查找时间最短 ) 的请求作为下一次服务的对象。 SSTF 査找模式有高度局部化的倾向,会推迟一些请求的服务,甚至引起无限拖延 ( 这种现象称为 “ 饥饿” )

( 3 ) SCAN ( 电梯 ) 算法 : 不仅考虑到欲访问的磁道与当前磁道的距离,而且优先考虑的是磁头的当前移动方向,是在磁头前进方向上的最短查找时间优先算法,它排除了磁头在盘面局部位置上的往复移动 。SCAN 算法在很大程度上消除了 SSTF 算法的不公平性,但仍有利于对中间磁道的请求 。SCAN 算法的缺陷是当磁头刚由里向外移动过某一磁道时,恰有一进程请求访向此磁道,这时进程必须等待,待磁头由里向外,然后再从外向里扫描完所有要访问的磁道后,才处理该进程的请求,致使该进程的请求被严重地推迟。

(4 ) N - SCAN ( N 步 SCAN ) 算法 : 这是对 SCAN 算法的改良,磁头的移动与 SCAN 算法是一样的,不同的是扫描期间只对那些在扫描开始前已等待服务的请求提供服务。在服务期间,新到达的请求即使在磁头前进方向上也得不到服务,直到下一个新扫描周期开始。 N - SCAN 算法的实质是把 FCFS 和 SCAN 的优点结合起来,以便取得较好的性能。如果新到达的请求按优化次序排列,则下一个扫描周期必然花费最少的磁头移动时间。

(5 ) C- SCAN (循环扫描 ) 算法 : 这是对 SCAN 算法的另一种改良,是单向服务的 N 步 SCAN 算法,C- SCAN 算法规定磁头单向移动。C- SCAN 算法彻底消除了对两端磁道请求的不公平。

3 虚设备与 SPOOLING 技术

采用假脱机技术,可以将低速的独占设备改造成一种可共享的设备,而且一台物理设备可以对应若干台虚拟的同类设备。假脱机( Simultaneous Peripheral Operation On Line,SPOOLING)的意思是外部设备同时联机操作,又称为假脱机输入/输出操作,采用一组程序或进程模拟一台输入/输出处理器。

SPOOLING 系统的组成如图 1 所示。该技术利用了专门的外围控制机将低速 I/O 设备上的数据传送到高速设备上,或者相反。但是当引入多道程序后,完全可以利用其中的一道程序来模拟脱机输入时的外围控制机的功能,把低速的 I/O 设备上的数据传送到高速磁盘上;再利用另一道程序来模拟脱机输出时外围控制机的功能,把高速磁盘上的数据传送到低速的 I/O 设备上。这样便可以在主机的控制下实现脱机输入、输出的功能。此时的外围操作与 CPU 对数据的处理同时进行。

从图 1 可以看出, Spooling 系统主要包括以下3个部分 :

  1. 输入井和输出井 : 这是在磁盘上开辟出来的两个存储区域。输入井模拟脱机输入时的磁盘,用于存放 IO 设备输入的数据 : 输出井模拟脱机输出时的磁盘,用于存放用户程序的输出数据。因此, Spooling 系统必须有高速 、 大容量 、 随机存取的外存的支持。
  2. 输入缓冲区和输出缓冲区 : 这是在内存中开辟的两个缓冲区。输入缓冲区用于暂存有输入设备送来的数据,以后再传送到输出井。输出缓冲区用于暂存从输出井送来的数据,以后再传送到输出设备 。
  3. 输入进程和输出进程 : 输入进程模拟脱机输入时的外围控制机,将用户要求的数据有输入设备到输入缓冲区,再送到输入井。当 CPU 需要输入设备时,直接从输入井读入内存。输出进程模拟脱机输出时的外围控制机,把用户要求输入的数据,先从内存送到输出井,待输出设备空闲时,再将输出井中的数据,经过输出缓冲区送到输出设备上 。

采用假脱机技术,可以将低速的独占设备改造成一种可共享的设备,而且一台物理设备可以对应若干台虚拟的同类设备。 SPOOLING 系统必须有高速、大容量并且可随机存取的外存(例如,磁盘或磁鼓)支持。

在现代计算机系统中,还可以用一台设备来模拟自身。例如,常见 的多窗口技术,即在一个终端上开多个窗口,每个窗口可以独立地进行显示,以监视用户不同任务的执行情况。这是通过缩小显示区域、平铺或重叠显示来模拟多个显示器的。

作者:deniro
链接:https://www.jianshu.com/p/c3cfbe59babf
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

独占设备的分配和回收模拟_系统设计硬核知识(4)——操作系统的设备管理...相关推荐

  1. 某系统有6台输出设备 有多个进程均需要使用2台_系统设计硬核知识(4)——操作系统的设备管理...

    在计算机系统中,除了处理器和内存之外,其他的大部分硬设备称为外部设备.它包括输入/输出设备,辅存设备及终端设备等.这些设备种类繁多,特性各异,操作方式的差异很大,从而使操作系统的设备管理变得十分繁杂. ...

  2. 操作系统实验文件管理_系统设计硬核知识(5)——操作系统的文件管理

    操作系统对计算机的管理包括两个方面:硬件资源和软件资源.硬件资源的管理包括CPU 的管理.存储器的管理.设备管理等,主要解决硬件资源的有效和合理利用问题. 软件资源包括各种系统程序.各种应用程序.各种 ...

  3. 如何保证进程间同步工作_系统设计硬核知识(2)——操作系统的进程管理

    操作系统基本原理包含以下 5 大管理. 我们先来说说进程管理. 因为处理机是计算机系统的核心资源,所以整个操作系统的重心是处理机管理. 处理机管理中最基本的.最重要的概念是进程.进程是系统并发执行的体 ...

  4. 操作系统实验四:C++实现独占设备的分配与回收算法模拟

    目录 一.实验要求 1.实验名称 2.实验目的 3.实验内容 二.实验图解 三.实验代码 四.实验数据 1.设备插入功能 2.回收程序功能 3.查找功能 一.实验要求 1.实验名称 独占设备的分配与回 ...

  5. 独占设备的分配与回收_灵魂拷问:Java对象的内存分配过程是如何保证线程安全的?...

    点击上方"linkoffer", 选择关注公众号高薪职位第一时间送达 作者 l Hollis JVM内存结构,是很重要的知识,相信每一个静心准备过面试的程序员都可以清楚的把堆.栈. ...

  6. 18 操作系统第五章 设备管理 IO设备的基本概念和分类 IO控制器 IO控制方式 IO软件层次结构 IO核心子系统 假脱机技术 设备的分配与回收 缓冲区管理

    文章目录 1 IO设备的基本概念和分类 1.1 什么是I/O设备 1.2 I/O设备分类 2 IO控制器 2.1 I/O设备组成 2.2 I/O控制器功能 2.3 I/O控制器的组成 2.4 寄存器编 ...

  7. 操作系统之I/O管理:3、设备的分配与回收(设备控制表DCT、控制器控制表COCT、通道控制表CHCT、系统设备表SDT、逻辑设备表LUT)

    3.设备的分配与回收 思维导图 设备分配时应考虑的因素 设备分配方式 设备分配管理中的数据结构 设备控制表(DCT) 控制器控制表(COCT) 通道控制表(CHCT) 系统设备表(SDT) 逻辑设备表 ...

  8. 请简述独占设备的分配过程。

    独占设备的分配过程. (1).分配设备. 首先根据I/O请求中的物理设备名查找系统设备表SDT,从中找出该设备的DCT,再根据DCT中的设备状态字段,可知该设备是否正忙,若忙,便将请求I/O的进程的P ...

  9. 多余的读写端口什么时候会对程序造成影响_程序员需要了解的硬核知识之控制硬件...

    应用和硬件的关系 我们作为程序员一般很少直接操控硬件,我们一般通过 C.Java 等高级语言编写的程序起到间接控制硬件的作用.所以大家很少直接接触到硬件的指令,硬件的控制是由 Windows 操作系统 ...

最新文章

  1. 2021年春季学期-信号与系统-第十五次作业参考答案-第八小题参考答案
  2. MVC的概念及MVC 3.0开发环境
  3. 怎么让用一行代码实现页面的定时强制刷新?脚本刷流量再也不用愁了!
  4. 微软颜龄Windows Phone版开发小记
  5. 超燃| 2019 中国.NET 开发者峰会视频发布
  6. C++获取指向二维数组的首元素指针
  7. File Operation
  8. Linux 之 shell 比较运算符
  9. 软件测试的正反两面性思维,软件测试中破坏性测试思维的思考
  10. 量化交易策略研发的三个层次
  11. 前端常用标签与注意事项
  12. 我在蚂蚁金服做后端:那些坚持在一个岗位做八年的人,后来怎么样了?...
  13. 明翰大数据Spark与机器学习笔记V0.1(持续更新)
  14. 电子签约存证及印章管理整体化解决方案
  15. 1688搜索店铺列表 API
  16. iOS 13 修改状态栏背景色
  17. 倍福PLC模拟量输入模块的使用方法
  18. 蓝桥杯学习记录-基础练习
  19. 湖泊水库水质安全监测系统解决方案
  20. 重新出发的陌陌,新故事不好讲

热门文章

  1. 46、Power Query-Table.FillDown函数简介
  2. SAP推出下一代数字转型平台SAP HANA 2
  3. SAP为企业不同员工带来了什么?
  4. SD--va01的屏幕增强
  5. 从一年关店千家到营利双增,都市丽人做对了什么?
  6. 在线旅游的2020:洗牌重组、直播自救、跨界面敌
  7. 灵宝机器人编程学校_灵宝两所学校上榜“河南省中小学人工智能教育实验学校”...
  8. list循环赋值_一步一步学Python3(小学生也适用) 第十七篇:循环语句for in循环
  9. ms+sql迁移到mysql_mssql数据迁移到mysql
  10. 一个黑魔法,竟能让Python支持方法重载