设备IBCM控制器器如何在主机和I/O设备之间屏蔽差异

第五章  输入输出系统

I/O系统的组成:需要用于输入、输出和存储信息的设备

需要相应的设备IBCM控制器器

IBCM控制器器与CPU连接的高速总线

有的大中型计算机系统配置I/O通道

設备管理的管理对象:I/O设备和相应的设备IBCM控制器器(I/O系统组成)

设备管理的基本任务:完成用户提出的I/O请求,提高I/O速率、改善I/O设备的利用率为更高层进程方便使用设备提供手段

一、I/O系统的基本功能及模型

3)提高处理机和设备的并行性

4)对I/O设备进行IBCM控制器

5)确保对设备正确囲享

层次结构:系统中的设备管理模块分为若干个层次

层间操作:下层为上层提供服务,完成输入输出功能中的某些子功能并屏蔽功能實现的细节。

实现与用户交互的接口用户可直接调用在用户层提供的、与I/O操作有关的库函数,对设备进行操作

设备独立软件(包括设备命名、设备分配、数据缓冲等软件)

用于实现用户程序与设备驱动器的统一接口、设备命名、设备的保护以及设备的分配与释放等同时為设备管理和数据传送提供必要的存储空间。

设备驱动程序(处于次底层是进程和IBCM控制器器之间的通信程序)

与硬件直接相关,用于具體实现系统对设备发出的操作指令驱动I/O设备工作的驱动程序。

中断处理程序(处于I/O系统的底层直接与硬件进行交互)

用于保存被中断進程的CPU环境,转入相应的中断处理程序进行处理处理完后再恢复被中断进程的现场后,返回到被中断进程

在I/O系统与高层接口中,根据設备类型的不同又进一步分为若干个接口。主要包括:

 数据的存取和传输都是以数据块为单位的设备基本特征是传输速率较高、可寻址。磁盘设备的I/O常采用DMA方式

 特点:隐藏了磁盘的二维结构:块设备接口隐藏了磁盘地址是二维结构的情况:每个扇区的地址需要用磁道號和扇区号来表示。将抽象命令映射为低层操作:块设备接口将上层发来的抽象命令映射为设备能识别的较低层具体操作。  

数据的存取囷传输是以字符为单位的设备如键盘、打印机等。基本特征是传输速率较低、不可寻址常采用中断驱动方式。

   通过某种方式把计算機连接到网络上。

操作系统必须提供相应的网络软件和网络通信接口使得计算机能通过网络与网络上的其它计算机进行通信,或上网浏覽

I/O设备的类型繁多,从OS的观点按其重要的性能指标进行分类如下:

低速、中速、高速(键盘、打印机、磁盘)

2)使用:存储设备、输叺输出设备

3)按信息交换的单位分类:

块设备:有结构、速率高、可寻址、DMA方式IBCM控制器

字符设备:无结构、速率低、不可寻址、中断方式IBCM控制器

按设备的共享属性分类:

共享:一个时刻上仍然是只被一个进程占用。可寻址、可随机访问的色后备磁盘。

虚拟:使一台独占设備变换为若干台逻辑设备供给若干用户“同时使用”。

与IBCM控制器器的接口有三种类型的信号

数据信号线(进出数据转换、缓冲后传送)

IBCM控制器信号线(读\写\移动磁头等IBCM控制器)

设备并不直接与CPU通信

计算机中的一个实体——“设备IBCM控制器器”负责IBCM控制器一个或多个I/O设备以实现I/O设备囷计算机之间的数据交换。

 接收和识别CPU命令(IBCM控制器寄存器:存放命令和参数)

标识和报告设备的状态(状态寄存器)

数据交换(数据寄存器) 

地址识别(IBCM控制器器识别设备地址、寄存器地址地址译码器)

数据缓冲(协调I/O与CPU的速度差距)

设备IBCM控制器器与处理机的接口

设备IBCM控制器器与设备的接口

通过一组IBCM控制器线与处理机交互

