前面一篇文章总结了一下工业HART总线,今天来聊聊RS-485总线。RS-485也是应用非常广泛的一种通信接口,本文来讨论一下要点,文章稍微有点长,约5000字。
前世今生
RS-485,RS是什么意思呢?是Recommended Standard的缩写,就是推荐标准的意思。485是标准标识号,至于为什么定这个标识号,则无需深究。RS-485又称为ANSI/TIA/EIA-485,这几个前缀是标准协会的名称缩写,比如EIA就是电子工业协会 (Electronics Industries Association EIA)的缩写。1983年,RS-485通讯接口被电子工业协会 (Electronics Industries Association EIA)批准为一种通讯接口标准。即便在现在IOT火热的今天,RS-485仍然有大量的应用。很多协议使用RS-485作为物理层,比如常用标准协议使用RS-485作为物理层的有哪些呢?比如:- 工业HART总线
- modbus协议
- Profibus DP
- .......
电气特性
信号采样差模传输,差模是相对于共模而言的,差模也称为差分,那么什么样的传输是差模呢?一图胜千言,看下面两个图就明白了:共模传输
差模传输
对于这个干扰,我们来实际抓个波形看看:

电气参数
RS-485的电气参数为:- 共模电压范围为-7~+12V
- 可支持32个多点拓扑连接,见下面的网络拓扑图
- 使用40英尺线缆时,传输速率可达10Mbps,1英尺相当于30.48cm,这里Mbps是兆bit/s的意思
- 使用4000英尺线缆时,传输速率可达到100kbps
- 半双工通信
- 最小差分电压容限:200mV,也就是说接收端在差分电压低于200mV时就无法正确识别0/1了。这句话应该怎么理解呢?

上面这个图怎么理解呢?RS-485收发器的发送电路至少提供1.5V差分电压输出能力,经由总线线路阻抗衰减,32个接收电路输入阻抗,以及120Ω端接电阻,差分信号的幅度必然逐渐衰减,那么至最末端还需要至少提供200mV的差分电压给末端接收电路。
:对于接收电路是判决A线共模电压与B线共模电压之差:
- 如果 ,则接收电路R识别为逻辑 1
- 如果 ,则接收电路R识别为逻辑0

- RS-485通信从单片机/DSP/处理器接口而言,是利用UART接口与RS-485收发器接口。当然你说我用FPGA难道不行么?肯定是可以的,用FPGA实现一个串口收发的IP模块,当然也是可以的。甚至你想说,我拿GPIO去模拟一下 UART 是不是就不行?也是能办得到的,只不过这么干意义不大,需要占用CPU资源实现底层BIT的收发。
- 前面说到半双工,有半双工就有全双工。什么是半双工呢?首先半双工以及全双工,所界定的对象一定是点对点而言的,这里说点对点就是指在同一时刻而言,所谓半双工,就是设备在同一时刻要么处于收数据状态, 要么处于发数据状态, 不允许同时收发数据。 全双工则刚好相反,允许同时收发。比如 I2C 总线就是半双工总线,4线制 SPI 是全双工,而三线制SPI则是半双工总线;又譬如RS-422或者RS-232 是全双工接口;而CAN总线则是半双工总线。RS-485就是一种半双工总线:

- 当Host发送数据时,数据沿着红色的线经由双绞线,传输至Slave的差分接收电路,当slave应答时,数据沿着兰色的方向传输至Host的接收电路,但是传输介质是一对双绞线,所以一方在传输数据的时候,另一方是无法传输信号的,从收发器的控制角度来看:控制芯片侧,用一个GPIO脚来控制收发使能,来一张芯片内部原理框图,就很容易理解了:

- 当DIR=0时,接收电路使能,发送电路禁止DE=0,对总线而言相当于高阻;当 DIR=1 时,接收电路使能 ,发送电路禁止DE=1,对总线A/B信号取决于DI的信号。这里有两个问题:1.为什么芯片要把和设计成相反的有效逻辑呢?这样其实也是方便用一个GPIO同时控制收发电路的考虑。2.那收发器芯片收发使能为什么不做成一个脚呢?比如就叫DIR?做成两个脚收/发也可以用两个脚单独控制,比如:
- 甚至可以在DE=1的时候,将设置为0,这样是不是就可以自环了?产品中也可以就这样设计,可以实现收发器以及布线的自诊断,通过接收到的报文与发送出去的报文比较,可以诊断出芯片焊接,收发器是否损坏或者断路,以及布线是否存在短路故障。或许你会说,瞎扯!你前面才说RS-485不能同时收发,这里又说能同时收发,岂不是自相矛盾吗?不矛盾,前面所说的不能同时收发,是指发的同时不能收来自其他设备的发送报文,这里收的是自身发出的报文。所以半双工的本质,是通讯介质不存在双向通道,在向总线发送数据的时候,介质被占用,即便想发送也是无法正确的将信号发送到介质上的,如果强行发送,数据将会错乱,甚至收发器芯片有可能损坏。
- : Receiver Output Enable,接收器使能,
- DE:Driver Output Enable,驱动输出使能
- 图中的DIR脚就是控制当前RS-485是处于“收”还是处于“发”模式。

