接口技术-输入输出接口概述ppt课件.ppt
《接口技术-输入输出接口概述ppt课件.ppt》由会员分享,可在线阅读,更多相关《接口技术-输入输出接口概述ppt课件.ppt(123页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1输入输出接口概述2输入输出接口(教材8.1节) I/O接口概述 查询传送方式及其接口 中断传送方式及其接口 DMA传送方式3I/O接口概述为什么需要I/O接口(电路)? 微机的外部设备多种多样 工作原理、驱动方式、信息格式、以及工作速度方面彼此差别很大 它们不能与CPU直接相连 必须经过中间电路再与系统相连 这部分电路被称为I/O接口电路多种外设多种外设4I/O接口概述(续1)什么是I/O接口(电路)? I/O接口是位于系统与外设间、用来协助完成数据传送和控制任务的逻辑电路 PC机系统板的可编程接口芯片、I/O总线槽的电路板(适配器)都是接口电路5I/O接口概述(续2)什么是微机接口技术?
2、处理微机系统与外设间联系的技术 注意其软硬结合的特点 根据应用系统的需要,使用和构造相应的接口电路,编制配套的接口程序,支持和连接有关的设备6I/O接口的主要功能 对输入输出数据进行缓冲和锁存输出接口有锁存环节,输入接口有缓冲环节实际的电路常用:输出锁存缓冲环节,输入锁存缓冲环节 对信号的形式和数据的格式进行变换微机直接处理:数字量、开关量、脉冲量 对I/O端口进行寻址 与CPU和I/O设备进行联络7I/O接口的典型结构控制总线控制总线CB地址总线地址总线ABI/O接口电路接口电路数据数据控制控制状态状态数据总线数据总线DBCPU外设外设控制寄存器控制寄存器状态寄存器状态寄存器数据寄存器数据寄
3、存器1. 接口电路的内部结构2. 接口电路的外部特性3. 接口电路芯片的分类4. 接口电路的可编程性81. 接口电路的内部结构 CPU与外设主要有数据、状态和控制信息需要相互交换,于是从应用角度看内部: 数据寄存器 保存外设给CPU和CPU发往外设的数据 状态寄存器 保存外设或接口电路的状态 控制寄存器 保存CPU给外设或接口电路的命令92. 接口电路的外部特性 主要体现在引脚上,分成两侧信号面向CPU一侧的信号: 用于与CPU连接 主要是数据、地址和控制信号面向外设一侧的信号: 用于与外设连接 提供的信号五花八门 功能定义、时序及有效电平等差异较大103. 接口电路芯片的分类 接口电路核心部
4、分往往是一块或数块大规模集成电路芯片(接口芯片): 通用接口芯片 支持通用的数据输入输出和控制的接口芯片 如:并行接口芯片、串行接口芯片等。 面向外设的专用接口芯片 针对某种外设设计、与该种外设接口 如:显示接口电路、磁盘驱动接口电路等。 面向微机系统的专用接口芯片 与CPU和系统配套使用,以增强其总体功能 如:8259A、8237、8253等。114. 接口电路的可编程性 许多接口电路具有多种功能和工作方式,可以通过编程的方法选定其中一种 接口需要进行物理连接,还需要编写接口软件 接口软件有两类: 初始化程序段设定芯片工作方式等 数据交换程序段管理、控制、驱动外设,负责外设和系统间信息交换1
5、2I/O端口的编址接口电路占用的I/O端口有两类编排形式 I/O端口单独编址 I/O地址空间独立于存储地址空间 如8086/8088 I/O端口与存储器统一编址 它们共享一个地址空间 如M68000理解端口理解端口13I/O端口单独编址 优点: I/O端口的地址空间独立 控制和地址译码电路相对简单 专门的I/O指令使程序清晰易读 缺点: I/O指令没有存储器指令丰富内存内存空间空间I/O空间空间FFFFF0FFFF80 x86采用采用I/O端口独立编址端口独立编址14I/O端口与存储器统一编址 优点: 不需要专门的I/O指令 I/O数据存取与存储器数据存取一样灵活 缺点: I/O端口要占去部分
6、存储器地址空间 程序不易阅读(不易分清访存和访问外设)内存内存部分部分I/O部分部分存储器空间存储器空间00000FFFFF158088/8086的I/O端口 8088/8086只能通过输入输出指令与外设进行数据交换;呈现给程序员的外设是端口(Port),即I/O地址16端口(PORT) 端口泛指I/O地址,通常对应寄存器 一个接口电路可以具有多个I/O端口,每个端口用来保存和交换不同的信息 数据寄存器、状态寄存器和控制寄存器占有的I/O地址常依次被称为数据端口、状态端口和控制端口,用于保存数据、状态和控制信息 输入、输出端口可以是同一个I/O地址一定要理解一定要理解 8086用于寻址外设端口
7、的地址线为16条,端口最多为21665536(64K)个,端口号为0000H FFFFH 每个端口用于传送一个字节的外设数据18I/O寻址方式 8088/8086的端口有64K个,无需分段,设计有两种寻址方式v直接寻址:只用于寻址00H FFH前256个端口,操作数i8表示端口号v间接寻址:可用于寻址全部64K个端口,DX寄存器的值就是端口号 对大于FFH的端口只能采用间接寻址方式19数据交换方式 如果输入输出一个字节,利用AL寄存器 如果输入输出一个字,利用AX寄存器 输入一个字,实际上是从连续两个端口输入两个字节,分别送AL(对应低地址端口)和AH(对应高地址端口) 输出一个字,实际上是将
8、AL(对应低地址端口)和AH(对应高地址端口)两个字节的内容输出给连续两个端口20I/O指令指令功功 能能说说 明明IN AL,PORTIN AX,PORTIN AL,DXIN AX,DXOUT PORT,ALOUT PORT,AXOUT DX,ALOUT DX,AXAL(PORT)AH,AL(PORT+1,PORT)AL(DX)AH,AL(DX+1,DX)(PORT)AL(PORT+1,PORT)AH,AL(DX)AL(DX+1,DX)AH,AL单字节访问单字节访问双字节访问双字节访问单字节访问单字节访问双字节访问双字节访问单字节访问单字节访问双字节访问双字节访问单字节访问单字节访问双字节访
9、问双字节访问 8086/8088的I/O指令21IN指令(从20H、21H端口输入一个字);方法1:字量输入,直接寻址in ax,20h;方法2:字量输入,间接寻址mov dx,20hin ax,dx;方法方法3:字节输入,直接寻址字节输入,直接寻址in al,21hin al,21hmovmov ah,alah,alin al,20hin al,20h;方法方法4:字节输入,字节输入,间间接寻址接寻址movmov dx,21h dx,21hin in al,dxal,dxmovmov ah,alah,aldecdec dxdxin in al,dxal,dx22OUT指令(向300H端口输出
10、一个字节);唯一的方法:间接寻址,字节量输出mov al,bvar ;bvar是字节变量mov dx,300hout dx,al23I/O地址的译码常见的I/O地址的译码(或称端口地址选择)方法有三种: 门电路组合法门电路组合法 译码器译码法译码器译码法 比较器比较法比较器比较法 门电路组合法是最简单的一种端口地址选择方法,它采用常见的逻辑门电路,比如与门、或门、非门等作为基本的组合元件。 一般端口都是指寄存器、锁存器或缓冲器,这些器件都有一个芯片选择信号,简称片选信号,多数是低电平有效,当然,也有一些芯片没有片选信号,而是有使能端,或脉冲控制端,总之是使器件产生动作的控制端。 端口地址选择的
11、目的,是当地址线上出现某种信息组合时端口地址选择的目的,是当地址线上出现某种信息组合时,在电路的输出端会产生一个有效信号,在电路的输出端会产生一个有效信号(有效信号有四种状态,即高电平、低电平、上跳沿、下降沿,具体使用哪种状态,视所使用器件而定),该信号连到器件的控制端,使器件产生动作,从而完成I/O端口的读/写操作。 这种方法简单、直观,适合于单个端口,常用的基本门电路有7400(2输入4与非门)、7408(2输入4与门)、7420(4输入双与非门)、7430(8输入与非门)、7402(2输入4或非门)、7432(2输入4或门)、7404(六反相器)等等。25逻辑门电路进行I/O地址译码A9
12、A8A7A6A5A2A4A3AENA1A074LS033E7H译码器译码法译码器译码法是最常用的一种方法,就是利用译码器芯片对地址进行译码。 PC/XT微型机系统板上接口芯片的端口地址译码采用了一个74LS138译码电路。这些芯片也都有片选信号,74LSl38译码器的输出与这些芯片的片选信号连接。各接口芯片内部有多个寄存器,因而应有多个端口地址。译码器只直接使用A9A5,其余的低5位地址A4A0未接,留给各接口芯片自行内部译码,以便寻址多个寄存器。显然,由于A4A0未接到译码器,所以每个译码器的输出端对应25=32个端口地址,系统为每个接口芯片预留出32个端口地址,至于每个接口芯片用多少,则视
13、接口芯片内部寄存器的数目而定。 译码器译码法可以方便地对多个地址进行译码,适合于多个端口的电路。常用的译码器有 74139/74155(双2线-4线译码器)、74138(3线-8线译码器)、74154(4线-16线译码器)。 82378237000H 000H 01FH01FH82598259020H 020H 03FH03FH82538253040H 040H 05FH05FH82558255060H 060H 07FH07FHDMADMA页面寄存器页面寄存器 080H 080H 09FH09FHNMINMI屏蔽寄存器屏蔽寄存器 0A0H 0A0H 0BFH0BFH保留保留 0C0H 0C0
14、H 0DFH0DFH保留保留0E0H 0E0H 0FFH 0FFH 27IBM PC/XT主机板的I/O译码电路Y0 Y1 Y2 Y3 Y4 Y5Y6 Y7A5A6 A7A8A9 AENIOWAB CG2BG2AG1DMA CS(8237)INTR CS(8259)T/C CS(8253)PPI CS (8255)WRTDMAPG(写(写DMA页面寄存器)页面寄存器)WRTNMIREG(写(写NMI屏蔽寄存器)屏蔽寄存器)28IBM PC/AT主机板的I/O译码电路接口芯片内部译码接口芯片内部译码A0A4DMA控制器控制器1中断控制器中断控制器1定时计数器定时计数器并行接口电路并行接口电路DM
15、A页面寄存器页面寄存器中断控制器中断控制器2DMA控制器控制器2协处理器协处理器A5A6A7A8A9LS138译码器译码器HLDAMASTERABCE1E2E3Y0*Y1*Y2*Y3*Y4*Y5*Y6*Y7* 比较器比较法比较器比较法是比较灵活的一种方法,就是利用数码比较器把地址线上的地址同拨码开关预定的地址相比较,进而确定地址是否相符。如果比较后两个地址相等,则表示地 址总线送来的端口地址就是该端口的地址。用比较器比较法进行端口地址译码不仅原理直观,方法简便,更主要的是通过改变预设置,就能够很容易地改变接口电路中端口的地址,而不需要改变线路,使用非常灵活。在一些通用接口模板中,这一方法已得到
16、广泛的应用。 常用的比较器有7485(4位数字比较器)、74688(8位数字比较器)。 用用74LS688作译码器的译码电路作译码器的译码电路 简单接口电路 数据输入接口 必须具有三态输出能力,以便与总线挂接 外设有数据保持能力时可用三态门实现 外设无数据保持能力时用三态输出的锁存器实现 数据输出接口 常用锁存器实现 三态门:高电平、低电平、高阻态 通常一个器件中包含8个三态门 常用芯片:74LS244(8位三态缓冲器) 应用例子:开关接口 工作波形图如下:A0A15IOR#译码输出D0D7开关状态地址有效简单的输入接口举例(8位开关量输入)接口电路图如下:83FCH83FFH译码器 锁存器:
17、由D触发器构成 通常一个器件包含8个D触发器 常用芯片: 74LS273(8-D触发器) 74LS374(具有三态输出的锁存器)简单的输出接口举例(发光二极管接口)译码器=1=1.+5VRD0D7CPQ0Q7.D0D7A0A15IOW#74LS273R输入/输出接口综合应用例子 根据开关状态在7段数码管上显示数字或符号 共阳极7段数码管结构 用74LS273作为输出接口,把数据送到7段数码管 74LS273的地址假设为F0H 用74LS244作为输入口,读入开关K0K3的状态 74LS244的地址假设为F1H 当开关的状态分别为00001111时,在7段数码管上对应显示0F (7段码表见下页)
18、 符号形状7段码.gfedcba符号形状7段码.gfedcba000111111801111111100000110901100111201011011A01110111301001111B01111100401100110C00111001501101101D01011110601111101E01111001700000111F01110001O1 I1O2 I2O3 I3O4 I4#E1 K0K3+5VGG2AG2BCBA174LS244D0 Q0 | Q1D7 Q2 Q3 Q4CP Q5 Q6 Q7 abcdefgDP74068个反相器74LS273Rx8174LS138D0D7IOW
19、#IOR#Y0Y1F0H = 0000 0000 1111 0000F1H = 0000 0000 1111 0001&1A7A4A15A8A3A2A1A0D0D1D2D3译码电路相应程序段如下:Seg7DB3FH,06H,5BH,4FH,66H,6DH,7DH,07HDB7FH,67H,77H,7CH,39H,5EH,79H,71HLEABX, Seg7;取7段码表基地址MOVAH, 0GO:MOVDX, 0F1H;开关接口的地址为F1HINAL, DX;读入开关状态ANDAL, 0FH ;保留低4位MOVSI, AX;作为7段码表的表内位移量MOVAL, BX+SI;取7段码MOVDX,
20、0F0H;7段数码管接口的地址为F0HOUTDX, ALJMPGOI/O设备与存储器的区别 存储器的工作速度几乎和中央处理机一样,而大多数I/O设备工作较慢,且不同的I/O设备又有不同的工作速度。 存储器的字长一般是以字节为单位或等于机器字长,而I/O设备传送的过程中可能是8位数据,也可能是1位,2位不等的状态或控制信息。 存储器中的信号形式与CPU相同,而I/O设备可能是数字信号也可能是模拟信号,可能是电压信号也可能是电流信号,可能是并行的也可能是串行的等等。 存储器的控制信号主要是读/写信号,而I/O设备一般有多种控制信号,如设备工作,空闲等状态信号,设备的启动,清除等控制信号。 这些差异
21、都使得I/O数据传送过程较为复杂,随之而来的就是根据不同设备需采用不同的传送方式,相应的也就要采用不同的控制方式。 输入输出的控制方式 主机与I/O设备之间数据传送的控制方式有以下三种: 查询式传送查询式传送 中断方式传送中断方式传送 直接存储器存取直接存储器存取(DMA, Direct Memory Access)查询方式传送 适用于外设并不总是准备好,而且对传送速率、传送效率要求不高的场合。 CPU在与外设交换数据前必须询问外设状态“你准备好没有?” 对外设的要求:应提供设备状态信息 对接口的要求:需要提供状态端口 优点:软件比较简单 缺点:CPU效率低,数据传送的实时性差,速度较慢动画演
22、示42就绪(Ready) 在输入场合 “就绪”说明输入接口已准备好送往CPU的数据,正等着CPU来读取 该状态也可用接口中数据缓冲器已“满”来描述 在输出场合 “就绪”说明输出接口已做好准备,等待接收CPU要输出的数据 该状态也可用接口数据缓冲器已“空”、或者用接口(外设)“闲”或不“忙(Busy)”来描述就绪:满,空、闲、不忙就绪:满,空、闲、不忙查询方式的流程图超时?READY?与外设进行数据交换超时错读入并测试外设状态YNYN传送完?防止死循环复位计时器NY44查询传送的两个环节 查询环节 寻址状态口 读取状态寄存器的标志位 若不就绪就继续查询,直至就绪 传送环节 寻址数据口 是输入,通
23、过输入指令从数据端口读入数据 是输出,通过输出指令向数据端口输出数据输入状态输入状态就绪?就绪?数据交换数据交换YN传送流程传送流程接口实例接口实例45查询输入接口IOR+5V8D锁存器锁存器8位位三态三态缓冲器缓冲器译码译码1位位三态三态缓冲器缓冲器RQ A0A158000H8001HD0D7D0D输入输入设备设备IORSTBmov dx,8000h;DX指向状态端口status:in al,dx;读状态端口test al,01h;测试标志位D0jz status;D00,未就绪,继续查询inc dx;D01,就绪,DX指向数据端口in al,dx;从数据端口输入数据46查询输出接口8D锁存
24、器锁存器译码译码1位位三态三态缓冲器缓冲器RQ A0A158000H8001HD0D7D7D+5V输出输出设备设备ACKIOWIORmov dx,8000h;DX指向状态端口status:in al,dx;读取状态端口的状态数据test al,80h;测试标志位D7jnz status;D71,未就绪,继续查询inc dx;D70,就绪,DX指向数据端口mov al,buf;变量buf送ALout dx,al;将数据输出给数据端口47EEPROM编程(查询方式)2817AA0A10A0A108000HI/O0I/O7D0D7D0译码译码A11A19译码译码A0A15 RDY/BUSYIORWE
25、RDMEMWMEMRCEnext:mov al,55h;写入内容55Hmov bx,al;写入存储单元nop;空操作指令,起延时作用nopnext1:in al,dx;查询状态口test al,01h;测试D0jz next1;D00,芯片还在写入inc bx;D01,写毕,指针移动loop next;循环至全部字节写完例:用查询方式进行输出外设状态端口地址为3FBH,第5位(bit5)为状态标志(=1忙,=0准备好)外设数据端口地址为3F8H,写入数据会使状态标志置1 ;外设把数据读走后又把它置0。试画出其电路图。(电路图见下页)D5D7-D0A9|A31&A15|A101IOWD7-D03
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 接口 技术 输入输出 概述 ppt 课件
限制150内