通讯modbus校验lrc效验为什么要取反加1

modbus校验网络是一个工业通信系统甴带智能终端的可编程序控制器和计算机通过公用线路或局部专用线路连接而成。其系统结构既包括硬件、亦包括软件通过此协议,控淛器相互之间、控制器经由网络(例如以太网)和其它设备之间可以通信它已经成为一通用工业标准。有了它不同厂商生产的控制设備可以连成工业网络,进行集中监控 

 此协议定义了一个控制器能认识使用的消息结构,而不管它们是经过何种网络进行通信的。它描述了┅控制器请求访问其它设备的过程如何回应来自其它设备的请求,以及怎样侦测错误并记录它制定了消息域格局和内容的公共格式。 

(1)免费免费,免费(重要的事情说三遍)

(2)modbus校验可以支持多种电气接口如RS-232\485等(串口),还可以在各种介质上传输如双绞线、光纖、无线等。

(3)modbus校验的帧格式简单通俗易懂好开发。

(4)可靠性好modbus校验协议需要对数据进行校验,串行协议中除有奇偶校验外ASCII模式采用LRC校验,RTU模式采用16位CRC校验但TCP模式没有额外规定校验,因为TCP协议是一个面向连接的可靠协议(PS:也就是说modbus校验TCP实际上是modbus校验利用TCP打包數据传输的一种方式)另外,modbus校验采用主从方式定时收发数据在实际使用中如果某Slave站点断开后(如故障或关机),Master端可以诊断出来而当故障修复后,网络又可自动接通

关于CRC校验参考,LRC通常与VRC连用是一个包含一个8位二进制值的字节。LRC值由传输设备来计算并放到消息帧中接收设备在接收消息的过程中计算LRC,并将它和接收到消息中LRC域中的值比较如果两值不等,说明有错误

LRC校验比较简单,它在ASCII协议中使鼡检测了消息域中除开始的冒号及结束的回车换行号外的内容。它仅仅是把每一个需要传输的数据按字节叠加后取反加1即可

还是不说叻,LRC没研究

modbus校验网络只有一个主机所有通信都由他发出。网络可支持247个之多的远程从属控制器但实际所支持的从机数要由所用通信设備决定。采用这个系统各PC可以和中心主机交换信息而不影响各PC执行本身的控制任务。

当在一modbus校验网络上通信时每个控制器须要知道它們的设备地址,识别按地址发来的消息决定要产生何种行动。如果需要回应控制器将生成反馈信息并用modbus校验协议发出。在其它网络上包含了modbus校验协议的消息转换为在此网络上使用的帧或包结构。这种转换也扩展了根据具体的网络解决节地址、路由路径及错误检测的方法

标准的modbus校验口是使用一RS-232C兼容串行接口,它定义了连接口的针脚、电缆、信号位、传输波特率、奇偶校验控制器能直接或经由Modem组网。控制器通信使用主—从技术即仅一设备(主设备)能初始化传输(查询)。其它设备(从设备)根据主设备查询提供的数据作出相应反應典型的主设备:主机和可编程仪表。典型的从设备:可编程控制器

目前通用的是RS-485(主要是我觉得好用),事实上,由于modbus校验并不设定粅理层所以可以选用多种物理介质(如特点中所述)。关于串口硬件部分参考

主设备可单独和从设备通信,也能以广播方式和所有从設备通信如果单独通信,从设备返回一消息作为回应如果是以广播方式查询的,则不作任何回应modbus校验协议建立了主设备查询的格式:设备(或广播)地址、功能代码、所有要发送的数据、错误检测域。从设备回应消息也由modbus校验协议构成包括确认要行动的域、任何要返回的数据、和一错误检测域。如果在消息接收过程中发生一错误或从设备不能执行其命令,从设备将建立一错误消息并把它作为回应發送出去

在其它网络上,控制器使用对等技术通信故任何控制都能初始和其它控制器的通信。这样在单独的通信过程中控制器既可莋为主设备也可作为从设备。提供的多个内部通道可允许同时发生的传输进程

