`
buliedian
  • 浏览: 1249102 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论
阅读更多

计算机输入输出系统

摘自《操作系统精髓与设计原理》 BY William Stallings
刘建文略译(http://blog.csdn.net/keminlau

KEY:功能 逻辑分层 功能分步 系统

INTRO

I/O子系统可能是操作系统设计最麻烦的部分了。因为硬件设备和应用都是多种多样的,很难为其设计一套通用和统一的解决方案。本部分按照由一般到特殊的顺序讲述I/O子系统相关的内容。

  • 首先从最一般的I/O结构开始,也就是在计算机体系结构(computer architecture)的有关I/O组织与功能;
  • 接着是操作系统里的I/O系统实现,内容包括I/O设计目标、I/O功能的结构化方式、I/O缓存功能详细(缓存功能是操作系统提供基本的I/O服务,有助于提高I/O整体性能)等。
  • 下一部分特别讲讲更特殊的具体的磁盘I/O。现代计算机中磁盘I/O在系统整体性能中起着重要的作用(第一,现在很多的应用都数据处理集中的;第二,多道程序功能需要快速的外存辅助等)。

I/O设备

I/O设备分类方式有很多种,其中一种是分成以下三大类:人可读设备、机器可读设备和通信设备。

  1. 人可读设备:这种设备是面向人面向用户的,与用户交互的设备,像打印机、显示器、键盘和终端等
  2. 机器可读设备:这种设备是面向机器的,交互时没有用户介入,像磁盘驱动器、传感器、设备的控制器(控制器是设备的一部分,但也可单独出来成为一种设备,像主板的很多芯片实现了很多控制器)等。
  3. 通信设备:这种设备也是面向机器的,交互时没有用户介入,但是交互的对象不在本地。像网卡、猫。

这三类设备不仅在各大类之间设备差异性很大,同一类内的各种设备的差异也是很大的(所以这种分类对是I/O系统的设计显然是初步的),它们之间的差异关键点如下:

  • 数据传输率(data rate):各种设备间数据传输率可能达一个到几个数量级的差别,看下图;
  • 应用(application):设备的使用方式上的差异也会影响其它配套的软件和操作系统对这些设备实施的管理策略(policy)的不同。比如为了让磁盘设备实现以文件方式存储数据,操作系统必须为磁盘设备配置文件管理软件(像文件系统);为了让磁盘设备用作虚拟内存,操作系统和CPU都要联合提供一些虚拟内存硬件和软件设施。再举一个终端设备的例子。使用终端的用户可能是一般的用户,也可能是管理员。这意味着操作系统得为终端设备实施不同使用特权级别和不同优先级别的软件策略。
  • 操控的复杂度(complexity of controls):不同的设备的控制接口肯定不一样,像打印机只需要很简单的控制接口,但像磁盘这样的,控制接口则会很复杂。存在不同的控制接口复杂度的结果是,操作系统必须把部分I/O控制硬件化,做进一个叫I/O模块的控制器, I/O模块面对设备的一端负责设备专用的控制规则,另一端提供一致的接口给操作系统(驱动程序)控制。
  • 传输单元(unit of transfer):设备传输的数据可能是字符流(字节流),或者是很大的数据块。
  • 数据编码(data representation):不同的设备使用不同的编码方案,包括字符集和奇偶校验规则。
  • 错误检测(error conditions):设备产生的错误的性质、报告方式、处理方法都是不尽相同的。

各种外设备速率对比

无论是从操作系统角度还是从用户进程的角度看,为如此多样化的设备设计一套统一的I/O系统都是很困难的。

I/O功能的变革

计算机技术日新月异,计算机系统及各独立组件的演变表现出一定的模式。I/O功能的演变最明显。下面是I/O功能演变过程的概况:

  • 1. 处理器直接控制外部设备。这种I/O功能可以在一些微处理控制设备中找到原型。
    P.S.这种方式的I/O就像是CPU的寄存器或者内存读写。只不过这些字节数据具有I/O操作语义罢了。
  • 2. 增设设备的控制器(controller)(或者叫I/O模块)。处理器通过使用编程I/O方式(也叫循环测试或轮询polling)与设备相联。这种I/O方式使处理器脱离了特定设备物特性使用更一致的方式进行输入输出。
    P.S.一致在什么地方?控制器一般都有状态寄存器标识设备当前状态,比如设备是否准备好、待输入的数据是否在数据寄存器和是否有错误发生。CPU必须先读状态寄存器判断设备状态再进行I/O操作。这是一种扫描式同步操作。这样I/O端口至少具有三种操作语义:输入、输出和状态。
  • 3. 在先前演化的基础上引入中断机制。中断机制可以让CPU不必等待IO操作,提高了效率。
  • 4. I/O模块通过DMA技术直接控制内存。这样,除了数据传输的起动和结束外,设备的输入输出可以不用CPU的干预了。
  • 5. I/O模块(原来只是控制器)被升级为独立的处理器,使用专为I/O功能设计的指令。这种有独立处理器的I/O被称为I/O通道(channel)。中央处理器CPU负责指示I/O处理器执行在主存的I/O程序。I/O处理器在没有CPU介入的情况下读取并执行这些指令。这样,中央处理器进一步的脱离了数据输入输出处理,专注于高度计算的任务。(KEMIN:这等于有两个处理器了,一个通用处理器,一个专用处理器)
  • 6. I/O通道拥有了自己的内存。演变到这一步,I/O系统成了切头切尾的专用计算机了。 (KEMIN:那之前的I/O模块都是有限状态机?计算能力有限的机器?如果答案是肯定的话,计算机内部有很多功能和能力各异的自动机在相互协作来完成计算任务?) 常用的带专用处理机的I/O系统,像交互式终端。交互式终端的处理机负责对终端的的控制(KEMIN:具体如何控制?)

Direct Memory Access

下图展示了DMA最一般的逻辑构成。与CPU一样,DMA也是计算机的逻辑单元(部件),负责接替CPU完成部分系统功能——控制系统总线并进行内存数据传送。通常,DMA模块必须只在CPU不需要使用总线时工作,或者强迫CPU临时挂起操作后工作。后者被称为周期窃取或周期挪用。

DMA技术工作过程是这样的。当CPU要读或写一块数据时,它向DMA模块发出一条命令,内容如下:

  • 操作命令(读或写),通过CPU与DMA模块之间的读写控制线(read or write control line);
  • 待传输的I/O设备的地址,通过数据线(data line)传送;
  • 待读写的内存起始地址,通过数据线传送并保存到DMA的地址寄存器(address register)中;
  • 待读写的数据数据量,通过数据线传送并保存到DMA的数据计数寄存器(data count register)中;

当完整的下达DMA命令后,CPU继续自己的工作,与DMA控制器这个特殊的处理器并行工作。DMA控制器负责传送大块数据(一次一字)进出内存,无须CPU干涉。当传输完成后,DMA会发送一个中断信号给CPU表示完成;因此在数据传输的全程中,CPU只涉及传输开始和结束处理。

下图展示了CPU在指令周期何处被挂起。CPU在试图使用被DMA占用的总线时被挂起。DMA然后在传输完一个字后把控制权交还给CPU。注间这个过程并不是中断,CPU并不保持上下文信息或做其它动作,CPU只是被暂停了一个总线周期。整体效果是感觉CPU运行慢了(KEMIN:因为是共用总线,多少要有点代价)。虽然如此,在传输大块数据的情况时,DMA还是要比中断方式或编程I/O有效得多。

DMA机制可以按需要配置(configured)成各种不同的模式。下图展示了几种可能的模式。在第一种模式中,计算机的所有模块共享单一的总线。DMA模块扮演着代理(surrogate)的角色,负责使用编程I/O的方式交换内存和I/O模块间的数据。这种配置模式显然是很经济的,效率低下也是很明显的。因为使用编程I/O的方式,每传输一个字都消耗两个总线周期。

DMA配置

提高效率的通用手法是把通用的东西改为专用的。所以通过给I/O模块集成DMA可以大大的降低传输所需的总线周期。如图中的第二种配置模式,DMA模块与一个或几个I/O模块之间有单独的非系统总线通路(path)。DMA逻辑上是I/O模块的一部分,或者是独立的模块,但是负责控制部分I/O模块。这个思想可以往前推进一步,把所有I/O模块用单独的I/O总线链接到DMA模块,看第三种配置模式。通过共用I/O总线,把连接DMA的接口降低到一个,这样提供一种极易扩展的配置方式(KEMIN:看原文,具体如何配置没讲)。在后两种配置模式里,DMA与CPU、内存共用的系统总线只用于传送从CPU到DMA的控制信号和DMA与内存间数据信息,DMA和I/O模块间的数据传输完全被移离系统总线。

操作系统设计

设计目标

I/O系统设计有两个至高(paramount)的目标:效率(efficiency)和通用性(generality)。效率的重要性体现在I/O操作已经成为目前计算机性能的第一大瓶颈。

由本文第一张图可见,输入输出设备的速度远远慢于内存和处理器。解决办法之一就是引入多道程序,使得一些进程等待IO操作时,另一些进程可以继续执行。虽然现今的机器内存已经相当的大了,但是I/O操作常常还是跟不上处理器。而为了让处理器操持忙碌,引入对换(swapping)机制把额外就绪的进程从磁盘调入内存执行,可是这个动作本身就是I/O操作。所以I/O系统设计主要目标是试图提高效率。由于磁盘I/O的重要性,这方面也是受到最多的关注,本章主要研究磁盘I/O的效率。

另一个主要目标是通用性。为了追求简单性和降低输入输入出的错误,人们想使用一致的方式处理输入输入出。包括面向用户进程的接口和操作系统的管理接口。因为设备的差异性(diversity),实践中上很难做到真正的一致。实际上能做到的是利用分层的模块化的方法设计I/O功能(function)。这种方法把设备I/O操作的细节隐藏入一些低级别的例程中,而用户进程和高一级的操作系统把设备看成一系列通用功能,如read,write,open,close,lock,unlock。

I/O功能的逻辑分层结构

在讨论系统结构的时候,我们看到了现代操作系统是分层结构的。分层的指导原则是,操作系统各层必须根据功能复杂度、时间量程(time scale)特性和抽象级别进行分隔。分层思想把操作系统分成数层,每一层负责实现操作系统功能的一个子集(KEMIN:如果是分层的话,这个功能子集不应该是横向,而应该是纵向的,不是吗?如果回答是肯定,那不能叫子集,叫某一个功能的某一步,是么?)。高一层的功能的实现有赖于低一层提供的原始操作原始功能,而这一层本身对这些原始的操作进行包装提供给更高一层的功能的实现。在理想的情况下,各层通过接口互操作,一层的修改都不影响另一层。分层思想使我们可以把复杂的大问题分解成多个可管理的小问题。

通常,层次更低的操作工作在更短的时间量程(time scale)内。比如,操作系统的一些部分是直接与硬件交互的,而这些交互操作的时间量程一般在十亿分之一秒;而交互的另一端,操作系统与用户交互则在数秒之内。这种情况是使用分层思想的理想之地。
分层思想应用于I/O系统时有如下图的分层结构。结构的具体详细可能会因不同的设备和应用而有所不同。图中展示的是最重要的三种逻辑分层结构:本地外围设备、通信端口和文件系统。

I/O分层组织

我们来分析最简单的I/O例子——通过字符流或记录流通信的本地外围设备:

逻辑I/O层:顾名思义,本层提供的I/O是逻辑的(包括逻辑资源和逻辑操作),是对具体的I/O数据和控制进行包装,为用户进行提供简易接口,比如设备标识和设备操作命令open,close,read,write等。

设备I/O层:来自逻辑层的数据(缓冲的字符和记录)和操作请求会在本层被转译成相应的I/O指令序列、通道命令(channel commands)和控制器命令(controller orders)。缓冲技术会在本层实现,用来提高性能。

调度与控制层(scheduling and control):操作系统对I/O操作的排队与调度发生在本层,也包括对操作的控制。因此,中断处理和I/O状态报告也发生在本层。本层是软件层中最底的一层,是与硬件进行实际交互的一层。

在通信设备的例子中,分层结构与外围设备很类似,只是逻辑I/O被替换成通信架构(communications architecture)。通信架构本身也由一系列逻辑层组成,比如我们熟知的七层的开放系统互联结构(OSI)。

在文件系统的例子中,有三层是以上两个例子的分层结构所没有的,它们是:

目录管理层:在这一层中,文件名符号被转换为一个标识,这标识通过一个文件描述符或索引表直接或间接地引用一个文件。本层也会处理面向用户的一些文件目录操作,比如添加、删除和重组。

文件系统层:本层处理文件的逻辑结构和面向用户的一些文件操作,像open, close, read, write。文件访问权限管理也在这一层实现。

物理组织层:就像虚拟内存地址通过分段和分页结构转为物理内存地址一样,对文件或记录的逻辑引用也必须通过文件的物理轨道和扇区结构转换为外存的物理地址。外存空间管理以及外存缓冲管理功能也在这一层实现。

分享到:
评论

相关推荐

    计算机输入输出系统课件

    计算机输入输出系统课件

    第七章计算机输入输出系统与接口技术.ppt

    计算机输入输出系统与接口技术是计算机科学中的重要组成部分,它涉及到计算机硬件与软件之间的通信以及数据传输的方式。在这个领域,CPU(中央处理器)是核心组件,负责执行指令和控制整个系统的运行。I/O(Input/...

    计算机系统结构输入输出系统PPT课件.pptx

    "计算机系统结构输入输出系统" 计算机系统结构输入输出系统是指处理机与主存储器之外的部分统称为输入输出系统,包括输入输出设备、输入输出接口和输入输出软件等。实际上,运算器、控制器、主存储器和总线等也要...

    计算机输入输出系统接口实验报告

    计算机输入输出系统接口实验报告 本实验报告涵盖了计算机输入输出系统接口的基本概念和实验方法,包括 I/O 地址译码、可编程中断控制器 8259 和可编程定时器计数器 8253 等内容。 一、I/O 地址译码 I/O 地址译码...

    计算机输入输出.zip

    期末复习的时候自己整理的计算机输入输出系统的期末复习资料,包括对编程题可能会用到的指令的总结以及对设计题的总结,希望对大家有所帮助。*****************************************************************

    计算机组成原理作业八:输入输出设备与输入输出系统.docx

    计算机系统内部各个组件之间的信息交换,主要通过输入输出设备与输入输出系统来实现。在本篇作业中,我们深入了解了总线的定义与功能、同步总线与异步总线的特点、RS-232串行接口的信号及其作用、以及SCSI外设总线的...

    计算机组成原理:7输入输出系统-2.ppt

    计算机输入输出系统包括广泛种类的外部设备,比如我们日常工作中使用的键盘、鼠标等输入设备,以及显示器、打印机等输出设备。除此之外,还涵盖了外存储设备,如硬盘驱动器、磁盘阵列和光盘存储器等。这些设备与主机...

    第 微型计算机的输入输出PPT学习教案.pptx

    本文旨在详细解读微型计算机输入输出系统的基本功能、接口的作用以及主要的传输方式,为理解计算机硬件架构提供有力支持。 微型计算机的输入输出系统通过一系列精心设计的接口来实现CPU与外设的连接。接口的功能...

    计算机组成原理(第2版):第5章 输入输出系统.ppt

    计算机组成原理(第2版):第5章 输入输出系统.ppt

    输入输出系统.xmind

    总结计算机组成原理中的输入输出系统的思维导图,内置有大量的文字和图片解释,以及大量的视频和博客文章,请购清晰,内容详尽,适合对计算机组成原理的学习和总结

    计算机组成原理实验报告(系统总线和具有基本输入输出功能的总线接口实验).pdf

    本篇实验报告聚焦于系统总线及基本输入输出功能的总线接口实验,旨在让学生透彻理解并掌握计算机内部硬件通信的关键技术。 系统总线是连接计算机各部件的桥梁,负责传输数据、地址和控制信号。它按照功能分为数据...

    第四章输入输出系统.ppt

    这是关于计算机网络中关于输入输出系统的课件,希望可以帮到大家

    常用输入输出设备概述.pptx

    计算机输入输出系统由三部分构成:计算机总线、输入输出接口和输入输出设备。计算机总线是连接计算机内部各个组件的通道,允许数据、指令和控制信号在不同部件间传输。输入输出接口则起到了连接I/O设备与计算机内部...

    计算机控制系统:第2章 计算机输入输出技术1.pptx

    【计算机控制系统:第2章 计算机输入输出技术】 计算机控制系统在现代工业生产中扮演着至关重要的角色,尤其体现在其核心组件——计算机输入输出技术上。本章主要介绍了几种常见的计算机控制系统主机模式,包括工业...

    计算机系统结构输入输出系统PPT学习教案.pptx

    【计算机系统结构输入输出系统】是计算机科学中的一个重要组成部分,主要负责处理机与外部设备之间的数据交换。在本文中,我们将深入探讨输入输出系统的基本原理、组织方式以及基本的输入输出方式。 首先,输入输出...

    计算机图形输入输出PPT

    计算机图形输入输出是计算机科学中的一个关键领域,它涉及到如何将数据转化为可见的图像,并将用户的交互转换为可处理的数据。在本章“第2章 图形输入输出设备”中,我们将深入探讨这一主题,主要关注用于实现这些...

    计算机组成基本原理讲义输入输出设备和输入输出系统.ppt

    计算机组成基本原理是理解计算机系统工作方式的关键,其中包括了输入输出设备和输入输出系统这两个重要组成部分。本讲义主要探讨了这些主题,旨在提供对计算机硬件基础的深入理解。 5.1 输入输出设备概述 输入输出...

    计算机组成输入输出系统(共50张PPT)精选.pptx

    "计算机组成输入输出系统" 计算机组成输入输出系统是一种计算机系统中重要的软、硬件结合的子系统,它的主要任务是对各种形式的信息进行输入和输出的控制。该系统由I/O设备和I/O接口组成,I/O设备包括输入设备、...

    计算机组成原理第八章输入输出系统8.3-8.5.ppt

    计算机组成原理第八章输入输出系统8.3-8.5.ppt 计算机组成原理第八章输入输出系统是计算机科学中的一门重要课程,本章节主要讲解输入输出系统的基本概念、I/O系统的组成、I/O接口和DMA方式。 第八章输入输出系统...

Global site tag (gtag.js) - Google Analytics