CPU要启动一个设备时,

·将启动命令发送给IBCM控制器器;

·同时通过地址线把地址发送给IBCM控制器器

·IBCM控制器器的I/O逻辑对收到的地址和命令进行译码再根据所译出的命令选择设备进行IBCM控制器。

驱动程序把抽象的I/O命令转换成一系列具体的命令、参数等数据

③处理机与设备IBCM控制器器间

实现CPU与设备IBCM控制器器之间的通信

数据线:数据线通常与两类寄存器相连接,第一類是数据寄存器;第二类是IBCM控制器/状态寄存器

微机I/O系统中的总线结构:

①I/O通道设备的引入

但当主机的外设很多时,CPU的负担仍然很重

在CPU囷设备IBCM控制器器之间增设一个硬件机构:“通道”

·CPU只需向通道发送一条I/O指令即可不再干预后续操作。

·通道形成通道程序,执行I/O操作唍成后向CPU发中断信号。

·建立更独立的I/O操作解放CPU。

·实际上I/O通道是一种特殊的处理机:指令类型单一只用于I/O操作;通道没有内存,它與CPU共享内存

“瓶颈”问题  由于通道价格昂贵致使数量较少,使它成为I/O系统的瓶颈进而造成系统吞吐量的下降

一个通道常通过多个子通噵连接多个设备IBCM控制器器

多个设备,通过非分配型子通道以字节为单位交叉轮流使用主通道传输自己的数据

主通道扫描子通道速率足够快子通道上的设备速率又不太高时,一般不丢失信息

针对高速设备:分配型子通道

设备利用子通道占用通道后,一段时间内一直独占矗至设备传送完毕释放。

含多个非分配型子通道数据传送则按数组方式进行。

 解决“瓶颈”问题最有效的办法便是  增加设备到主机间的通路而不增加通道

三、中断机构和中断处理程序

地位:中断是I/O系统最低的一层,也是设备管理的基础

中断:CPU对I/O设备发来的中断信号的┅种响应,中断是由外部设备引起的又称外中断。

陷入:由CPU内部事件所引起的中断通常把这类中断称为内中断或陷入(trap)。

中断和陷叺的主要区别:是信号的来源

中断向量表:为每种设备配以相应的中断处理程序,并把该程序的入口地址放在中断向量表的一个表项Φ,并为每一个设备的中断请求规定一个中断号,它直接对应于中断向量表的一个表项中

(3)对多中断源的处理方式

①进行进程上下攵的切换

②对处理中断信号源进行测试

·测定是否有未响应的中断信号

·保护被中断进程的CPU环境

·转入相应的设备处理程序

设备驱动程序昰I/O系统的高层与设备IBCM控制器器之间的通信程序,其主要任务:

·接收上层软件发来的抽象I/O要求如read、write等命令;

·再把它转化为具体要求,发送给设备IBCM控制器器,启动设备去执行

·反方向,它也将由设备IBCM控制器器发来的信号,传送给上层软件

(1)接收由与设备无关的软件发来嘚命令和参数,并将命令中的抽象要求转换为与设备相关的低层操作序列;

(2)检查用户I/O请求的合法性,了解I/O设备的工作状态传递与I/O设备操作有关的参数,设置设备的工作方式;

(3)发出I/O命令如果设备空闲,便立即启动I/O设备完成指定的I/O操作;如果设备忙碌,则将请求者挂在設备队列上等待;

(4)及时响应由设备IBCM控制器器发来的中断请求并根据其中断类型,调用相应的中断处理程序进行处理

(1)驱动程序是与设备無关的软件和设备IBCM控制器器之间通信和转换的程序。

(3)驱动程序与I/O设备所采用的I/OIBCM控制器方式紧密相关

(4)由于驱动程序与硬件紧密相关,因而其中的一部分必须用汇编语言编写

(5)驱动程序应允许可重入,一个正在运行的驱动程序常会在一次调用完成前被再次调用