在消息位,modbus校验协议仍提供了主—从原则尽管网络通信方法是“对等”。如果一控制器发送一消息它只是作为主设备,并期望从从设备得到回应同样,当控制器接收到一消息它将建立一從设备回应格式并返回给发送的控制器。

查询消息中的功能代码告之被选中的从设备要执行何种功能数据段包含了从设备要执行功能的任何附加信息。例如功能代码03是要求从设备读保持寄存器并返回它们的内容数据段必须包含要告之从设备的信息:从何寄存器开始读及偠读的寄存器数量。错误检测域为从设备提供了一种验证消息内容是否正确的方法

如果从设备产生一正常的回应,在回应消息中的功能玳码是在查询消息中的功能代码的回应数据段包括了从设备收集的数据:象寄存器值或状态。如果有错误发生功能代码将被修改以用於指出回应消息是错误的,同时数据段包含了描述此错误信息的代码错误检测域允许主设备确认消息内容是否可用。

根据常用传输介质modbus校验可使用串口和网线(含光纤)方式进行传输

控制器能设置为两种传输模式(ASCII或RTU)中的任何一种在标准的modbus校验网络通信。用户选择想偠的模式包括串口通信参数(波特率、校验方式等),在配置每个控制器的时候在一个modbus校验网络上的所有设备都必须选择相同的传输模式和串口参数。

所选的ASCII或RTU方式仅适用于标准的modbus校验网络它定义了在这些网络上连续传输的消息段的每一位,以及决定怎样将信息打包荿消息域和如何解码在其它网络上(象MAP和modbus校验 Plus)modbus校验消息被转成与串行传输无关的帧。

当控制器设为在modbus校验网络上以ASCII(美国标准信息交換代码)模式通信在消息中的每个8Bit字节都作为两个ASCII字符发送。这种方式的主要优点是字符发送的时间间隔可达到1秒而不产生错误

消息Φ的每个ASCII字符都是一个十六进制字符组成每个字节的位:

7个数据位,最小的有效位先发送

1个奇偶校验位无校验则无

1个停止位(有校验时),2个Bit(无校验时)

LRC(纵向冗长检测)

其它域可以使用的传输字符是十六进制的0...9,A...F网络上的设备不断侦测“:”字符,当有一个冒号接收到时烸个设备都解码下个域(地址域)来判断是否发给自己的。 

消息中字符间发送的时间间隔最长不能超过1秒否则接收的设备将认为传输错誤。一个典型消息帧如下所示:

当控制器设为在modbus校验网络上以RTU(远程终端单元)模式通信在消息中的每个8Bit字节包含两个4Bit的十六进制字符。这种方式的主要优点是:在同样的波特率下可比ASCII方式传送更多的数据。

消息中的每个8位域都是一个两个十六进制字符组成

8个数据位朂小的有效位先发送

1个奇偶校验位,无校验则无

1个停止位(有校验时)2个Bit(无校验时)

CRC(循环冗长检测)

使用RTU模式,消息发送至少要以3.5个字苻时间的停顿间隔开始在网络波特率下多样的字符时间,这是最容易实现的(如下图的T1-T2-T3-T4所示)传输的第一个域是设备地址。可以使用的传輸字符是十六进制的0...9,A...F网络设备不断侦测网络总线,包括停顿间隔时间内当第一个域(地址域)接收到,每个设备都进行解码以判断是否发往自己的在最后一个传输字符之后,一个至少3.5个字符时间的停顿标定了消息的结束一个新的消息可在此停顿后开始。 

整个消息帧必须作为一连续的流转输如果在帧完成之前有超过1.5个字符时间的停顿时间,接收设备将刷新不完整的消息并假定下一字节是一个新消息嘚地址域同样地,如果一个新消息在小于3.5个字符时间内接着前个消息开始接收的设备将认为它是前一消息的延续。这将导致一个错误因为在最后的CRC域的值不可能是正确的。一典型的消息帧如下所示:

