美文网首页
6-2 设备管理 用户层IO软件 缓冲 磁盘

6-2 设备管理 用户层IO软件 缓冲 磁盘

作者: Xue先生的猫 | 来源:发表于2018-12-08 23:32 被阅读0次

    1)系统调用与库函数

    不允许运行在用户态的应用进程,去直接调用运行在核心态(系统态)的OS过程。

    应用进程在运行时,又必须取得OS所提供的服务。

    于是:

    OS在用户层中引入了系统调用,应用程序可以通过它,间接调用OS中的I/O过程,对I/O设备进行操作。

    2)设备分配中的虚拟技术� —— SPOOLing技术

    虚拟性是OS的四大特征之一。

    多道程序技术将一台物理CPU虚拟为多台逻辑CPU,实现多个用户共享一台主机;

    如何将一台物理I/O设备虚拟为多台逻辑I/O设备,允许多个用户共享“同时使用” ?

    假脱机技术

    多道程序技术,专门利用程序模拟脱机I/O的外围机,完成设备I/O操作。

    称这种联机情况下实现的同时外围操作为SPOOLing 技术(Simultaneaus Periphernal Operating On—Line,或称为假脱机操作)

    一般进程对独占设备的需求被假脱机模拟到磁盘上。所以实现设备虚拟,多道是前提,还需高速、大容量、可随机存取的外存支持。

    SPOOLing系统的组成

    主要有三大部分(如下页图)

    输入井和输出井:磁盘上开辟两大存储空间。输入井模拟脱机输入的磁盘设备,输出井模拟脱机输出时的磁盘。

    输入缓冲区和输出缓冲区:为缓解速度矛盾,内存中开辟两大缓冲空间,输入缓冲区暂存输入设备送来的数据,再送给输入井;输出缓冲区暂存输出井送来的数据,再送输出设备。

    输入进程和输出进程。

    用一进程模拟脱机输入时外围设备控制器的功能,把低速输入设备上的数据传送到高速磁盘上;

    用另一进程模拟脱机输出时外围设备控制器的功能,把数据从磁盘上传送到低速输出设备上。

    nSPOOLing技术的使用:

    ¨当用户进程请求打印输出时,SPOOLing系统同意为它打印输出,但并不真正立即把打印机分配给用户进程,而只为它做两件事:

    n①由输出进程在输出井中为之请求一个空闲磁盘块区,并将要打印的数据送入其中.

    n②输出进程再为用户进程申请一张空白的用户请求打印表,并将用户的打印要求填入其中,再将该表挂在请求打印队列上.

    SPOOLing系统的特点

    1.提高了I/O的速度。利用输入输出井模拟成脱机输入输出,缓和了CPU和I/O设备速度不匹配的矛盾。

    2.将独占设备改造为共享设备。并没有为进程分配设备,而是为进程分配一存储区和建立一张I/O请求表。

    3.最终,实现了虚拟设备功能。多个进程可“同时”使用一台独占设备。

    缓冲管理

    I/O控制方式减少CPU对I/O的干预提高利用率;

    缓冲则通过缓和CPU和I/O设备速度不匹配矛盾,增加CPU和I/O设备的并行性,提高利用率。

    现代OS中,几乎所有的I/O设备与处理机交换数据时,都用了缓冲区。

    引入缓冲区的主要原因:

    缓和CPU与I/O设备间速度不匹配的矛盾。

    缓冲区数据成批传入内存,也可进一步减少对CPU的中断频率

    最终目的:提高CPU和I/O设备的并行性。

    使用缓冲区的方式:

    1)单缓冲、多缓冲

    2)循环缓冲

    3)缓冲池(Buffer Pool)

    ①循环缓冲的组成

    多个缓冲区。大小相同,三种类型:

    预备装输入数据的空缓冲区R

    装满数据的缓冲区G

    计算进程正在使用的现行工作缓冲区C

    多个指针。

    指示正在使用的缓冲区C的指针Current

    指示计算进程下一个可取的缓冲区G的指针Nextg

    指示输入进程下次可放的缓冲区R的指针Nexti

    ②循环缓冲区的使用

    计算进程(CPU)和输入进程(I/O操作)可利用两个过程来使用循环缓冲区。

    主要就是利用指针,操作上述不同类型缓冲区

    Getbuf过程:使用缓冲区时,可调用该过程

    计算进程取:current=Nextg,G—>C,nextg下移一个。

    输入进程放:current=nexti,R—>C,nexti下移一个

    Releasebuf过程:

    计算进程:C->R

    输入进程:C->G

    ③进程同步

    两个进程的控制:输入进程和计算进程并行执行,如何控制相应的两个指针不断顺时针方向移动,这样就可能出现两种情况:

    Nexti赶上Nextg。意味着输入速度大于计算速度,缓冲区满,只能阻塞输入进程等计算进程取,此情况称为系统受计算限制。

    Nextg赶上Nexti。意味着输入速度低于计算速度,缓冲区空,只能阻塞计算进程等输入进程放,此情况称为系统受I/O限制。

    ①缓冲池的组成

    对于既可输入又可输出的公用缓冲池,至少应含有下列三种类型的缓冲区:

    空缓冲区;

    装满输入数据的缓冲区;

    装满输出数据的缓冲区;

    为方便管理,将上述类型相同的缓冲区连成队列

    空缓冲区队列(所有进程都可用)

    输入队列(n个进程有各自的队列)

    输出队列(n个进程有各自的队列)

    *(队列长度不固定,根据进程实际情况灵活变动,需要多少用多少)

    1)磁盘性能简述

    首先与格式有关

    数据的组织和格式

    盘片、面、磁道、扇区

    为方便处理,每条磁道存储容量相同,每个磁道上的每个扇区相当于一个盘块。磁盘”格式化”的过程就是按规定的格式规划盘块。

    2)磁盘调度方法

    n对所有请求访问磁盘的进程进行合理调度,使对磁盘的平均访问时间最小。

    n目标:使平均寻道时间最少。

    n算法:

    ¨FCFS

    ¨最短寻道时间优先SSTF

    ¨扫描算法SCAN(磁盘电梯调度算法)

    循环扫描算法CSCAN

    N-Step-SCAN算法

    FSCAN算法

    ③扫描算法SCAN(磁盘电梯调度算法)

    SSTF会导致“饥饿”现象

    总选择最近的磁道访问,远磁道请求的进程会长时间得不到执行。

    改进:

    考虑距离的同时,更优先考虑方向

    SCAN算法

    规定磁头移动方向:自里向外,再自外向里移动。

    后续的I/O磁道请求,哪个在规定方向上距离最近,就先执行哪个。

    如当前为100,后续要求55,86,95,180,165,105

    先由内向外:选最近的105执行,再判断剩余的,选165,180。

    再由外向内:95,86,55

    循环扫描CSCAN

    SCAN的错过问题:

    容易错过与当前磁道距离近,但方向不一致的磁道。

    修改:将SCAN规定的移动方向改为“单向移动”

    由里向外后,再由里向外。

    N-Step-SCAN

    前述最近寻道算法共同问题:

    “磁臂粘着”——磁头静止在一个磁道上,导致其它进程无法及时进行磁盘I/O。(因:高密度盘,进程的读写可能集中在某一磁道)

    如现有一系列请求:

    3 3 5 2 3 3 3 2 3 3 2 3 3 4 4 5 2 3 3 3 4 4 2 3 3 3 2 2 2 3

    不管哪种算法,从3开始向下执行会是

    3 3 3 3 3 3 3 3 3 3….2 2 2 2 2 2 … 4 4 ….

    相关文章

      网友评论

          本文标题:6-2 设备管理 用户层IO软件 缓冲 磁盘

          本文链接:https://www.haomeiwen.com/subject/tagchqtx.html