为什么你的设备总『听不懂人话』?Modbus协议入门的5个救命技巧(附详细图解)

原创 小麦大叔 2025-04-12 12:04

点击上方,选择“置顶/星标公众号”

福利干货,第一时间送达

大家好,我是麦鸽

以前写过一篇文章是关于modbus协议的,只是简单地做了一下介绍,这次对于modbus RTU协议进行了深入的学习。

1 背景

介绍modbus rtu之前,我们可以了解到,Modbus是施耐德电气公司,于1979年发明的,是全球第一个真正用于工业现场的总线协议。四十多年过去了,现在仍然被广泛使用在各个工业控制领域。除了这个协议很稳定的原因之外:

  1. 免费;
  2. 方便部署和维护;
  3. 对供应商来说,修改移动本地的比特或字节没有很多限制;

modbus 是OSI模型第七层上的应用层报文传输协议,OSI定义了开放系统的层次结构、层次之间的相互关系以及各层所包括的可能的任务,作为一个框架来协调和组织各层所提供的服务。

OSI参考模型并没有提供一个可以实现的方法,而是描述了一些概念,用来协调进程间通信标准的制定。即OSI参考模型并不是一个标准,而是一个在制定标准时所使用的概念性框架。

modbusOSI模型中,可以描述为下图;

modbus osi模型中的位置

EIA485/TIA485就是RS485,随着技术不断发展,485标准目前是电信行业协会(TIA)维护,所以名称为TIA-485,当然工程师及应用指南仍继续用RS-485来称呼也是没问题的;

下面我们来介绍一些串行链路协议。

2 Modbus 串行链路协议

Modbus串行链路协议是一个主从模式(主机和从机),半双工的数据传输协议,485标准通常需要两条线,在某一个确定时刻,有一个主机和从机进行通讯。

  • 主从模式:通常总线上有一个主机和多个从机,每个从机有唯一的ID,主机通过ID进行寻址从机,然后进行数据传输;
  • 半双工传输:相对应半双工的是全双工,全双工运行发送数据接收数据同时发生,所以半双工就不难理解了,同一时刻只能进行发送数据,或者只能接收数据;

整体的结构图如下所示;

一个485总线的主从模式

这里我们还要明确几点:

  1. 从机无法主动向从机发送数据,只有在主机发送数据给从机(发送请求),然后从机接收到主机发送的数据之后,再回传数据给主机;具体如下所示;
主从模式

正如前面所提到的,modbus是半双工传输的,即主机发送数据的时候,是不能接收数据的,所以这里总共分为两步来进行。

  1. 主机发送数据的方式有两种,一个是 1对1,一个是1对多,也就是我们常说的广播形式,所有从机都可以收到主机发送的数据;

    1对1 只需要发送数据给特定地址的从机即可,广播只需要把发送地址设置为0即可,所以广播地址为0;

这里我们已经大致了解了主机和从机之间的数据传输的情况,下面我们就再来介绍一下数据传输的具体格式;

3 传输模式

先来说说Modbus有两种传输模式,RTU传输模式和ASCII传输模式;

  • RTU传输:Remote Terminal Unit模式在Modbus中消息由十六进制组成,数据密度高,吞吐率高;

  • ASCII传输:消息由ASCII 字符发送效率不及RTU模式,无法使用RTU模式的定时管理时,使用ASCII模式;

    比如:0x12会被整合成两个字符发送:0x310x32发送,

    因为 0x31等于字符1;0x32等于字符2

下面我们会主要介绍modbus RTU

4 帧格式

在讲帧格式之前,首先我们想象一下,人与人之间的对话,最基本单元是汉字,然后相互交流就用汉字组成的句子,比如下面的对话;

  • 老板问:中午吃什么?
  • 小樟说:吃饭吧!

所以机器之间的通信也是类似的,我们可以把字节当作最基本的数据单元,然后由字节组成句子,也就是通信帧;