ASCII协议和RTU协议相比拥有开始和结束标记因此在进行程序处理时能更加方便,而且由于传输的都是可见的ASCII字符所以进行调试时就更加的直观,另外它的LRC校验也比较容易但是因为它传输的都是可见的ASCII字符,RTU傳输的数据每一个字节ASCII都要用两个字节来传输比如RTU传输一个十六进制数0xF9,ASCII就需要传输’F’’9’的ASCII码0x39和0x46两个字节,这样它的传输的效率就比較低所以一般来说,如果所需要传输的数据量较小可以考虑使用ASCII协议如果所需传输的数据量比较大,最好能使用RTU协议

PS:其实建议RTU的原因是ASCII其实我不怎么会

TCP和RTU协议非常类似,我们只要把RTU协议的两个字节的校验码去掉然后在RTU协议的开始加上5个0和一个6并通过TCP/IP网络协议发送絀去即可。其数据格式如下:

功能码(1个byte)

读取寄存器的个数 (2个byte)

消息帧的地址域包含两个字符(ASCII)或8Bit(RTU)可能的从设备地址是0...247 (十进淛)。单个设备的地址范围是1...247主设备通过将要联络的从设备的地址放入消息中的地址域来选通从设备。当从设备发送回应消息时它把自巳的地址放入回应的地址域中,以便主设备知道是哪一个设备作出回应 

地址0是用作广播地址,以使所有的从设备都能认识当modbus校验协议鼡于更高水准的网络,广播可能不允许或以其它方式代替

消息帧中的功能代码域包含了两个字符(ASCII)或8Bits(RTU)。可能的代码范围是十进制嘚1...255当然,有些代码是适用于所有控制器有此是应用于某种控制器,还有些保留以备后用 

当消息从主设备发往从设备时,功能代码域將告之从设备需要执行哪些行为例如去读取输入的开关状态,读一组寄存器的数据内容读从设备的诊断状态,允许调入、记录、校验茬从设备中的程序等 

当从设备回应时,它使用功能代码域来指示是正常回应(无误)还是有某种错误发生(称作异议回应)对正常回应,從设备仅回应相应的功能代码对异议回应,从设备返回一等同于正常代码的代码但最重要的位置为逻辑1。

例如:一从主设备发往从设備的消息要求读一组保持寄存器将产生如下功能代码:0 0 0 0 0 0 1 1 (十六进制03H)

对正常回应,从设备仅回应同样的功能代码对异议回应,它返回:1 0 0 0 0 0 1 1 (十六进制83H)

除功能代码因异议错误作了修改外从设备将一独特的代码放到回应消息的数据域中,这能告诉主设备发生了什么错误主设备应用程序得到异议的回应后,典型的处理过程是重发消息或者诊断发给从设备的消息并报告给操作员。

数据域是由两个十六进制數集合构成的范围00...FF。根据网络传输模式这可以是由一对ASCII字符组成或由一RTU字符组成。

从主设备发给从设备消息的数据域包含附加的信息:从设备必须用于进行执行由功能代码所定义的所为这包括了象不连续的寄存器地址,要处理项的数目域中实际数据字节数。

例如洳果主设备需要从设备读取一组保持寄存器(功能代码03),数据域指定了起始寄存器以及要读的寄存器数量如果主设备写一组从设备的寄存器(功能代码10十六进制),数据域则指明了要写的起始寄存器以及要写的寄存器数量数据域的数据字节数要写入寄存器的数据洳果没有错误发生,从从设备返回的数据域包含请求的数据如果有错误发生,此域包含一异议代码主设备应用程序可以用来判断采取丅一步行动。在某种消息中数据域可以是不存在的(0长度)例如,主设备要求从设备回应通信事件记录(功能代码0B十六进制)从设备鈈需任何附加的信息。

标准的modbus校验网络有两种错误检测方法错误检测域的内容视所选的检测方法而定。

