收藏 分享(赏)

计算机和外设之间的数据传输.doc

上传人:gnk289057 文档编号:8157842 上传时间:2019-06-11 格式:DOC 页数:4 大小:40.50KB
下载 相关 举报
计算机和外设之间的数据传输.doc_第1页
第1页 / 共4页
计算机和外设之间的数据传输.doc_第2页
第2页 / 共4页
计算机和外设之间的数据传输.doc_第3页
第3页 / 共4页
计算机和外设之间的数据传输.doc_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

1、计算机和外设之间的数据传输本章学习要点 输入输出接口技术的概念和功能 IO 端口的编址方式 输入输出控制方式 可编程控制器 8237A 的应用61 本章知识重点611 输入输出接口技术的基本概念1输入输出接口的概念输入输出接口简称 IO 接口,它是指 CPU 和存储器、外部设备或者两种外部设备之间,或者两种机器之间通过系统总线进行连接的逻辑部件(或称电路),它是 CPU 与外界进行信息交换的中转站。2输入输出接口的功能(1)数据缓冲功能:CPU 和外设速度不匹配的问题可以通过在接口电路中设置数据缓冲来解决,数据缓冲经常使用锁存器和缓冲器,并配以适当的联络信号来实现这种功能。(2)信号转换功能:

2、外部设备大都是复杂的机电设备,其信号电平大多是 TTL 电平或CMOS 电平,需要用接口电路来完成信号的电平转换。(3)对外设的控制和检测功能:接口电路接受 CPU 送来的命令或控制信号、定时信号,实施对外设的控制与管理,外设的工作状态和应答信号也通过接口及时返回给 CPU,以握手联络信号来保证主机和外部输入输出操作的同步。(4)设备选择功能:系统中一般带有多种外设,同一种外设也可能由多台,而 CPU 在同一时间里只能与一台外设交换信息,这就要借助于接口的地址译码以选定外设。只有被选定的外部设备才能与 CPU 进行数据交换。(5)中断或 DMA 管理功能:为了满足实时|生和主机与外设并行工作的

3、要求需要采用中断传送的方式,为了提高传送的速率有时又采用 DMA 传送方式,这就要求接口有产生中断请求和 DMA 请求的能力以及管理中断和 DMA 的能力。(6)可编程功能:现在的接口芯片大多数都是可编程的,这样在不改变硬件的情况下,只需修改程序就可以改变接口的工作方式,大大增加了接口的灵活性和可扩充性,使接口向智能化方向发展。3CPU 与 IO 接口之间传递的信息类型 ,CPU 与 IO 设备之间要传送的信息,通常包括数据信息、状态信息和控制信息。(1)数据信息:是 CPU 与外设交换的基本信息,有数字量、模拟量和开关量等。(2)状态信息:反映外设当前所处的工作状态,以便 CPU 对外设进行

4、监视。(3)控制信息:是 CPU 通过接口发给外设的,用来控制外设的工作。在微型计算机中,状态信息、控制信息实际上也是一种数据信息,即状态信息为一种输入数据,而控制信息则为一种输出数据,均通过数据总线传送。CPU 送往外设的数据或者外设送往 CPU 的数据先进入接口的数据缓冲器;从外设送往 CPU 的状态信息放在接口的状态寄存器中;而 CPU 送往外设的控制信息则送到接口的控制寄存器中。4I0 端口的编址方式(1)统一编址这种编址方式是把每一个端口视为一个存储器单元,并赋予相应的存储器地址,CPU访问端口就如同访问存储器,只是地址不同而已,所有访问内存的指令都适用于 IO 端口。由于端口地址被

5、映像到存储空间作为存储空间的一部分,因此这种编址方法又称为“存储器映像编址” 。主要优点:对 I0 接口的操作与对存储器的操作完全相同,任何存储器操作指令都可用来操作 IO 接口,而不必使用专用的 I0 指令,这可大大增强系统的 UO 功能,使访问外设端口的操作方便、灵活;可以使外设数目或 IO 寄存器数目几乎不受限制,从而大大增加系统的吞吐率;可以使微型计算机系统的读写控制逻辑较简单。主要缺点:占用了存储器的一部分地址空间,使可用的内存空间减少;访问内存的指令一般较长,执行速度较慢;为了识别一个 IO 端口,必须对全部地址线译码,这样不仅增加了地址译码电路的复杂性,而且使执行外设寻址的操作时