但是现在情况出现了变化,对话的人里,除了小樟,还有一个小红,这时候,为了明确和谁说话,就需要在对话前面加上名字:

  • 老板:小樟,中午吃面吗?
  • 小樟:老板,吃饭去吧。
  • 小红,没有叫他,语言柚子;

所以我们继续回到modbus的数据帧格式,这里的协议定义了一个基础通信层的简单协议数据单元(PDU),具体如下图所示;

所以这里基本分为四个部分,地址域功能码数据差错校验(CRC/LRC),统称为ADU (Application Data Unit),基本上进行传输的数据都要满足这个格式,作为一个完整的帧,对照前面老板的对话内容,我们这里可以简单的理解一下:

  • 地址域:可以理解成 具体和谁说话
  • 功能码:可以理解成 具体动作,比如 去做,来拿,去吃 等等;
  • 数据:可以理解成 具体内容,比如 面,饭 等等,也可以是其他,这里配合上下文,所以是吃的东西;
  • 差错校验:可以理解成,说出来的话必须可以让人理解,不然别人听不懂啊;实际上在协议中通常使用CRC或LRC保证传输的数据没有错误;

下面我们再深入分析一下;

PDU

Modbus PDU(protocol data unit)格式被定义为一个功能代码,后面跟着一组关联的数据。

该数据的大小和内容由功能代码定义,整个PDU(功能代码和数据)的大小不能超过253个字节。

每个功能代码都有一个特定的行为,从设备可以根据所需的应用程序行为灵活地实现这些行为。

PDU规范定义了数据访问和操作的核心概念;但是,从设备可能会以规范中未明确定义的方式处理数据。

地址域

地址域占用一个字节,所以一般来说寻址范围是0~255,一般在系统中用1~147,其他地址暂时保留,另外,同一个总线上的从机,每个地址必须唯一。

其中0是广播地址;

下面是Freemodbus的一个从机初始化代码,0x02就是这个从机的地址,

eMBInit(MB_RTU, 0x023115200, MB_PAR_NONE);

功能码

功能码占一个字节,所以范围是 0~255,协议中规定了功能码分为三类:公共功能码,用户自定义功能码,保留功能码。整体如下所示;


公共功能码必须保证它的唯一性,这是由Modbus组织已经规定好,并且具有一致性测试的功能码,所以在一定程度上,它保证了协议的可复用性。

由上表可知,公共功能码分为四种,分别是:

  • 离散量输入:只读类型,单位:bit
  • 线圈:读写类型,单位:bit
  • 输入寄存器:只读类型,单位:字节;
  • 保持寄存器:读写类型,单位:字节;

下面是移植Freemodbus协议,从机上需要对这四个公共功能码处理的回调函数:

//输入寄存器量
eMBErrorCode eMBRegInputCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNRegs )
{
  eMBErrorCode    eStatus = MB_ENOERR;
return eStatus;
}
//保持寄存器量
eMBErrorCode
eMBRegHoldingCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNRegs,
                 eMBRegisterMode eMode )

{
    eMBErrorCode    eStatus = MB_ENOERR;
    return eStatus;
}

//线圈数量 
eMBErrorCode
eMBRegCoilsCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNCoils,
               eMBRegisterMode eMode )

{
    eMBErrorCode    eStatus = MB_ENOERR;
    return eStatus;
}

//离散输入数量 
eMBErrorCode
eMBRegDiscreteCB( UCHAR * pucRegBuffer, USHORT usAddress, USHORT usNDiscrete )
{
    eMBErrorCode    eStatus = MB_ENOERR;
    return eStatus;
}

5 底层如何传输

我们先看一下最底层modbus数据是如何发送的,没错,看到RS485和232,那我们自然想到了串口。

所以最根本的数据格式可以参考一下串口数据的定义,也就是我们说的起始位,数据位,校验位,数据位;具体如下所示;

所以这里我们可以规定一下:

起始位+数据位+校验位(可选)+ 停止位 等于一个字符;因此这里可以通过串口的波特率去计算出单个字符所需要的时间。