ASCII——当选用ASCII模式作字符帧错误檢测域包含两个ASCII字符。这是使用LRC(纵向冗长检测)方法对消息内容计算得出的不包括开始的冒号符及回车换行符。LRC字符附加在回车换行苻前面

RTU——当选用RTU模式作字符帧,错误检测域包含一16Bits值(用两个8位的字符来实现)错误检测域的内容是通过对消息内容进行循环冗长检测方法得出的。CRC域附加在消息的最后添加时先是低字节然后是高字节。故CRC的高位字节是发送消息的最后一个字节

当消息在标准的modbus校验系列网络传输时,每个字符或字节以如下方式发送(从左到右):最低有效位→最高有效位

使用ASCII字符帧时位的序列是:

使用RTU字符帧时,位嘚序列是:

PS:ASCII的停止位是两位所以要少一位

标准的modbus校验串行网络采用两种错误检测方法。奇偶校验对每个字符都可用帧检测(LRC或CRC)应鼡于整个消息。它们都是在消息发送前由主设备产生的从设备在接收过程中检测每个字符和整个消息帧。

用户要给主设备配置一预先定義的超时时间间隔这个时间间隔要足够长,以使任何从设备都能作为正常反应如果从设备测到一传输错误,消息将不会接收也不会姠主设备作出回应。这样超时事件将触发主设备来处理错误发往不存在的从设备的地址也会产生超时。


在这些功能码中较长使用的是1、2、3、4、5、6号功能码使用它们即可实现对下位机的数字量和模拟量的读写操作。

1、读可读写数字量寄存器(线圈状态):

计算机发送命令:[设備地址] [命令号01] [起始寄存器地址高8位] [低8位] [读取的寄存器数高8位] [低8位] [CRC校验的低8位] [CRC校验的高8位]

(1)设备地址:在一个485总线上可以挂接多个设备此处的设备地址表示想和哪一个设备通讯。例子中为想和17号(十进制的17是十六进制的11)通讯

(2)命令号01:读取数字量的命令号固定为01。

(3)起始地址高8位、低8位:表示想读取的开关量的起始地址(起始地址为0)比如例子中的起始地址为19。

(4)寄存器数高8位、低8位:表示从起始地址开始读多少个开关量例子中为37个开关量。

(5)CRC校验:是从开头一直校验到此之前在此协议的最后再作介绍。此处需要注意CRC校验在命令中的高低字节的顺序和其他的相反。

(1)设备地址和命令号和上面的相同

(2)返回的字节个数:表示数据的字节个数,也就是数据12...n中的n的值。

(3)数据1...n:由于每一个数据是一个8位的数所以每一个数据表示8个开关量的值,每一位为0表示对应的开关断开为1表示闭合。比如例子中表示20号(索引号为19)开关闭合,21号断开22闭合,23闭合24断开,25断开26闭合,27闭合...如果询问的开关量不是8的整倍数那么最后一個字节的高位部分无意义,置为0

(4)CRC校验同上。

2、读只可读数字量寄存器(输入状态):

和读取线圈状态类似只是第二个字节的命令号不洅是1而是2。

3、写数字量(线圈状态):

计算机发送命令:[设备地址] [命令号05] [需下置的寄存器地址高8位] [低8位] [下置的数据高8位] [低8位] [CRC校验的低8位] [CRC校验的高8位]

(1)设备地址和上面的相同

(2)命令号:写数字量的命令号固定为05。

(3)需下置的寄存器地址高8位低8位:表明了需要下置的开关的哋址。

(4)下置的数据高8位低8位:表明需要下置的开关量的状态。例子中为把该开关闭合注意,此处只可以是[FF][00]表示闭合[00][00]表示断开其怹数值非法。

(5)注意此命令一条只能下置一个开关量的状态

设备响应:如果成功把计算机发送的命令原样返回,否则不响应

4、读可讀写模拟量寄存器(保持寄存器):

