其实很早就想写写关于Modbus的开发历程,但牵扯项目较多,不同语言版本较多,头绪繁杂,一时不知从何写起。最近的医疗项目的通信部分,重新调整为Modbus协议,并且内容几乎涵盖了Modbus的方方面面(Rtu/Tcp,Slave/Client相关开发),所以更坚定了写Modbus信心,今天忙里偷闲,以时间为序,以项目为纲,把Modbus相关开发经历一一道来。
一、焦炉四大车通信系统(2002~2005)
<shapetype id="_x0000_t75" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75" coordsize="21600,21600"><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock></shapetype><shape id="_x0000_s1027" style="WIDTH: 356.25pt; HEIGHT: 257.1pt; mso-position-horizontal-relative: char; mso-position-vertical-relative: line" type="#_x0000_t75"><imagedata o:title="456" src="file:///C:%5CWINDOWS%5CTEMP%5Cmsohtml1%5C01%5Cclip_image001.png"></imagedata><wrap type="none"></wrap><anchorlock></anchorlock></shape>
硬件平台:西门子PLC200
操作系统:Win2000/XP
1、 主PLC与PC机的通信
最早主PLC与PC机通信,采用自定义的协议,主PLC中做了一个类似木马的程序来响应PC机下发的读写V变量区的指令。这样就完成了PLC的读写操作。
后来西门子PLC的开发软件进行了升级,提供了Modbus Rtu Slave库,这样只要上位机实现Modbus Rtu Client就可以直接读写PLC变量区了,之后用VB开发了Modbus相应的组件,这样很长一段内,该系统PC与主PLC就采用了Modbus的通信。
前两年开发组态软件,所以西门子PPI协议顺礼成章也就知道了,当然PC与西门子采用PPI协议是最棒的,因为PLC中不需要写一行代码,也无需占用程序和变量空间。所以之后Modbus被放弃了,转而采用了PPI通信协议。
2、 主PLC与从PLC的通信(无线电台通信)
刚开始主PLC与从PLC采用自定义协议,最早在首钢做实验的时候,只有四个从站,并且个数是唯一确定的,所以自定义协议用的很好,效率也很高;但是项目推广后,在其它现场有7个从站的,也有8个,9个的,不确定,并且从站要分组,此外通信传递内容也更多了,不光位置信息、推焦电流、推焦、平煤信号、连锁信号都要传递,最后选择了Modbus协议。
但是使用Modbus有几个问题,第一西门子提供的Modbus Slave不支持广播命令,第二只提供了Modbus Slave程序,从PLC没有什么问题,但是主PLC却没有Modbus Client程序。
对第一个问题,没有办法,不支持就算了,只要一个个来写。(注:后来的某一天,西门子MicroWIN开发环境突然出bug了,竟然看到了部分的西门子Modbus Slave源码,我在此基础上实现了可支持广播的Modbus Slave代码)。
对第二个问题,只好老老实实的用西门子 PLC 语句表命令开发Modbus Client,只要实现3号和16号命令就可以了,还好,Modbus Client本身协议不难,难在PLC的运行机制和PC程序不同,PLC是大循环扫描的,等待数据返回时,不能直接等待,否则运行看门狗会超时,总之克服重重困难,终于开发出稳定可靠的Modbus Client程序,直到现在,现场的PLC通信仍采用该方式。
附记:有人会问,为什么没有采用PPI协议,PLC本身就支持主和从协议啊?但太让人遗憾的是,PPI协议通信节奏太快,目前还没有无线电台(普通工业用)可以正常实现PPI协议通信。
该焦炉四大机车相关介绍,可以参见我以前写的文章:
http://www.gongkong.com/tech/example/detail_1.asp?id=4055
相关专利
http://www.cpsfu.com/C10B/2003/1456635.shtml
我开发的Modbus控件介绍
http://blog.csdn.net/yefanqiu/archive/2005/11/20/533315.aspx
我开发的PPI控件介绍
http://blog.csdn.net/yefanqiu/archive/2005/11/18/532256.aspx
二、AB PLC扩展模块ProSoft MVI56通信模块(2005年11月)
在做济钢四车项目的时候,由于PLC采用的是AB RsLogix5000系列的PLC,上面的端口不支持自由口编程,无法读取我们定位标尺的数据,所以购买了与其合作的ProSoft公司专门生产第三方模块。ProSoft生产的模块有很多种,由于没有经验,很不幸,我们选择的是MVI56的模块,而这个模块却是全部自由编程,不含有任何默认协议。
该模块典型的就是一个嵌入式系统,相当一个带三个串口的386的电脑,操作系统为小型的DOS系统(TINY DOS),用C++为其开发程序。
在开发完我们的红外定位标尺的读取程序后,顺便也开发一个Modbus Rtu Client的程序,这样AB的PLC可以直接和Modbus 的设备进行通信了。
相关文章,请参见我以前写的文章:
http://blog.csdn.net/yefanqiu/archive/<chsdate w:st="on" year="2005" month="11" day="20" islunardate="False" isrocdate="False">2005/11/20</chsdate>/533440.aspx
三、隧道广告影像系统(2004~2006)
<shape id="_x0000_s1026" style="WIDTH: 392.35pt; HEIGHT: 238.55pt; mso-position-horizontal-relative: char; mso-position-vertical-relative: line" type="#_x0000_t75"><font size="3"><imagedata o:title="地铁广告硬件图" src="file:///C:%5CWINDOWS%5CTEMP%5Cmsohtml1%5C01%5Cclip_image003.jpg"></imagedata><wrap type="none"></wrap><anchorlock></anchorlock></font></shape>
隧道广告影像系统的通信系统,采用12个通信子站(NetBoxII),刚开始并没有任何Modbus协议,直到有一天,客户提出要控制节目播放的次序、次数和播放时间,最后决定在地铁隧道里,添加一个西门子PLC200系统,由于设备早已安装完成,不可能为PLC布一个五六百米的通信线路,只好利用原通信线路,而最上层的通信为TCP,NetBoxII下一层才是485总线,所以NetBoxII当仁不让的成了通信桥的设备。
但是,问题来了,上位机PC如何通过TCP与基于485的PLC进行通信?
最后,决定西门子PLC中安装Modbus Rtu Slave程序,实现一个标准Modbus设备,NetBoxII实现 Modbus Tcp到Modbus Rtu的协议转换。也就是说,在NetBoxII中实现Modbus Tcp Slave和Modbus Rtu Client代码。
这样用BC3.0,DOS平台下实现了Modbus Tcp/Rtu协议转换功能,实现了上位机PC与PLC的通信的要求。
隧道广告的相关介绍,可以参见我以前写的文章:
http://blog.csdn.net/yefanqiu/archive/2006/08/16/1074382.aspx
四、嵌入式组态系统(2006年1月~至今)
<shape id="_x0000_i1027" style="WIDTH: 383.25pt; HEIGHT: 289.5pt" type="#_x0000_t75"><imagedata o:title="" src="file:///C:%5CWINDOWS%5CTEMP%5Cmsohtml1%5C01%5Cclip_image005.png"><font size="3"></font></imagedata></shape>
开发组态系统,自然而然的要实现各种通信协议的驱动,所以Modbus 协议的开发不在话下。
分别用EVC和VC实现了Modbus Rtu/AscII/Tcp的Client通信协议驱动。
嵌入式组态系统的相关介绍,可以参见我以前写的文章:
http://blog.csdn.net/yefanqiu/archive/2006/11/29/1419479.aspx
http://blog.csdn.net/yefanqiu/archive/2006/11/19/1396827.aspx
http://blog.csdn.net/yefanqiu/archive/2006/10/24/1348840.aspx
五、LED影像系统(2006年12月~至今)
目前关于通信这块代码还没有做,不过已决定用C#开发Modbus Rtu Client程序和单片机开发的硬件设备进行通信(单片机中实现Modbus Rtu Slave,这部分有专门的硬件工程师实现),通过Modbus的通信实现LED大屏各种参数的配置。
LED系统相关介绍
http://blog.csdn.net/yefanqiu/archive/2007/05/28/1627782.aspx
六、医疗系统(2007年6月~至今)
<shape id="_x0000_i1029" style="WIDTH: 415.5pt; HEIGHT: 240.75pt" type="#_x0000_t75"><imagedata o:title="1" src="file:///C:%5CWINDOWS%5CTEMP%5Cmsohtml1%5C01%5Cclip_image009.jpg"><font size="3"></font></imagedata></shape>
目前这部分正在做,除红外通信板的Modbus Rtu Slave用汇编实现外,其它的都用C#语言实现。
七、Modbus Rtu 通信协议(3,16号命令)
1、 读取保持寄存器(单个和多个,以字为最小单位)
发送命令帧:
设备地址
|
功能码
|
地址H
|
地址L
|
数据量H
|
数据量L
|
CRC H
|
CRC L
|
Addr0
|
3 H
|
HoldStart
|
DataNum
|
CRC高位
|
CRC低位
|
帧 长 度:8个字节
设备地址:1~247
功 能 码:3H
数据地址:0~65535 具体范围与相关设备有关
数 量:1~65535 具体范围与相关设备有关
校 验 码:CRC16校验
返回命令帧:
设备地址
|
功能码
|
数据量
|
数据1
|
数据N
|
CRC H
|
CRC L
|
Addr1
|
3 H
|
返回数据的字节数N
|
Data (1~N)
|
CRC高位
|
CRC低位
|
帧 长 度:5+N 个字节
设备地址:1~247
功 能 码:3H
数 据 量:实际的读取数据数量
数 据:返回数据的意义
a=HoldStart
n= DataNum-1
VW a (VB a)
|
VWa(VB a+1)
|
…
|
VW a+n(VB a+n)
|
VWa+n(VB a+n+1)
|
Data(1)
|
Data(2)
|
…
|
Data(N-1)
|
Data(N)
|
校 验 码:CRC16校验
命令有误:
1) 没有任何返回
2) 返回异议帧
设备地址
|
功能码
|
错误信息
|
CRC H
|
CRC L
|
Addr1
|
83 H
|
一个字节的错误信息
|
CRC高位
|
CRC低位
|
2、 设置保持寄存器(多个,以字为最小单位)
发送命令帧:
设备地址
|
功能码
|
地址H
|
地址L
|
数据量H
|
数据量L
|
数据字节数
|
具体
数据
|
CRC H
|
CRC L
|
Addr0
|
10 H
|
HoldStart
|
DataNum
|
bytN
|
1~bytN
|
CRC高位font-size: 9p
分享到:
Global site tag (gtag.js) - Google Analytics
|
相关推荐
前言 Modbus协议是由Modicon公司(现在的施耐德电气Schneider Electric)推出,主要建立在物理串口、以太网TCP/...当用于支持Modbus RTU/ASCII协议时,ModbusPoll作为一个主站设备, ModbusSlave作为一个从站设备,从站
此外,它还支持ASCII、RTU(远程终端单元)和TCP/IP三种Modbus通信模式,以覆盖各种网络环境下的应用场景。 在进行功能码级别的测试时,用户可以逐个测试每一个可能的功能码,确保其在与真实设备交互时能够正常工作...
Modbus支持多种通信介质和协议类型,包括ASCII、RTU和TCP/IP,其中TCP/IP是通过网络进行通信的一种方式。 Libmodbus是一个开源的库,用于实现Modbus协议,支持TCP和RTU模式。这个库为开发者提供了方便的API,使得...
- 支持数据转换,以便控制MODBUS TCP/ASCII/RTU设备; - 扩展了iRidium系统的兼容性,使得更多类型的设备可以被集成进来。 #### 三、iOS设备上的iRidium HD Client - **简介**:iRidium HD Client是专门为iOS设备...
ModbusTCP协议由施耐德公司在1996年推出,基于以太网TCP/IP。在基于ModbusTCP协议的系统集成通讯中,主站(Master)和从站(Slave)设备之间进行通信,主站发送请求帧,从站响应请求。在TCP通信模式下,主站作为...
RTU(Remote Terminal Unit)模式是Modbus的两种工作模式之一,另一种是ASCII模式。RTU模式效率更高,因为它使用二进制编码而非ASCII字符。在RTU模式下,数据以16位的字节对形式发送,每个消息以连续的两个相同字节...
1. **Modbus协议**: Modbus协议是基于ASCII或RTU(远程终端单元)的串行通信协议,也可用于TCP/IP网络。它定义了设备之间交换信息的格式和规则。 2. **Modbus RTU与Modbus TCP**: RTU模式是原始的Modbus协议,适用...
- ModBus协议是基于串行通信的,分为ASCII、RTU和TCP三种模式,其中TCP模式常用于上位机与远程设备的网络通信。 - ModBus协议定义了主设备(Master)和从设备(Slave)之间的通信规则,允许主设备请求从设备执行...
1. **MODBUS TCP**:适用于以太网环境,利用TCP/IP协议栈进行通信。 2. **MODBUS RTU**:用于异步串行传输,如RS-232/422/485等,特点是数据紧凑且无校验字符间的空闲时间。 3. **MODBUS ASCII**:也用于异步串行...
客户端通常支持不同类型的Modbus协议,如RTU(远程终端单元)、ASCII(美国标准代码交换信息)和TCP/IP(传输控制协议/互联网协议)。 2. **Modbus Server**:这是一个模拟从设备的工具,用户可以设置虚拟的寄存器...
在Modbus TCP中,数据通过TCP/IP协议传输,提高了通信的可靠性。它定义了一套规则,使得不同的设备即使来自不同制造商,也能理解并交换数据。 **libmodbus**是开源的C语言库,它提供了对Modbus协议的全面支持,包括...
其中,Modbus RTU和Modbus ASCII是基于串行线路的两种主要通信模式,而Modbus TCP则是基于以太网的网络通信协议。在Modbus TCP中,IP地址和TCP端口替代了传统的物理设备地址。 Modbus协议的简单性、开放性和易用性...
Modbus协议分为ASCII(美国标准代码交换信息)、RTU(远程终端单元)和TCP/IP三种模式,其中RTU模式由于其高效性而在嵌入式系统中尤为常见。 在压缩包中,`V6-RS485_client` 和 `V6-RS485_sever` 分别代表了Modbus...
Modbus TCP Client using FB's.zip Omron CS1 Sequencer.zip OMRON E6CP绝对值编码器使用实例。编码器为8位格雷码输出.rar Omron Modbus Slave Ladder.zip Omron Plc 变频一带三例程.rar OMRON PLC编程示范.rar ...