6、间相对增长。(2)独立编址这种编址方式是将 IO 端口单独编址,不占用存储空间,即两者的地址空间是互相独立的,不会影响到存储器的地址空间。采用这种编址方式时,CPU 访问 FO 端口必须采用专用的 IO 指令,所以也叫专用 IO 指令方式。这种编址方式的优点是节省内存空间。由于系统需要的 IO 端口寄存器一般比存储器单元要少得多,故 IO 地址线较少,因此 IO 端口地址译码较简单,寻址速度较快。缺点是专用 IO 指令类型少,远不如存储器访问指令丰富,使程序设计灵活性较差,且使用IO 指令一般只能在累加器和 IO 端口交换信息,处理能力不如存储器映像方式强。6-1-2 CPU 与外设之间的数据

7、传送方式1程序控制方式程序控制方式是指 CPU 与外设之间的数据传送是在程序控制下完成,它又可分成无条件传送和条件传送两种方式。(1)无条件传送无条件传送方式也称为同步传送方式,主要用于对简单外设进行操作,或者外设的定时是固定的或已知的场合。(2)条件传送方式条件传送方式也称为查询传送方式。传送数据前,CPU 要先执行一条输入指令,从外设的状态口读取它的当前状态。如果外设未准备好数据或处于忙碌状态,则程序要反复执行读状态指令,不断检测外设状态;如果该外设的输入数据已准备好,CPU 便可从外设读入数据。优点:简单,可以编制程序控制数据传送。缺点:无条件传送方式的应用受到很大限制,条件传送方式在设

8、备未准备就绪时,必须反复查询,进入循环等待状态,导致 CPU 的工作效率严重降低。2中断控制方式采用中断控制方式后,CPU 平时执行主程序,只有当输入设备将数据准备好了,或者输出端口的数据缓冲器已空时,才向 CPU 发中断请求。CPU 响应中断后,暂停执行当前的程序,转去执行管理外设的中断服务程序。在中断服务程序中,用输入或输出指令在 CPU 和外设之间进行一次数据交换,等输入或输出操作完成之后,CPU 又回去执行原来的程序。优点:CPU 的工作效率可以大大提高。缺点:每进行一次数据传送,CPU 都要执行一次中断服务程序。这时,CPU 要保护和恢复断点,通常还要执行一系列保护和恢复寄存器的指令

9、,即保护现场,以便完成中断处理后能正确返回主程序。显然,这些操作与数据传送没有直接关系,但会花费掉 CPU 的不少时间。所以,在这段时间内执行部件和总线接口部件就不能并行工作,这也会造成数据传输效率的降低。3DMA 控制方式DMA 控制方式是利用系统的数据总线、地址总线和控制总线来传送数据。当外设需要利用 DMA 方式进行数据传送时,接口电路可以向 CPU 提出请求,要求 CPU 让出对总线的控制权,用 DMA 控制器来取代 CPU 临时接管总线,控制外设和存储器之间直接进行高速的数据传送,而不要 CPU 进行干预。这种控制方式能给出访问内存所需要的地址信息,并能自动修改地址指针,也能设定和修

10、改传送的字节数,还能向存储器和外设发出相应的读写控制信号。在 DMA 传送结束后,它能释放总线,把对总线的控制权又交给 CPU。可见,用 DMA 方式传输数据时,不需要进行保护和恢复断点及现场之类的额外操作,一旦进入 DMA 操作,就可直接在硬件的控制下快速完成一批数据的交换任务,数据传送的速度基本上取决于外设和存储器的存取速度。6-1-3 8237A DMA 控制器18237A 的工作状态8237A DMA 控制器有两种不同的工作状态。(1)在 DMA 控制器未取得总线控制权时必须由 CPU 对 DMA 控制器进行编程,这时 CPU 处于主控状态,而 DMA 控制器就和一般的 VO 芯片一样

11、,是系统总线的从设备,DMA 控制器的这种工作方式称为从态方式。(2)当 DMA 控制器取得总线控制权后,系统就完全在它的控制之下,使 VO 设备和存储器之间或存储器与存储器之间进行直接的数据传送,DMA 控制器的这种工作方式称为主态方式。28237A 的内部结构8237A 的内部结构主要由 5 个部分组成:(1)时序与控制逻辑:从态时,该部分电路接受系统送来的时钟、复位、片选和读写控制等信号,完成相应的控制操作;主态时则向系统发出相应的控制信号。(2)优先级编码电路:对同时提出 DMA 请求的多个通道进行排队判优,决定哪一个通道的优先级最高。(3)数据和地址缓冲器组:是三态缓冲器,可以接管或