然后我们再看一下,modbus帧是如何发送的?

RTU模式中,帧之间的间隔至少为3.5个字符的空闲时间间隔,以便于表示帧的开始和帧的结束,所以如果想自己整一个modbus rtu就需要一个定时器去结算空闲时间的长度。

3.5字符时间

整个数据必须以连续的字符流进行发送,如果两个字符之间的长度等于1.5个字符时间,则认为帧消息不完整,则认为设备不该接收该消息,具体如下所示;

1.5字符时间

这里需要注意的是RTU需要定时器中断的参与,所以,1.5字符时间和3.5字符时间的检测,在串口通讯速率很高的时候,需要高频率得进入中断,这就会增加系统开销。

所以通常在波特率低于19200的时候,可以严格遵守1.5和3.5字符时间的规定。

如果波特率大于19200的时候,需要满足两个固定时间即可:

  • 1.5字符时间:750 us;
  • 3.5字符时间:1.75ms;

总结

本文简单介绍了modbus rtu协议,包括串行链路通信,帧格式以及硬件链路层的消息格式,能力有限,本文难免存在错误和纰漏,请指正。

篇幅有限本文先到这里,下一篇介绍一下如何移植Freemodbus协议以及调试协议的过程。

如何本文帮到了您,请帮忙点赞鼓励一下。

最后

🫵兄弟们!一个人单打独斗确实能冲得挺快,但要想走得更远、更稳,还得靠一群志同道合的伙伴啊!

👊 麦鸽的知识星球现在已经聚集了一波人,大家都在这里互相学习、共同进步。


如果你也想找个靠谱的学习圈子

赶紧   戳链接 🔗 加入我们吧!


在这里,你能读到星球专栏的干货,优质教程,练手项目,随时向麦鸽提问,还能帮你定制学习计划。别犹豫了,兄弟,一起冲!💪



往期推荐



这些GUI库凭什么火?10款轻量级嵌入式GUI,新手开发学习首选

单片机的Flash又爆满了,快来试试这个无损压缩库heatshrink

工程师必存干货:步进电机原理深度解剖(附控制方法图解)

工程师必备神器!2MB超轻量串口示波器,小巧好用,调试效率提升3倍