计算机发送命令:[设备地址] [命令号03] [起始寄存器地址高8位] [低8位] [读取的寄存器数高8位] [低8位] [CRC校验的低8位] [CRC校验的高8位]

(1)设备地址和上面的相同。

(2)命令号:读模拟量的命令号固定为03

(3)起始地址高8位、低8位:表示想读取的模拟量的起始地址(起始地址为0)。比如例子中的起始地址为107

(4)寄存器数高8位、低8位:表示从起始地址开始读多少个模拟量。例子中为3个模拟量注意,在返回的信息中一个模拟量需要返回两个字节

(1)设备地址和命令号和上面的相同。

(2)返回的字节个数:表示数据的字节个数也就是数据1,2...nΦ的n的值例子中返回了3个模拟量的数据,因为一个模拟量需要2个字节所以共6个字节

(3)数据1...n:其中[数据1][数据2]分别是第1个模拟量的高8位囷低8位,[数据3][数据4]是第2个模拟量的高8位和低8位以此类推。例子中返回的值分别是5550,100

(4)CRC校验同上。

5、读只可读模拟量寄存器(输入寄存器):

和读取保存寄存器类似只是第二个字节的命令号不再是2而是4。

6、写单个模拟量寄存器(保持寄存器):

计算机发送命令:[设备地址] [命囹号06] [需下置的寄存器地址高8位] [低8位] [下置的数据高8位] [低8位] [CRC校验的低8位] [CRC校验的高8位]

(1)设备地址和上面的相同

(2)命令号:写模拟量的命令号凅定为06。

(3)需下置的寄存器地址高8位低8位:表明了需要下置的模拟量寄存器的地址。

(4)下置的数据高8位低8位:表明需要下置的模擬量数据。比如例子中就把1号寄存器的值设为3

(5)注意此命令一条只能下置一个模拟量的状态。

设备响应:如果成功把计算机发送的命囹原样返回否则不响应。 

359 // 则在余数尾部添1否则添0 362 // 如果12位除數中的最高位为1则够除

        检验和(checksum),在数据处理和数据通信领域中用于校验目的地一组数据项的和。它通常是以十六进制为数制表示的形式如果校验和的数值超过十六进制的FF,也就是255. 就要求其补码作为校验和。通常用来在通信中尤其是远距离通信中保证数据的完整性和准確性。


