Modbus通讯协议及编程.docx
- 文档编号:10597612
- 上传时间:2023-02-21
- 格式:DOCX
- 页数:18
- 大小:50.48KB
Modbus通讯协议及编程.docx
《Modbus通讯协议及编程.docx》由会员分享,可在线阅读,更多相关《Modbus通讯协议及编程.docx(18页珍藏版)》请在冰豆网上搜索。
Modbus通讯协议及编程
MODBUS通讯协议及编程
ModBus通讯协议分为RTU协议和ASCII协议,我公司的多种仪表都采用ModBusRTU通讯协议,如:
CH2000智能电力监测仪、CH2000M电力参数采集模块、巡检表、数显表、光柱数显表等。
下面就ModBusRTU协议简要介绍如下:
一、通讯协议
(一)、通讯传送方式:
通讯传送分为独立的信息头,和发送的编码数据。
以下的通讯传送方式定义也与MODBUSRTU通讯规约相兼容:
编码
8位二进制
起始位
1位
数据位
8位
奇偶校验位
1位(偶校验位)
停止位
1位
错误校检
CRC(冗余循环码)
初始结构=≥4字节的时间
地址码=1字节
功能码=1字节
数据区=N字节
错误校检=16位CRC码
结束结构=≥4字节的时间
地址码:
地址码为通讯传送的第一个字节。
这个字节表明由用户设定地址码的从机将接收由主机发送来的信息。
并且每个从机都有具有唯一的地址码,并且响应回送均以各自的地址码开始。
主机发送的地址码表明将发送到的从机地址,而从机发送的地址码表明回送的从机地址。
功能码:
通讯传送的第二个字节。
ModBus通讯规约定义功能号为1到127。
本仪表只利用其中的一部分功能码。
作为主机请求发送,通过功能码告诉从机执行什么动作。
作为从机响应,从机发送的功能码与从主机发送来的功能码一样,并表明从机已响应主机进行操作。
如果从机发送的功能码的最高位为1(比如功能码大与此同时127),则表明从机没有响应操作或发送出错。
数据区:
数据区是根据不同的功能码而不同。
数据区可以是实际数值、设置点、主机发送给从机或从机发送给主机的地址。
CRC码:
二字节的错误检测码。
(二)、通讯规约:
当通讯命令发送至仪器时,符合相应地址码的设备接通讯命令,并除去地址码,读取信息,如果没有出错,则执行相应的任务;然后把执行结果返送给发送者。
返送的信息中包括地址码、执行动作的功能码、执行动作后结果的数据以及错误校验码。
如果出错就不发送任何信息。
1.信息帧结构
地址码
功能码
数据区
错误校验码
8位
8位
N×8位
16位
地址码:
地址码是信息帧的第一字节(8位),从0到255。
这个字节表明由用户设置地址的从机将接收由主机发送来的信息。
每个从机都必须有唯一的地址码,并且只有符合地址码的从机才能响应回送。
当从机回送信息时,相当的地址码表明该信息来自于何处。
功能码:
主机发送的功能码告诉从机执行什么任务。
表1-1列出的功能码都有具体的含义及操作。
代码
含义
操作
03
读取数据
读取当前寄存器内一个或多个二进制值
06
重置单一寄存器
把设置的二进制值写入单一寄存器
数据区:
数据区包含需要从机执行什么动作或由从机采集的返送信息。
这些信息可以是数值、参考地址等等。
例如,功能码告诉从机读取寄存器的值,则数据区必需包含要读取寄存器的起始地址及读取长度。
对于不同的从机,地址和数据信息都不相同。
错误校验码:
主机或从机可用校验码进行判别接收信息是否出错。
有时,由于电子噪声或其它一些干扰,信息在传输过程中会发生细微的变化,错误校验码保证了主机或从机对在传送过程中出错的信息不起作用。
这样增加了系统的安全和效率。
错误校验采用CRC-16校验方法。
注:
信息帧的格式都基本相同:
地址码、功能码、数据区和错误校验码。
2.错误校验
冗余循环码(CRC)包含2个字节,即16位二进制。
CRC码由发送设备计算,放置于发送信息的尾部。
接收信息的设备再重新计算接收到信息的CRC码,比较计算得到的CRC码是否与接收到的相符,如果两者不相符,则表明出错。
CRC码的计算方法是,先预置16位寄存器全为1。
再逐步把每8位数据信息进行处理。
在进行CRC码计算时只用8位数据位,起始位及停止位,如有奇偶校验位的话也包括奇偶校验位,都不参与CRC码计算。
在计算CRC码时,8位数据与寄存器的数据相异或,得到的结果向低位移一字节,用0填补最高位。
再检查最低位,如果最低位为1,把寄存器的内容与预置数相异或,如果最低位为0,不进行异或运算。
这个过程一直重复8次。
第8次移位后,下一个8位再与现在寄存器的内容相相异或,这个过程与以上一样重复8次。
当所有的数据信息处理完后,最后寄存器的内容即为CRC码值。
CRC码中的数据发送、接收时低字节在前。
计算CRC码的步骤为:
∙预置16位寄存器为十六进制FFFF(即全为1)。
称此寄存器为CRC寄存器;
∙把第一个8位数据与16位CRC寄存器的低位相异或,把结果放于CRC寄存器;
∙把寄存器的内容右移一位(朝低位),用0填补最高位,检查最低位;
∙如果最低位为0:
重复第3步(再次移位);如果最低位为1:
CRC寄存器与多项式A001(1010000000000001)进行异或;
∙重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
∙重复步骤2到步骤5,进行下一个8位数据的处理;
∙最后得到的CRC寄存器即为CRC码。
3.功能码03,读取点和返回值:
仪表采用ModbusRTU通讯规约,利用通讯命令,可以进行读取点(“保持寄存器”)或返回值(“输入寄存器”)的操作。
保持和输入寄存器都是16位(2字节)值,并且高位在前。
这样用于仪表的读取点和返回值都是2字节。
一次最多可读取寄存器数是60。
由于一些可编程控制器不用功能码03,所以功能码03被用作读取点和返回值。
从机响应的命令格式是从机地址、功能码、数据区及CRC码。
数据区中的寄存器数据都是每两个字节高字节在前。
4.功能码06,单点保存
主机利用这条命令把单点数据保存到仪表的存储器。
从机也用这个功能码向主机返送信息。
二、编程举例
下面是一个用VC编写的ModBusRTU通讯的例子
(一)、通讯口设置
DCBdcb;
hCom=CreateFile("COM1",
GENERIC_READ|GENERIC_WRITE,
0,
NULL,
OPEN_EXISTING,
0,
NULL);
if(hCom==INVALID_HANDLE_VALUE)
{
MessageBox("createfileerror,error");
}
BOOLerror=SetupComm(hCom,1024,1024);
if(!
error)
MessageBox("setupcommerror");
error=GetCommState(hCom,&dcb);
if(!
error)
MessageBox("getcommstate,error");
dcb.BaudRate=2400;
dcb.ByteSize=8;
dcb.Parity=EVENPARITY;//NOPARITY;
dcb.StopBits=ONESTOPBIT;
error=SetCommState(hCom,&dcb);
(二)、CRC校验码计算
UINTcrc
voidcalccrc(BYTEcrcbuf)
{
BYTEi;
crc=crc^crcbuf;
for(i=0;i<8;i++)
{
BYTETT;
TT=crc&1;
crc=crc>>1;
crc=crc&0x7fff;
if(TT==1)
crc=crc^0xa001;
crc=crc&0xffff;
}
}
(三)、数据发送
zxaddr=11;//读取地址为11的巡检表数据
zxnum=10;//读取十个通道的数据
writebuf2[0]=zxaddr;
writebuf2[1]=3;
writebuf2[2]=0;
writebuf2[3]=0;
writebuf2[4]=0;
writebuf2[5]=zxnum;
crc=0xffff;
calccrc(writebuf2[0]);
calccrc(writebuf2[1]);
calccrc(writebuf2[2]);
calccrc(writebuf2[3]);
calccrc(writebuf2[4]);
calccrc(writebuf2[5]);
writebuf2[6]=crc&0xff;
writebuf2[7]=crc/0x100;
WriteFile(hCom,writebuf2,8,&comnum,NULL);
(四)、数据读取
ReadFile(hCom,writebuf,5+zxnum*2,&comnum,NULL);//读取zxnum个通道数据
可增加错误处理程序,如地址码错误、CRC码错误判断、通讯故障处理等。
Modbus通讯协议及编程
技术分类:
网络与通讯发表时间:
2007-02-17
Modbus通讯协议分为RTU协议和ASCII协议,我公司的多种仪表都采用ModBusRTU通讯协议。
下面就ModBusRTU协议简要介绍如下:
一、通讯协议:
1、通讯传送方式:
通讯传送分为独立的信息头,和发送的编码数据。
以下的通讯传送方式定义也与MODBUSRTU通讯规约相兼容:
编码8位二进制
起始位1位
数据位8位
奇偶校验位1位(偶校验位)
停止位1位
错误校检CRC(冗余循环码)
初始结构=≥4字节的时间
地址码=1字节
功能码=1字节
数据区=N字节
错误校检=16位CRC码
结束结构=≥4字节的时间
地址码:
地址码为通讯传送的第一个字节。
这个字节表明由用户设定地址码的从机将接收由主机发送来的信息。
并且每个从机都有具有唯一的地址码,并且响应回送均以各自的地址码开始。
主机发送的地址码表明将发送到的从机地址,而从机发送的地址码表明回送的从机地址。
功能码:
通讯传送的第二个字节。
ModBus通讯规约定义功能号为1到127。
本仪表只利用其中的一部分功能码。
作为主机
请求发送,通过功能码告诉从机执行什么动作。
作为从机响应,从机发送的功能码与从主机发送来的功能码一样,并表明从机已响应主机进行操作。
如果从机发送的功能码的最高位为1(比如功能码大与此同时127),则表明从机没有响应操作或发送出错。
数据区:
数据区是根据不同的功能码而不同。
数据区可以是实际数值、设置点、主机发送给从机或从机发送给主机的地址。
CRC码:
二字节的错误检测码。
2、通讯规约:
当通讯命令发送至仪器时,符合相应地址码的设备接通讯命令,并除去地址码,读取信息,如果没有出错,则执行相应的任务;然后把执行结果返送给发送者。
返送的信息中包括地址码、执行动作的功能码、执行动作后结果的数据以及错误校验码。
如果出错就不发送任何信息。
(1)信息帧结构
地址码功能码数据区错误校验码
8位8位N×8位16位
地址码:
地址码是信息帧的第一字节(8位),从0到255。
这个字节表明由用户设置地址的从机将接收由主机发送来的信息。
每个从机都必须有唯一的地址码,并且只有符合地址码的从机才能响应回送。
当从机回送信息时,相当的地址码表明该信息来自于何处。
功能码:
主机发送的功能码告诉从机执行什么任务。
表1-1列出的功能码都有具体的含义及操作。
代码含义操作
03读取数据读取当前寄存器内一个或多个二进制值
06重置单一寄存器把设置的二进制值写入单一寄存器
数据区:
数据区包含需要从机执行什么动作或由从机采集的返送信息。
这些信息可以是数值、参考地址等等。
例如,功能码告诉从机读取寄存器的值,则数据区必需包含要读取寄存器的起始地址及读取长度。
对于不同的从机,地址和数据信息都不相同。
错误校验码:
主机或从机可用校验码进行判别接收信息是否出错。
有时,由于电子噪声或其它一些干扰,信息在传输过程中会发生细微的变化,错误校验码保证了主机或从机对在传送过程中出错的信息不起作用。
这样增加了系统的安全和效率。
错误校验采用CRC-16校验方法。
注:
信息帧的格式都基本相同:
地址码、功能码、数据区和错误校验码。
(2)错误校验
冗余循环码(CRC)包含2个字节,即16位二进制。
CRC码由发送设备计算,放置于发送信息的尾部。
接收信息的设备再重新计算接收到信息的CRC码,比较计算得到的CRC码是否与接收到的相符,如果两者不相符,则表明出错。
CRC码的计算方法是,先预置16位寄存器全为1。
再逐步把每8位数据信息进行处理。
在进行CRC码计算时只用8位数据位,起始位及停止位,如有奇偶校验位的话也包括奇偶校验位,都不参与CRC码计算。
在计算CRC码时,8位数据与寄存器的数据相异或,得到的结果向低位移一字节,用0填补最高位。
再检查最低位,如果最低位为1,把寄存器的内容与预置数相异或,如果最低位为0,不进行异或运算。
这个过程一直重复8次。
第8次移位后,下一个8位再与现在寄存器的内容相相异或,这个过程与以上一样重复8次。
当所有的数据信息处理完后,最后寄存器的内容即为CRC码值。
CRC码中的数据发送、接收时低字节在前。
计算CRC码的步骤为:
1、预置16位寄存器为十六进制FFFF(即全为1)。
称此寄存器为CRC寄存器;
2、把第一个8位数据与16位CRC寄存器的低位相异或,把结果放于CRC寄存器;
3、把寄存器的内容右移一位(朝低位),用0填补最高位,检查最低位;
4、如果最低位为0:
重复第3步(再次移位);如果最低位为1:
CRC寄存器与多项式A001(10100000
00000001)进行异或;
5、重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
6、重复步骤2到步骤5,进行下一个8位数据的处理;
7、最后得到的CRC寄存器即为CRC码。
(3)功能码03,读取点和返回值:
仪表采用ModbusRTU通讯规约,利用通讯命令,可以进行读取点(“保持寄存器”)或返回值(“输入寄存器”)的操作。
保持和输入寄存器都是16位(2字节)值,并且高位在前。
这样用于仪表的读取点和返回值都是2字节。
一次最多可读取寄存器数是60。
由于一些可编程控制器不用功能码03,所以功能码03被用作读取点和返回值。
从机响应的命令格式是从机地址、功能码、数据区及CRC码。
数据区中的寄存器数据都是每两个字节高字节在前。
(4)功能码06,单点保存
主机利用这条命令把单点数据保存到仪表的存储器。
从机也用这个功能码向主机返送信息。
二、编程举例:
下面是一个用VC编写的ModBusRTU通讯的例子
通讯口设置
DCBdcb;
hCom=CreateFile("COM1"
GENERIC_READ|GENERIC_WRITE,
0,
NULL,
OPEN_EXISTING,
0,
NULL);
if(hCom==INVALID_HANDLE_VALUE)
{
MessageBox("createfileerror,error");
}
BOOLerror=SetupComm(hCom,1024,1024);
if(!
error)
MessageBox("setupcommerror");
error=GetCommState(hCom,&dcb);
if(!
error)
MessageBox("getcommstate,error");
dcb.BaudRate=2400;
dcb.ByteSize=8;
dcb.Parity=EVENPARITY;//NOPARITY;
dcb.StopBits=ONESTOPBIT;
error=SetCommState(hCom,&dcb);
CRC校验码计算
UINTcrc
voidcalccrc(BYTEcrcbuf)
{
BYTEi;
crc=crc^crcbuf;
for(i=0;i<8;i++)
{
BYTETT;
TT=crc&1;
crc=crc>>1;
crc=crc&0x7fff;
if(TT==1)
crc=crc^0xa001;
crc=crc&0xffff;
}
}
数据发送
zxaddr=11;//读取地址为11的巡检表数据
zxnum=10;//读取十个通道的数据
writebuf2[0]=zxaddr;
writebuf2[1]=3;
writebuf2[2]=0;
writebuf2[3]=0;
writebuf2[4]=0;
writebuf2[5]=zxnum;
crc=0xffff;
calccrc(writebuf2[0]);
calccrc(writebuf2[1]);
calccrc(writebuf2[2]);
calccrc(writebuf2[3]);
calccrc(writebuf2[4]);
calccrc(writebuf2[5]);
writebuf2[6]=crc&0xff;
writebuf2[7]=crc/0x100;
WriteFile(hCom,writebuf2,8,&comnum,NULL);
数据读取
ReadFile(hCom,writebuf,5+zxnum*2,&comnum,NULL);//读取zxnum个通道数据可增加错误处理程序,如地址码错误、CRC码错误判断、通讯故障处理等。
Modbus协议在涩宁兰SCADA系统中的应用
来源:
录入时间:
07-03-2811:
29:
24 Englishversion
摘要:
工业控制已进入网络时代,在如今工控技术和工控产品百家争鸣的时代,各种不同设备之间的通讯已成为一个系统的关键所在。
Modbus工业网络协议就是解决这一问题的一种利器。
本文简单阐述了Modbus协议的基本原理,并结合涩宁兰输气管线SCADA系统中Modbus协议的实际应用,介绍了Modbus应用的一般方法和注意事项。
主题词:
Modbus帧ASCII模式RTU模式SCADARS-485
Modbus协议是Modicon公司开发的一种数据通讯协议,通过这个协议,各种不同的设备和网络可相互进行通讯,由于其具有高度的可操作性和开放性,Modbus协议已经成为一种通用性很强的工业控制网络通讯协议。
许多不同品牌、不同厂家的设备之间都可通过该协议交换数据。
涩宁兰输气管线SCADA系统应用了多种通讯和网络协议,使各种设备有机的结合在一起,成为一个完整的三级集散控制系统,Modbus协议是其中一种重要的协议。
Modbus协议简介
一、Modbus的通讯过程
Modbus协议定义了一种信息结构,这种信息结构可以被所有支持该协议的各种设备在通讯时认可和使用。
它描述了控制器向其他设备发出查询的过程以及其他设备如何进行应答,以及错误的检测和报告。
Modbus协议采用master-slave(主-从)的技术。
在一个Modbus总线上,只能有一个master,而slave最多可有247个,地址为1——247。
进行通讯时,只有master才可以发起一个“查询”,充当slave的设备不断的检测,当检测到有自己地址的“查询”时,就会向master发出一个“回应”,或者根据master的命令采取相应的动作。
当master发出的“查询”是一个“广播”(地址码为0)时,所有的slave都执行master的命令,但不向master发出回应信息。
二、Modbus的帧
在网络通信中,数据都是以“包”(Packet)或“帧”(Frame)的形式进行传输,“包”和“帧”含义基本相同,均指通信中的一个数据块。
对于某种具体通信网络,一般使用术语“帧”。
在Modbus协议中,引用了“帧”(Frame)作为通讯过程中的数据单位,Modbus中的“帧”由以下几部分组成:
1、标志位:
表示一个“帧”的开始。
2、地址位:
表示该“帧”的信息是发给哪一个slave的,或是由哪个slave发出的信息。
3、功能代码:
表示指令,在Modbus协议中,有一系列代码表示不同的指令,例如:
代码“3”表示读数据。
4、数据位:
是对功能代码的进一步补充与说明,说明指令的具体内容。
5、校验位:
CRC或LRC校验。
6、停止位:
表示该“帧”的结束。
每部分的位数和表示方法依采取的模式不同而略有区别,下文将详细论述。
三、Modbus的两种通讯模式
在Modbus协议中,依数据在传输的过程中的具体形式不同,分为两种模式:
ASCII和RTU,采用哪种模式由用户自己根据需要进行选择。
在选择时,同一Modbus网络中的所有设备的模式选择必须一致。
1、ASCII模式
ASCII(AmericanStandardCodeforInformationInterchange),即美国信息交换标准代码。
在这种模式中,每个8比特的字节被转换两个ASCII字符进行传送。
这种模式的主要优点是传送的每相邻的两字节之间允许最大的时间间隔是1秒。
表一:
ASCII模式的帧格式
在此帧中:
帧是以一个冒号(:
)来做为开始的标志;以CRLF(carriagereturn-linefeed即“回车-换行”)为结束标志;
代码系统采用十六进制,ASCII字符0...9,A...F
每个ASCII字符由一个16进制的字符组成;
每个字节中包括:
1个开始位;7个数据位(低位先传送);1个奇偶校验位(无奇偶校验时为0位);1个(有奇偶校验时)或2位(无奇偶校验时)停止位;
ASCII模式采用LRC(纵向冗余校验)检错方法。
2、RTU模式
RTU(RemoteTerminalUnit),即远程终端单元,这种模式的特点是信息中每个8比特的字节被转换为两个4比特的十六进制字符来传输。
它的优点是更大的数据密度使它在相同的波特率下比ASCII模式有更强的数据吞吐能力。
表二:
RTU模式的帧格式
在此帧中:
该帧是以一个相当于至少3.5个字节传输时间的空闲做为开始和结束的标志;整个帧的所有数据必须连续传送,如果中间间隔超过1.5个字符传输时间,接收设备会认为下一个字符为一个新帧的开始,即为一个地址码;
代码系统采用8位二进制,十六进制数0...9,A...F;
信息的每个8比特字符由两个16进制的字符组成;
每个字节中包括:
一个开始位;8个数据位(低位先传送);1个奇偶校验位(无奇偶校验时为0);1个(有奇偶校验时)或2位(无奇偶校验时)停止位;
ASCII模式采用CRC(循环冗余校验)检错方法。
四、Modbus与其他网络的通讯
Modbus网络可以通过设备内置的部件或网络适配器
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Modbus 通讯 协议 编程