- 1、本文档共99页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第9章 80C1单片机系统扩展技术
(2) 方式1 选通输入/输出工作方式 三个端口分为A、B两组。A、B口仍作为两个独立的8位I/O数据通道,可单独连接外设,通过编程设置它们为输入或输出,C口则要由六位(分成两个3位)分别作为A口和B口的应答信号线,其余两位分别仍可工作在方式0。 A. 方式1输入 控制联络信号如下页图所示,STB与IBF构成了一对应答联络信号。 * * 方式1输入 * * INTR (Interrupt request) :中断请求信号,高电平有效。 由8255A输出,向单片机发中断请求。 INTEA (Interrupt Enable):A口中断允许,由PC4控制, INTE B:B口中断允许,由PC2控制。 STB (Strobe):选通输入,是由外设送来的输入信号。当其为低时,将外设数据输入8255A。 IBF (Input Buffer Full) :输入缓冲器满,高电平有效。表示数据已送入 8255A的输入锁存器,它由STB信号的下降沿置 位,由RD信号的上升沿使其复位。 * * B. 方式1输出 如下页图所示。OBF与ACK构成了一对应答联络信号,各信号的功能如下: OBF (Output Buffer Full) :输出缓冲器满信号,8255A给外设的联络信号,外设可以将数据取走。 ACK (Acknowledge) :外设的响应信号,外设已将数据取走。 INTR:中断请求信号。表示该数据已被外设取走,请求单片机继续输出下一个数据。 INTE A:中断允许,由PC6控制。 INTE B:中断允许,由PC2控制。 * * 方式1输出 * * C. 方式2 只有A口才能设定为方式2。方式2工作示意图如下页所示。 在方式2下,PA7~PA0为双向I/O总线。 当输入时,PA7~PA0受STBA和IBFA控制,其工作过程和方式1输入时相同; 当输出时,PA7~PA0受OBFA、ACKA控制,其工作过程和方式1输出时相同。 * * 方 式 2 * * 5. 8255A的控制字和初始化编程 8255A芯片的初始化编程是通过对控制口写入控制字的方式实现的。 控制字有两个,一是方式控制字,另一个是C口按位置位/复位控制字,用D7位来区分,故D7位称为特征位。 方式控制字用于设置8255A芯片三个端口的工作方式以及输入输出状态,用D7位为1来标识。 图9-19 8255A的方式控制字 例如,设定A口为方式1输入,B口为方式0输出,PC7~PC4为输入,PC3~PC0为输出的方式控制字为:。 * * C口的按位置位/复位控制字用于对C口的某一位进行置位或复位,用D7位为1来标识,如图9-20所示。 图9-20 8255A的C口按位置位/复位控制字 C口具有位操作能力,每一位都可以通过向控制口写入置位/复位控制字设置为1或0而不影响其他位的状态。 例如PC5置1的置位控制字为: 注意:将C口的某位置位或复位时,置位/复位控制字一定要写入控制口,即所写入的地址应为控制口的地址而不是C口的地址,这一点常被疏忽。 * * 例9-5 电路连接如图9-18,对8255A芯片进行初始化,要求A口工作在方式0输入,B口为方式1输出,C口高4位PC4~PC7为输入,C口低4位PC3~PC0为输出。编写实现上述功能的初始化程序段。 解:首先根据CS、A1和A0的接线计算8255A控制口的地址,当CS=0;A1=1;A0=1时选择控制口,即P2.7=1,P2.6=1,P2.5=1,P0.1=1,P0.0=1,P2口和P0口的其他各位都为0,则控制口的地址为1110 0000 0000 0011B=E003H。 * * 方式控制字为=0x9C。 初始化程序如下: #includereg52.h #includeabsacc.h #define COM8255 XBYTE[0xe003] #define uchar unsigned char Void init8255(void) { COM8255=0x9C; } * * 例9-6 电路连接如图9-18,编写程序将C口的PC3置0,PC5置1。 解:控制口的地址计算和例9-5一样,为1110 0000 0000 0011B=E003H。 PC3复位的控制字为:0000 0110B=0x06。 PC5置位的控制字为:0000 1011B=0x0B。 初始化程序如下: #includereg51.h #includeabsacc.h #define COM8255 XBYTE[0xe003] #define uchar unsigned cha
您可能关注的文档
最近下载
- 卫健系统党课讲稿:掌握科学方法提升党风廉政建设质效.docx VIP
- 酒业公司业务员培训方案.ppt
- 第四章python基础教学设计-高中信息技术必修1数据与计算课件教学设计.pdf VIP
- 《人类面临的主要环境问题》精品课件.ppt VIP
- GB_T8110-2020熔化极气体保护电弧焊用非合金钢及细晶粒钢实心焊丝.pdf
- 怎样培养一年级学生的数学审题能力PPT22页.ppt
- 党课讲稿:夯实基础 把握重点 切实提升基层党组织建设质效.docx VIP
- 2025中国海洋石油集团有限公司校园招聘笔试参考题库附带答案详解.doc
- 《非煤岩岩爆倾向性评价规范-第2部分:数值模拟方法与材料模型参数标定》.pdf VIP
- 100以内连加连减打印版-100题.doc
文档评论(0)