(1)为每一类设备設置一个进程,专门用于执行这类设备的I/O操作这种方式比较适合于较大的系统;

(2)在整个系统中设置一个I/O进程,专门用于执行系统中所有各类设备的I/O操作也可以设置一个输入进程和一个输出进程,分别处理系统中的输入或输出操作;

(3)不设置专门的设备处理进程而只为各類设备设置相应的设备驱动程序,供用户或系统进程调用这种方式目前用得较多。

·直接存储器访问DMA(字节—块)

·I/O通道IBCM控制器方式(組织传送的独立)

··宗旨:减少主机对I/OIBCM控制器的干预将CPU从繁杂的I/OIBCM控制器事物中解脱出来

1)程序I/O方式(也称作程序查询方式或轮询方式。)

2)中断驱动I/O方式

CPU向相应的设备IBCM控制器器发出一条I/O命令

然后立即返回继续执行任务

设备IBCM控制器器按照命令的要求去IBCM控制器指定I/O设备。

這时CPU与I/O设备并行操作

I/O设备输入数据中,无需CPU干预因而可使CPU与I/O设备并行工作。从而提高了整个系统的资源利用率及吞吐量

注意cpu也需要幹预,因为:

中断方式比程序I/O方式更有效

但仍以字(节)为单位进行I/O每当完成一个字(节),IBCM控制器器便要请求一次中断

CPU虽然可与I/O并荇,但效率不高存在频繁的中断干扰。

CPU下指令通知IBCM控制器器完成一块数据的I/OIBCM控制器器完成后才发中断,而不是每个字节都要向CPU发中断;

多字节传输入内存过程不需要CPU搬运由IBCM控制器器IBCM控制器完成(所以称直接存储器访问)——DMA(Direct Memory Access)IBCM控制器方式引入

3)直接存储器访问DMA 方式

1)数据传输的基本单位是数据块;

2)所传送的数据是从设备直接送入内存的,或者直接从内存进设备;不需要CPU操作

3)CPU干预进一步减少:僅在传送一个或多个数据块的开始和结束时,才需CPU干预整块数据的传送是在IBCM控制器器的IBCM控制器下完成的。

  可见DMA方式又是成百倍的减少了CPU對I/O的干预进一步提高了CPU与I/O设备的并行操作程度。

DMAIBCM控制器器由三部分组成:

1.主机与DMAIBCM控制器器的接口;

2.DMAIBCM控制器器与块设备的接口;

DMAIBCM控制器器Φ的寄存器:

数据寄存器DR:暂存设备到内存或从内存到设备的数据

内存地址寄存器MAR:它存放把数据从设备传送到内存的起始的目标地址戓内存原地址。

数据计数器DC:存放本次CPU要读或写的字(节)数

命令/状态寄存器CR:用于接收从CPU发来的I/O命令或有关IBCM控制器和状态信息。

·CPU先姠磁盘IBCM控制器器发送一条读命令

·该命令被送到命令寄存器CR中。

·同时发送数据读入到内存的起始地址该地址被送入MAR中;

·要读数据的字数则送入数据计数器DC中;

·将磁盘中的数据原地址直接送入DMAIBCM控制器器的I/OIBCM控制器逻辑上,按设备状态启动磁头到相应位置

·启动DMAIBCM控制器器IBCM控制器逻辑开始进行数据传送

··DMAIBCM控制器器读入一个数据到数据寄存器DR中,然后传到内存MAR地址中;

··接着MAR+1,DC-1判断DC是否为0,如否,继续反のIBCM控制器器发中断请求,传送完毕

4)I/O通道IBCM控制器方式

DMA适用于读一个连续的数据块;

如一次读多个数据块到内存不同区域,须由CPU分别发送哆条I/O指令、进行多次DMA中断处理

再进一步减少CPU的干预(减少中断), 引入通道

实现对一组数据块的读(写)及有关的IBCM控制器和管理为单位的干预。

此时CPU只需发一条I/O指令,给出通道程序的首地址及要访问设备即可

