- 1、本文档共45页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8章 80C51串行扩展技术 本章要点 §8-1 串行扩展概述 一、串行扩展特点 1、一线制 三线制(不包括片选线)主要有两种: ⑴ 由Motorala公司推出的SPI(Serial peripheral Interface); ⑵ 由NS公司推出的Micro wire /PLUS。 1、80C51扩展并行输出口 2、80C51扩展并行输入口 80C51串行方式0归一化子程序: ⑴ 单字节串行输出子程序 ⑵ 单字节串行输入子程序 ⑶ 多字节串行输出子程序 ⑷ 多字节串行输入子程序 80C51虚拟串行I/O口归一化子程序: ⑴ 单字节虚拟串行输出子程序 ⑵ 单字节虚拟串行输入子程序 ⑶ 多字节虚拟串行输出子程序 ⑷ 多字节虚拟串行输入子程序 解: PIOX1 BIT P1.0 ;定义PIOX1 WORK: MOV A, ;置D7灯亮,其余暗 LOOP: CLR PIOX1 ;74LS164输出全0,灯全暗 LCALL UART0 ;调用单字节串行输出子程序 LCALL DLY1s ;调用延时1秒子程序(略) RR A ;右移 SJMP LOOP ; 1、扩展连接方式 2、器件寻址方式 I2C总线器件地址SLA格式如下: 表8-1 常用I2C器件地址SLA 3、接口电气结构 I2C总线端口输出为开漏结构,总线上必须外接上拉电阻Rp,其阻值通常可选5~10KΩ。 4、总线驱动能力 由于I2C总线器件均为CMOS器件,总线具有足够的电流驱动能力。 I2C总线的电容负载能力为400 pF(通过驱动扩展可达4000pF)。 I2C总线传输速率为100Kb/s(改进后的规范为400 Kb/s)。 5、I2C总线时序 80C51只能采用虚拟I2C总线方式,并且只能用于单主系统,虚拟I2C总线接口可用通用I/O口中任一端线充任,数据线定义为VSDA,时钟线定义为VSCL。 WRNB: MOV R3,NUMB ;取发送数据字节数N(存在内RAM NUMB单元) WRNB0:LCALL STAT ;启动I2C总线 MOV A,SLA ;读发送寻址字节(存在内RAM SLA单元) LCALL WR1B ;发送寻址字节 LCALL CACK ;检查应答位 JB F0,WRNB0;应答不正常,返回重发 MOV R1,#MTD ;应答(A)正常,取发送数据存储区首址 WRDA: MOV A,@R1 ;读一个字节发送数据 LCALL WR1B ;发送一个字节 LCALL CACK ;检查应答位 JB F0,WRNB ;应答不正常,返回重发 INC R1 ;应答(A)正常,指向发送数据下一字节 DJNZ R3,WRDA ;判N个数据发送完毕否?未完继续 LCALL STOP ;N个数据发送完毕,发送结束信号 RET ; 入口条件: ① 伪指令定义NUMB、SLA、MRD地址; ② 接收数据字节数存内RAM NUMB单元; ③ 接收寻址字节存内RAM SLA单元。 出口状态:接收N个字节依次存在首址MRD的内RAM中。 占用资源:Acc、R1、R2、R3、Cy、F0。 RDNB: MOV R3,NUMB ;取接收数据字节数N(存在内RAM NUMB单元) RDNB0: LCALL STAT ;启动I2C总线 MOV A,SLA ;读接收寻址字节(存在内RAM SLA单元) LCALL WR1B ;发送接收寻址字节 LCALL CACK ;检查应答位 JB F0,RDNB0 ;应答不正常,返回重新开始 RDA0: MOV R1,#MRD ;应答(A)正常,取接收数据存储区首址 RDA1: LCALL RD1B ;接收一个字节数据 MOV @R1,A ;存一个字节数据 DJNZ R3,ACK ;判N个数据接收完毕否?未完
文档评论(0)