如果想看差分信号,就可以利用双通道示波器加MATH减功能观测。或许有的示波器没有MATH功能,那么这里还可以使用一个技巧:

- 信号A在空闲时候为高电平;信号B在空闲时为低电平。所以你会看到有设备上会标识485_A+,485_B-。
- 每个通道的共模电压值都在标准要求的-7~12V之内,信号A为4V,信号B为5V:

这里抓的数据是一个MODBUS-RTU主端发送给从设备的报文,其内容前面两个字节是0x01 0x03,UART模式为1个起始位,8个数据位,1个停止位,无校验位,低位在前,此例中UART的通讯格式为


对于解析这种异步串行时序波形而言,最重要就是根据通信格式计算位时间,字节时间,进而可以直接解析波形数据。从这一点思考,假设要利用FPGA来实现一个UART协议逻辑分析仪,这就是最为核心的指标,通过检测到起始位边沿,进而通过时间轴将数据解析出来。这里我来充当一个肉眼UART逻辑分析仪吧:

驱动能力
电气参数里总结说RS-485最大电气驱动能力,在多点网络拓扑结构下,可最大驱动32个站点。那么怎么去解读这一指标呢?首先来考察一个站点收发电路特性,收发器的接收电路其标准等效输入阻抗为12kΩ,比如MAX 485数据手册为例:

数据监控
比如一个基于RS-485的Modbus-RTU多点网络中,在做协议编程或者实际多站点总线调试的时候,有可能需要监控总线上所有的报文。甚至还有可能就像实现一个总线报文的的记录器,将总线上所有的报文都记录下来。应该怎么实现呢?买一根USB转RS-485的转换线或者自己做一个也可以。将A/B线并接在总线上,USB 插入电脑。使用串口监控终端或者自己写一个串口接收小软件,就可以监控所有总线上的报文了。比如这个AccessPort串口工具就比较好用:
应用设计
作为应用设计而言,需要考虑这些维度:- 端接设计
- 接口芯片
- 隔离设计
端接设计
首先为什么要端接?这是由于RS-485采用双绞线传输,标准规定的双绞线的差分特征阻抗在100Ω至150Ω之间。RS-485标准制定者选择120Ω作为标称特征阻抗。

在TI的资料上看到这样一个端接接法:

接口设计
RS-485收发器芯片很多芯片公司都提供,比如TI,Microchip 等厂家都有,选择接口芯片的时候需要考虑,芯片的供电电压输入逻辑是否与使用的单片机/DSP的电平兼容,另外就是前面提到的其接收电路的阻抗是否是符合RS-485标准输入阻抗的。如果不是的,那么在考虑网络部署的时候,所能带的负载数量就有可能需要做调整。另外注意一下,有的新设计RS-485收发器具备fail-safe功能。另外,前面说到标准收发器可以驱动32个标准收发器负载设备,也即是(12kΩ)标准单位输入阻抗。在做具体接口电路设计的时候还需要考虑EMC要求,在一些设备现场真的有很强的干扰,比如电网上有大的电机等感性设备运行,有时候就会干扰设备;另外也有可能有空间辐射干扰,这时候可以考虑采用带屏蔽双绞线,屏蔽层接大地,抗干扰方面我了解的不是很深入,仅整理一下。在这里看到一个防雷接口电路的设计方案,可以参考一下:
隔离设计
为什么要隔离,是为了降低接地噪声。在很多现场可能有大电流开关设备,电机感性设备等,噪声很有可能通过通讯的接地耦合进设备。尤其在工业设备中,一般都会设计成带隔离的接口电路。要设计隔离接口,可以考虑选择具有隔离功能的芯片,比如ADI的 iCoupler技术产品ADM2481,ADM2485。当然也可以采用光耦+普通RS-485收发器的方式。唯一需要注意的是需要设计一个带隔离的电源,给隔离两侧电路分别供电。
总结一下
RS-485看似简单,实际应用设计的时候还是有很多需要去理解和注意的地方。做一个稳健的产品,往往所差不是大方向,而是一些细微处容易导致产品不稳定。推荐关注????下方公众号学习更多电子技术知识!