12、释放总线。(4)命令控制逻辑:接收或发出各种控制命令。(5)内部寄存器:每个通道都有基地址寄存器、基字计数器、当前地址寄存器、当前字节计数器和工作方式寄存器。还有命令寄存器、屏蔽寄存器、请求寄存器、状态寄存器和暂存寄存器共用。上述这些寄存器均是可编程寄存器。另外还有字数暂存器和地址暂存器等不可编程的寄存器。38237A 内部寄存器功能及格式(1)当前地址寄存器:16 位,用于存放 DMA 传送的存储器地址值。每传送一个数据,地址值自动增 1 或减 1,以指向下一个存储单元。(2)当前字节计数寄存器:16 位,保存当前 DMA 传送的字节数。每次传送以后,字节计数器减 1。(3)基地址寄存器:1

13、6 位,用来存放对应通道当前地址寄存器的初值,是在 CPU 对 DMA 控制器进行编程时,与当前地址寄存器的值一起被写入的。(4)基字节计数寄存器:16 位,用于存放对应通道当前字节计数器的初值。(5)命令寄存器:8 位,编程时,CPU 对其写入命令字来控制 8237A 的操作。(6)工作方式寄存器:8 位,用于指定 DMA 的操作类型、传送方式、是否自动预置和传送一字节数据后地址是按增 1 还是减 1 修改。8237A 进行 DMA 传送时,有 4 种传送方式: 单字节传送方式:该方式下,每一次 DMA 操作只传送个字节的数据。传送后字节计数器减 1,地址寄存器加 1 或减 1(由 D5 位

14、决定),保持请求信号 HQR 无效,并释放系统总线。当字节计数器由 0 减为 FFFFH 时,产生终止信号 TC。数据块传送方式:在每次 DREQ 有效后,若 CPU 响应其请求让出总线控制权给8237A,8237A 就会连续传送数据,直到字节汁数器计数由 0 减为 FFFFH 产生 TC 信号或外部送来有效的/EOP 信号时,才将总线控制权交给 CPU,结束 DMA 服务。 请求传送方式:当 DREQ 有效,若 CPU 让出总线控制权,8237A 进行 DMA 服务。每传送一个字节都将测试 DREQ,以确定是否继续传送。若 DREQ 一直有效,则连续传送数据,直至字节计数器减为 FFFFH

15、或外部送来有效的/EOP 信号,或 DREQ 变为无效时为止。 级联传送方式:该方式用于将多个 8237A 连在一起,以便扩充系统的 DMA 通道。(7)请求寄存器:请求寄存器就是用于由软件发出 DREQ 信号请求 DMA 服务的设备。(8)屏蔽寄存器:当某通道的屏蔽标志位置 l 时,禁止该通道的 DREQ 请求,并禁止该通道DMA 操作。分通道屏蔽字和主屏蔽字。(9)状态寄存器:用来存放状态信息,可供 CPU 读出。(10)暂存寄存器:用来暂存从源地址单元读出的数据。(11)软件命令:8237A 设置了 3 条软件命令:主清除命令、清除字节指示器命令和清除屏蔽寄存器命令。主清除命令:该命令能

16、清除命令寄存器、状态寄存器、各通道的请求标志位、暂存寄存器和字节指示器,并把个通道的屏蔽标志位置 1,使 8237A 进入空闲周期。清除字节指示器命令:该命令用来清除字节指示器。清除屏蔽寄存器命令:该命令清除 4 个通道的全部屏蔽位,使各通道均能接受 DMA请求。48237A 的初始化编程8237A 的初始化编程主要有一下个方面:(1)输出主清除命令,使 8237A 处于复位状态,以接收新的命令。(2)写入工作方式寄存器,以确定 8237A 工作方式和传送类型。(3)写入命令寄存器,以控制 8237A 的上作。(4)根据所选通道,输入相应通道当前地址寄存器和基地址寄存器的初始值。(5)输入当前字节计数器和基字节寄存器的初始值。(6)写入屏蔽寄存器。(7)写入请求寄存器,便可由软件 DMA 传送。62 经典例题1、 什么是 I/O 端口? CPU 使用什么指令与外设进行数据交换?答:CPU 与 I/O 设备通过硬件接口或控制器相连接, 这 些接口或控制器都有数量不等的端口,这些端口有统一的地址 编码, CPU 通过这些端口使用输入输出指令 IN、OUT 与外设进行数据交换。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报