导图社区 Modbus-RTU协议
Modbus-RTU协议说明,Modbus RTU协议是一种开放的、主要基于串行链路(如RS232C或RS485)的通信协议,也有在TCP或者UDP方式下使用这种标准通信协议的。其名称中的RTU是英文“Remote Terminal Unit”的缩写,即“远程终端设备”。
编辑于2024-07-24 09:03:23Modbus-RTU协议
一、简介
MODBUS RTU协议是一种开放的、主要基于串行链路(RS232C或RS485)的通信协议,也有在TCP或者UDP方式下使用这种标准通信协议
RTU是英文 "Remote Terminal Unit"的缩写,即"远程终端设备"
传送介质:双绞线、光纤、无线等
二、主站/从站
主站
主站会向从站发出查询或者写入命令
从站
从站被动接收命令然后根据功能码和寄存器号反馈相应的数据结果或者执行写入命令
挂载数量
一个485网络里理论上最多可以挂254个从站,实际应用中考虑线路损耗和干扰一般不会超过100个
三、协议格式
数据帧(ADU)由地址+PDU+校验组成;
MBAP:无
地址:1字节
功能码:1字节
数据:N字节
CRC16位校验:2字节
四、寄存器分类
线圈寄存器
数据类型:位;
访问类型:读写;
功能码:
01H
05H
0FH
寄存器地址:0000H-FFFFH;
离散输入寄存器
数据类型:位;
访问类型:只读;
功能码:02H
寄存器地址:0000H-FFFFH;
输入寄存器
数据类型:字;
访问类型:只读;
功能码:04H
寄存器地址:0000H-FFFFH;
保持寄存器
数据类型:字;
访问类型:读写;
功能码:
03H
06H
10H
寄存器地址:0000H-FFFFH;
五、功能码介绍
功能码01H
功能描述:读线圈寄存器
寄存器地址:0000H-FFFFH;
数据类型:位操作;
操作数量:单个或多个;
功能码02H
功能描述:读离散输入寄存器
寄存器地址:0000H-FFFFH;
数据类型:位操作;
操作数量:单个或多个;
功能码03H
功能描述:读保持寄存器
寄存器地址:0000H-FFFFH;
数据类型:字操作;
操作数量:单个或多个;
功能码04H
功能描述:读输入寄存器
寄存器地址:0000H-FFFFH;
数据类型:字操作;
操作数量:单个或多个;
功能码05H
功能描述:写单个线圈寄存器
寄存器地址:0000H-FFFFH;
数据类型:位操作;
操作数量:单个;
功能码06H
功能描述:写单个保持寄存器
寄存器地址:0000H-FFFFH;
数据类型:字操作;
操作数量:单个;
功能码0FH
功能描述:写多个线圈寄存器
寄存器地址:0000H-FFFFH;
数据类型:位操作;
操作数量:多个;
功能码10H
功能描述:写多个保持寄存器
寄存器地址:0000H-FFFFH;
数据类型:字操作;
操作数量:多个;
六、读线圈寄存器
说明:功能码01H读取Modbus从机中线圈寄存器的状态,可以是单个寄存器,或者多个连续的寄存器。
发送
假设从机地址为01H,读取的线圈寄存器的起始地址为0017H,读取38个寄存器,
读线圈寄存器指令
应答
各线圈的状态与数据内容的每个bit对应,1代表ON,0代表OFF。如果查询的线圈数量不是8的倍数,则在最后一个字节的高位补0。
返回指令
其中,第一个字节CDH对应线圈0017H到001E的状态,转为二进制是11001101,其中bit0对应0017H,bit7对应001EH,如表所示
线圈0017H到001EH的状态
最后一个字节为1BH,对应线圈0037H到003CH的状态,转为二进制是00011011,其中bit0对应0037H,bit5对应003CH,其余两位用0填充,如表所示:
七、读离散输入寄存器(02H)
说明:功能码02H读取Modbus从机中离散输入寄存器的状态,可以是单个寄存器,或者多个连续的寄存器
发送
假设从机地址为01H,读取的离散输入寄存器的起始地址为00C4H,读取22个寄存器,指令如表所示:
读离散输入寄存器指令:
应答
各个离散输入寄存器的状态与数据内容的每个bit对应,1代表ON,0代表OFF。如果查询的线圈数量不是8的倍数,则在最后一个字节的高位补0。
返回指令
其中,第一个字节ACH对应00C4H到00CBH寄存器的状态,转为二进制是10101100,其中bit0对应00C4H,bit7对应00CB,如表7.2.2所示:
寄存器00C4H到00CBH的状态
最后一个字节为35H,对应寄存器00D4H到00D9H的状态,转为二进制是00110101,其中bit0对应00D4H,bit5对应00D9H,其余两位用0填充,如表7.2.3所示:
寄存器00D4H到00D9H的状态
八、读保持寄存器(03H)
说明:功能码03H读取Modbus从机中保持寄存器的数据,可以是单个寄存器,或者多个连续的寄存器。
发送
假设从机地址为01H,读取的保持寄存器的起始地址为006BH,读取3个寄存器,指令如表8.1所示:
读保持寄存器指令:
应答
每个保持寄存器的长度为2个字节。保持寄存器之间,低地址寄存器先传输,高地址寄存器后传输。单个保持寄存器,高字节数据先传输,低字节数据后传输。
读保持寄存器的返回结果
九、读输入寄存器(04H)
说明:功能码04H读取Modbus从机中输入寄存器的数据,可以是单个寄存器,或者多个连续的寄存器。
发送
假设从机地址为01H,读取的保持寄存器的起始地址为0008H,读取2个寄存器,指令如表9.1所示:
读输入寄存器指令:
应答
每个输入寄存器的长度为2个字节。输入寄存器之间,低地址寄存器先传输,高地址寄存器后传输。单个输入寄存器,高字节数据先传输,低字节数据后传输。
读输入寄存器的返回结果
十、写单个线圈寄存器(05H)
说明:功能码05H写单个线圈寄存器,FF00H请求线圈处于ON状态,0000H请求线圈处于OFF状态。
发送
假设从机地址为01H,线圈寄存器的地址为00ACH,使其处于ON状态的指令如表
写单个线圈指令:
应答
如果写入成功,返回发送的指令,即010500ACFF004C1B。
十一、写单个保持寄存器(06H)
说明:功能码06H写单个保持寄存器。
发送
假设从机地址为01H,保持寄存器的地址为0001H,数据位0003H,指令如表11.1所示:
写单个保持寄存器指令:
应答
如果写入成功,返回发送的指令,即010600010003980B。
十二、写多个线圈寄存器(0FH)
说明:功能码0FH写多个线圈寄存器。如果对应的数据位为1,表示线圈状态为ON;如果对应的数据位为0,表示线圈状态为OFF。线圈寄存器之间,低地址寄存器先传输,高地址寄存器后传输。单个线圈寄存器,高字节数据先传输,低字节数据后传输。如果写入的线圈寄存器的个数不是8的倍数,则在最后一个字节的高位补0。
发送
假设从机地址为01H,线圈寄存器的起始地址为0013H,写入10个寄存器,指令如表12.1.1所示:
写入多个线圈寄存器指令
其中,CDH对应线圈0013H到001AH的内容,01H对应线圈001B到001CH的内容,未使用位用0填充。此时,线圈寄存器的内容如表12.1.2所示:线圈寄存器0013H到001CH的内容
应答
如果写入成功,返回写入的寄存器数量,如表12.2所示:
写多个线圈寄存器的返回结果