




已阅读5页,还剩216页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第5章 接口芯片与接口技术,详细,5.1 I/O 概 述,5.1.1 I/O接口电路的作用 计算机系统的除了CPU、 存储器外, 还必须有外部设备。 计算机通过输入/输出设备和外界进行通信。 计算机所用的数据以及现场采集的各种信息都要通过输入设备送到计算机; 计算的结果和计算机产生的各种控制信号又需通过输出设备输出到外部设备。51单片机4个I/O,P3口,P2口会被其他应用,只能P1口能被完全利用,不够用,详细,计算机的I/O操作, 即CPU和外部设备之间的数据传送却十分复杂。 主要表现在以下几个方面: (1) 外部设备的工作速度与计算机相比要低得多。开关,继电器 (2) 外部设备的种类繁多, 有机械式、 机电式及电子式等等。 转换成芯片能够识别的信号 (3) 外部设备的数据信号是多种多样的, 既有电压信号, 也有电流信号; 既有数字量, 还有模拟量。 (4) 外部设备的数据传送有近距离的, 也有远距离的; 有的使用并行数据传送, 而有的则使用串行传送数据。,详细,接口电路:对CPU 和外部设备之间的数据传送进行协调具体说来, 接口电路主要有以下几项功能: (1) 速度协调。 (2) 数据锁存。 (3) 三态缓冲。 (4) 数据转换。,详细,(1) 速度协调。,CPU,接口,I/O设备,询问,READY,在CS 有效下,CPU先给锁存器发送11,灯泡亮,再断开CS,锁存器的信号保持;在CS 有效下,CPU先给锁存器发送00,灯泡灭。,(2) 数据锁存数据在数据总线上停留的时间十分短暂,CPU,接口,CS,详细,灯泡,8051的4个并行I/O 口,都是通过锁存器和外界联系,总线隔离技术:任一时刻,只允许一个数据源使用总线。其余数据源和数据总线隔离。三态缓冲是门电路,不像锁存器是触发器,锁存器能够保持信息,门电路不能保持,有输入和输出,一旦使能端有效,输入和输出信号相同,使能端无 效,输出是高阻。,详细,控制信号,(3) 三态缓冲,详细,(4) 数据转换A/D、D/A转换,转换电路,缓冲器、锁存器应用概念,锁存器:是由触发器作为基本单元,有输入也有输出,输入连接内部总线,输出连接外部设备,有控制信号;看图8-2控制信号有效,输入和输出相等,把相应数据总线数据保存上去,控制信号无效,输出信号不受输入信号的影响。锁存器用作输出,缓冲器:门电路,不具有保存功能,有输入也有输出,输入连接外部设备,输出连接数据总线。看图8-3缓冲器用作输入,一旦控制信号有效,把外部信号传到数据总线,控制信号无效,处于高阻态,详细,详细,5.1.2 接口与端口 “接口”一词是从英文interface翻译过来的, 具有界面、 相互联系等含义。 接口这个术语在计算机领域中应用十分广泛, 本章所讲述的接口则特指计算机与外设之间在数据传送方面的联系, 其功能主要是通过电路实现的, 因此称之为接口电路, 简称接口。,详细,5.1.3 I/O的编址方式计算机中, 凡需进行读写操作的设备都存在着编址问题。 计算机中两种编址的器件:一 存储器;二 接口电路。 存储器是对存储单元进行编址, 接口电路是对其中的端口进行编址。对端口编址是为I/O操作而进行的, 称为I/O编址。 常用的I/O编址有两种方式: 独立编址方式 统一编址方式,详细,存储器扩展中,RAM和ROM是独立编制,独立空间,反映了他们的特点-指令不同,信号不同,将I/O 和存储器分开进行编址计算机形成两各独立的地址空间,也就有各自的独立的读写指令。,独立编制,统一编制,将I/O 和存储器统一进行编址,只需一套的存储器指令,直接对存储器和I/O操作。,详细,如果51 单片机把I/O和RAM统一编址,就用MOVX一个命令就行,5.2 输入/输出I/O传送方式,5.2.1 无条件传送方式也称为同步程序传送, 类似于CPU和存储器之间的数据传送。 只有那些一直为数据I/O传送作好准备的外部设备, 才能使用无条件传送方式。 这种传送方式不需要测试外部设备的状态, 可以根据需要随时进行数据传送操作。外部设备总是处于准备好的状态,无需测试,随时可以传送数据。例如指示灯、发光二极管,详细,(1) 外设的工作速度非常快, 足以和CPU同步工作。 (2) 具有常驻的或变化缓慢的数据信号的外设。,无条件传送方式适用于以下两类外部设备的输入输出:,5.2.2 查询传送方式 查询传送又称为条件传送, 即数据的传送是有条件的。 在输入/输出之前, 先要检测外设的状态, 以了解外设是否已为数据输入输出作好了准备, 只有在确认外设已“准备好”的情况下, CPU才能执行数据输入/输出操作。 通常把通过程序对外设状态的检测称之为“查询”, 所以这种有条件的传送方式又叫做程序查询方式。查询的流程图如图51所示。,详细,图51 查询方式流程图,详细,5.2.3 中断传送方式 由于查询传送方式为CPU主动要求传送数据,而它又不能控制外设的工作速度,因此只能用等待的方式来解决配合的问题。耗费CPU资源中断方式则是在外设为数据传送作好准备之后,就向CPU发出中断请求信号(相当于通知CPU),CPU接收到中断请求信号之后立即作出响应,暂停正在执行的原程序(主程序),而转去为外设的数据输入输出服务,待服务完之后,程序返回,CPU再继续执行被中断的原程序。中断方式大大提高CPU的效率。,详细,由于CPU的工作速度很快,传送1次数据(包括转入中断和退出中断)所需的时间很短。对外设来讲,似乎是对CPU发出数据传送请求的瞬间,CPU就实现了;对主程序来讲,虽然中断了1个瞬间,但由于时间很短,也不会有什么影响。,详细,5.2.4 MCS-51单片机I/O口的直接应用 I/O操作指令,输出数据 输入数据MOV Px, A MOV A , PxMOV Px, Rn MOV Rn, PxMOV Px,Ri MOV Ri ,PxMOV Px, direct MOV direct ,Pxx=03 Px=P0P3,将I/O口作为寄存器使用,进行字节数据传送,详细,MOV (位传送 ) MOV Px,y, C CLE CLE Px,y SETB SETB Px,y CPL (位取反 ) CPL Px,y J B ( 位为1转移) J B Px,y, rel J NB ( 位为0转移) J NB Px,y, rel JBC ( 位为0转移清0) JBC Px,y, rel x=03 y=07,详细,I/O位操作指令,I/O的其他操作指令,详细,ANL ANL Px,AORL ORL Px,AXRL XRL Px,AINC INC PxDEC DEC PxDJNZ 数值减1条件转移 DJNZ Px,relCJNE (数值比较转移) CJNE A ,Px,rel,I/O口直接应用举例,P1.0 P1.1 P1.2 P1.38031 P1.4 P1.5 P1.6 P1.7,K1,K2,K3,K4,K是开关,产生0,1电平,灯泡,5V,P1.0,D0,D1,D2,D3,510欧,510k欧,详细,P1.0P1.3是输入, P1.4P1.7是输出;开关按下是0 ,打开是1;要求:用k0,k3分别控制灯泡D0D3,状态取反,读开关状态,状态送高4位,输出,中断方式I/O口直接数据传送,&,&,5v,1k,1k,INT0,详细,开关按下一次再弹起,产生一个脉冲(负跳变),给外部中断0端口产生中断请求。,置外中断方式0脉冲触发方式,总中断允许,等待中断,外中断0允许,开始,详细,MAIN: SETB IT0 / 脉冲边沿触发 SETB EX0 /开放外部中断0 SETB EA /开放中断HERE: AJMP HERE /等待中断EXTR: MOV A,#0FH /中断服务程序MOV P1,A /熄灭发光二极管MOV A,P1 /输入开关状态CPL A /状态取反ANL A,#0FH /屏蔽高字节SWAP A /高低半字节交换MOV P1,A /输出开关状态RETI,详细,5.3单片机简单I/O口扩展应用有2类:输入口扩展;输出口扩展5.3.1 简单输入口扩展,简单输入解决数据缓冲问题简单输入扩展就是扩展缓冲器,74LS244,CE 1A1 2Y4 1A2 2Y3 1A3 2Y2 1A4 2Y1 GND,AccCE2 1Y1 2A4 1Y2 2A3 1Y3 2A2 1Y4 2A1,1A2A,1Y2Y,三态数据缓冲器,详细,74LS244:2个四位数据缓冲器(8位),A是和外设连,Y连总线,利用74LS244进行简单输入扩展,P08031 ALE RD,74LS373,2716,74LS244CE1 CE2,外设,详细,说明:2716 是扩展ROM本系统没有RAM74LS244缓冲器没有地址,可以和 RAM统一编址,要读设备时,地址随便一个数据就可以,使用指令 MOVX A, DPTR ; MOVX指令就会使RD有效;DPTR可以为任意值。本题很特殊,只有一个外部设备,P08031 ALE RD,74LS373,2764,74LS32,74LS32,74LS32,74LS32,74LS32,Y CE244A,Y CE244A,Y CE244A,Y CE244A,Y CE244A,P2.3,P2.4,P2.5,P2.6,P2.7,P2.0P2.4,74LS32: 或门58=40,5个缓冲器244 ,就需要通过线选法P2.7位为0 选中最后一个244,地址:0111,1xxx,xxxx,xxxx可以xxx取0,地址7800H,详细,详细,5-3-2简单输出的扩展主要功能:数据保持(锁存)典型芯片具有使能控制的8D锁存器8D1D: 8位数据输入8Q1Q: 8位数据输出CK:时钟信号,上升沿数据锁存G:使能信号,G Vcc1Q 8Q1D 8D2D 7D2Q 7Q3Q 6Q3D 6D4D 5D4Q 5QGND CK,74LS377锁存器,74LS377真值表,D QCK G,G,详细,小结:锁存器和缓冲器的特点及使用 1组成锁存器单元电路:触发器(带时钟控制端触发器)有记忆 2组成缓冲器单元电路:门电路(三态传输电路)没有记忆,Q0 Q7CP 锁存器 GD0 D7,D0 D7 CE 缓冲器 A0 A7,DBUS,DBUS,详细,5-3用串行口扩展并行口,RxD TxD P1.0,DATA CD4094CLK STB,DATA CD4014CLK P/S,RxD TxD P1.0,输出,输入,详细,说明:用单片机自身带的串行口来扩展并行口4094是一个移位寄存器,串行输入并行输出。通过TxD发送脉冲,把RxD的数据由CPU的SBUF一位一位移到4094;当p1.0有效,8位同时输出。4014是一个移位寄存器,并行输入串行输出。通过TxD发送脉冲,把4094 的8位数据一位一位移到RxD的 SBUF ;当p1.0有效,8位同时输入。,详细,6.1 可编程并行I/O接口8255A,详细,可编程I/O扩展:还具有状态寄存和命令寄存功能,通过软件编程方式,确定扩展芯片的工作方式。典型芯片:8255 ,8155,简单I/O扩展:实现数据缓冲和数据锁存,8255A可编程并行输入/输出接口芯片是Intel公司生产的标准外围接口电路。它采用NMOS工艺制造,用单一5V电源供电,具有40条引脚,采用双列直插式封装。它有A、B、C3个端口共24条I/O线,可以通过编程的方法来设定端口的各种I/O功能。由于它功能强,又能方便地与各种微机系统相接,而且在连接外部设备时,通常不需要再附加外部电路,所以得到了广泛的应用。,6.1.1 8255A的内部结构与引脚 1. 8255A的接口电路(图6-2) 数据端口A、B、C,8255A有3个8位数据端口,即端口A、端口B和端口C。编程人员可以通过软件将它们分别作为输入端口或输出端口,不过这3个端口在不同的工作方式下有不同的功能及特点。PA,PB口是单纯数据(输入输出)PC口既可做数据口,也可做控制口,用于控制PA,PBI/O有无条件输入输出,也有有条件输入输出,详细,图62 8255A的芯片引脚图,假如有条件 ,由PC口来输入条件PC7PC4控制PAPC3PC0控制PBA组: 由 控制电路控制端口A和端口C的上半部(PC7PC4)。B组: 由控制电路控制端口B和端口C的下半部(PC3PC0),详细,2. 8255A的芯片引脚 8255A是一种有40个引脚的双列直插式标准芯片,其引脚排列如图62所示。除电源(5V)和地址以外,其它信号可以分为两组: (1)与外设相连接的有: PA7PA0:A口数据线 PB7PB0:B口数据线 PC7PC0:C口数据线,详细,(2)总线接口电路: D7D0:8255A的数据线,和系统数据总线相连。数据总线缓冲器,8位双向三态缓冲器,所有数据(包括控制字,状态信息)通过该缓冲器传送。 RESET:复位信号,高电平有效。当RESET有效时,所有内部寄存器都被清除,同时,3个数据端口被自动设为输入方式。和 CPU上的RESET相连。,:片选信号,低电平有效。只有当 有效时,芯片才被选中,允许8255A与CPU交换信息。 :读信号,低电平有效。当 有效时,CPU可以从8255A中读取输入数据。,:写信号,低电平有效。当 有效时,CPU可以往8255A中写入控制字或数据。 A1、A0:端口选择信号。8255A内部有3个数据端口和1个控制端口,当A1A0=00时选中端口A;A1A0=01时选中端口B;A1A0=10时选中端口C;A1A0=11时选中控制口。 A1、A0和 、 及 组合所实现的各种功能如表6-2所示。,详细,表62 8255A端口选择表,详细,6.1.2 8255A的工作方式 8255A有3种工作方式,即方式0、方式1和方式2,这些工作方式可用软件编程来指定。方式0是无条件,方式1,方式2是有条件,详细,1.方式0(基本输入/输出方式;属于无条件数据传输) 这种工作方式不需要任何选通信号,A口、B口及C口的高4位和低4位都可以设定为输入或输出。输入输出任意组合(写控制字时来决定),适用于无条件数据传送。 也可以对C口进行位操作,以C口某一位状态实现查询方式数据传送。,详细,2.方式1(选通输入/输出方式) 方式1下,A口可由编程设定为输入口或输出口,C口的3位用来作为输入/输出操作的控制和同步信号; B口同样可由编程设定为输入口或输出口,C口的另3位用来作为输入/输出操作的控制和同步信号。在方式1下,A口和B口的输入数据或输出数据都能被锁存。 1)方式1下A口、B口均为输入 在方式1下,A口和B口均工作在输入状态时,需利用C口的6条线作为控制和状态信号线,其定义如图64(a)所示。,图64 方式1下的信号定义(a)A口、B口均为输入时;(b)A口、B口均为输出时,详细,C口所提供的用于输入的联络信号有: (Strobe):选通脉冲信号(输入),低电平有效。当外设送来 信号时,输入的数据被装入8255A的输入锁存器中。 IBF(InputBufferFull):输入缓冲器满信号(输出),高电平有效。此信号有效时,表示已有一个有效的外设数据锁存于8255A的口锁存器中,尚未被CPU取走,暂不能向接口输入数据,它是一个状态信号。,详细,INTR(InterruptRequest):中断请求信号(输出),高电平有效。当IBF为高、 信号由低变高(后沿)时,该信号有效,向CPU发出中断请求。 方式1 数据输入过程如下: 当外设的数据准备好后,发出 信号,输入的数据被装入锁存器中,然后IBF信号有效(变为高电平)。 INTR(InterruptRequest)有效,向CPU发出中断请求,要求CPU取走数据。,详细,2) 方式1下A口、B口均为输出 与输入时一样,要利用C口的6根信号线,其定义如图64(b)所示。用于输出的联络信号有: (1) (Acknowledge):外设响应信号(输入),低电平有效。当外设取走数据后,并处理完后,向单片机发回信号。 (2) (OutputBuffeFull):输出缓冲器满信号(输出),低电平有效。 (3)INTR:中断请求信号(输出),高电平有效。,详细,方式1下数据输出过程如下: 当外设接收并处理完1组数据后,发回 响应信号。 应当指出,当8255A的A口与B口同时为方式1的输入或输出时,需使用C口的6条线,C口剩下的2条线还可以用程序来指定数据的传送方向是输入还是输出,而且也可以对它们实现置位或复位操作。当一个口工作在方式1时,则C口剩下的5条线也可按照上述情况工作。,详细,3. 方式2 8255A只有A口具有这种双向输入输出工作方式, 在这种方式下,A口为8位双向传输口,C口的PC7PC3的5位用来作为输入/输出的同步控制信号。 在这种情况下,B口和PC2PC0只能编程为方式0或方式1工作,而C口剩下的3条线可作为输入或输出线使用或用作B口方式1之下的控制线。,详细,图67 方式2下的信号定义,详细,方式2下 1) 输入操作 当外设向8255A送数据时,选通信号STBA也同时送到,选通信号将数据锁存到8255A的输入锁存器中,从而使输入缓冲器满信号IBFA成为高电平(有效),告诉外设,A口已收到数据。选通信号结束时,使中断请求信号为高,向CPU请求中断。,2)输出操作 ACK:外设响应信号(输入),当外设取走数据并处理完,向单片机发回响应信号。OBF:输出缓冲器满信号(输出),低电平有效。状态信息。输出数据写入8255锁存器,信号有效INTR:中断请求信号,6.1.3 8255A的控制字及初始化 1.8255A的控制字(A1A2=1 1) 8255A为可编程接口芯片,以控制字形式对其工作方式和C口各位的状态进行设置。两种控制字:工作方式控制字和C口置位/复位控制字。 1) 工作方式控制字 工作方式控制字用于确定各口的工作方式及数据传送方向,其格式如图69所示。,详细,图69 8255A控制字格式(a)工作方式控制字; (b)C口置位/复位控制字,对工作方式控制字作如下说明: (1) A口有3种工作方式,而B口只有2种工作方式。 (2)A组包括A口与C口的高4位,B组包括B口与C口的低4位。 (3)在方式1或方式2下,对C口的定义(输入或输出)不影响作为联络线使用的C口各位的功能。 (4)最高位(D7位)为标志位,D7=1为方式控制字。,详细,2) C口置位/复位控制字 利用C口置位/复位控制字可以很方便地使C口8位中的任一位清0或置1,该控制字的格式如图69(b)所示。D7位为该控制字的标志位,D7=0为C口置位/复位控制字。 在使用中,该控制字每次只能对C口中的一位进行置位或复位。应注意的是,作为联络线使用的C口各位是不能采用置位/复位操作来使其置位或复位的。其数值应视现场的具体情况而定。,详细,2. 8255A的初始化编程 8255A初始化的内容就是向控制寄存器写入工作方式控制字或C口置位/复位控制字。 这两个控制字可按同一地址(A1A2=11)写入,且不受先后顺序限制。 由于两个控制字因标志位的状态不同,因此8255A能加以区分。,例如对8255A各口作如下设置:A口方式0输入,B口方式0输出,C口高位部分为输出、低位部分为输入。设控制寄存器的地址为03FFH,则其工作方式控制字可设置为: D0=1:C口低半部输入; D1=0:B口输出; D2=0:B口方式0; D3=0:C口高半部输出; D4=1:A口输入; D6D5=00:A口方式0; D7=1:工作方式字标志。,详细,因此工作方式控制字为10010001B即91H。,初始化程序段为: MOV DPTR,03FFH MOV A,91H MOVX DPTR,A 若要使端口C的D3位置位的控制字为00000111B(即07H),而使D3位复位的控制字为00000110B(即06H)。,详细,例如对8255A各口作如下设置:A口方式0输入,B口方式1输出,PC2 PC0用于 PB方式1的控制;PC4PC7为输出;余下PC3为输入。设8255A地址为5FFCH5FFFH其工作方式控制字可设置为:,A 组 B 组,控 方 式 0 输 输 方 输 输制 入 出 式 出 入字 A口 C口 1 B口 C口位,因此工作方式控制字为10010101B即95H。 初始化程序段为: MOV DPTR,05FFH ;8255控制字地址 MOV A,95H MOVX DPTR,A ;方式字写入,初始化程序段为: MOV DPTR,05FFH ;8255控制字地址 MOV A,0BH MOVX DPTR,A ;方式字写入,例如:PC口用于置位/复位方式 ,PC5置位,6.1.4 8255A与系统的连接 由于8255A是Intel公司专为其主机配套设计制造的标准化外围接口芯片,因此它与MCS-51单片机的连接是比较简单方便的。 一般来说,MCS-51单片机扩展的I/O接口均与片外RAM统一编址。由于单片机系统片外RAM的实际容量一般均不太大,远远达不到64KB的范围,因此I/O接口芯片大多采用部分译码的方法,而用得比较多的则是直接利用地址线的线选法。这种方法虽然要浪费大量的地址号,但译码电路比较简单。图610就是一种较常用的连接实例。,详细,图610 8255A与8031的连接,详细,图610中,P0口为地址/数据复用口。数据通过P0口直接传送,地址的低8位是需通过锁存器74LS373得到的,而地址的高8位则由P2口传送。 现采用线选法,利用高8位地址线的P2.7作为线选信号,直接与8255A的片选端 相连,而A1、A0则与地址的最末2位相连。由图610所示接法,可得到8255A各个端口的地址,如表63所示。,详细,表63 8255A各端口的地址,6.1.5 8255A应用举例 8255A在微机和单片机控制系统中得到了广泛应用,现举两例加以说明。 例1:要求通过8255A的PC5端向外输出1个正脉冲信号,已知8255A的C口和控制口的地址分别为0002H和0003H。 解:若要从PC5端输出1个正脉冲信号,可通过对PC5位的置位和复位控制来实现。由于每送1个控制字,只能对1位作1次置位或复位操作,故产生1个正脉冲要对PC5位先送置位控制字,经过一定的延时后(延时时间视脉宽而定),再送复位控制字即能实现。程序编制如下:,详细,MOV DPTR,0003H ;指向8255A的控制口MOV A,OBH ;对PC5置1MOVX DPTR,ALCALL DELAY ;延时(调用延时子程序)DEC A ;对PC5置0MOVX DPTR,A,详细,不讲 例2:8255A作为连接打印机的接口。 图611是通过8255A连接打印机的接口电路,数据传送采用查询方式。8255A的地址译码采用线选法,将P0.7直接与8255A的 端相连(通过地址锁存器),其口地址A口为7CH,B口为7DH,C口为7EH,命令口为7FH。,详细,图611 8255A连接打印机的接口电路,详细,现要求编制打印50个字符的程序,该数据存于片内RAM从20H开始的50个连续单元中。 程序如下: MOV R0,7FH ;指向8255A的命令口 MOV A,88H ;取方式字:A口输出,C口低出高入 MOVX R0,A ;送入方式字 MOV R1,20H ;R1指向数据区首址 MOV R2,32H ;送数据块长度LP: MOV R0,7EH ;指向C口,不讲,LOOP1:MOVX A,R0 ;读入C口信息 JB A.7,LOOP1 ;若BUSY=1,继续查询 MOV R0,7CH ;指向A口 MOV A,R1 ;取RAM数据 MOVX R0,A ;数据输出到A口 INC R1 ;数据指针加1 MOV R0,7FH ;指向命令口 MOV A,00H ;C口置位/复位命令字(PC0=0) MOVX R0,A ;产生STBTX-的下降沿 MOV A,01H ;改变C口置位/复位命令字(PC0=1) MOVX R0,A ;产生STBTX-的上升沿 DJNZ R2,LP ;未完,则反复,详细,6.2 可编程RAM/IO/CTC接口8155,6.2.1 8155的结构与引脚 1. 8155的内部结构 8155的内部结构如图612(b)所示。它含有1个256字节的RAM、1个14位定时/计数器以及3个并行I/O口,其中A口、B口均为8位,C口为6位。A口、B口既可作为基本I/O口,也可作为选通I/O口;C口除可作为基本I/O口外,还可用作A口、B口的应答控制联络信号线。此外,8155内部还有一个控制寄存器组,用来存放控制命令字。,详细,图612 8155引脚排列及结构框图 (a)引脚排列; (b)内部结构框图,详细,图612 8155引脚排列及结构框图 (a)引脚排列; (b)内部结构框图,详细,2. 8155的引脚 8155为40引脚双列直插式封装芯片,其引脚排列如图612(a)所示。现将其各引脚的功能简介如下: AD0AD7:地址/数据复用线。 它与8031单片机的P0口直接相连。8155和CPU之间的地址、数据、命令及状态信号都通过这组信号线传送。 :片选信号,输入,低电平有效。 :RAM和I/O口选择线。当 =1时,选中I/O口;当 =0时,选中RAM。,详细,ALE:地址锁存信号。 :读选通信号,输入,低电平有效。 :写选通信号,输入,低电平有效。 TIMERIN:定时器输入。它是8155片内定时器的脉冲信号输入端。 TIMEROUT:定时器输出。通过它可以输出矩形波或脉冲波。 PA0PA7:A口通用的输入/输出线。由编程来决定是输入还是输出。 PB0PB7:B口通用的输入/输出线。由编程来决定是输入还是输出。 PC0PC5:C口的输入/输出或控制信号线。,详细,6.2.2 8155的RAM和I/O口的编址 与其它接口芯片一样,8155芯片中的RAM和I/O口均占用单片机系统片外RAM的地址,其中高8位地址由 和IO/ 信号决定。当 =0,且IO/ =0时,低8位的00HFFH为RAM的有效地址;当 =0,且 IO/ =1时,由低8位地址中的末3位(A2A1A0)来决定各个口的地址,如表64所示。,详细,表64 8155端口地址表,详细,对于多数单片机应用系统来说,由于片外RAM区的容量较大(最大为64KB),因此通常采用线选法对接口芯片进行编址。对8155来说,常用高8位地址中的两位来选择 和IO/ 。例如将P2.7接至 ,将P2.0接至IO/ ,那么8155的RAM和I/O口的编址为:,详细,RAM:P2.7=0,P2.0=0,其地址范围为: 01111110 00000000B01111110 11111111B, 即:7E00H7EFFH。 I/O口:P2.7=0,P2.0=1,口地址范围为: 01111111 00000000B01111111 00000101B,即7F00H7F05H。,详细,具体分配如下:命令口:7F00HA口:7F01HB口:7F02HC口:7F03H定时器低8位:7F04H定时器高8位:7F05H,详细,6.2.3 8155I/O口的工作方式 8155有3个I/O口,即A口、B口和C口,其中C口只有6位。A口和B口均可工作于基本I/O方式或选通I/O方式。C口既可作为I/O口线,工作于基本I/O方式,也可作为A口、B口选通工作时的状态联络控制信号线。 1.基本I/O 基本I/O为无条件传送,这是最简单的I/O操作,不需要任何联络信号,随时可以进行。 2.选通I/O 选通I/O为条件传送,传送的方式可用查询方式,也可用中断方式。,详细,(1)BF:I/O缓冲器满空标志,输出,高电平有效。 (2) :选通信号,输入,低电平有效。 (3)INTR:中断请求信号,输出,高电平有效。 以上这些信号线对A口与B口均适用,分别称之为ABF、A 、AINTR与BBF、 、BINTR。它们都是由C口提供的,如表65所示。,详细,6.2.4 8155的命令/状态字 8155有1个命令/状态寄存器,实际上这是两个不同的寄存器,分别存放命令字和状态字。由于对命令寄存器只能进行写操作,而对状态寄存器只能进行读操作,因此把它们编为同一个地址,合在一起称之为命令/状态寄存器。 1.命令字 命令字共8位,用于定义I/O端口及定时器的工作方式。对命令寄存器只能写入不能读出(读出的将是状态寄存器的内容)。 命令字的格式如图613所示。,详细,图613 8155的命令字格式,详细,对C口工作方式的说明: D3D2=00(ALT1):A口、B口为基本I/O,C口为输入。 D3D2=01(ALT2):A口、B口为基本I/O,C口为输出。 D3D2=10(ALT3):A口选通I/O,B口基本I/O,C口低3位为联络信号,高3位输出(参阅表65)。 D3D2=11(ALT4):A口、B口均为选通I/O,C口低3位作为A口联络信号,高3位作为B口联络信号(参阅表65)。,详细,C口有4种方式:方式1:A,B基本输入输出方式,C 是输入方式方式2: A,B基本输入输出方式,C是输出方式方式3:作为A口控制输入输出方式方式4:作为A口和B 口控制输入输出方式,表65 8155的PC口线联络信号定义,详细,2.状态字 8155的状态寄存器与命令寄存器共用1个地址,当使用读操作时,读入的便是状态寄存器中的内容。其格式如图614所示。,详细,图614 8155的状态字格式,详细,6.2.5 8155的定时/计数器 8155的定时/计数器是1个14位的减法计数器,由两个8位寄存器构成,其格式如下:,D7,D0,详细,AD2AD1AD0=101 高8位M2 M1 输出方式,AD2AD1AD0=100 低8位,定时器的工作状态由命令字D7D6(TM2,TM1)确定,当TM2、TM1=00时,不影响计数器工作(原来怎末工作还怎末工作)当TM2、TM1=01时,停止计数,如计数器未启动,则无操作;如正在运行,则停止计数。当TM2、TM1=10时,达到计数值(计数器减为0)停止当TM2、TM1=11时,启动计数,如计数器未运行,则在装入计数值后计数;如计数器已运行,则在当前计数值计满后,再以新的计数值进行计数。可以看出,只有TM2、TM1=11,才能真正定时。,详细,8155的定时/计数器与MCS-51单片机芯片内部的定时/计数器在功能上是相同的,都有定时和计数两种功能。但是在使用上却有很多不同之处。具体表现在: (1)8155的定时/计数器为减法计数,而MCS-51单片机内部的定时/计数器却是加法计数。有关初值问题 (2)MCS-51单片机内部的定时/计数器有多种工作方式,而8155的定时/计数器却只有一种固定的工作方式,即14位计数,通过软件方法进行计数值的加载。就是计数到产生中断,在中断服务程序中处理相关的问题。,详细,(3)MCS-51单片机内部的定时/计数器有两种计数脉冲:当定时工作时,由芯片内部按机器周期提供固定频率的计数脉冲;当计数工作时,从芯片外部引入计数脉冲p3.4p3.5。而8155的定时/计数器,不管是定时还是计数,都需要外部提供计数脉冲,如果定时,应该对外部的信号周期应该清楚。 (4)MCS-51单片机内部的定时/计数器,在计数溢出时自动置位TCON寄存器中的计数溢出标志位TF,供用户以查询或中断方式使用; 8155的定时/计数器,在计数溢出时却是通过TIMEROUT引脚向外部发出1个脉冲信号。 TIMEROUT信号有多种形式,由M2M1定义,详细,定时/计数器有 2个寄存器,其中低14位组成计数器,剩下的两个高位(M2M1)用于定义
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年橡胶管带行业当前发展趋势与投资机遇洞察报告
- 涉县2025届中考数学模拟试题含解析
- 2025年心理咨询师之心理咨询师基础知识考试题库(含答案)
- 2025年街道办事处应急演练工作方案及应急演练脚本
- 2025成人高考高升专试题(含答案)
- 2024年旅游团:导游基础及相关法律法规知识试题与答案
- 山东省枣庄市山亭区2024-2025学年七年级下学期期末考试语文试题
- 摄影测量基础知识培训课件
- 摄影基本知识培训课件
- 森林调查技术试题及答案
- 网络安全产品代理销售合同
- 广播工程系统施工方案
- 校园超市经营投标方案
- 带状疱疹护理查房
- 教育机构综合部的岗位职责
- VR体验馆商业计划书
- 房地产销售经理转正述职报告
- 2024年山东省省属事业单位招聘综合类岗位人员笔试真题
- 2025年广东省广州市天河区建设工程项目代建局招聘10人历年高频重点提升(共500题)附带答案详解
- 现场安全生产培训
- 机械公司生态环保C级申报资料
评论
0/150
提交评论