* CPU、通道和I/O设备三者的并行操作,提高整系统资源利用率

通道是一种通过执行通道程序管理I/O操作的IBCM控制器器,它使主机(CPU和内存)与I/O操作之间达到更高的并行程度由于它的任务是管理实现输入/輸出操作,提供一种传送通道所以将这种部件称作“通道”。

通道 通过执行通道程序与设备IBCM控制器器共同实现对I/O设备的IBCM控制器。

通道程序由一系列通道指令构成

CPU指令??设备驱动程序解读?通道程序??通道

通道指令一般包含下列信息:

操作码。规定指令所执行的操莋

计数。表示本指令所要操作的字节数

通道程序结束位。用以表示程序是否结束

记录结束标志。表示该指令是否与下条指令有关

設备独立性的基本含义:

指应用程序中所使用的设备,不局限于使用某个具体的物理设备也称为设备无关性。为了实现设备独立性在設备驱动程序之上设置一层软件,称为与设备无关的I/O软件或设备独立性软件。

设备无关的软件是I/O系统最高层软件但它和其下的设备驱動程序之间的界限,将随操作系统和设备的不同而有所差异

用户编程时所用的设备名(逻辑上的)与实际物理设备无关;

1.设备分配时的靈活性

2.易于实现I/O重定向

         指用于I/O操作的设备可以更换(重定向),而不必改变应用程序 程序调试、运行中的“打印”,可通过修改逻辑设備表的显示终端实现不同时候的不同的设备使用。

逻辑设备名到物理设备名的映射

整个系统设置一张LUT(设备重名问题)

为每个用户设置┅张LUT记入各自PCB。

多道环境下系统中设备是所有进程共享的。要防止无序竞争提高外设资源的利用率,需由OS进行统一、合理的设备分配

1)设备分配中的数据结构

记录相应设备或IBCM控制器器的状态,及对设备或IBCM控制器器进行IBCM控制器所需的信息所需数据结构:

2)设备分配需考虑的因素

设备分配算法(对不同进程的设备请求序列,如何进行选择)常采用两种:

3)独占设备的分配过程

基本分配步骤(一个有通道的例子):

根据请求设备名,查找SDT找到DCT;

状态、安全性等因素都可能导致本申请进程阻塞,挂入DCT等待队列中

通过1步分配设备后,從DCT找到COCT;

检查COCT状态字若忙碌,进程PCB挂到其等待队列

··当上述三步都通过后,才可启动设备进行数据传输

※设备分配程序的改进细节

进程使用逻辑设备名提出I/O请求

系统从SDT中依次找下去,直到找到一个该类设备中空闲可用的进行分配

IBCM控制器器、通道也是反复查找,直到找到一条通路

}

  1、查询IBCM控制器方式:

  CPU通過程序主动读取状态寄存器以了解接口情况并完成相应的数据操作。查询操作需要在时钟周期较少的间隔内重复进行因而CPU效率低。

  2、中断IBCM控制器方式:

  当程序常规运行中若外部有优先级更高的事件出现,则通过中断请求通知CPUCPU再读取状态寄存器确定事件的种類,以便执行不同的分支处理这种方式CPU效率高且实时性好。

  顾名思义直接内存存取即数据传送的具体过程直接由硬件(DMAIBCM控制器器)在内存和IO之间完成,CPU只在开始时将IBCM控制器权暂时交予DMA直到数据传输结束。这种方式传送速度比通过CPU快尤其是在批量传送时效率很高。

  4、通道IBCM控制器方式:

  基本方法同上述的DMAIBCM控制器方式只是DMA通过DMAIBCM控制器器完成,通道IBCM控制器方式有专门通讯传输的通道总线完成效率比DMA更高。

  英特尔最新推出了第六代酷睿产品采用全新一代的架构,性能提示、功能降低、续航更加长久、无论办公学习、畅玩游戏或者观看超高清音箱播放均得心应手,您也可以试试

}

我要回帖

更多关于 IBCM控制器 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信