max485全双工原理图_MAX485典型电路

本文详细介绍了MAX485全双工串行接口的工作原理及其在RS485总线扩展中的应用。内容包括MAX485的管脚功能、典型工作电路以及与89C51单片机的接口电路。此外,还探讨了IIC总线扩展,包括IIC总线的基本原理、操作流程、数据传输子程序以及与串行I2C总线EEPROM如AT24CXX的接口应用。最后,文章提到了SPI总线扩展,展示了如何使用软件模拟SPI总线以及TLC5615和AD549的串行D/A和A/D转换器的接口和应用。
摘要由CSDN通过智能技术生成

《MAX485典型电路》由会员分享,可在线阅读,更多相关《MAX485典型电路(60页珍藏版)》请在人人文库网上搜索。

1、第9章 串行接口技术,单片机原理、接口及应用,内 容 提 要, RS-485总线扩展 IIC总线扩展接口及应用 SPI总线扩展接口及应用,9.1 RS485总线扩展,RS485标准接口是单片机系统种常用的一种串行总线之一。与RS232C比较,其性能有许多改进,细节请见表9.1所示。 表9.1 RS232C与RS485性能比较,RS485接口可连接成半双工和全双工两种通信方式。常见的半双工通信芯片有MAX481、MAX483、MAX485、MAX487等,全双工通信芯片有MAX488、MAX489、MAX490、MAX491等。,下面以MAX485为例来介绍RS485串行接口的应用。MAX485。

2、的封装有DIP、SO和uMAX三种,其中DIP封装的管脚如图9.1所示。 管脚的功能如下:RO:接收器输出端。若A比B大200mV,RO为高;反之为低电平。RE:接收器输出使能端。RE为低时,RO有效;为高时,RO呈高阻状态。DE:驱动器输出使能端。若DE1,驱动器输出A和B有效;若DE0,则它们呈高阻态。若驱动器输出有效,器件作为线驱动器用,反之作为线接收器用。DI:驱动器输入端。DI0,有A0,B1;当DI1,则A1,B0。GND:接地。A:同相接收器输入和同相驱动器输出。B:反相接收器输入和反相驱动器输出。VCC:电源端,一般接+5V。,图9.1 MAX485芯片的DIP封装管脚图,MA。

3、X485典型的工作电路如图9.2所示,其中平衡电阻Rp通常取100300欧姆。MAX485的收发功能见表9.3。,表9.3 MAX485的收发功能,89C51与MAX485的接口电路如图9.4所示。P1.7用来控制MAX485的接收或发送,其余操作同串口 。,9.2 I2C总线扩展接口及应用,9.2.1 原理 I2C(IIC)总线是Philip公司推出的芯片间串行传输总线。它用两根线实现了完善的全双工同步数据传送,可以极为方便地构成多机系统和外围器件扩展系统。IIC总线采用了器件地址的硬件设置方法,通过软件寻址完全避免了器件的片选线寻址方法,从而使硬件系统具有简单灵活的扩展方法。按照IIC总线。

4、规范,总线传输中的所有状态都生成相对应的状态码,系统中的主机能够依照这些状态码自动地进行总线管理,用户只要在程序中装入这些标准处理模块,根据数据操作要求完成IIC总线的初始化,启动IIC总线就能自动完成规定的数据传送操作。,IIC总线接口为开漏或开集电极输出,需加上拉电阻。系统中所有的单片机、外围器件都将数据线SDA和时钟线SCL的同名端相连在一起,总线上的所有节点都由器件和管脚给定地址。系统中可以直接连接具有IIC总线接口的单片机,也可以通过总线扩展芯片或I/O口的软件仿真与IIC总线相连。在IIC总线上可以挂接各种类型的外围器件,如RAM/EEPROM、日历/时钟、A/D、D/A、以及由I。

5、/O口、显示驱动器构成的各种模块。,9.2.2 软件IIC总线 假设单片机所用晶体振荡器的频率为6MHz。用P1.7和P1.6分别模拟SDA和SCL,定义如下: SDAEQUP1.7 SCLEQUP1.6 (1)产生起始位和停止位 如果单片机则每个机器周期为2us,我们可分别写出产生时钟SCL和SDA的发送起始条件和停止条件两段子程序如下。若晶振频率并非 6MHz,则要相应增删各程序段中NOP指令的条数,以满足时序的要求。例如,若fosc=12MHz ,则两条NOP指令应增至4条。,发送起始条件START STA: SETB SDA SETB SCL NOP NOP CLR SDA NOP N。

6、OP CLR SCL RET,发送停止条件STOP STOP:CLR SDA SETB SCL NOP NOP SETB SDA NOP NOP CLR SCL RET,(2)发送应答位和非应答位子程序 IIC总线上的第9个时钟对应于应答位,相应数据线上“0”为“ACK”和“1”为“”。发送应答位和非应答位的子程序分别如下。,发送应答位ACK MACK: CLR SDA SETB SCL NOP NOP CLR SCL SETB SDA RET,发送非应答位ACK MNACK: SETB SDA SETB SCL NOP NOP CLR SCL CLR SDA RET,(3)应答位检查子程序 。

7、在I2C总线数据传送中,接收器收到发送器传送来的一个字节后,必须向SDA线上返送一个应答位ACK,表明此字节已经收妥。本子程序使单片机产生一个额外的时钟(第九个时钟脉冲,在脉冲的高电平期间读ACK应答位,并将它的状态被复制到F0标志中以供检查。若有正常ACK,则F0标志为0,否则为1。 CACK: SETB SDA ;SDA作输入 SETB SCL ;第9个时钟脉冲开始 NOP MOV C,SDA ;读SDA线 MOV F0,C ;转存入F0中 CLR SCL ;时钟脉冲结束 NOP RET,(4)字节数据发送子程序 由于是SDA接在并行口线,无移位寄存器,因此数据通过指令完成移位再从SDA串。

8、行输出。遵循时序要求,数据在时钟低电平时变化,高电平时稳定,每一个时钟脉冲传送一位,编写字节数据传送子程序。 该子程序的入口条件是待发送的字节位于累加器ACC中。,WRB: MOV R7,#8 ;位计数器初值 WLP: RLC A ;欲发送位移入C中 JC WR1 ;此位为1,转WR1 CLR SDA ;此位为0,发送0 SETB SCL ;时钟脉冲变为高电平 NOP ;延时 NOP CLR SCL ;时钟脉冲变为低电平 DJNZ R7,WLP ;未发完8位,转WLP RET ;8位已发完,返回,WR1: SETB SDA ;此位为 1,发送1 SETB SCL ;时钟脉冲变高电 平 NOP 。

9、NOP ;延时 CLR SCL ;时钟脉冲变低电 平 CLR SDA DJNZ R7,WLP RET,(5)字节数据接收子程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值