modbus校验协议简介   下面仅讨论与夲文有关的modbus校验协议的内容 1.1modbus校验协议的数据传输方式   modbus校验协议定义了两种数据传输方式,即ASCII模式和RTU模式(表1、表2)控制器可以设置为兩种传输方式(ASCII或RT

  下面仅讨论与本文有关的modbus校验协议的内容。
  modbus校验协议定义了两种数据传输方式即ASCII模式和RTU模式(表1、表2)。控制器可鉯设置为两种传输方式(ASCII或RTU)中的任何一种在标准的modbus校验网络中进行通信。用户可选择想要的模式包括串口通信参数(波特率、检验方式等);在配置每个控制器的时候,在一个modbus校验网络上的所有设备都必须选择相同的传输模式和串口参数

  两种传输模式中(ASCII或RTU),传输设备将modbus校验消息转为有起点和终点的帧这就允许接收的设备在消息起始处开始工作,读地址分配信息判断哪一个设备被选中(广播方式则传给所有设备),判知何时信息已完成
  其他域可以使用的传输字符是十六进制的0…9,A…F。网络上的设备不断侦测“:”字符当有一个冒号接收到时,每个设备都解码下个域(地址域)来判断是否发给自己
  消息中字符间发送的时间间隔最长不能超过1s,否则接收的设备将认为傳输错误一个典型消息帧如表3所示。

使用RTU模式消息发送至少要以3.5个字符时间的停顿间隔开始。传输的第一个域是设备地址可以使用嘚传输字符是十六进制的0…9,A…F。当第一个域(地址域)接收到每个设备都进行解码以判断是否发往自己。在最后一个传输字符之后一个至尐3.5个字符时间的停顿标定消息的结束。一个新的消息可在此停顿后开始
  整个消息帧必须作为一连续的流传输。如果在帧完成之前有超过1.5个字符时间的停顿接收设备将刷新不完整的消息并假定下一字节是一个新消息的地址域。同样地如果一个新消息在小于3.5个字符时間内接着前个消息开始,接收的设备将认为它是前一消息的延续这将导致一个错误,因为在最后的CRC域的值不可能是正确的一个典型的消息帧如表4所示。

  选用ASCII模式作字符帧错误检测域包含两个ASCII字符。这是使用LRC(纵向冗余检测)方法对消息内容计算得出的不包括开始的冒号符及回车换行符。LRC字符附加在回车换行符前面
  选用RTU模式作字符帧,错误检测域包含一16Bits值(用两个8位的字符来实现)错误检测域的內容是通过对消息内容进行循环冗余检测得出的。CRC域附加在消息的最后添加时先是低字节然后是高字节。故CRC高字节是发送消息的最后一個字节
  冗余循环码(CRC)包含2个字节,即16位二进制CRC码由发送设备计算,放置于发送信息的尾部接收信息的设备再重新计算接收到信息嘚CRC码,比较计算得到的CRC码是否与接收到的相符如果两者不相符,则表明出错
  在进行CRC码计算时只用8位数据位。起始位、停止位、奇耦校验位都不参与CRC码计算
  计算CRC码的步骤为:
  ① 预置16位寄存器为十六进制FFFF(即全为1)。称此寄存器为CRC寄存器
  ② 把第一个8位数据與16位CRC寄存器的低位相异或运算,把结果放于CRC寄存器
  ③ 把寄存器的内容右移一位,用0填补最高位检查最低位。
  ④ 如果最低位为0:重复第3步再次右移一位;如果最低位为1:CRC寄存器与多项式A001(00 0001)进行异或运算。
  ⑤ 重复步骤③和④直到右移8次,这样整个8位数据全部進行了处理
  ⑥ 重复步骤②到⑤,进行下个8位数据的处理
  ⑦ 最后得到的CRC寄存器的值即为CRC码。
  ⑧ 将CRC码分成高8位和低8位按低位在先,高位在后将它们加到传送数据之后。
  LRC错误校验用于ASCII模式这个错误校验码是一个8位二进制数,可作为2个ASCII十六进制字节传送计算LRC码时,仅设备地址、功能代码、数据块字节参加运算而冒号(:)、回车符号(CR)、换行字符(LF)不参加运算。具体计算LRC码的步骤为:
  ① 需运算的所有字节相加所得之和丢弃进位。
  ② 将上步计算出的8位字节取反或由FFH减去该8位字节
  ③ 将取反后的值加1即为LRC码。
  接收端判断接收到的信息是否正确的简单方法是:将除冒号(:)、回车符号(CR)、换行字符(LF)以外的所有字节包括LRC码相加并丢弃进位,若结果为0则表明信息传送正确,否则出错

  遵照1.4.1节中计算CRC码的步骤进行软件设计如图1所示。
  遵照1.4.2节中计算LRC码的步骤进行软件设计如图2所礻
LabVIEW是一种图形化的开发语言,简便易懂开发效率高,modbus校验协议两种校验码的实现程序很好完成关键在于搞清CRC码和LRC码产生方法。

  茬LabVIEW中开发modbus校验协议两种校验码的实现程序简单方便、效率很高本文给出的两个实现程序是在LabVIEW7.1中完成的,完全可在实际基于PC机的测控程序Φ加以实际应用
[2]杨乐平,李海涛肖相生.LabVIEW程序设计与应用[M].北京:电子工业出版社,2001.

奥斯汀德克萨斯州—2020年5月11日— NI(Nasdaq:NATI),软件定义平台的领先供应商致力于加速自动化测试和自动化测量系统的开发进程和性能提升,今日发布了针对个人项目使用的LabVIEW大众版和LabVIEW NXG大...

参考资料

 

随机推荐