小麦大叔 一位热衷技术的攻城狮,懂点技术,会讲故事,交个朋友?
评论 (0)
  • 最近,途虎养车发布的2024年财报数据,可谓相当吸睛。全年营收达到147.59亿元,同比增长8.5%,这个数字直观地展现了途虎在市场上的强大吸金能力,在行业里稳稳占据前列。利润方面同样出色,毛利37.46亿元,毛利率提升0.7个百分点至25.4%;经调整净利润6.24亿元,同比增长 29.7%,经营利润同比更是增长104%至3.31亿元,盈利能力显著增强,这样的利润增长幅度,在同行业中十分亮眼。在用户规模上,途虎养车同样成绩斐然。累计注册用户近1.4亿,同比增长20.4%,交易用户数达2410万
    用户1742991715177 2025-04-24 19:12 51浏览
  • 为通过金融手段积极推进全球绿色发展,国际金融论坛(IFF)于2020年创立了“IFF全球绿色金融奖”,旨在对全球绿色金融领域取得突出成绩的机构及创新性的解决方案进行表彰和奖励。该奖项依托IFF“高层次、高水平、国际化”一流智库资源优势,积极促进绿色金融领域的国际交流合作和创新实践,助力联合国可持续发展目标的实现。“IFF全球绿色金融奖”重点关注和鼓励那些促进经济增长模式转型、防治环境污染、应对气候变化,以及致力于提高能效水平、强化节能减排实效的绿色金融创新解决方案。该奖项面向全球,是对政策创新、
    华尔街科技眼 2025-04-24 20:43 33浏览
  •   电磁频谱数据综合管理平台系统解析   一、系统定义与目标   北京华盛恒辉电磁频谱数据综合管理平台融合无线传感器、软件定义电台等前沿技术,是实现无线电频谱资源全流程管理的复杂系统。其核心目标包括:优化频谱资源配置,满足多元通信需求;运用动态管理与频谱共享技术,提升资源利用效率;强化频谱安全监管,杜绝非法占用与干扰;为电子战提供频谱监测分析支持,辅助作战决策。   应用案例   目前,已有多个电磁频谱数据综合管理平台在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁频谱数
    华盛恒辉l58ll334744 2025-04-23 16:27 212浏览
  •   高海拔区域勤务与装备保障调度系统平台解析   北京华盛恒辉高海拔区域勤务与装备保障调度系统平台专为高海拔特殊地理环境打造,致力于攻克装备适应、人员健康保障、物资运输及应急响应等难题。以下从核心功能、技术特点、应用场景及发展趋势展开全面解读。   应用案例   目前,已有多个高海拔区域勤务与装备保障调度系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润高海拔区域勤务与装备保障调度系统。这些成功案例为高海拔区域勤务与装备保障调度系统的推广和应用提供了有力支持。   一、核心
    华盛恒辉l58ll334744 2025-04-24 10:13 124浏览
  •   基于 GIS 的任务规划与决策系统平台解析   北京华盛恒辉基于 GIS 的任务规划与决策系统平台是空间信息技术与决策科学融合的成果,通过地理空间数据处理与分析,为复杂任务提供科学智能的规划决策支持。以下从架构、功能、技术、应用及趋势展开解读。   应用案例   目前,已有多个基于 GIS 的任务规划与决策系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润基于 GIS 的任务规划与决策系统。这些成功案例为基于 GIS 的任务规划与决策系统的推广和应用提供了有力支持
    华盛恒辉l58ll334744 2025-04-25 15:47 16浏览
  • 引言在智能语音技术飞速发展的今天,语音交互已成为消费电子、智能家居、工业控制等领域的标配功能。传统的ISD系列录音芯片虽应用广泛,但其高成本与功能局限性逐渐难以满足市场对高性价比、高灵活性的需求。推出的WT2000P录音语音芯片,凭借其卓越性能、低功耗设计及高度可定制化特性,成为ISD系列芯片的理想替代方案,助力开发者突破产品创新瓶颈。一、WT2000P产品概述WT2000P是一款专为嵌入式语音场景设计的多功能录音芯片,采用ESOP8封装,体积小巧(尺寸仅4.9mm×3.9mm),集成度高,支持
    广州唯创电子 2025-04-25 08:44 59浏览
  • 2025-4-25全球信息报告出版商Global Info Research(环洋市场咨询)发布了【2025年全球市场高介电常数材料总体规模、主要生产商、主要地区、产品和应用细分研究报告】,报告主要调研全球高介电常数材料总体规模、主要地区规模、主要生产商规模和份额、产品分类规模、下游主要应用规模以及未来发展前景预测。统计维度包括销量、价格、收入,和市场份额。同时也重点分析全球市场主要厂商(品牌)产品特点、产品规格、价格、销量、销售收入及发展动态。历史数据为2020至2024年,预测数据为2025
    用户1745398400862 2025-04-25 08:48 69浏览
  •   通用装备论证与评估系统平台解析   北京华盛恒辉通用装备论证与评估系统平台是服务军事装备全生命周期管理的综合性信息化平台,通过科学化、系统化手段,实现装备需求论证、效能分析等核心功能,提升装备建设效益。   应用案例   目前,已有多个通用装备论证与评估系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润通用装备论证与评估系统。这些成功案例为通用装备论证与评估系统的推广和应用提供了有力支持。   一、系统分层架构   (一)数据层   整合装备性能、作战、试验等多源异
    华盛恒辉l58ll334744 2025-04-24 16:14 151浏览
  •   海上训练与保障调度指挥平台系统解析   北京华盛恒辉海上训练与保障调度指挥平台系统是现代海上作战训练的核心枢纽,融合信息技术、GIS、大数据及 AI 等前沿技术,旨在实现海上训练高效组织、作战保障科学决策。以下从架构功能、应用场景、系统优势及发展挑战展开解读。   应用案例   目前,已有多个海上训练与保障调度指挥平台在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润海上训练与保障调度指挥平台。这些成功案例为海上训练与保障调度指挥平台的推广和应用提供了有力支持。   一
    华盛恒辉l58ll334744 2025-04-24 15:26 136浏览
  • 引言:语音交互的智能化跃迁在全球化与智能化深度融合的今天,语音交互设备的应用场景已从单一提示功能向多语言支持、情感化表达及AI深度交互演进。传统离线语音方案受限于语种单一、存储容量不足等问题,而纯在线方案又依赖网络稳定性,难以满足复杂场景需求。WT3000A离在线TTS方案,通过“本地+云端”双引擎驱动,集成16国语种、7种方言切换、AI大模型对话扩展等创新功能,重新定义语音提示器的边界,为智能硬件开发者提供更灵活、更具竞争力的语音交互解决方案。一、方案核心亮点离在线双模融合,场景全覆盖离线模式
    广州唯创电子 2025-04-25 09:14 65浏览
  •   有效样本分析决策系统平台全面解析   一、引言   北京华盛恒辉有效样本分析决策系统在当今数据驱动的时代,企业、科研机构等面临着海量数据的处理与分析挑战。有效样本分析决策系统平台应运而生,它通过对样本数据的精准分析,为决策提供有力支持,成为提升决策质量和效率的关键工具。   应用案例   目前,已有多个有效样本分析决策系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润有效样本分析决策系统。这些成功案例为有效样本分析决策系统的推广和应用提供了有力支持。   二、平台概述
    华盛恒辉l58ll334744 2025-04-24 11:13 121浏览
  •   陆地装备体系论证与评估综合平台系统解析   北京华盛恒辉陆地装备体系论证与评估综合平台系统是契合现代军事需求而生的专业系统,借助科学化、智能化手段,实现对陆地装备体系的全方位论证与评估,为军事决策和装备发展提供关键支撑。以下从功能、技术、应用及展望展开分析。   应用案例   目前,已有多个陆地装备体系论证与评估综合平台在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润陆地装备体系论证与评估综合平台。这些成功案例为陆地装备体系论证与评估综合平台的推广和应用提供了有力支持。
    华盛恒辉l58ll334744 2025-04-24 10:53 125浏览
  •   航空兵训练与战术对抗仿真平台系统解析   北京华盛恒辉航空兵训练与战术对抗仿真平台系统是现代军事训练的关键工具,借助计算机技术构建虚拟战场,支持多兵种协同作战模拟,为军事决策、训练及装备研发提供科学依据。   应用案例   目前,已有多个航空兵训练与战术对抗仿真平台在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润航空兵训练与战术对抗仿真平台。这些成功案例为航空兵训练与战术对抗仿真平台的推广和应用提供了有力支持。   一、系统架构与核心功能   系统由模拟器、计算机兵力生
    华盛恒辉l58ll334744 2025-04-24 16:34 154浏览
  • 随着轻薄笔记本的普及,再加上电竞玩家对于高画质音视频体验的需求日益高涨,如何让轻薄笔记本在兼顾轻便携带性的同时,还能提供足以支持3A(AAA/Triple-A game)大作的良好运算性能,便成为各家品牌急欲突破的共同难题。然而,对于主打轻巧便携的轻薄笔记本而言,若要内置独立显卡,势必要先突破空间受限的瓶颈,同时还需解决散热问题,确实难以兼顾两全!对此,“Thunderbolt”与“OCuLink”这两项技术应运而生。用户可以通过这两种传输接口,再搭配外接显卡盒(eGPU)及高性能显卡(如NVI
    百佳泰测试实验室 2025-04-24 17:56 49浏览
我要评论
0
3
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