- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第9章 MCS-51扩展I/O接口的设计 9.1 I/O接口扩展概述 9.2 MCS-51与可编程并行I/O芯片8255A的接口 9.3 MCS-51单片机与8155H的接口 9.4 用74LSTTL电路扩展并行I/O口 9.5 用MCS-51的串行口扩展并行口 9.1 I/O接口扩展概述 I/O (输入/输出)接口是MCS-51与外设交换数字信息的桥梁。I/O扩展也属于系统扩展的一部分。真正用作I/O口线的只有P1口的8位I/O线和P3口的某些位线。在多数应用系统中,MCS-51单片机都需要外扩I/O接口电路。 表9-1 8255A端口工作状态选择 2.8155H的引脚功能8155H的引脚功能 9.5 I/O接口的扩展 MCS-51单片机共有4个8位并行I/O口, 在外部扩展时, P0和P2口做为总线使用, 因而提供给用户的 I /O口就只有P1或P3口的部分口线所接的外设较多时, 就必须扩展I/O接口。 MCS-51单片机扩展的I/O口和外部数据存储器统一编址、 采用相同的控制信号、 相同的寻址方式和相同的指令。 扩展I/O所用的芯片有通用可编程芯片 ( 如8251, 8155, 8255等)和TTL, CMOS锁存器,缓冲器(如273, 377, 244, 245等),用户可根据系统对输入输出的要求适当选择芯片。 图9-24为8XX51 扩展一个输入接口244 和一个输出接口273 的电路 244的选通信号由RD和P2.0相或产生,当执行读该片的指令时, RD和P2.0有效, 打开244控制门, 从而把数据通过244读入8XX51。 273的选通信号由WR和P2.0相或产生,通过执行对该片的写指令,WR和P2.0有效,使8XX51的数据往273输出。 8XX51内部有ROM/EPROM, 不用扩展外部程序存储器, 所以P0口作为双向数据线连在的数据端。 273、244有相同的地址FEFFH(实际上只要保证P2.0=0,其他地址位无关紧要), 然而由于使用不同的控制信号RD或WR ,它们地址相同却不会发生数据传送冲突。 (1)8255的工作方式 方式0——基本方式 无需查询状态,直接输入或输出。 在此方式下,8255的三个接口(A、B、C口)全部规定为数据的输入或输出口。 三个口输出均有锁存能力,即只要向这些口写入数据,则数据将一直维持到写入新的数据为止。 三个口输出全无锁存能力,即外设的数据要一直加在这些接口上,必须保持到被单片机读走。 方式0下,可以对C口实现按位操作 方式0使用简便,可以实现无条件传送和查询方式传送。 方式1 ——选通输入输出方式 只有A口、B口能在此方式下工作,并利用C口的某些引线(注意不是A、B对分C口资源)作为联络信号线。可以进行查询或中断方式传送数据。 A口、B口均可以作为输入、输出口工作,且输入或输出都具有锁存能力。 方式2—— 双向总线方式 仅A口有,且需要占用C口5根线作为控制线。 (2)8255的控制寄存器 8255的工作方式通过方式控制字选择 1个控制口地址,2个控制字 工作方式控制字, D7=1 C口置位/复位控制字,D7=0 注意:在写C口置位/复位控制字之前必须先写工作方式控制字。 MOV DPTR, #7FFFH ;DPTR指向控制口 MOV A, #82H MOVX @DPTR, A ; 控制字写入控制口 MOV DPTR, #7DFFH ;DPTR指向PB口 MOVX A, @DPTR ;从PB口输入数据 CPL A ;开关合上的对应LED亮 DEC DPL ;DPTR指向PA口 MOVX @DPTR, A ;从PA口输出 SJMP $ 例9-3 进一步分析 回顾:由图可知,P2.7=0方选中该8255,A1 A0(P2.1 P2.0)为00 01对应PA口和PB口、为11时对应控制口。其余地址写1,A口、B口、控制口地址分别为7CFFH、 7DFFH、7FFFH。设定PA口方式0输出, B口方式0输入,控制=82H 此电路特点:只扩展一个芯片,且地址总线只需要三根,因此,将地址总线和数据总线分离,分别用P2和P0口。 改进方案一:占用高位地址 A口、B口、C口、控制口地址分别为FFFCH,FFFDH,FFFEH,FFFFH。 但是地址不唯一,占用8000~7FFFH高
文档评论(0)